js-draw 0.18.1 → 0.19.0

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 (485) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/dist/bundle.js +2 -2
  3. package/dist/bundledStyles.js +1 -0
  4. package/dist/cjs/src/Color4.d.ts +69 -0
  5. package/dist/cjs/src/Color4.js +264 -0
  6. package/dist/cjs/src/Editor.d.ts +308 -0
  7. package/dist/cjs/src/Editor.js +904 -0
  8. package/dist/cjs/src/EditorImage.d.ts +97 -0
  9. package/dist/cjs/src/EditorImage.js +486 -0
  10. package/dist/cjs/src/EventDispatcher.d.ts +30 -0
  11. package/dist/cjs/src/EventDispatcher.js +57 -0
  12. package/dist/cjs/src/Pointer.d.ts +24 -0
  13. package/dist/cjs/src/Pointer.js +84 -0
  14. package/dist/cjs/src/SVGLoader.d.ts +48 -0
  15. package/dist/cjs/src/SVGLoader.js +475 -0
  16. package/dist/cjs/src/UndoRedoHistory.d.ts +19 -0
  17. package/dist/cjs/src/UndoRedoHistory.js +93 -0
  18. package/dist/cjs/src/Viewport.d.ts +71 -0
  19. package/dist/cjs/src/Viewport.js +264 -0
  20. package/dist/cjs/src/bundle/bundled.d.ts +4 -0
  21. package/dist/cjs/src/bundle/bundled.js +24 -0
  22. package/dist/cjs/src/commands/Command.d.ts +16 -0
  23. package/dist/cjs/src/commands/Command.js +34 -0
  24. package/dist/cjs/src/commands/Duplicate.d.ts +14 -0
  25. package/dist/cjs/src/commands/Duplicate.js +39 -0
  26. package/dist/cjs/src/commands/Erase.d.ts +14 -0
  27. package/dist/cjs/src/commands/Erase.js +63 -0
  28. package/dist/cjs/src/commands/SerializableCommand.d.ts +12 -0
  29. package/dist/cjs/src/commands/SerializableCommand.js +42 -0
  30. package/dist/cjs/src/commands/UnresolvedCommand.d.ts +14 -0
  31. package/dist/cjs/src/commands/UnresolvedCommand.js +28 -0
  32. package/dist/cjs/src/commands/invertCommand.d.ts +4 -0
  33. package/dist/cjs/src/commands/invertCommand.js +49 -0
  34. package/dist/cjs/src/commands/lib.d.ts +7 -0
  35. package/dist/cjs/src/commands/lib.js +18 -0
  36. package/dist/cjs/src/commands/localization.d.ts +23 -0
  37. package/dist/cjs/src/commands/localization.js +24 -0
  38. package/dist/cjs/src/commands/uniteCommands.d.ts +4 -0
  39. package/dist/cjs/src/commands/uniteCommands.js +121 -0
  40. package/dist/cjs/src/components/AbstractComponent.d.ts +73 -0
  41. package/dist/cjs/src/components/AbstractComponent.js +258 -0
  42. package/dist/cjs/src/components/ImageBackground.d.ts +42 -0
  43. package/dist/cjs/src/components/ImageBackground.js +146 -0
  44. package/dist/cjs/src/components/ImageComponent.d.ts +31 -0
  45. package/dist/cjs/src/components/ImageComponent.js +152 -0
  46. package/dist/cjs/src/components/RestylableComponent.d.ts +43 -0
  47. package/dist/cjs/src/components/RestylableComponent.js +88 -0
  48. package/dist/cjs/src/components/SVGGlobalAttributesObject.d.ts +21 -0
  49. package/dist/cjs/src/components/SVGGlobalAttributesObject.js +65 -0
  50. package/dist/cjs/src/components/Stroke.d.ts +75 -0
  51. package/dist/cjs/src/components/Stroke.js +225 -0
  52. package/dist/cjs/src/components/TextComponent.d.ts +75 -0
  53. package/dist/cjs/src/components/TextComponent.js +280 -0
  54. package/dist/cjs/src/components/UnknownSVGObject.d.ts +18 -0
  55. package/dist/cjs/src/components/UnknownSVGObject.js +50 -0
  56. package/dist/cjs/src/components/builders/ArrowBuilder.d.ts +19 -0
  57. package/dist/cjs/src/components/builders/ArrowBuilder.js +117 -0
  58. package/dist/cjs/src/components/builders/FreehandLineBuilder.d.ts +33 -0
  59. package/dist/cjs/src/components/builders/FreehandLineBuilder.js +173 -0
  60. package/dist/cjs/src/components/builders/LineBuilder.d.ts +18 -0
  61. package/dist/cjs/src/components/builders/LineBuilder.js +89 -0
  62. package/dist/cjs/src/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +36 -0
  63. package/dist/cjs/src/components/builders/PressureSensitiveFreehandLineBuilder.js +347 -0
  64. package/dist/cjs/src/components/builders/RectangleBuilder.d.ts +20 -0
  65. package/dist/cjs/src/components/builders/RectangleBuilder.js +59 -0
  66. package/dist/cjs/src/components/builders/types.d.ts +12 -0
  67. package/dist/cjs/src/components/builders/types.js +2 -0
  68. package/dist/cjs/src/components/lib.d.ts +13 -0
  69. package/dist/cjs/src/components/lib.js +43 -0
  70. package/dist/cjs/src/components/localization.d.ts +11 -0
  71. package/dist/cjs/src/components/localization.js +13 -0
  72. package/dist/cjs/src/components/util/StrokeSmoother.d.ts +35 -0
  73. package/dist/cjs/src/components/util/StrokeSmoother.js +217 -0
  74. package/dist/cjs/src/components/util/describeComponentList.d.ts +4 -0
  75. package/dist/cjs/src/components/util/describeComponentList.js +16 -0
  76. package/dist/cjs/src/lib.d.ts +64 -0
  77. package/dist/cjs/src/lib.js +93 -0
  78. package/dist/cjs/src/localization.d.ts +14 -0
  79. package/dist/cjs/src/localization.js +13 -0
  80. package/dist/cjs/src/localizations/de.d.ts +3 -0
  81. package/dist/cjs/src/localizations/de.js +6 -0
  82. package/dist/cjs/src/localizations/en.d.ts +3 -0
  83. package/dist/cjs/src/localizations/en.js +6 -0
  84. package/dist/cjs/src/localizations/es.d.ts +3 -0
  85. package/dist/cjs/src/localizations/es.js +20 -0
  86. package/dist/cjs/src/localizations/getLocalizationTable.d.ts +3 -0
  87. package/dist/cjs/src/localizations/getLocalizationTable.js +50 -0
  88. package/dist/cjs/src/math/LineSegment2.d.ts +24 -0
  89. package/dist/cjs/src/math/LineSegment2.js +131 -0
  90. package/dist/cjs/src/math/Mat33.d.ts +118 -0
  91. package/dist/cjs/src/math/Mat33.js +332 -0
  92. package/dist/cjs/src/math/Path.d.ts +71 -0
  93. package/dist/cjs/src/math/Path.js +655 -0
  94. package/dist/cjs/src/math/Rect2.d.ts +52 -0
  95. package/dist/cjs/src/math/Rect2.js +234 -0
  96. package/dist/cjs/src/math/Triangle.d.ts +11 -0
  97. package/dist/cjs/src/math/Triangle.js +22 -0
  98. package/dist/cjs/src/math/Vec2.d.ts +13 -0
  99. package/dist/cjs/src/math/Vec2.js +19 -0
  100. package/dist/cjs/src/math/Vec3.d.ts +106 -0
  101. package/dist/cjs/src/math/Vec3.js +177 -0
  102. package/dist/cjs/src/math/lib.d.ts +7 -0
  103. package/dist/cjs/src/math/lib.js +18 -0
  104. package/dist/cjs/src/math/rounding.d.ts +4 -0
  105. package/dist/cjs/src/math/rounding.js +135 -0
  106. package/dist/cjs/src/rendering/Display.d.ts +75 -0
  107. package/dist/cjs/src/rendering/Display.js +214 -0
  108. package/dist/cjs/src/rendering/RenderingStyle.d.ts +31 -0
  109. package/dist/cjs/src/rendering/RenderingStyle.js +48 -0
  110. package/dist/cjs/src/rendering/TextRenderingStyle.d.ts +36 -0
  111. package/dist/cjs/src/rendering/TextRenderingStyle.js +29 -0
  112. package/dist/cjs/src/rendering/caching/CacheRecord.d.ts +20 -0
  113. package/dist/cjs/src/rendering/caching/CacheRecord.js +61 -0
  114. package/dist/cjs/src/rendering/caching/CacheRecordManager.d.ts +12 -0
  115. package/dist/cjs/src/rendering/caching/CacheRecordManager.js +50 -0
  116. package/dist/cjs/src/rendering/caching/RenderingCache.d.ts +11 -0
  117. package/dist/cjs/src/rendering/caching/RenderingCache.js +51 -0
  118. package/dist/cjs/src/rendering/caching/RenderingCacheNode.d.ts +29 -0
  119. package/dist/cjs/src/rendering/caching/RenderingCacheNode.js +326 -0
  120. package/dist/cjs/src/rendering/caching/testUtils.d.ts +9 -0
  121. package/dist/cjs/src/rendering/caching/testUtils.js +27 -0
  122. package/dist/cjs/src/rendering/caching/types.d.ts +19 -0
  123. package/dist/cjs/src/rendering/caching/types.js +2 -0
  124. package/dist/cjs/src/rendering/lib.d.ts +7 -0
  125. package/dist/cjs/src/rendering/lib.js +17 -0
  126. package/dist/cjs/src/rendering/localization.d.ts +10 -0
  127. package/dist/cjs/src/rendering/localization.js +12 -0
  128. package/dist/cjs/src/rendering/renderers/AbstractRenderer.d.ts +68 -0
  129. package/dist/cjs/src/rendering/renderers/AbstractRenderer.js +170 -0
  130. package/dist/cjs/src/rendering/renderers/CanvasRenderer.d.ts +63 -0
  131. package/dist/cjs/src/rendering/renderers/CanvasRenderer.js +236 -0
  132. package/dist/cjs/src/rendering/renderers/DummyRenderer.d.ts +35 -0
  133. package/dist/cjs/src/rendering/renderers/DummyRenderer.js +112 -0
  134. package/dist/cjs/src/rendering/renderers/SVGRenderer.d.ts +57 -0
  135. package/dist/cjs/src/rendering/renderers/SVGRenderer.js +311 -0
  136. package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.d.ts +29 -0
  137. package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.js +63 -0
  138. package/dist/cjs/src/testing/beforeEachFile.d.ts +1 -0
  139. package/dist/cjs/src/testing/beforeEachFile.js +12 -0
  140. package/dist/cjs/src/testing/createEditor.d.ts +4 -0
  141. package/dist/cjs/src/testing/createEditor.js +14 -0
  142. package/dist/cjs/src/testing/lib.d.ts +2 -0
  143. package/dist/cjs/src/testing/lib.js +10 -0
  144. package/dist/cjs/src/testing/loadExpectExtensions.d.ts +2 -0
  145. package/dist/cjs/src/testing/loadExpectExtensions.js +28 -0
  146. package/dist/cjs/src/testing/sendPenEvent.d.ts +12 -0
  147. package/dist/cjs/src/testing/sendPenEvent.js +24 -0
  148. package/dist/cjs/src/testing/sendTouchEvent.d.ts +42 -0
  149. package/dist/cjs/src/testing/sendTouchEvent.js +87 -0
  150. package/dist/cjs/src/toolbar/HTMLToolbar.d.ts +103 -0
  151. package/dist/cjs/src/toolbar/HTMLToolbar.js +383 -0
  152. package/dist/cjs/src/toolbar/IconProvider.d.ts +62 -0
  153. package/dist/cjs/src/toolbar/IconProvider.js +660 -0
  154. package/dist/cjs/src/toolbar/lib.d.ts +3 -0
  155. package/dist/cjs/src/toolbar/lib.js +24 -0
  156. package/dist/cjs/src/toolbar/localization.d.ts +49 -0
  157. package/dist/cjs/src/toolbar/localization.js +51 -0
  158. package/dist/cjs/src/toolbar/makeColorInput.d.ts +6 -0
  159. package/dist/cjs/src/toolbar/makeColorInput.js +120 -0
  160. package/dist/cjs/src/toolbar/types.d.ts +4 -0
  161. package/dist/cjs/src/toolbar/types.js +2 -0
  162. package/dist/cjs/src/toolbar/widgets/ActionButtonWidget.d.ts +15 -0
  163. package/dist/cjs/src/toolbar/widgets/ActionButtonWidget.js +31 -0
  164. package/dist/cjs/src/toolbar/widgets/BaseToolWidget.d.ts +11 -0
  165. package/dist/cjs/src/toolbar/widgets/BaseToolWidget.js +50 -0
  166. package/dist/cjs/src/toolbar/widgets/BaseWidget.d.ts +72 -0
  167. package/dist/cjs/src/toolbar/widgets/BaseWidget.js +313 -0
  168. package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.d.ts +18 -0
  169. package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.js +126 -0
  170. package/dist/cjs/src/toolbar/widgets/EraserToolWidget.d.ts +17 -0
  171. package/dist/cjs/src/toolbar/widgets/EraserToolWidget.js +63 -0
  172. package/dist/cjs/src/toolbar/widgets/HandToolWidget.d.ts +17 -0
  173. package/dist/cjs/src/toolbar/widgets/HandToolWidget.js +201 -0
  174. package/dist/cjs/src/toolbar/widgets/InsertImageWidget.d.ts +19 -0
  175. package/dist/cjs/src/toolbar/widgets/InsertImageWidget.js +176 -0
  176. package/dist/cjs/src/toolbar/widgets/OverflowWidget.d.ts +25 -0
  177. package/dist/cjs/src/toolbar/widgets/OverflowWidget.js +77 -0
  178. package/dist/cjs/src/toolbar/widgets/PenToolWidget.d.ts +27 -0
  179. package/dist/cjs/src/toolbar/widgets/PenToolWidget.js +226 -0
  180. package/dist/cjs/src/toolbar/widgets/SelectionToolWidget.d.ts +13 -0
  181. package/dist/cjs/src/toolbar/widgets/SelectionToolWidget.js +153 -0
  182. package/dist/cjs/src/toolbar/widgets/TextToolWidget.d.ts +16 -0
  183. package/dist/cjs/src/toolbar/widgets/TextToolWidget.js +115 -0
  184. package/dist/cjs/src/toolbar/widgets/lib.d.ts +10 -0
  185. package/dist/cjs/src/toolbar/widgets/lib.js +26 -0
  186. package/dist/cjs/src/tools/BaseTool.d.ts +22 -0
  187. package/dist/cjs/src/tools/BaseTool.js +66 -0
  188. package/dist/cjs/src/tools/Eraser.d.ts +23 -0
  189. package/dist/cjs/src/tools/Eraser.js +112 -0
  190. package/dist/cjs/src/tools/FindTool.d.ts +21 -0
  191. package/dist/cjs/src/tools/FindTool.js +121 -0
  192. package/dist/cjs/src/tools/PanZoom.d.ts +52 -0
  193. package/dist/cjs/src/tools/PanZoom.js +421 -0
  194. package/dist/cjs/src/tools/PasteHandler.d.ts +23 -0
  195. package/dist/cjs/src/tools/PasteHandler.js +99 -0
  196. package/dist/cjs/src/tools/Pen.d.ts +39 -0
  197. package/dist/cjs/src/tools/Pen.js +179 -0
  198. package/dist/cjs/src/tools/PipetteTool.d.ts +18 -0
  199. package/dist/cjs/src/tools/PipetteTool.js +45 -0
  200. package/dist/cjs/src/tools/SelectionTool/SelectAllShortcutHandler.d.ts +8 -0
  201. package/dist/cjs/src/tools/SelectionTool/SelectAllShortcutHandler.js +28 -0
  202. package/dist/cjs/src/tools/SelectionTool/Selection.d.ts +64 -0
  203. package/dist/cjs/src/tools/SelectionTool/Selection.js +488 -0
  204. package/dist/cjs/src/tools/SelectionTool/SelectionHandle.d.ts +38 -0
  205. package/dist/cjs/src/tools/SelectionTool/SelectionHandle.js +85 -0
  206. package/dist/cjs/src/tools/SelectionTool/SelectionTool.d.ts +36 -0
  207. package/dist/cjs/src/tools/SelectionTool/SelectionTool.js +405 -0
  208. package/dist/cjs/src/tools/SelectionTool/TransformMode.d.ts +34 -0
  209. package/dist/cjs/src/tools/SelectionTool/TransformMode.js +107 -0
  210. package/dist/cjs/src/tools/SelectionTool/types.d.ts +9 -0
  211. package/dist/cjs/src/tools/SelectionTool/types.js +14 -0
  212. package/dist/cjs/src/tools/SoundUITool.d.ts +24 -0
  213. package/dist/cjs/src/tools/SoundUITool.js +164 -0
  214. package/dist/cjs/src/tools/TextTool.d.ts +33 -0
  215. package/dist/cjs/src/tools/TextTool.js +262 -0
  216. package/dist/cjs/src/tools/ToolController.d.ts +18 -0
  217. package/dist/cjs/src/tools/ToolController.js +192 -0
  218. package/dist/cjs/src/tools/ToolEnabledGroup.d.ts +6 -0
  219. package/dist/cjs/src/tools/ToolEnabledGroup.js +14 -0
  220. package/dist/cjs/src/tools/ToolSwitcherShortcut.d.ts +16 -0
  221. package/dist/cjs/src/tools/ToolSwitcherShortcut.js +38 -0
  222. package/dist/cjs/src/tools/ToolbarShortcutHandler.d.ts +12 -0
  223. package/dist/cjs/src/tools/ToolbarShortcutHandler.js +29 -0
  224. package/dist/cjs/src/tools/UndoRedoShortcut.d.ts +8 -0
  225. package/dist/cjs/src/tools/UndoRedoShortcut.js +28 -0
  226. package/dist/cjs/src/tools/lib.d.ts +17 -0
  227. package/dist/cjs/src/tools/lib.js +38 -0
  228. package/dist/cjs/src/tools/localization.d.ts +31 -0
  229. package/dist/cjs/src/tools/localization.js +33 -0
  230. package/dist/cjs/src/types.d.ts +151 -0
  231. package/dist/cjs/src/types.js +38 -0
  232. package/dist/cjs/src/util/assertions.d.ts +23 -0
  233. package/dist/cjs/src/util/assertions.js +51 -0
  234. package/dist/cjs/src/util/fileToBase64.d.ts +3 -0
  235. package/dist/cjs/src/util/fileToBase64.js +15 -0
  236. package/dist/cjs/src/util/untilNextAnimationFrame.d.ts +3 -0
  237. package/dist/cjs/src/util/untilNextAnimationFrame.js +9 -0
  238. package/dist/cjs/src/util/waitForTimeout.d.ts +2 -0
  239. package/dist/cjs/src/util/waitForTimeout.js +9 -0
  240. package/dist/mjs/src/Color4.d.ts +69 -0
  241. package/dist/mjs/src/Color4.mjs +257 -0
  242. package/dist/mjs/src/Editor.d.ts +308 -0
  243. package/dist/mjs/src/Editor.mjs +874 -0
  244. package/dist/mjs/src/EditorImage.d.ts +97 -0
  245. package/dist/mjs/src/EditorImage.mjs +477 -0
  246. package/dist/mjs/src/EventDispatcher.d.ts +30 -0
  247. package/dist/mjs/src/EventDispatcher.mjs +54 -0
  248. package/dist/mjs/src/Pointer.d.ts +24 -0
  249. package/dist/mjs/src/Pointer.mjs +80 -0
  250. package/dist/mjs/src/SVGLoader.d.ts +48 -0
  251. package/dist/mjs/src/SVGLoader.mjs +445 -0
  252. package/dist/mjs/src/UndoRedoHistory.d.ts +19 -0
  253. package/dist/mjs/src/UndoRedoHistory.mjs +91 -0
  254. package/dist/mjs/src/Viewport.d.ts +71 -0
  255. package/dist/mjs/src/Viewport.mjs +256 -0
  256. package/dist/mjs/src/bundle/bundled.d.ts +4 -0
  257. package/dist/mjs/src/bundle/bundled.mjs +5 -0
  258. package/dist/mjs/src/commands/Command.d.ts +16 -0
  259. package/dist/mjs/src/commands/Command.mjs +30 -0
  260. package/dist/mjs/src/commands/Duplicate.d.ts +14 -0
  261. package/dist/mjs/src/commands/Duplicate.mjs +33 -0
  262. package/dist/mjs/src/commands/Erase.d.ts +14 -0
  263. package/dist/mjs/src/commands/Erase.mjs +57 -0
  264. package/dist/mjs/src/commands/SerializableCommand.d.ts +12 -0
  265. package/dist/mjs/src/commands/SerializableCommand.mjs +36 -0
  266. package/dist/mjs/src/commands/UnresolvedCommand.d.ts +14 -0
  267. package/dist/mjs/src/commands/UnresolvedCommand.mjs +22 -0
  268. package/dist/mjs/src/commands/invertCommand.d.ts +4 -0
  269. package/dist/mjs/src/commands/invertCommand.mjs +44 -0
  270. package/dist/mjs/src/commands/lib.d.ts +7 -0
  271. package/dist/mjs/src/commands/lib.mjs +7 -0
  272. package/dist/mjs/src/commands/localization.d.ts +23 -0
  273. package/dist/mjs/src/commands/localization.mjs +21 -0
  274. package/dist/mjs/src/commands/uniteCommands.d.ts +4 -0
  275. package/dist/mjs/src/commands/uniteCommands.mjs +116 -0
  276. package/dist/mjs/src/components/AbstractComponent.d.ts +73 -0
  277. package/dist/mjs/src/components/AbstractComponent.mjs +252 -0
  278. package/dist/mjs/src/components/ImageBackground.d.ts +42 -0
  279. package/dist/mjs/src/components/ImageBackground.mjs +139 -0
  280. package/dist/mjs/src/components/ImageComponent.d.ts +31 -0
  281. package/dist/mjs/src/components/ImageComponent.mjs +146 -0
  282. package/dist/mjs/src/components/RestylableComponent.d.ts +43 -0
  283. package/dist/mjs/src/components/RestylableComponent.mjs +80 -0
  284. package/dist/mjs/src/components/SVGGlobalAttributesObject.d.ts +21 -0
  285. package/dist/mjs/src/components/SVGGlobalAttributesObject.mjs +59 -0
  286. package/dist/mjs/src/components/Stroke.d.ts +75 -0
  287. package/dist/mjs/src/components/Stroke.mjs +219 -0
  288. package/dist/mjs/src/components/TextComponent.d.ts +75 -0
  289. package/dist/mjs/src/components/TextComponent.mjs +274 -0
  290. package/dist/mjs/src/components/UnknownSVGObject.d.ts +18 -0
  291. package/dist/mjs/src/components/UnknownSVGObject.mjs +44 -0
  292. package/dist/mjs/src/components/builders/ArrowBuilder.d.ts +19 -0
  293. package/dist/mjs/src/components/builders/ArrowBuilder.mjs +86 -0
  294. package/dist/mjs/src/components/builders/FreehandLineBuilder.d.ts +33 -0
  295. package/dist/mjs/src/components/builders/FreehandLineBuilder.mjs +165 -0
  296. package/dist/mjs/src/components/builders/LineBuilder.d.ts +18 -0
  297. package/dist/mjs/src/components/builders/LineBuilder.mjs +58 -0
  298. package/dist/mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +36 -0
  299. package/dist/mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.mjs +339 -0
  300. package/dist/mjs/src/components/builders/RectangleBuilder.d.ts +20 -0
  301. package/dist/mjs/src/components/builders/RectangleBuilder.mjs +50 -0
  302. package/dist/mjs/src/components/builders/types.d.ts +12 -0
  303. package/dist/mjs/src/components/builders/types.mjs +1 -0
  304. package/dist/mjs/src/components/lib.d.ts +13 -0
  305. package/dist/mjs/src/components/lib.mjs +12 -0
  306. package/dist/mjs/src/components/localization.d.ts +11 -0
  307. package/dist/mjs/src/components/localization.mjs +10 -0
  308. package/dist/mjs/src/components/util/StrokeSmoother.d.ts +35 -0
  309. package/dist/mjs/src/components/util/StrokeSmoother.mjs +210 -0
  310. package/dist/mjs/src/components/util/describeComponentList.d.ts +4 -0
  311. package/dist/mjs/src/components/util/describeComponentList.mjs +14 -0
  312. package/dist/mjs/src/lib.d.ts +64 -0
  313. package/dist/mjs/src/lib.mjs +64 -0
  314. package/dist/mjs/src/localization.d.ts +14 -0
  315. package/dist/mjs/src/localization.mjs +10 -0
  316. package/dist/mjs/src/localizations/de.d.ts +3 -0
  317. package/dist/mjs/src/localizations/de.mjs +4 -0
  318. package/dist/mjs/src/localizations/en.d.ts +3 -0
  319. package/dist/mjs/src/localizations/en.mjs +4 -0
  320. package/dist/mjs/src/localizations/es.d.ts +3 -0
  321. package/dist/mjs/src/localizations/es.mjs +18 -0
  322. package/dist/mjs/src/localizations/getLocalizationTable.d.ts +3 -0
  323. package/dist/mjs/src/localizations/getLocalizationTable.mjs +45 -0
  324. package/dist/mjs/src/math/LineSegment2.d.ts +24 -0
  325. package/dist/mjs/src/math/LineSegment2.mjs +125 -0
  326. package/dist/mjs/src/math/Mat33.d.ts +118 -0
  327. package/dist/mjs/src/math/Mat33.mjs +326 -0
  328. package/dist/mjs/src/math/Path.d.ts +71 -0
  329. package/dist/mjs/src/math/Path.mjs +648 -0
  330. package/dist/mjs/src/math/Rect2.d.ts +52 -0
  331. package/dist/mjs/src/math/Rect2.mjs +228 -0
  332. package/dist/mjs/src/math/Triangle.d.ts +11 -0
  333. package/dist/mjs/src/math/Triangle.mjs +19 -0
  334. package/dist/mjs/src/math/Vec2.d.ts +13 -0
  335. package/dist/mjs/src/math/Vec2.mjs +13 -0
  336. package/dist/mjs/src/math/Vec3.d.ts +106 -0
  337. package/dist/mjs/src/math/Vec3.mjs +174 -0
  338. package/dist/mjs/src/math/lib.d.ts +7 -0
  339. package/dist/mjs/src/math/lib.mjs +7 -0
  340. package/dist/mjs/src/math/rounding.d.ts +4 -0
  341. package/dist/mjs/src/math/rounding.mjs +128 -0
  342. package/dist/mjs/src/rendering/Display.d.ts +75 -0
  343. package/dist/mjs/src/rendering/Display.mjs +207 -0
  344. package/dist/mjs/src/rendering/RenderingStyle.d.ts +31 -0
  345. package/dist/mjs/src/rendering/RenderingStyle.mjs +38 -0
  346. package/dist/mjs/src/rendering/TextRenderingStyle.d.ts +36 -0
  347. package/dist/mjs/src/rendering/TextRenderingStyle.mjs +23 -0
  348. package/dist/mjs/src/rendering/caching/CacheRecord.d.ts +20 -0
  349. package/dist/mjs/src/rendering/caching/CacheRecord.mjs +55 -0
  350. package/dist/mjs/src/rendering/caching/CacheRecordManager.d.ts +12 -0
  351. package/dist/mjs/src/rendering/caching/CacheRecordManager.mjs +43 -0
  352. package/dist/mjs/src/rendering/caching/RenderingCache.d.ts +11 -0
  353. package/dist/mjs/src/rendering/caching/RenderingCache.mjs +45 -0
  354. package/dist/mjs/src/rendering/caching/RenderingCacheNode.d.ts +29 -0
  355. package/dist/mjs/src/rendering/caching/RenderingCacheNode.mjs +320 -0
  356. package/dist/mjs/src/rendering/caching/testUtils.d.ts +9 -0
  357. package/dist/mjs/src/rendering/caching/testUtils.mjs +20 -0
  358. package/dist/mjs/src/rendering/caching/types.d.ts +19 -0
  359. package/dist/mjs/src/rendering/caching/types.mjs +1 -0
  360. package/dist/mjs/src/rendering/lib.d.ts +7 -0
  361. package/dist/mjs/src/rendering/lib.mjs +5 -0
  362. package/dist/mjs/src/rendering/localization.d.ts +10 -0
  363. package/dist/mjs/src/rendering/localization.mjs +9 -0
  364. package/dist/mjs/src/rendering/renderers/AbstractRenderer.d.ts +68 -0
  365. package/dist/mjs/src/rendering/renderers/AbstractRenderer.mjs +144 -0
  366. package/dist/mjs/src/rendering/renderers/CanvasRenderer.d.ts +63 -0
  367. package/dist/mjs/src/rendering/renderers/CanvasRenderer.mjs +230 -0
  368. package/dist/mjs/src/rendering/renderers/DummyRenderer.d.ts +35 -0
  369. package/dist/mjs/src/rendering/renderers/DummyRenderer.mjs +106 -0
  370. package/dist/mjs/src/rendering/renderers/SVGRenderer.d.ts +57 -0
  371. package/dist/mjs/src/rendering/renderers/SVGRenderer.mjs +304 -0
  372. package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.d.ts +29 -0
  373. package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.mjs +57 -0
  374. package/dist/mjs/src/testing/beforeEachFile.d.ts +1 -0
  375. package/dist/mjs/src/testing/beforeEachFile.mjs +7 -0
  376. package/dist/mjs/src/testing/createEditor.d.ts +4 -0
  377. package/dist/mjs/src/testing/createEditor.mjs +9 -0
  378. package/dist/mjs/src/testing/lib.d.ts +2 -0
  379. package/dist/mjs/src/testing/lib.mjs +2 -0
  380. package/dist/mjs/src/testing/loadExpectExtensions.d.ts +2 -0
  381. package/dist/mjs/src/testing/loadExpectExtensions.mjs +24 -0
  382. package/dist/mjs/src/testing/sendPenEvent.d.ts +12 -0
  383. package/dist/mjs/src/testing/sendPenEvent.mjs +19 -0
  384. package/dist/mjs/src/testing/sendTouchEvent.d.ts +42 -0
  385. package/dist/mjs/src/testing/sendTouchEvent.mjs +62 -0
  386. package/dist/mjs/src/toolbar/HTMLToolbar.d.ts +103 -0
  387. package/dist/mjs/src/toolbar/HTMLToolbar.mjs +376 -0
  388. package/dist/mjs/src/toolbar/IconProvider.d.ts +62 -0
  389. package/dist/mjs/src/toolbar/IconProvider.mjs +654 -0
  390. package/dist/mjs/src/toolbar/lib.d.ts +3 -0
  391. package/dist/mjs/src/toolbar/lib.mjs +3 -0
  392. package/dist/mjs/src/toolbar/localization.d.ts +49 -0
  393. package/dist/mjs/src/toolbar/localization.mjs +48 -0
  394. package/dist/mjs/src/toolbar/makeColorInput.d.ts +6 -0
  395. package/dist/mjs/src/toolbar/makeColorInput.mjs +113 -0
  396. package/dist/mjs/src/toolbar/types.d.ts +4 -0
  397. package/dist/mjs/src/toolbar/types.mjs +1 -0
  398. package/dist/mjs/src/toolbar/widgets/ActionButtonWidget.d.ts +15 -0
  399. package/dist/mjs/src/toolbar/widgets/ActionButtonWidget.mjs +25 -0
  400. package/dist/mjs/src/toolbar/widgets/BaseToolWidget.d.ts +11 -0
  401. package/dist/mjs/src/toolbar/widgets/BaseToolWidget.mjs +44 -0
  402. package/dist/mjs/src/toolbar/widgets/BaseWidget.d.ts +72 -0
  403. package/dist/mjs/src/toolbar/widgets/BaseWidget.mjs +307 -0
  404. package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.d.ts +18 -0
  405. package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.mjs +120 -0
  406. package/dist/mjs/src/toolbar/widgets/EraserToolWidget.d.ts +17 -0
  407. package/dist/mjs/src/toolbar/widgets/EraserToolWidget.mjs +57 -0
  408. package/dist/mjs/src/toolbar/widgets/HandToolWidget.d.ts +17 -0
  409. package/dist/mjs/src/toolbar/widgets/HandToolWidget.mjs +172 -0
  410. package/dist/mjs/src/toolbar/widgets/InsertImageWidget.d.ts +19 -0
  411. package/dist/mjs/src/toolbar/widgets/InsertImageWidget.mjs +170 -0
  412. package/dist/mjs/src/toolbar/widgets/OverflowWidget.d.ts +25 -0
  413. package/dist/mjs/src/toolbar/widgets/OverflowWidget.mjs +71 -0
  414. package/dist/mjs/src/toolbar/widgets/PenToolWidget.d.ts +27 -0
  415. package/dist/mjs/src/toolbar/widgets/PenToolWidget.mjs +220 -0
  416. package/dist/mjs/src/toolbar/widgets/SelectionToolWidget.d.ts +13 -0
  417. package/dist/mjs/src/toolbar/widgets/SelectionToolWidget.mjs +147 -0
  418. package/dist/mjs/src/toolbar/widgets/TextToolWidget.d.ts +16 -0
  419. package/dist/mjs/src/toolbar/widgets/TextToolWidget.mjs +109 -0
  420. package/dist/mjs/src/toolbar/widgets/lib.d.ts +10 -0
  421. package/dist/mjs/src/toolbar/widgets/lib.mjs +10 -0
  422. package/dist/mjs/src/tools/BaseTool.d.ts +22 -0
  423. package/dist/mjs/src/tools/BaseTool.mjs +63 -0
  424. package/dist/mjs/src/tools/Eraser.d.ts +23 -0
  425. package/dist/mjs/src/tools/Eraser.mjs +106 -0
  426. package/dist/mjs/src/tools/FindTool.d.ts +21 -0
  427. package/dist/mjs/src/tools/FindTool.mjs +114 -0
  428. package/dist/mjs/src/tools/PanZoom.d.ts +52 -0
  429. package/dist/mjs/src/tools/PanZoom.mjs +414 -0
  430. package/dist/mjs/src/tools/PasteHandler.d.ts +23 -0
  431. package/dist/mjs/src/tools/PasteHandler.mjs +93 -0
  432. package/dist/mjs/src/tools/Pen.d.ts +39 -0
  433. package/dist/mjs/src/tools/Pen.mjs +173 -0
  434. package/dist/mjs/src/tools/PipetteTool.d.ts +18 -0
  435. package/dist/mjs/src/tools/PipetteTool.mjs +39 -0
  436. package/dist/mjs/src/tools/SelectionTool/SelectAllShortcutHandler.d.ts +8 -0
  437. package/dist/mjs/src/tools/SelectionTool/SelectAllShortcutHandler.mjs +22 -0
  438. package/dist/mjs/src/tools/SelectionTool/Selection.d.ts +64 -0
  439. package/dist/mjs/src/tools/SelectionTool/Selection.mjs +459 -0
  440. package/dist/mjs/src/tools/SelectionTool/SelectionHandle.d.ts +38 -0
  441. package/dist/mjs/src/tools/SelectionTool/SelectionHandle.mjs +81 -0
  442. package/dist/mjs/src/tools/SelectionTool/SelectionTool.d.ts +36 -0
  443. package/dist/mjs/src/tools/SelectionTool/SelectionTool.mjs +398 -0
  444. package/dist/mjs/src/tools/SelectionTool/TransformMode.d.ts +34 -0
  445. package/dist/mjs/src/tools/SelectionTool/TransformMode.mjs +98 -0
  446. package/dist/mjs/src/tools/SelectionTool/types.d.ts +9 -0
  447. package/dist/mjs/src/tools/SelectionTool/types.mjs +11 -0
  448. package/dist/mjs/src/tools/SoundUITool.d.ts +24 -0
  449. package/dist/mjs/src/tools/SoundUITool.mjs +158 -0
  450. package/dist/mjs/src/tools/TextTool.d.ts +33 -0
  451. package/dist/mjs/src/tools/TextTool.mjs +256 -0
  452. package/dist/mjs/src/tools/ToolController.d.ts +18 -0
  453. package/dist/mjs/src/tools/ToolController.mjs +163 -0
  454. package/dist/mjs/src/tools/ToolEnabledGroup.d.ts +6 -0
  455. package/dist/mjs/src/tools/ToolEnabledGroup.mjs +11 -0
  456. package/dist/mjs/src/tools/ToolSwitcherShortcut.d.ts +16 -0
  457. package/dist/mjs/src/tools/ToolSwitcherShortcut.mjs +32 -0
  458. package/dist/mjs/src/tools/ToolbarShortcutHandler.d.ts +12 -0
  459. package/dist/mjs/src/tools/ToolbarShortcutHandler.mjs +23 -0
  460. package/dist/mjs/src/tools/UndoRedoShortcut.d.ts +8 -0
  461. package/dist/mjs/src/tools/UndoRedoShortcut.mjs +22 -0
  462. package/dist/mjs/src/tools/lib.d.ts +17 -0
  463. package/dist/mjs/src/tools/lib.mjs +17 -0
  464. package/dist/mjs/src/tools/localization.d.ts +31 -0
  465. package/dist/mjs/src/tools/localization.mjs +30 -0
  466. package/dist/mjs/src/types.d.ts +151 -0
  467. package/dist/mjs/src/types.mjs +35 -0
  468. package/dist/mjs/src/util/assertions.d.ts +23 -0
  469. package/dist/mjs/src/util/assertions.mjs +45 -0
  470. package/dist/mjs/src/util/fileToBase64.d.ts +3 -0
  471. package/dist/mjs/src/util/fileToBase64.mjs +13 -0
  472. package/dist/mjs/src/util/untilNextAnimationFrame.d.ts +3 -0
  473. package/dist/mjs/src/util/untilNextAnimationFrame.mjs +7 -0
  474. package/dist/mjs/src/util/waitForTimeout.d.ts +2 -0
  475. package/dist/mjs/src/util/waitForTimeout.mjs +7 -0
  476. package/package.json +6 -4
  477. package/src/Editor.css +86 -0
  478. package/src/styles.js +7 -0
  479. package/src/toolbar/toolbar.css +213 -0
  480. package/src/toolbar/widgets/InsertImageWidget.css +44 -0
  481. package/src/toolbar/widgets/OverflowWidget.css +27 -0
  482. package/src/tools/FindTool.css +7 -0
  483. package/src/tools/SelectionTool/SelectionTool.css +23 -0
  484. package/src/tools/SoundUITool.css +15 -0
  485. package/src/tools/tools.css +4 -0
