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,164 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const Color4_1 = __importDefault(require("../Color4"));
7
+ const LineSegment2_1 = __importDefault(require("../math/LineSegment2"));
8
+ const BaseTool_1 = __importDefault(require("./BaseTool"));
9
+ class SoundFeedback {
10
+ constructor() {
11
+ this.closed = false;
12
+ // No AudioContext? Exit!
13
+ if (!window.AudioContext) {
14
+ console.warn('Accessibility sound UI: Unable to open AudioContext.');
15
+ this.closed = true;
16
+ return;
17
+ }
18
+ this.ctx = new AudioContext();
19
+ // Color oscillator and gain
20
+ this.colorOscHue = this.ctx.createOscillator();
21
+ this.colorOscValue = this.ctx.createOscillator();
22
+ this.colorOscSaturation = this.ctx.createOscillator();
23
+ this.colorOscHue.type = 'triangle';
24
+ this.colorOscSaturation.type = 'sine';
25
+ this.colorOscValue.type = 'sawtooth';
26
+ this.valueGain = this.ctx.createGain();
27
+ this.colorOscValue.connect(this.valueGain);
28
+ this.valueGain.gain.setValueAtTime(0.18, this.ctx.currentTime);
29
+ this.colorGain = this.ctx.createGain();
30
+ this.colorOscHue.connect(this.colorGain);
31
+ this.valueGain.connect(this.colorGain);
32
+ this.colorOscSaturation.connect(this.colorGain);
33
+ this.colorGain.connect(this.ctx.destination);
34
+ // Boundary oscillator and gain
35
+ this.boundaryGain = this.ctx.createGain();
36
+ this.boundaryOsc = this.ctx.createOscillator();
37
+ this.boundaryOsc.type = 'sawtooth';
38
+ this.boundaryGain.gain.setValueAtTime(0, this.ctx.currentTime);
39
+ this.boundaryOsc.connect(this.boundaryGain);
40
+ this.boundaryGain.connect(this.ctx.destination);
41
+ // Prepare for the first announcement/feedback.
42
+ this.colorOscHue.start();
43
+ this.colorOscSaturation.start();
44
+ this.colorOscValue.start();
45
+ this.boundaryOsc.start();
46
+ this.pause();
47
+ }
48
+ pause() {
49
+ if (this.closed)
50
+ return;
51
+ this.colorGain.gain.setValueAtTime(0, this.ctx.currentTime);
52
+ void this.ctx.suspend();
53
+ }
54
+ play() {
55
+ if (this.closed)
56
+ return;
57
+ void this.ctx.resume();
58
+ }
59
+ setColor(color) {
60
+ const hsv = color.asHSV();
61
+ // Choose frequencies that roughly correspond to hue, saturation, and value.
62
+ const hueFrequency = (-Math.cos(hsv.x / 2)) * 220 + 440;
63
+ const saturationFrequency = hsv.y * 440 + 220;
64
+ const valueFrequency = (hsv.z + 0.1) * 440;
65
+ // Sigmoid with maximum 0.25 * alpha.
66
+ // Louder for greater value.
67
+ const gain = 0.25 * Math.min(1, color.a) / (1 + Math.exp(-(hsv.z - 0.5) * 3));
68
+ this.colorOscHue.frequency.setValueAtTime(hueFrequency, this.ctx.currentTime);
69
+ this.colorOscSaturation.frequency.setValueAtTime(saturationFrequency, this.ctx.currentTime);
70
+ this.colorOscValue.frequency.setValueAtTime(valueFrequency, this.ctx.currentTime);
71
+ this.valueGain.gain.setValueAtTime((1 - hsv.z) * 0.4, this.ctx.currentTime);
72
+ this.colorGain.gain.setValueAtTime(gain, this.ctx.currentTime);
73
+ }
74
+ announceBoundaryCross(boundaryCrossCount) {
75
+ this.boundaryGain.gain.cancelScheduledValues(this.ctx.currentTime);
76
+ this.boundaryGain.gain.setValueAtTime(0, this.ctx.currentTime);
77
+ this.boundaryGain.gain.linearRampToValueAtTime(0.01, this.ctx.currentTime + 0.1);
78
+ this.boundaryOsc.frequency.setValueAtTime(440 + Math.atan(boundaryCrossCount / 2) * 100, this.ctx.currentTime);
79
+ this.boundaryGain.gain.linearRampToValueAtTime(0, this.ctx.currentTime + 0.25);
80
+ }
81
+ close() {
82
+ this.ctx.close();
83
+ this.closed = true;
84
+ }
85
+ }
86
+ /**
87
+ * This tool, when enabled, plays a sound representing the color of the portion of the display
88
+ * currently under the cursor. This tool adds a button that can be navigated to with the tab key
89
+ * that enables/disables the tool.
90
+ *
91
+ * This allows the user to explore the content of the display without a working screen.
92
+ */
93
+ class SoundUITool extends BaseTool_1.default {
94
+ constructor(editor, description) {
95
+ super(editor.notifier, description);
96
+ this.editor = editor;
97
+ this.soundFeedback = null;
98
+ // Create a screen-reader-usable method of toggling the tool:
99
+ this.toggleButtonContainer = document.createElement('div');
100
+ this.toggleButtonContainer.classList.add('js-draw-sound-ui-toggle');
101
+ this.toggleButton = document.createElement('button');
102
+ this.toggleButton.onclick = () => {
103
+ this.setEnabled(!this.isEnabled());
104
+ };
105
+ this.toggleButtonContainer.appendChild(this.toggleButton);
106
+ this.updateToggleButtonText();
107
+ editor.createHTMLOverlay(this.toggleButtonContainer);
108
+ }
109
+ updateToggleButtonText() {
110
+ const containerEnabledClass = 'sound-ui-tool-enabled';
111
+ if (this.isEnabled()) {
112
+ this.toggleButton.innerText = this.editor.localization.disableAccessibilityExploreTool;
113
+ this.toggleButtonContainer.classList.add(containerEnabledClass);
114
+ }
115
+ else {
116
+ this.toggleButton.innerText = this.editor.localization.enableAccessibilityExploreTool;
117
+ this.toggleButtonContainer.classList.remove(containerEnabledClass);
118
+ }
119
+ }
120
+ setEnabled(enabled) {
121
+ var _a;
122
+ super.setEnabled(enabled);
123
+ if (!enabled) {
124
+ (_a = this.soundFeedback) === null || _a === void 0 ? void 0 : _a.close();
125
+ this.soundFeedback = null;
126
+ }
127
+ this.updateToggleButtonText();
128
+ }
129
+ onPointerDown({ current, allPointers }) {
130
+ var _a, _b, _c;
131
+ if (!this.soundFeedback) {
132
+ this.soundFeedback = new SoundFeedback();
133
+ }
134
+ // Allow two-finger gestures to move the screen.
135
+ if (allPointers.length >= 2) {
136
+ return false;
137
+ }
138
+ // Accept multiple cursors -- some screen readers require multiple (touch) pointers to interact with
139
+ // an image instead of using the built-in navigation features.
140
+ (_a = this.soundFeedback) === null || _a === void 0 ? void 0 : _a.play();
141
+ (_b = this.soundFeedback) === null || _b === void 0 ? void 0 : _b.setColor((_c = this.editor.display.getColorAt(current.screenPos)) !== null && _c !== void 0 ? _c : Color4_1.default.black);
142
+ this.lastPointerPos = current.canvasPos;
143
+ return true;
144
+ }
145
+ onPointerMove({ current }) {
146
+ var _a, _b, _c;
147
+ (_a = this.soundFeedback) === null || _a === void 0 ? void 0 : _a.setColor((_b = this.editor.display.getColorAt(current.screenPos)) !== null && _b !== void 0 ? _b : Color4_1.default.black);
148
+ const pointerMotionLine = new LineSegment2_1.default(this.lastPointerPos, current.canvasPos);
149
+ const collisions = this.editor.image.getElementsIntersectingRegion(pointerMotionLine.bbox).filter(component => component.intersects(pointerMotionLine));
150
+ this.lastPointerPos = current.canvasPos;
151
+ if (collisions.length > 0) {
152
+ (_c = this.soundFeedback) === null || _c === void 0 ? void 0 : _c.announceBoundaryCross(collisions.length);
153
+ }
154
+ }
155
+ onPointerUp(_event) {
156
+ var _a;
157
+ (_a = this.soundFeedback) === null || _a === void 0 ? void 0 : _a.pause();
158
+ }
159
+ onGestureCancel() {
160
+ var _a;
161
+ (_a = this.soundFeedback) === null || _a === void 0 ? void 0 : _a.pause();
162
+ }
163
+ }
164
+ exports.default = SoundUITool;
@@ -0,0 +1,33 @@
1
+ import Color4 from '../Color4';
2
+ import Editor from '../Editor';
3
+ import { PointerEvt } from '../types';
4
+ import BaseTool from './BaseTool';
5
+ import { ToolLocalization } from './localization';
6
+ import TextRenderingStyle from '../rendering/TextRenderingStyle';
7
+ export default class TextTool extends BaseTool {
8
+ private editor;
9
+ private localizationTable;
10
+ private textStyle;
11
+ private textEditOverlay;
12
+ private textInputElem;
13
+ private textTargetPosition;
14
+ private textMeasuringCtx;
15
+ private textRotation;
16
+ private textScale;
17
+ private removeExistingCommand;
18
+ constructor(editor: Editor, description: string, localizationTable: ToolLocalization);
19
+ private getTextAscent;
20
+ private flushInput;
21
+ private getTextScaleMatrix;
22
+ private updateTextInput;
23
+ private startTextInput;
24
+ setEnabled(enabled: boolean): void;
25
+ onPointerDown({ current, allPointers }: PointerEvt): boolean;
26
+ onGestureCancel(): void;
27
+ private dispatchUpdateEvent;
28
+ setFontFamily(fontFamily: string): void;
29
+ setColor(color: Color4): void;
30
+ setFontSize(size: number): void;
31
+ getTextStyle(): TextRenderingStyle;
32
+ private setTextStyle;
33
+ }
@@ -0,0 +1,262 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const Color4_1 = __importDefault(require("../Color4"));
7
+ const TextComponent_1 = __importDefault(require("../components/TextComponent"));
8
+ const EditorImage_1 = __importDefault(require("../EditorImage"));
9
+ const Rect2_1 = __importDefault(require("../math/Rect2"));
10
+ const Mat33_1 = __importDefault(require("../math/Mat33"));
11
+ const Vec2_1 = require("../math/Vec2");
12
+ const Pointer_1 = require("../Pointer");
13
+ const types_1 = require("../types");
14
+ const BaseTool_1 = __importDefault(require("./BaseTool"));
15
+ const Erase_1 = __importDefault(require("../commands/Erase"));
16
+ const uniteCommands_1 = __importDefault(require("../commands/uniteCommands"));
17
+ const overlayCssClass = 'textEditorOverlay';
18
+ class TextTool extends BaseTool_1.default {
19
+ constructor(editor, description, localizationTable) {
20
+ super(editor.notifier, description);
21
+ this.editor = editor;
22
+ this.localizationTable = localizationTable;
23
+ this.textInputElem = null;
24
+ this.textTargetPosition = null;
25
+ this.textMeasuringCtx = null;
26
+ this.textScale = Vec2_1.Vec2.of(1, 1);
27
+ this.removeExistingCommand = null;
28
+ this.textStyle = {
29
+ size: 32,
30
+ fontFamily: 'sans-serif',
31
+ renderingStyle: {
32
+ fill: Color4_1.default.purple,
33
+ },
34
+ };
35
+ this.textEditOverlay = document.createElement('div');
36
+ this.textEditOverlay.classList.add(overlayCssClass);
37
+ this.editor.addStyleSheet(`
38
+ .${overlayCssClass} {
39
+ height: 0;
40
+ overflow: visible;
41
+ }
42
+
43
+ .${overlayCssClass} textarea {
44
+ background-color: rgba(0, 0, 0, 0);
45
+
46
+ white-space: pre;
47
+ overflow: hidden;
48
+
49
+ padding: 0;
50
+ margin: 0;
51
+ border: none;
52
+ padding: 0;
53
+
54
+ min-width: 100px;
55
+ min-height: 1.1em;
56
+ }
57
+ `);
58
+ this.editor.createHTMLOverlay(this.textEditOverlay);
59
+ this.editor.notifier.on(types_1.EditorEventType.ViewportChanged, () => this.updateTextInput());
60
+ }
61
+ getTextAscent(text, style) {
62
+ var _a;
63
+ (_a = this.textMeasuringCtx) !== null && _a !== void 0 ? _a : (this.textMeasuringCtx = document.createElement('canvas').getContext('2d'));
64
+ if (this.textMeasuringCtx) {
65
+ TextComponent_1.default.applyTextStyles(this.textMeasuringCtx, style);
66
+ return this.textMeasuringCtx.measureText(text).actualBoundingBoxAscent;
67
+ }
68
+ // Estimate
69
+ return style.size * 2 / 3;
70
+ }
71
+ // Take input from this' textInputElem and add it to the EditorImage.
72
+ // If [removeInput], the HTML input element is removed. Otherwise, its value
73
+ // is cleared.
74
+ flushInput(removeInput = true) {
75
+ if (this.textInputElem && this.textTargetPosition) {
76
+ const content = this.textInputElem.value.trimEnd();
77
+ this.textInputElem.value = '';
78
+ if (removeInput) {
79
+ // In some browsers, .remove() triggers a .blur event (synchronously).
80
+ // Clear this.textInputElem before removal
81
+ const input = this.textInputElem;
82
+ this.textInputElem = null;
83
+ input.remove();
84
+ }
85
+ if (content === '') {
86
+ return;
87
+ }
88
+ const textTransform = Mat33_1.default.translation(this.textTargetPosition).rightMul(this.getTextScaleMatrix()).rightMul(Mat33_1.default.scaling2D(this.editor.viewport.getSizeOfPixelOnCanvas())).rightMul(Mat33_1.default.zRotation(this.textRotation));
89
+ const textComponent = TextComponent_1.default.fromLines(content.split('\n'), textTransform, this.textStyle);
90
+ const action = EditorImage_1.default.addElement(textComponent);
91
+ if (this.removeExistingCommand) {
92
+ // Unapply so that `removeExistingCommand` can be added to the undo stack.
93
+ this.removeExistingCommand.unapply(this.editor);
94
+ this.editor.dispatch((0, uniteCommands_1.default)([this.removeExistingCommand, action]));
95
+ this.removeExistingCommand = null;
96
+ }
97
+ else {
98
+ this.editor.dispatch(action);
99
+ }
100
+ }
101
+ }
102
+ getTextScaleMatrix() {
103
+ return Mat33_1.default.scaling2D(this.textScale.times(1 / this.editor.viewport.getSizeOfPixelOnCanvas()));
104
+ }
105
+ updateTextInput() {
106
+ var _a, _b, _c;
107
+ if (!this.textInputElem || !this.textTargetPosition) {
108
+ (_a = this.textInputElem) === null || _a === void 0 ? void 0 : _a.remove();
109
+ return;
110
+ }
111
+ const viewport = this.editor.viewport;
112
+ const textScreenPos = viewport.canvasToScreen(this.textTargetPosition);
113
+ this.textInputElem.placeholder = this.localizationTable.enterTextToInsert;
114
+ this.textInputElem.style.fontFamily = this.textStyle.fontFamily;
115
+ this.textInputElem.style.fontVariant = (_b = this.textStyle.fontVariant) !== null && _b !== void 0 ? _b : '';
116
+ this.textInputElem.style.fontWeight = (_c = this.textStyle.fontWeight) !== null && _c !== void 0 ? _c : '';
117
+ this.textInputElem.style.fontSize = `${this.textStyle.size}px`;
118
+ this.textInputElem.style.color = this.textStyle.renderingStyle.fill.toHexString();
119
+ this.textInputElem.style.position = 'relative';
120
+ this.textInputElem.style.left = `${textScreenPos.x}px`;
121
+ this.textInputElem.style.top = `${textScreenPos.y}px`;
122
+ this.textInputElem.style.margin = '0';
123
+ this.textInputElem.style.width = `${this.textInputElem.scrollWidth}px`;
124
+ this.textInputElem.style.height = `${this.textInputElem.scrollHeight}px`;
125
+ // Get the ascent based on the font, using a character that is tall in most fonts.
126
+ const tallCharacter = '⎢';
127
+ const ascent = this.getTextAscent(tallCharacter, this.textStyle);
128
+ const rotation = this.textRotation + viewport.getRotationAngle();
129
+ const scale = this.getTextScaleMatrix();
130
+ this.textInputElem.style.transform = `${scale.toCSSMatrix()} rotate(${rotation * 180 / Math.PI}deg) translate(0, ${-ascent}px)`;
131
+ this.textInputElem.style.transformOrigin = 'top left';
132
+ }
133
+ startTextInput(textCanvasPos, initialText) {
134
+ this.flushInput();
135
+ this.textInputElem = document.createElement('textarea');
136
+ this.textInputElem.value = initialText;
137
+ this.textInputElem.style.display = 'inline-block';
138
+ this.textTargetPosition = this.editor.viewport.roundPoint(textCanvasPos);
139
+ this.textRotation = -this.editor.viewport.getRotationAngle();
140
+ this.textScale = Vec2_1.Vec2.of(1, 1).times(this.editor.viewport.getSizeOfPixelOnCanvas());
141
+ this.updateTextInput();
142
+ // Update the input size/position/etc. after the placeHolder has had time to appear.
143
+ setTimeout(() => this.updateTextInput(), 0);
144
+ this.textInputElem.oninput = () => {
145
+ if (this.textInputElem) {
146
+ this.textInputElem.style.width = `${this.textInputElem.scrollWidth}px`;
147
+ this.textInputElem.style.height = `${this.textInputElem.scrollHeight}px`;
148
+ }
149
+ };
150
+ this.textInputElem.onblur = () => {
151
+ // Delay removing the input -- flushInput may be called within a blur()
152
+ // event handler
153
+ const removeInput = false;
154
+ const input = this.textInputElem;
155
+ this.flushInput(removeInput);
156
+ this.textInputElem = null;
157
+ setTimeout(() => {
158
+ input === null || input === void 0 ? void 0 : input.remove();
159
+ }, 0);
160
+ };
161
+ this.textInputElem.onkeyup = (evt) => {
162
+ var _a, _b;
163
+ if (evt.key === 'Enter' && !evt.shiftKey) {
164
+ this.flushInput();
165
+ this.editor.focus();
166
+ }
167
+ else if (evt.key === 'Escape') {
168
+ // Cancel input.
169
+ (_a = this.textInputElem) === null || _a === void 0 ? void 0 : _a.remove();
170
+ this.textInputElem = null;
171
+ this.editor.focus();
172
+ (_b = this.removeExistingCommand) === null || _b === void 0 ? void 0 : _b.unapply(this.editor);
173
+ this.removeExistingCommand = null;
174
+ }
175
+ };
176
+ this.textEditOverlay.replaceChildren(this.textInputElem);
177
+ setTimeout(() => { var _a; return (_a = this.textInputElem) === null || _a === void 0 ? void 0 : _a.focus(); }, 0);
178
+ }
179
+ setEnabled(enabled) {
180
+ super.setEnabled(enabled);
181
+ if (!enabled) {
182
+ this.flushInput();
183
+ }
184
+ this.textEditOverlay.style.display = enabled ? 'block' : 'none';
185
+ }
186
+ onPointerDown({ current, allPointers }) {
187
+ if (current.device === Pointer_1.PointerDevice.Eraser) {
188
+ return false;
189
+ }
190
+ if (allPointers.length === 1) {
191
+ // Are we clicking on a text node?
192
+ const canvasPos = current.canvasPos;
193
+ const halfTestRegionSize = Vec2_1.Vec2.of(2.5, 2.5).times(this.editor.viewport.getSizeOfPixelOnCanvas());
194
+ const testRegion = Rect2_1.default.fromCorners(canvasPos.minus(halfTestRegionSize), canvasPos.plus(halfTestRegionSize));
195
+ const targetNodes = this.editor.image.getElementsIntersectingRegion(testRegion);
196
+ let targetTextNodes = targetNodes.filter(node => node instanceof TextComponent_1.default);
197
+ // Don't try to edit text nodes that contain the viewport (this allows us
198
+ // to zoom in on text nodes and add text on top of them.)
199
+ const visibleRect = this.editor.viewport.visibleRect;
200
+ targetTextNodes = targetTextNodes.filter(node => !node.getBBox().containsRect(visibleRect));
201
+ // End any TextNodes we're currently editing.
202
+ this.flushInput();
203
+ if (targetTextNodes.length > 0) {
204
+ const targetNode = targetTextNodes[targetTextNodes.length - 1];
205
+ this.setTextStyle(targetNode.getTextStyle());
206
+ // Create and temporarily apply removeExistingCommand.
207
+ this.removeExistingCommand = new Erase_1.default([targetNode]);
208
+ this.removeExistingCommand.apply(this.editor);
209
+ this.startTextInput(targetNode.getBaselinePos(), targetNode.getText());
210
+ const transform = targetNode.getTransform();
211
+ this.textRotation = transform.transformVec3(Vec2_1.Vec2.unitX).angle();
212
+ const scaleFactor = transform.transformVec3(Vec2_1.Vec2.unitX).magnitude();
213
+ this.textScale = Vec2_1.Vec2.of(1, 1).times(scaleFactor);
214
+ this.updateTextInput();
215
+ }
216
+ else {
217
+ this.removeExistingCommand = null;
218
+ this.startTextInput(current.canvasPos, '');
219
+ }
220
+ return true;
221
+ }
222
+ return false;
223
+ }
224
+ onGestureCancel() {
225
+ this.flushInput();
226
+ this.editor.focus();
227
+ }
228
+ dispatchUpdateEvent() {
229
+ this.updateTextInput();
230
+ this.editor.notifier.dispatch(types_1.EditorEventType.ToolUpdated, {
231
+ kind: types_1.EditorEventType.ToolUpdated,
232
+ tool: this,
233
+ });
234
+ }
235
+ setFontFamily(fontFamily) {
236
+ if (fontFamily !== this.textStyle.fontFamily) {
237
+ this.textStyle = Object.assign(Object.assign({}, this.textStyle), { fontFamily: fontFamily });
238
+ this.dispatchUpdateEvent();
239
+ }
240
+ }
241
+ setColor(color) {
242
+ if (!color.eq(this.textStyle.renderingStyle.fill)) {
243
+ this.textStyle = Object.assign(Object.assign({}, this.textStyle), { renderingStyle: Object.assign(Object.assign({}, this.textStyle.renderingStyle), { fill: color }) });
244
+ this.dispatchUpdateEvent();
245
+ }
246
+ }
247
+ setFontSize(size) {
248
+ if (size !== this.textStyle.size) {
249
+ this.textStyle = Object.assign(Object.assign({}, this.textStyle), { size });
250
+ this.dispatchUpdateEvent();
251
+ }
252
+ }
253
+ getTextStyle() {
254
+ return this.textStyle;
255
+ }
256
+ setTextStyle(style) {
257
+ // Copy the style — we may change parts of it.
258
+ this.textStyle = Object.assign(Object.assign({}, style), { renderingStyle: Object.assign({}, style.renderingStyle) });
259
+ this.dispatchUpdateEvent();
260
+ }
261
+ }
262
+ exports.default = TextTool;
@@ -0,0 +1,18 @@
1
+ import { InputEvt } from '../types';
2
+ import Editor from '../Editor';
3
+ import BaseTool from './BaseTool';
4
+ import ToolEnabledGroup from './ToolEnabledGroup';
5
+ import { ToolLocalization } from './localization';
6
+ export default class ToolController {
7
+ private tools;
8
+ private activeTool;
9
+ private primaryToolGroup;
10
+ /** @internal */
11
+ constructor(editor: Editor, localization: ToolLocalization);
12
+ setTools(tools: BaseTool[], primaryToolGroup?: ToolEnabledGroup): void;
13
+ addPrimaryTool(tool: BaseTool): void;
14
+ getPrimaryTools(): BaseTool[];
15
+ addTool(tool: BaseTool): void;
16
+ dispatchInputEvent(event: InputEvt): boolean;
17
+ getMatchingTools<Type extends BaseTool>(type: new (...args: any[]) => Type): Type[];
18
+ }
@@ -0,0 +1,192 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ const types_1 = require("../types");
30
+ const PanZoom_1 = __importStar(require("./PanZoom"));
31
+ const Pen_1 = __importDefault(require("./Pen"));
32
+ const ToolEnabledGroup_1 = __importDefault(require("./ToolEnabledGroup"));
33
+ const Eraser_1 = __importDefault(require("./Eraser"));
34
+ const SelectionTool_1 = __importDefault(require("./SelectionTool/SelectionTool"));
35
+ const Color4_1 = __importDefault(require("../Color4"));
36
+ const UndoRedoShortcut_1 = __importDefault(require("./UndoRedoShortcut"));
37
+ const TextTool_1 = __importDefault(require("./TextTool"));
38
+ const PipetteTool_1 = __importDefault(require("./PipetteTool"));
39
+ const ToolSwitcherShortcut_1 = __importDefault(require("./ToolSwitcherShortcut"));
40
+ const PasteHandler_1 = __importDefault(require("./PasteHandler"));
41
+ const ToolbarShortcutHandler_1 = __importDefault(require("./ToolbarShortcutHandler"));
42
+ const PressureSensitiveFreehandLineBuilder_1 = require("../components/builders/PressureSensitiveFreehandLineBuilder");
43
+ const FindTool_1 = __importDefault(require("./FindTool"));
44
+ const SelectAllShortcutHandler_1 = __importDefault(require("./SelectionTool/SelectAllShortcutHandler"));
45
+ const SoundUITool_1 = __importDefault(require("./SoundUITool"));
46
+ class ToolController {
47
+ /** @internal */
48
+ constructor(editor, localization) {
49
+ this.activeTool = null;
50
+ const primaryToolGroup = new ToolEnabledGroup_1.default();
51
+ this.primaryToolGroup = primaryToolGroup;
52
+ const panZoomTool = new PanZoom_1.default(editor, PanZoom_1.PanZoomMode.TwoFingerTouchGestures | PanZoom_1.PanZoomMode.RightClickDrags, localization.touchPanTool);
53
+ const keyboardPanZoomTool = new PanZoom_1.default(editor, PanZoom_1.PanZoomMode.Keyboard, localization.keyboardPanZoom);
54
+ const primaryPenTool = new Pen_1.default(editor, localization.penTool(1), { color: Color4_1.default.purple, thickness: 8 });
55
+ const primaryTools = [
56
+ // Three pens
57
+ primaryPenTool,
58
+ new Pen_1.default(editor, localization.penTool(2), { color: Color4_1.default.clay, thickness: 4 }),
59
+ // Highlighter-like pen with width=40
60
+ new Pen_1.default(editor, localization.penTool(3), { color: Color4_1.default.ofRGBA(1, 1, 0, 0.5), thickness: 40 }, PressureSensitiveFreehandLineBuilder_1.makePressureSensitiveFreehandLineBuilder),
61
+ new Eraser_1.default(editor, localization.eraserTool),
62
+ new SelectionTool_1.default(editor, localization.selectionTool),
63
+ new TextTool_1.default(editor, localization.textTool, localization),
64
+ new PanZoom_1.default(editor, PanZoom_1.PanZoomMode.SinglePointerGestures, localization.anyDevicePanning),
65
+ ];
66
+ // Accessibility tools
67
+ const soundExplorer = new SoundUITool_1.default(editor, localization.soundExplorer);
68
+ soundExplorer.setEnabled(false);
69
+ this.tools = [
70
+ new PipetteTool_1.default(editor, localization.pipetteTool),
71
+ soundExplorer,
72
+ panZoomTool,
73
+ ...primaryTools,
74
+ keyboardPanZoomTool,
75
+ new UndoRedoShortcut_1.default(editor),
76
+ new ToolbarShortcutHandler_1.default(editor),
77
+ new ToolSwitcherShortcut_1.default(editor),
78
+ new FindTool_1.default(editor),
79
+ new PasteHandler_1.default(editor),
80
+ new SelectAllShortcutHandler_1.default(editor),
81
+ ];
82
+ primaryTools.forEach(tool => tool.setToolGroup(primaryToolGroup));
83
+ panZoomTool.setEnabled(true);
84
+ primaryPenTool.setEnabled(true);
85
+ editor.notifier.on(types_1.EditorEventType.ToolEnabled, event => {
86
+ if (event.kind === types_1.EditorEventType.ToolEnabled) {
87
+ editor.announceForAccessibility(localization.toolEnabledAnnouncement(event.tool.description));
88
+ }
89
+ });
90
+ editor.notifier.on(types_1.EditorEventType.ToolDisabled, event => {
91
+ if (event.kind === types_1.EditorEventType.ToolDisabled) {
92
+ editor.announceForAccessibility(localization.toolDisabledAnnouncement(event.tool.description));
93
+ }
94
+ });
95
+ this.activeTool = null;
96
+ }
97
+ // Replaces the current set of tools with `tools`. This should only be done before
98
+ // the creation of the app's toolbar (if using `HTMLToolbar`).
99
+ setTools(tools, primaryToolGroup) {
100
+ this.tools = tools;
101
+ this.primaryToolGroup = primaryToolGroup !== null && primaryToolGroup !== void 0 ? primaryToolGroup : new ToolEnabledGroup_1.default();
102
+ }
103
+ // Add a tool that acts like one of the primary tools (only one primary tool can be enabled at a time).
104
+ // This should be called before creating the app's toolbar.
105
+ addPrimaryTool(tool) {
106
+ tool.setToolGroup(this.primaryToolGroup);
107
+ if (tool.isEnabled()) {
108
+ this.primaryToolGroup.notifyEnabled(tool);
109
+ }
110
+ this.addTool(tool);
111
+ }
112
+ getPrimaryTools() {
113
+ return this.tools.filter(tool => {
114
+ return tool.getToolGroup() === this.primaryToolGroup;
115
+ });
116
+ }
117
+ // Add a tool to the end of this' tool list (the added tool receives events after tools already added to this).
118
+ // This should be called before creating the app's toolbar.
119
+ addTool(tool) {
120
+ this.tools.push(tool);
121
+ }
122
+ // Returns true if the event was handled
123
+ dispatchInputEvent(event) {
124
+ var _a, _b;
125
+ let handled = false;
126
+ if (event.kind === types_1.InputEvtType.PointerDownEvt) {
127
+ for (const tool of this.tools) {
128
+ if (tool.isEnabled() && tool.onPointerDown(event)) {
129
+ if (this.activeTool !== tool) {
130
+ (_a = this.activeTool) === null || _a === void 0 ? void 0 : _a.onGestureCancel();
131
+ }
132
+ this.activeTool = tool;
133
+ handled = true;
134
+ break;
135
+ }
136
+ }
137
+ }
138
+ else if (event.kind === types_1.InputEvtType.PointerUpEvt) {
139
+ (_b = this.activeTool) === null || _b === void 0 ? void 0 : _b.onPointerUp(event);
140
+ this.activeTool = null;
141
+ handled = true;
142
+ }
143
+ else if (event.kind === types_1.InputEvtType.PointerMoveEvt) {
144
+ if (this.activeTool !== null) {
145
+ this.activeTool.onPointerMove(event);
146
+ handled = true;
147
+ }
148
+ }
149
+ else if (event.kind === types_1.InputEvtType.GestureCancelEvt) {
150
+ if (this.activeTool !== null) {
151
+ this.activeTool.onGestureCancel();
152
+ this.activeTool = null;
153
+ }
154
+ }
155
+ else {
156
+ let allCasesHandledGuard;
157
+ for (const tool of this.tools) {
158
+ if (!tool.isEnabled()) {
159
+ continue;
160
+ }
161
+ switch (event.kind) {
162
+ case types_1.InputEvtType.KeyPressEvent:
163
+ handled = tool.onKeyPress(event);
164
+ break;
165
+ case types_1.InputEvtType.KeyUpEvent:
166
+ handled = tool.onKeyUp(event);
167
+ break;
168
+ case types_1.InputEvtType.WheelEvt:
169
+ handled = tool.onWheel(event);
170
+ break;
171
+ case types_1.InputEvtType.CopyEvent:
172
+ handled = tool.onCopy(event);
173
+ break;
174
+ case types_1.InputEvtType.PasteEvent:
175
+ handled = tool.onPaste(event);
176
+ break;
177
+ default:
178
+ allCasesHandledGuard = event;
179
+ return allCasesHandledGuard;
180
+ }
181
+ if (handled) {
182
+ break;
183
+ }
184
+ }
185
+ }
186
+ return handled;
187
+ }
188
+ getMatchingTools(type) {
189
+ return this.tools.filter(tool => tool instanceof type);
190
+ }
191
+ }
192
+ exports.default = ToolController;
@@ -0,0 +1,6 @@
1
+ import BaseTool from './BaseTool';
2
+ export default class ToolEnabledGroup {
3
+ private activeTool;
4
+ constructor();
5
+ notifyEnabled(tool: BaseTool): void;
6
+ }