@@ -0,0 +1,219 @@
1
+ import Path from '../math/Path.mjs';
2
+ import Rect2 from '../math/Rect2.mjs';
3
+ import { styleFromJSON, styleToJSON } from '../rendering/RenderingStyle.mjs';
4
+ import AbstractComponent from './AbstractComponent.mjs';
5
+ import { createRestyleComponentCommand } from './RestylableComponent.mjs';
6
+ /**
7
+ * Represents an {@link AbstractComponent} made up of one or more {@link Path}s.
8
+ *
9
+ * @example
10
+ * For some {@link Editor} editor and `Stroke` stroke,
11
+ *
12
+ * **Restyling**:
13
+ * ```ts
14
+ * editor.dispatch(stroke.updateStyle({ color: Color4.red }));
15
+ * ```
16
+ *
17
+ * **Transforming**:
18
+ * ```ts
19
+ * editor.dispatch(stroke.transformBy(Mat33.translation(Vec2.of(10, 0))));
20
+ * ```
21
+ */
22
+ export default class Stroke extends AbstractComponent {
23
+ /**
24
+ * Creates a `Stroke` from the given `parts`. All parts should have the
25
+ * same color.
26
+ *
27
+ * @example
28
+ * ```ts
29
+ * // A path that starts at (1,1), moves to the right by (2, 0),
30
+ * // then moves down and right by (3, 3)
31
+ * const path = Path.fromString('m1,1 2,0 3,3');
32
+ *
33
+ * const stroke = new Stroke([
34
+ * // Fill with red
35
+ * path.toRenderable({ fill: Color4.red })
36
+ * ]);
37
+ * ```
38
+ */
39
+ constructor(parts) {
40
+ var _a;
41
+ super('stroke');
42
+ // @internal
43
+ // eslint-disable-next-line @typescript-eslint/prefer-as-const
44
+ this.isRestylableComponent = true;
45
+ this.approximateRenderingTime = 0;
46
+ this.parts = [];
47
+ for (const section of parts) {
48
+ const path = Path.fromRenderable(section);
49
+ const pathBBox = this.bboxForPart(path.bbox, section.style);
50
+ if (!this.contentBBox) {
51
+ this.contentBBox = pathBBox;
52
+ }
53
+ else {
54
+ this.contentBBox = this.contentBBox.union(pathBBox);
55
+ }
56
+ this.parts.push({
57
+ path,
58
+ // To implement RenderablePathSpec
59
+ startPoint: path.startPoint,
60
+ style: section.style,
61
+ commands: path.parts,
62
+ });
63
+ this.approximateRenderingTime += path.parts.length;
64
+ }
65
+ (_a = this.contentBBox) !== null && _a !== void 0 ? _a : (this.contentBBox = Rect2.empty);
66
+ }
67
+ getStyle() {
68
+ if (this.parts.length === 0) {
69
+ return {};
70
+ }
71
+ const firstPart = this.parts[0];
72
+ if (firstPart.style.stroke === undefined
73
+ || firstPart.style.stroke.width === 0) {
74
+ return {
75
+ color: firstPart.style.fill,
76
+ };
77
+ }
78
+ return {
79
+ color: firstPart.style.stroke.color,
80
+ };
81
+ }
82
+ updateStyle(style) {
83
+ return createRestyleComponentCommand(this.getStyle(), style, this);
84
+ }
85
+ forceStyle(style, editor) {
86
+ if (!style.color) {
87
+ return;
88
+ }
89
+ this.parts = this.parts.map((part) => {
90
+ const newStyle = Object.assign(Object.assign({}, part.style), { stroke: part.style.stroke ? Object.assign({}, part.style.stroke) : undefined });
91
+ // Change the stroke color if a stroked shape. Else,
92
+ // change the fill.
93
+ if (newStyle.stroke && newStyle.stroke.width > 0) {
94
+ newStyle.stroke.color = style.color;
95
+ }
96
+ else {
97
+ newStyle.fill = style.color;
98
+ }
99
+ return {
100
+ path: part.path,
101
+ startPoint: part.startPoint,
102
+ commands: part.commands,
103
+ style: newStyle,
104
+ };
105
+ });
106
+ if (editor) {
107
+ editor.image.queueRerenderOf(this);
108
+ editor.queueRerender();
109
+ }
110
+ }
111
+ intersects(line) {
112
+ for (const part of this.parts) {
113
+ if (part.path.intersection(line).length > 0) {
114
+ return true;
115
+ }
116
+ }
117
+ return false;
118
+ }
119
+ render(canvas, visibleRect) {
120
+ var _a, _b;
121
+ canvas.startObject(this.getBBox());
122
+ for (const part of this.parts) {
123
+ const bbox = this.bboxForPart(part.path.bbox, part.style);
124
+ if (visibleRect) {
125
+ if (!bbox.intersects(visibleRect)) {
126
+ continue;
127
+ }
128
+ const muchBiggerThanVisible = bbox.size.x > visibleRect.size.x * 2 || bbox.size.y > visibleRect.size.y * 2;
129
+ 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)) {
130
+ continue;
131
+ }
132
+ }
133
+ canvas.drawPath(part);
134
+ }
135
+ canvas.endObject(this.getLoadSaveData());
136
+ }
137
+ getProportionalRenderingTime() {
138
+ return this.approximateRenderingTime;
139
+ }
140
+ // Grows the bounding box for a given stroke part based on that part's style.
141
+ bboxForPart(origBBox, style) {
142
+ if (!style.stroke) {
143
+ return origBBox;
144
+ }
145
+ return origBBox.grownBy(style.stroke.width / 2);
146
+ }
147
+ applyTransformation(affineTransfm) {
148
+ this.contentBBox = Rect2.empty;
149
+ let isFirstPart = true;
150
+ // Update each part
151
+ this.parts = this.parts.map((part) => {
152
+ const newPath = part.path.transformedBy(affineTransfm);
153
+ const newStyle = Object.assign(Object.assign({}, part.style), { stroke: part.style.stroke ? Object.assign({}, part.style.stroke) : undefined });
154
+ // Approximate the scale factor.
155
+ if (newStyle.stroke) {
156
+ const scaleFactor = affineTransfm.getScaleFactor();
157
+ newStyle.stroke.width *= scaleFactor;
158
+ }
159
+ const newBBox = this.bboxForPart(newPath.bbox, newStyle);
160
+ if (isFirstPart) {
161
+ this.contentBBox = newBBox;
162
+ isFirstPart = false;
163
+ }
164
+ else {
165
+ this.contentBBox = this.contentBBox.union(newBBox);
166
+ }
167
+ return {
168
+ path: newPath,
169
+ startPoint: newPath.startPoint,
170
+ commands: newPath.parts,
171
+ style: newStyle,
172
+ };
173
+ });
174
+ }
175
+ /**
176
+ * @returns the {@link Path.union} of all paths that make up this stroke.
177
+ */
178
+ getPath() {
179
+ let result = null;
180
+ for (const part of this.parts) {
181
+ if (result) {
182
+ result = result.union(part.path);
183
+ }
184
+ else {
185
+ result !== null && result !== void 0 ? result : (result = part.path);
186
+ }
187
+ }
188
+ return result !== null && result !== void 0 ? result : Path.empty;
189
+ }
190
+ description(localization) {
191
+ return localization.stroke;
192
+ }
193
+ createClone() {
194
+ return new Stroke(this.parts);
195
+ }
196
+ serializeToJSON() {
197
+ return this.parts.map(part => {
198
+ return {
199
+ style: styleToJSON(part.style),
200
+ path: part.path.serialize(),
201
+ };
202
+ });
203
+ }
204
+ /** @internal */
205
+ static deserializeFromJSON(json) {
206
+ if (typeof json === 'string') {
207
+ json = JSON.parse(json);
208
+ }
209
+ if (typeof json !== 'object' || typeof json.length !== 'number') {
210
+ throw new Error(`${json} is missing required field, parts, or parts is of the wrong type.`);
211
+ }
212
+ const pathSpec = json.map((part) => {
213
+ const style = styleFromJSON(part.style);
214
+ return Path.fromString(part.path).toRenderable(style);
215
+ });
216
+ return new Stroke(pathSpec);
217
+ }
218
+ }
219
+ AbstractComponent.registerComponent('stroke', Stroke.deserializeFromJSON);
@@ -0,0 +1,75 @@
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 { TextRenderingStyle } from '../rendering/TextRenderingStyle';
8
+ import AbstractComponent from './AbstractComponent';
9
+ import { ImageComponentLocalization } from './localization';
10
+ import RestyleableComponent, { ComponentStyle } from './RestylableComponent';
11
+ /**
12
+ * Displays text.
13
+ */
14
+ export default class TextComponent extends AbstractComponent implements RestyleableComponent {
15
+ protected readonly textObjects: Array<string | TextComponent>;
16
+ private transform;
17
+ private style;
18
+ protected contentBBox: Rect2;
19
+ readonly isRestylableComponent: true;
20
+ /**
21
+ * Creates a new text object from a list of component text or child TextComponents.
22
+ *
23
+ * @see {@link fromLines}
24
+ */
25
+ constructor(textObjects: Array<string | TextComponent>, transform: Mat33, style: TextRenderingStyle);
26
+ static applyTextStyles(ctx: CanvasRenderingContext2D, style: TextRenderingStyle): void;
27
+ private static textMeasuringCtx;
28
+ private static estimateTextDimens;
29
+ private static getTextDimens;
30
+ private computeBBoxOfPart;
31
+ private recomputeBBox;
32
+ private renderInternal;
33
+ render(canvas: AbstractRenderer, _visibleRect?: Rect2): void;
34
+ getProportionalRenderingTime(): number;
35
+ intersects(lineSegment: LineSegment2): boolean;
36
+ getStyle(): ComponentStyle;
37
+ updateStyle(style: ComponentStyle): SerializableCommand;
38
+ forceStyle(style: ComponentStyle, editor: Editor | null): void;
39
+ getTextStyle(): {
40
+ renderingStyle: {
41
+ fill: import("../Color4").default;
42
+ stroke: {
43
+ color: import("../Color4").default;
44
+ width: number;
45
+ } | undefined;
46
+ };
47
+ size: number;
48
+ fontFamily: string;
49
+ fontWeight?: string | undefined;
50
+ fontVariant?: string | undefined;
51
+ };
52
+ getBaselinePos(): import("../lib").Vec3;
53
+ getTransform(): Mat33;
54
+ protected applyTransformation(affineTransfm: Mat33): void;
55
+ protected createClone(): AbstractComponent;
56
+ getText(): string;
57
+ description(localizationTable: ImageComponentLocalization): string;
58
+ protected serializeToJSON(): Record<string, any>;
59
+ static deserializeFromString(json: any): TextComponent;
60
+ /**
61
+ * Creates a `TextComponent` from `lines`.
62
+ *
63
+ * @example
64
+ * ```ts
65
+ * const textStyle = {
66
+ * size: 12,
67
+ * fontFamily: 'serif',
68
+ * renderingStyle: { fill: Color4.black },
69
+ * };
70
+ *
71
+ * const text = TextComponent.fromLines('foo\nbar'.split('\n'), Mat33.identity, textStyle);
72
+ * ```
73
+ */
74
+ static fromLines(lines: string[], transform: Mat33, style: TextRenderingStyle): AbstractComponent;
75
+ }
@@ -0,0 +1,274 @@
1
+ import LineSegment2 from '../math/LineSegment2.mjs';
2
+ import Mat33 from '../math/Mat33.mjs';
3
+ import Rect2 from '../math/Rect2.mjs';
4
+ import { Vec2 } from '../math/Vec2.mjs';
5
+ import { cloneTextStyle, textStyleFromJSON, textStyleToJSON } from '../rendering/TextRenderingStyle.mjs';
6
+ import AbstractComponent from './AbstractComponent.mjs';
7
+ import { createRestyleComponentCommand } from './RestylableComponent.mjs';
8
+ const componentTypeId = 'text';
9
+ /**
10
+ * Displays text.
11
+ */
12
+ export default class TextComponent extends AbstractComponent {
13
+ /**
14
+ * Creates a new text object from a list of component text or child TextComponents.
15
+ *
16
+ * @see {@link fromLines}
17
+ */
18
+ constructor(textObjects, transform, style) {
19
+ super(componentTypeId);
20
+ this.textObjects = textObjects;
21
+ this.transform = transform;
22
+ this.style = style;
23
+ // eslint-disable-next-line @typescript-eslint/prefer-as-const
24
+ this.isRestylableComponent = true;
25
+ this.recomputeBBox();
26
+ // If this has no direct children, choose a style representative of this' content
27
+ // (useful for estimating the style of the TextComponent).
28
+ const hasDirectContent = textObjects.some(obj => typeof obj === 'string');
29
+ if (!hasDirectContent && textObjects.length > 0) {
30
+ this.style = textObjects[0].getTextStyle();
31
+ }
32
+ }
33
+ static applyTextStyles(ctx, style) {
34
+ var _a, _b;
35
+ // Quote the font family if necessary.
36
+ const fontFamily = style.fontFamily.match(/\s/) ? style.fontFamily.replace(/["]/g, '\\"') : style.fontFamily;
37
+ ctx.font = [
38
+ ((_a = style.size) !== null && _a !== void 0 ? _a : 12) + 'px',
39
+ (_b = style.fontWeight) !== null && _b !== void 0 ? _b : '',
40
+ `${fontFamily}`,
41
+ style.fontWeight
42
+ ].join(' ');
43
+ ctx.textAlign = 'left';
44
+ }
45
+ // Roughly estimate the bounding box of `text`. Use if no CanvasRenderingContext2D is available.
46
+ static estimateTextDimens(text, style) {
47
+ const widthEst = text.length * style.size;
48
+ const heightEst = style.size;
49
+ // Text is drawn with (0, 0) as its baseline. As such, the majority of the text's height should
50
+ // be above (0, 0).
51
+ return new Rect2(0, -heightEst * 2 / 3, widthEst, heightEst);
52
+ }
53
+ // Returns the bounding box of `text`. This is approximate if no Canvas is available.
54
+ static getTextDimens(text, style) {
55
+ var _a, _b;
56
+ (_a = TextComponent.textMeasuringCtx) !== null && _a !== void 0 ? _a : (TextComponent.textMeasuringCtx = (_b = document.createElement('canvas').getContext('2d')) !== null && _b !== void 0 ? _b : null);
57
+ if (!TextComponent.textMeasuringCtx) {
58
+ return this.estimateTextDimens(text, style);
59
+ }
60
+ const ctx = TextComponent.textMeasuringCtx;
61
+ TextComponent.applyTextStyles(ctx, style);
62
+ const measure = ctx.measureText(text);
63
+ // Text is drawn with (0,0) at the bottom left of the baseline.
64
+ const textY = -measure.actualBoundingBoxAscent;
65
+ const textHeight = measure.actualBoundingBoxAscent + measure.actualBoundingBoxDescent;
66
+ return new Rect2(0, textY, measure.width, textHeight);
67
+ }
68
+ computeBBoxOfPart(part) {
69
+ if (typeof part === 'string') {
70
+ const textBBox = TextComponent.getTextDimens(part, this.style);
71
+ return textBBox.transformedBoundingBox(this.transform);
72
+ }
73
+ else {
74
+ const bbox = part.contentBBox.transformedBoundingBox(this.transform);
75
+ return bbox;
76
+ }
77
+ }
78
+ recomputeBBox() {
79
+ let bbox = null;
80
+ for (const textObject of this.textObjects) {
81
+ const currentBBox = this.computeBBoxOfPart(textObject);
82
+ bbox !== null && bbox !== void 0 ? bbox : (bbox = currentBBox);
83
+ bbox = bbox.union(currentBBox);
84
+ }
85
+ this.contentBBox = bbox !== null && bbox !== void 0 ? bbox : Rect2.empty;
86
+ }
87
+ renderInternal(canvas) {
88
+ const cursor = this.transform;
89
+ for (const textObject of this.textObjects) {
90
+ if (typeof textObject === 'string') {
91
+ canvas.drawText(textObject, cursor, this.style);
92
+ }
93
+ else {
94
+ canvas.pushTransform(cursor);
95
+ textObject.renderInternal(canvas);
96
+ canvas.popTransform();
97
+ }
98
+ }
99
+ }
100
+ render(canvas, _visibleRect) {
101
+ canvas.startObject(this.contentBBox);
102
+ this.renderInternal(canvas);
103
+ canvas.endObject(this.getLoadSaveData());
104
+ }
105
+ getProportionalRenderingTime() {
106
+ return this.textObjects.length;
107
+ }
108
+ intersects(lineSegment) {
109
+ // Convert canvas space to internal space.
110
+ const invTransform = this.transform.inverse();
111
+ const p1InThisSpace = invTransform.transformVec2(lineSegment.p1);
112
+ const p2InThisSpace = invTransform.transformVec2(lineSegment.p2);
113
+ lineSegment = new LineSegment2(p1InThisSpace, p2InThisSpace);
114
+ for (const subObject of this.textObjects) {
115
+ if (typeof subObject === 'string') {
116
+ const textBBox = TextComponent.getTextDimens(subObject, this.style);
117
+ // TODO: Use a better intersection check. Perhaps draw the text onto a CanvasElement and
118
+ // use pixel-testing to check for intersection with its contour.
119
+ if (textBBox.getEdges().some(edge => lineSegment.intersection(edge) !== null)) {
120
+ return true;
121
+ }
122
+ }
123
+ else {
124
+ if (subObject.intersects(lineSegment)) {
125
+ return true;
126
+ }
127
+ }
128
+ }
129
+ return false;
130
+ }
131
+ getStyle() {
132
+ return {
133
+ color: this.style.renderingStyle.fill,
134
+ // Make a copy
135
+ textStyle: Object.assign(Object.assign({}, this.style), { renderingStyle: Object.assign({}, this.style.renderingStyle) }),
136
+ };
137
+ }
138
+ updateStyle(style) {
139
+ return createRestyleComponentCommand(this.getStyle(), style, this);
140
+ }
141
+ forceStyle(style, editor) {
142
+ if (style.textStyle) {
143
+ this.style = cloneTextStyle(style.textStyle);
144
+ }
145
+ else if (style.color) {
146
+ this.style = Object.assign(Object.assign({}, this.style), { renderingStyle: Object.assign(Object.assign({}, this.style.renderingStyle), { fill: style.color }) });
147
+ }
148
+ else {
149
+ return;
150
+ }
151
+ for (const child of this.textObjects) {
152
+ if (child instanceof TextComponent) {
153
+ child.forceStyle(style, editor);
154
+ }
155
+ }
156
+ if (editor) {
157
+ editor.image.queueRerenderOf(this);
158
+ editor.queueRerender();
159
+ }
160
+ }
161
+ // See this.getStyle
162
+ getTextStyle() {
163
+ return cloneTextStyle(this.style);
164
+ }
165
+ getBaselinePos() {
166
+ return this.transform.transformVec2(Vec2.zero);
167
+ }
168
+ getTransform() {
169
+ return this.transform;
170
+ }
171
+ applyTransformation(affineTransfm) {
172
+ this.transform = affineTransfm.rightMul(this.transform);
173
+ this.recomputeBBox();
174
+ }
175
+ createClone() {
176
+ const clonedTextObjects = this.textObjects.map(obj => {
177
+ if (typeof obj === 'string') {
178
+ return obj;
179
+ }
180
+ else {
181
+ return obj.createClone();
182
+ }
183
+ });
184
+ return new TextComponent(clonedTextObjects, this.transform, this.style);
185
+ }
186
+ getText() {
187
+ const result = [];
188
+ for (const textObject of this.textObjects) {
189
+ if (typeof textObject === 'string') {
190
+ result.push(textObject);
191
+ }
192
+ else {
193
+ result.push(textObject.getText());
194
+ }
195
+ }
196
+ return result.join('\n');
197
+ }
198
+ description(localizationTable) {
199
+ return localizationTable.text(this.getText());
200
+ }
201
+ // Do not rely on the output of `serializeToJSON` taking any particular format.
202
+ serializeToJSON() {
203
+ const serializableStyle = textStyleToJSON(this.style);
204
+ const serializedTextObjects = this.textObjects.map(text => {
205
+ if (typeof text === 'string') {
206
+ return {
207
+ text,
208
+ };
209
+ }
210
+ else {
211
+ return {
212
+ json: text.serializeToJSON(),
213
+ };
214
+ }
215
+ });
216
+ return {
217
+ textObjects: serializedTextObjects,
218
+ transform: this.transform.toArray(),
219
+ style: serializableStyle,
220
+ };
221
+ }
222
+ // @internal
223
+ static deserializeFromString(json) {
224
+ if (typeof json === 'string') {
225
+ json = JSON.parse(json);
226
+ }
227
+ const style = textStyleFromJSON(json.style);
228
+ const textObjects = json.textObjects.map((data) => {
229
+ var _a;
230
+ if (((_a = data.text) !== null && _a !== void 0 ? _a : null) !== null) {
231
+ return data.text;
232
+ }
233
+ return TextComponent.deserializeFromString(data.json);
234
+ });
235
+ json.transform = json.transform.filter((elem) => typeof elem === 'number');
236
+ if (json.transform.length !== 9) {
237
+ throw new Error(`Unable to deserialize transform, ${json.transform}.`);
238
+ }
239
+ const transformData = json.transform;
240
+ const transform = new Mat33(...transformData);
241
+ return new TextComponent(textObjects, transform, style);
242
+ }
243
+ /**
244
+ * Creates a `TextComponent` from `lines`.
245
+ *
246
+ * @example
247
+ * ```ts
248
+ * const textStyle = {
249
+ * size: 12,
250
+ * fontFamily: 'serif',
251
+ * renderingStyle: { fill: Color4.black },
252
+ * };
253
+ *
254
+ * const text = TextComponent.fromLines('foo\nbar'.split('\n'), Mat33.identity, textStyle);
255
+ * ```
256
+ */
257
+ static fromLines(lines, transform, style) {
258
+ let lastComponent = null;
259
+ const components = [];
260
+ for (const line of lines) {
261
+ let position = Vec2.zero;
262
+ if (lastComponent) {
263
+ const lineMargin = Math.floor(style.size);
264
+ position = lastComponent.getBBox().bottomLeft.plus(Vec2.unitY.times(lineMargin));
265
+ }
266
+ const component = new TextComponent([line], Mat33.translation(position), style);
267
+ components.push(component);
268
+ lastComponent = component;
269
+ }
270
+ return new TextComponent(components, transform, style);
271
+ }
272
+ }
273
+ TextComponent.textMeasuringCtx = null;
274
+ AbstractComponent.registerComponent(componentTypeId, (data) => TextComponent.deserializeFromString(data));
@@ -0,0 +1,18 @@
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
+ export default class UnknownSVGObject extends AbstractComponent {
8
+ private svgObject;
9
+ protected contentBBox: Rect2;
10
+ constructor(svgObject: SVGElement);
11
+ render(canvas: AbstractRenderer, _visibleRect?: Rect2): void;
12
+ intersects(lineSegment: LineSegment2): boolean;
13
+ protected applyTransformation(_affineTransfm: Mat33): void;
14
+ isSelectable(): boolean;
15
+ protected createClone(): AbstractComponent;
16
+ description(localization: ImageComponentLocalization): string;
17
+ protected serializeToJSON(): string | null;
18
+ }
@@ -0,0 +1,44 @@
1
+ //
2
+ // Stores objects loaded from an SVG that aren't recognised by the editor.
3
+ // @internal
4
+ // @packageDocumentation
5
+ //
6
+ import Rect2 from '../math/Rect2.mjs';
7
+ import SVGRenderer from '../rendering/renderers/SVGRenderer.mjs';
8
+ import AbstractComponent from './AbstractComponent.mjs';
9
+ const componentId = 'unknown-svg-object';
10
+ export default class UnknownSVGObject extends AbstractComponent {
11
+ constructor(svgObject) {
12
+ super(componentId);
13
+ this.svgObject = svgObject;
14
+ this.contentBBox = Rect2.of(svgObject.getBoundingClientRect());
15
+ }
16
+ render(canvas, _visibleRect) {
17
+ if (!(canvas instanceof SVGRenderer)) {
18
+ // Don't draw unrenderable objects if we can't
19
+ return;
20
+ }
21
+ canvas.drawSVGElem(this.svgObject);
22
+ }
23
+ intersects(lineSegment) {
24
+ return this.contentBBox.getEdges().some(edge => edge.intersection(lineSegment) !== null);
25
+ }
26
+ applyTransformation(_affineTransfm) {
27
+ }
28
+ isSelectable() {
29
+ return false;
30
+ }
31
+ createClone() {
32
+ return new UnknownSVGObject(this.svgObject.cloneNode(true));
33
+ }
34
+ description(localization) {
35
+ return localization.svgObject;
36
+ }
37
+ serializeToJSON() {
38
+ return JSON.stringify({
39
+ html: this.svgObject.outerHTML,
40
+ });
41
+ }
42
+ }
43
+ // null: Do not deserialize UnknownSVGObjects.
44
+ AbstractComponent.registerComponent(componentId, null);
@@ -0,0 +1,19 @@
1
+ import Rect2 from '../../math/Rect2';
2
+ import AbstractRenderer from '../../rendering/renderers/AbstractRenderer';
3
+ import { StrokeDataPoint } from '../../types';
4
+ import Viewport from '../../Viewport';
5
+ import AbstractComponent from '../AbstractComponent';
6
+ import { ComponentBuilder, ComponentBuilderFactory } from './types';
7
+ export declare const makeArrowBuilder: ComponentBuilderFactory;
8
+ export default class ArrowBuilder implements ComponentBuilder {
9
+ private readonly startPoint;
10
+ private readonly viewport;
11
+ private endPoint;
12
+ constructor(startPoint: StrokeDataPoint, viewport: Viewport);
13
+ private getLineWidth;
14
+ getBBox(): Rect2;
15
+ private buildPreview;
16
+ build(): AbstractComponent;
17
+ preview(renderer: AbstractRenderer): void;
18
+ addPoint(point: StrokeDataPoint): void;
19
+ }