js-draw 0.17.4 → 0.18.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 (494) hide show
  1. package/.github/workflows/firebase-hosting-merge.yml +2 -0
  2. package/.github/workflows/firebase-hosting-pull-request.yml +2 -0
  3. package/.github/workflows/github-pages.yml +2 -0
  4. package/CHANGELOG.md +4 -0
  5. package/build_tools/postDist.ts +71 -0
  6. package/dist/bundle.js +9 -1
  7. package/dist/cjs/build_tools/BundledFile.js +163 -0
  8. package/dist/cjs/build_tools/buildTranslationTemplate.js +119 -0
  9. package/dist/cjs/build_tools/bundle.js +10 -0
  10. package/dist/cjs/build_tools/postDist.js +72 -0
  11. package/dist/{src → cjs/src}/Color4.d.ts +1 -0
  12. package/dist/cjs/src/Color4.js +197 -0
  13. package/dist/cjs/src/Editor.js +904 -0
  14. package/dist/cjs/src/EditorImage.js +486 -0
  15. package/dist/cjs/src/EventDispatcher.js +57 -0
  16. package/dist/cjs/src/Pointer.js +84 -0
  17. package/dist/cjs/src/SVGLoader.js +472 -0
  18. package/dist/cjs/src/UndoRedoHistory.js +93 -0
  19. package/dist/cjs/src/Viewport.js +264 -0
  20. package/dist/cjs/src/bundle/bundled.js +24 -0
  21. package/dist/cjs/src/commands/Command.js +34 -0
  22. package/dist/cjs/src/commands/Duplicate.js +39 -0
  23. package/dist/cjs/src/commands/Erase.js +63 -0
  24. package/dist/cjs/src/commands/SerializableCommand.js +42 -0
  25. package/dist/cjs/src/commands/UnresolvedCommand.js +28 -0
  26. package/dist/cjs/src/commands/invertCommand.js +49 -0
  27. package/dist/cjs/src/commands/lib.js +18 -0
  28. package/dist/cjs/src/commands/localization.js +24 -0
  29. package/dist/cjs/src/commands/uniteCommands.js +121 -0
  30. package/dist/cjs/src/components/AbstractComponent.js +258 -0
  31. package/dist/cjs/src/components/ImageBackground.js +146 -0
  32. package/dist/cjs/src/components/ImageComponent.js +152 -0
  33. package/dist/cjs/src/components/RestylableComponent.js +88 -0
  34. package/dist/cjs/src/components/SVGGlobalAttributesObject.js +65 -0
  35. package/dist/cjs/src/components/Stroke.js +191 -0
  36. package/dist/cjs/src/components/TextComponent.js +258 -0
  37. package/dist/cjs/src/components/UnknownSVGObject.js +50 -0
  38. package/dist/cjs/src/components/builders/ArrowBuilder.js +117 -0
  39. package/dist/cjs/src/components/builders/FreehandLineBuilder.js +173 -0
  40. package/dist/cjs/src/components/builders/LineBuilder.js +89 -0
  41. package/dist/cjs/src/components/builders/PressureSensitiveFreehandLineBuilder.js +347 -0
  42. package/dist/cjs/src/components/builders/RectangleBuilder.js +59 -0
  43. package/dist/cjs/src/components/builders/types.js +2 -0
  44. package/dist/cjs/src/components/lib.js +43 -0
  45. package/dist/cjs/src/components/localization.js +13 -0
  46. package/dist/cjs/src/components/util/StrokeSmoother.js +217 -0
  47. package/dist/cjs/src/components/util/describeComponentList.js +16 -0
  48. package/dist/cjs/src/lib.js +63 -0
  49. package/dist/cjs/src/localization.js +13 -0
  50. package/dist/cjs/src/localizations/de.js +6 -0
  51. package/dist/cjs/src/localizations/en.js +6 -0
  52. package/dist/cjs/src/localizations/es.js +20 -0
  53. package/dist/cjs/src/localizations/getLocalizationTable.js +50 -0
  54. package/dist/cjs/src/math/LineSegment2.js +131 -0
  55. package/dist/cjs/src/math/Mat33.js +332 -0
  56. package/dist/cjs/src/math/Path.js +655 -0
  57. package/dist/cjs/src/math/Rect2.js +234 -0
  58. package/dist/cjs/src/math/Triangle.js +22 -0
  59. package/dist/cjs/src/math/Vec2.js +19 -0
  60. package/dist/cjs/src/math/Vec3.js +177 -0
  61. package/dist/cjs/src/math/lib.js +18 -0
  62. package/dist/cjs/src/math/rounding.js +135 -0
  63. package/dist/cjs/src/rendering/Display.js +214 -0
  64. package/dist/cjs/src/rendering/RenderingStyle.js +48 -0
  65. package/dist/cjs/src/rendering/TextRenderingStyle.js +29 -0
  66. package/dist/cjs/src/rendering/caching/CacheRecord.js +61 -0
  67. package/dist/cjs/src/rendering/caching/CacheRecordManager.js +50 -0
  68. package/dist/cjs/src/rendering/caching/RenderingCache.js +51 -0
  69. package/dist/cjs/src/rendering/caching/RenderingCacheNode.js +326 -0
  70. package/dist/cjs/src/rendering/caching/testUtils.js +27 -0
  71. package/dist/cjs/src/rendering/caching/types.js +2 -0
  72. package/dist/cjs/src/rendering/lib.js +16 -0
  73. package/dist/cjs/src/rendering/localization.js +12 -0
  74. package/dist/cjs/src/rendering/renderers/AbstractRenderer.js +170 -0
  75. package/dist/cjs/src/rendering/renderers/CanvasRenderer.js +236 -0
  76. package/dist/cjs/src/rendering/renderers/DummyRenderer.js +112 -0
  77. package/dist/cjs/src/rendering/renderers/SVGRenderer.js +311 -0
  78. package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.js +63 -0
  79. package/dist/cjs/src/testing/beforeEachFile.js +12 -0
  80. package/dist/cjs/src/testing/createEditor.js +14 -0
  81. package/dist/cjs/src/testing/lib.js +10 -0
  82. package/dist/cjs/src/testing/loadExpectExtensions.js +28 -0
  83. package/dist/cjs/src/testing/sendPenEvent.js +24 -0
  84. package/dist/cjs/src/testing/sendTouchEvent.js +87 -0
  85. package/dist/cjs/src/toolbar/HTMLToolbar.js +383 -0
  86. package/dist/cjs/src/toolbar/IconProvider.js +660 -0
  87. package/dist/cjs/src/toolbar/lib.js +24 -0
  88. package/dist/cjs/src/toolbar/localization.js +51 -0
  89. package/dist/cjs/src/toolbar/makeColorInput.js +120 -0
  90. package/dist/cjs/src/toolbar/types.js +2 -0
  91. package/dist/cjs/src/toolbar/widgets/ActionButtonWidget.js +31 -0
  92. package/dist/cjs/src/toolbar/widgets/BaseToolWidget.js +50 -0
  93. package/dist/cjs/src/toolbar/widgets/BaseWidget.js +313 -0
  94. package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.js +126 -0
  95. package/dist/cjs/src/toolbar/widgets/EraserToolWidget.js +63 -0
  96. package/dist/cjs/src/toolbar/widgets/HandToolWidget.js +201 -0
  97. package/dist/cjs/src/toolbar/widgets/InsertImageWidget.js +176 -0
  98. package/dist/cjs/src/toolbar/widgets/OverflowWidget.js +77 -0
  99. package/dist/cjs/src/toolbar/widgets/PenToolWidget.js +226 -0
  100. package/dist/cjs/src/toolbar/widgets/SelectionToolWidget.js +153 -0
  101. package/dist/cjs/src/toolbar/widgets/TextToolWidget.js +115 -0
  102. package/dist/cjs/src/toolbar/widgets/lib.js +26 -0
  103. package/dist/cjs/src/tools/BaseTool.js +66 -0
  104. package/dist/cjs/src/tools/Eraser.js +112 -0
  105. package/dist/cjs/src/tools/FindTool.js +121 -0
  106. package/dist/cjs/src/tools/PanZoom.js +421 -0
  107. package/dist/cjs/src/tools/PasteHandler.js +99 -0
  108. package/dist/cjs/src/tools/Pen.js +179 -0
  109. package/dist/cjs/src/tools/PipetteTool.js +45 -0
  110. package/dist/cjs/src/tools/SelectionTool/SelectAllShortcutHandler.js +28 -0
  111. package/dist/cjs/src/tools/SelectionTool/Selection.js +488 -0
  112. package/dist/cjs/src/tools/SelectionTool/SelectionHandle.js +85 -0
  113. package/dist/cjs/src/tools/SelectionTool/SelectionTool.js +405 -0
  114. package/dist/cjs/src/tools/SelectionTool/TransformMode.js +107 -0
  115. package/dist/cjs/src/tools/SelectionTool/types.js +14 -0
  116. package/dist/cjs/src/tools/TextTool.js +262 -0
  117. package/dist/cjs/src/tools/ToolController.js +187 -0
  118. package/dist/cjs/src/tools/ToolEnabledGroup.js +14 -0
  119. package/dist/cjs/src/tools/ToolSwitcherShortcut.js +38 -0
  120. package/dist/cjs/src/tools/ToolbarShortcutHandler.js +29 -0
  121. package/dist/cjs/src/tools/UndoRedoShortcut.js +28 -0
  122. package/dist/cjs/src/tools/lib.js +36 -0
  123. package/dist/cjs/src/tools/localization.js +30 -0
  124. package/dist/cjs/src/types.js +38 -0
  125. package/dist/cjs/src/util/assertions.js +51 -0
  126. package/dist/cjs/src/util/fileToBase64.js +15 -0
  127. package/dist/cjs/src/util/untilNextAnimationFrame.js +9 -0
  128. package/dist/cjs/src/util/waitForTimeout.js +9 -0
  129. package/dist/mjs/build_tools/BundledFile.d.ts +13 -0
  130. package/dist/{build_tools/buildTranslationTemplate.js → mjs/build_tools/buildTranslationTemplate.mjs} +1 -1
  131. package/dist/{build_tools/bundle.js → mjs/build_tools/bundle.mjs} +1 -1
  132. package/dist/mjs/build_tools/postDist.d.ts +1 -0
  133. package/dist/mjs/build_tools/postDist.mjs +67 -0
  134. package/dist/mjs/src/Color4.d.ts +61 -0
  135. package/dist/{src/Color4.js → mjs/src/Color4.mjs} +1 -0
  136. package/dist/mjs/src/Editor.d.ts +308 -0
  137. package/dist/{src/Editor.js → mjs/src/Editor.mjs} +26 -26
  138. package/dist/mjs/src/EditorImage.d.ts +97 -0
  139. package/dist/{src/EditorImage.js → mjs/src/EditorImage.mjs} +8 -8
  140. package/dist/mjs/src/EventDispatcher.d.ts +30 -0
  141. package/dist/mjs/src/Pointer.d.ts +24 -0
  142. package/dist/{src/Pointer.js → mjs/src/Pointer.mjs} +1 -1
  143. package/dist/mjs/src/SVGLoader.d.ts +48 -0
  144. package/dist/{src/SVGLoader.js → mjs/src/SVGLoader.mjs} +11 -11
  145. package/dist/mjs/src/UndoRedoHistory.d.ts +19 -0
  146. package/dist/{src/UndoRedoHistory.js → mjs/src/UndoRedoHistory.mjs} +1 -1
  147. package/dist/mjs/src/Viewport.d.ts +71 -0
  148. package/dist/{src/Viewport.js → mjs/src/Viewport.mjs} +5 -5
  149. package/dist/mjs/src/bundle/bundled.d.ts +4 -0
  150. package/dist/{src/bundle/bundled.js → mjs/src/bundle/bundled.mjs} +2 -2
  151. package/dist/mjs/src/commands/Command.d.ts +16 -0
  152. package/dist/mjs/src/commands/Duplicate.d.ts +14 -0
  153. package/dist/{src/commands/Duplicate.js → mjs/src/commands/Duplicate.mjs} +3 -3
  154. package/dist/mjs/src/commands/Erase.d.ts +14 -0
  155. package/dist/{src/commands/Erase.js → mjs/src/commands/Erase.mjs} +3 -3
  156. package/dist/mjs/src/commands/SerializableCommand.d.ts +12 -0
  157. package/dist/{src/commands/SerializableCommand.js → mjs/src/commands/SerializableCommand.mjs} +1 -1
  158. package/dist/mjs/src/commands/UnresolvedCommand.d.ts +14 -0
  159. package/dist/{src/commands/UnresolvedCommand.js → mjs/src/commands/UnresolvedCommand.mjs} +1 -1
  160. package/dist/mjs/src/commands/invertCommand.d.ts +4 -0
  161. package/dist/{src/commands/invertCommand.js → mjs/src/commands/invertCommand.mjs} +2 -2
  162. package/dist/mjs/src/commands/lib.mjs +7 -0
  163. package/dist/mjs/src/commands/localization.d.ts +23 -0
  164. package/dist/mjs/src/commands/uniteCommands.d.ts +4 -0
  165. package/dist/{src/commands/uniteCommands.js → mjs/src/commands/uniteCommands.mjs} +2 -2
  166. package/dist/mjs/src/components/AbstractComponent.d.ts +73 -0
  167. package/dist/{src/components/AbstractComponent.js → mjs/src/components/AbstractComponent.mjs} +4 -4
  168. package/dist/mjs/src/components/ImageBackground.d.ts +42 -0
  169. package/dist/{src/components/ImageBackground.js → mjs/src/components/ImageBackground.mjs} +5 -5
  170. package/dist/mjs/src/components/ImageComponent.d.ts +31 -0
  171. package/dist/{src/components/ImageComponent.js → mjs/src/components/ImageComponent.mjs} +3 -3
  172. package/dist/mjs/src/components/RestylableComponent.d.ts +24 -0
  173. package/dist/{src/components/RestylableComponent.js → mjs/src/components/RestylableComponent.mjs} +4 -4
  174. package/dist/mjs/src/components/SVGGlobalAttributesObject.d.ts +21 -0
  175. package/dist/{src/components/SVGGlobalAttributesObject.js → mjs/src/components/SVGGlobalAttributesObject.mjs} +3 -3
  176. package/dist/mjs/src/components/Stroke.d.ts +40 -0
  177. package/dist/{src/components/Stroke.js → mjs/src/components/Stroke.mjs} +5 -5
  178. package/dist/mjs/src/components/TextComponent.d.ts +53 -0
  179. package/dist/{src/components/TextComponent.js → mjs/src/components/TextComponent.mjs} +7 -7
  180. package/dist/mjs/src/components/UnknownSVGObject.d.ts +18 -0
  181. package/dist/{src/components/UnknownSVGObject.js → mjs/src/components/UnknownSVGObject.mjs} +3 -3
  182. package/dist/mjs/src/components/builders/ArrowBuilder.d.ts +19 -0
  183. package/dist/{src/components/builders/ArrowBuilder.js → mjs/src/components/builders/ArrowBuilder.mjs} +2 -2
  184. package/dist/mjs/src/components/builders/FreehandLineBuilder.d.ts +33 -0
  185. package/dist/{src/components/builders/FreehandLineBuilder.js → mjs/src/components/builders/FreehandLineBuilder.mjs} +7 -7
  186. package/dist/mjs/src/components/builders/LineBuilder.d.ts +18 -0
  187. package/dist/{src/components/builders/LineBuilder.js → mjs/src/components/builders/LineBuilder.mjs} +2 -2
  188. package/dist/mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +36 -0
  189. package/dist/{src/components/builders/PressureSensitiveFreehandLineBuilder.js → mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.mjs} +6 -6
  190. package/dist/mjs/src/components/builders/RectangleBuilder.d.ts +20 -0
  191. package/dist/{src/components/builders/RectangleBuilder.js → mjs/src/components/builders/RectangleBuilder.mjs} +4 -4
  192. package/dist/mjs/src/components/builders/types.d.ts +12 -0
  193. package/dist/mjs/src/components/builders/types.mjs +1 -0
  194. package/dist/{src/components/lib.js → mjs/src/components/lib.d.ts} +3 -3
  195. package/dist/mjs/src/components/lib.mjs +12 -0
  196. package/dist/mjs/src/components/localization.d.ts +11 -0
  197. package/dist/mjs/src/components/util/StrokeSmoother.d.ts +35 -0
  198. package/dist/{src/components/util/StrokeSmoother.js → mjs/src/components/util/StrokeSmoother.mjs} +3 -3
  199. package/dist/mjs/src/components/util/describeComponentList.d.ts +4 -0
  200. package/dist/{src/lib.js → mjs/src/lib.d.ts} +2 -2
  201. package/dist/mjs/src/lib.mjs +34 -0
  202. package/dist/mjs/src/localization.d.ts +14 -0
  203. package/dist/{src/localization.js → mjs/src/localization.mjs} +5 -5
  204. package/dist/mjs/src/localizations/de.d.ts +3 -0
  205. package/dist/{src/localizations/de.js → mjs/src/localizations/de.mjs} +1 -1
  206. package/dist/mjs/src/localizations/en.d.ts +3 -0
  207. package/dist/{src/localizations/en.js → mjs/src/localizations/en.mjs} +1 -1
  208. package/dist/mjs/src/localizations/es.d.ts +3 -0
  209. package/dist/{src/localizations/es.js → mjs/src/localizations/es.mjs} +1 -1
  210. package/dist/mjs/src/localizations/getLocalizationTable.d.ts +3 -0
  211. package/dist/{src/localizations/getLocalizationTable.js → mjs/src/localizations/getLocalizationTable.mjs} +4 -4
  212. package/dist/mjs/src/math/LineSegment2.d.ts +24 -0
  213. package/dist/{src/math/LineSegment2.js → mjs/src/math/LineSegment2.mjs} +2 -2
  214. package/dist/mjs/src/math/Mat33.d.ts +118 -0
  215. package/dist/{src/math/Mat33.js → mjs/src/math/Mat33.mjs} +2 -2
  216. package/dist/mjs/src/math/Path.d.ts +71 -0
  217. package/dist/{src/math/Path.js → mjs/src/math/Path.mjs} +5 -5
  218. package/dist/mjs/src/math/Rect2.d.ts +52 -0
  219. package/dist/{src/math/Rect2.js → mjs/src/math/Rect2.mjs} +2 -2
  220. package/dist/mjs/src/math/Triangle.d.ts +11 -0
  221. package/dist/mjs/src/math/Vec2.d.ts +13 -0
  222. package/dist/{src/math/Vec2.js → mjs/src/math/Vec2.mjs} +1 -1
  223. package/dist/mjs/src/math/Vec3.d.ts +106 -0
  224. package/dist/mjs/src/math/lib.mjs +7 -0
  225. package/dist/mjs/src/math/rounding.d.ts +4 -0
  226. package/dist/mjs/src/rendering/Display.d.ts +75 -0
  227. package/dist/{src/rendering/Display.js → mjs/src/rendering/Display.mjs} +7 -7
  228. package/dist/mjs/src/rendering/RenderingStyle.d.ts +31 -0
  229. package/dist/{src/rendering/RenderingStyle.js → mjs/src/rendering/RenderingStyle.mjs} +1 -1
  230. package/dist/mjs/src/rendering/TextRenderingStyle.d.ts +36 -0
  231. package/dist/{src/rendering/TextRenderingStyle.js → mjs/src/rendering/TextRenderingStyle.mjs} +1 -1
  232. package/dist/mjs/src/rendering/caching/CacheRecord.d.ts +20 -0
  233. package/dist/{src/rendering/caching/CacheRecord.js → mjs/src/rendering/caching/CacheRecord.mjs} +1 -1
  234. package/dist/mjs/src/rendering/caching/CacheRecordManager.d.ts +12 -0
  235. package/dist/{src/rendering/caching/CacheRecordManager.js → mjs/src/rendering/caching/CacheRecordManager.mjs} +1 -1
  236. package/dist/mjs/src/rendering/caching/RenderingCache.d.ts +11 -0
  237. package/dist/{src/rendering/caching/RenderingCache.js → mjs/src/rendering/caching/RenderingCache.mjs} +3 -3
  238. package/dist/mjs/src/rendering/caching/RenderingCacheNode.d.ts +29 -0
  239. package/dist/{src/rendering/caching/RenderingCacheNode.js → mjs/src/rendering/caching/RenderingCacheNode.mjs} +3 -3
  240. package/dist/mjs/src/rendering/caching/testUtils.d.ts +9 -0
  241. package/dist/{src/rendering/caching/testUtils.js → mjs/src/rendering/caching/testUtils.mjs} +4 -4
  242. package/dist/mjs/src/rendering/caching/types.d.ts +19 -0
  243. package/dist/mjs/src/rendering/caching/types.mjs +1 -0
  244. package/dist/mjs/src/rendering/lib.mjs +5 -0
  245. package/dist/mjs/src/rendering/localization.d.ts +10 -0
  246. package/dist/mjs/src/rendering/renderers/AbstractRenderer.d.ts +68 -0
  247. package/dist/{src/rendering/renderers/AbstractRenderer.js → mjs/src/rendering/renderers/AbstractRenderer.mjs} +3 -3
  248. package/dist/mjs/src/rendering/renderers/CanvasRenderer.d.ts +63 -0
  249. package/dist/{src/rendering/renderers/CanvasRenderer.js → mjs/src/rendering/renderers/CanvasRenderer.mjs} +5 -5
  250. package/dist/mjs/src/rendering/renderers/DummyRenderer.d.ts +35 -0
  251. package/dist/{src/rendering/renderers/DummyRenderer.js → mjs/src/rendering/renderers/DummyRenderer.mjs} +2 -2
  252. package/dist/mjs/src/rendering/renderers/SVGRenderer.d.ts +57 -0
  253. package/dist/{src/rendering/renderers/SVGRenderer.js → mjs/src/rendering/renderers/SVGRenderer.mjs} +6 -6
  254. package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.d.ts +29 -0
  255. package/dist/{src/rendering/renderers/TextOnlyRenderer.js → mjs/src/rendering/renderers/TextOnlyRenderer.mjs} +2 -2
  256. package/dist/mjs/src/testing/beforeEachFile.d.ts +1 -0
  257. package/dist/{src/testing/beforeEachFile.js → mjs/src/testing/beforeEachFile.mjs} +1 -1
  258. package/dist/mjs/src/testing/createEditor.d.ts +4 -0
  259. package/dist/{src/testing/createEditor.js → mjs/src/testing/createEditor.mjs} +2 -2
  260. package/dist/mjs/src/testing/lib.mjs +2 -0
  261. package/dist/mjs/src/testing/loadExpectExtensions.d.ts +2 -0
  262. package/dist/mjs/src/testing/sendPenEvent.d.ts +12 -0
  263. package/dist/{src/testing/sendPenEvent.js → mjs/src/testing/sendPenEvent.mjs} +2 -2
  264. package/dist/mjs/src/testing/sendTouchEvent.d.ts +42 -0
  265. package/dist/{src/testing/sendTouchEvent.js → mjs/src/testing/sendTouchEvent.mjs} +2 -2
  266. package/dist/mjs/src/toolbar/HTMLToolbar.d.ts +103 -0
  267. package/dist/{src/toolbar/HTMLToolbar.js → mjs/src/toolbar/HTMLToolbar.mjs} +17 -17
  268. package/dist/mjs/src/toolbar/IconProvider.d.ts +62 -0
  269. package/dist/{src/toolbar/IconProvider.js → mjs/src/toolbar/IconProvider.mjs} +4 -4
  270. package/dist/mjs/src/toolbar/lib.mjs +3 -0
  271. package/dist/mjs/src/toolbar/localization.d.ts +49 -0
  272. package/dist/mjs/src/toolbar/makeColorInput.d.ts +6 -0
  273. package/dist/{src/toolbar/makeColorInput.js → mjs/src/toolbar/makeColorInput.mjs} +3 -3
  274. package/dist/mjs/src/toolbar/types.d.ts +4 -0
  275. package/dist/mjs/src/toolbar/types.mjs +1 -0
  276. package/dist/mjs/src/toolbar/widgets/ActionButtonWidget.d.ts +15 -0
  277. package/dist/{src/toolbar/widgets/ActionButtonWidget.js → mjs/src/toolbar/widgets/ActionButtonWidget.mjs} +1 -1
  278. package/dist/mjs/src/toolbar/widgets/BaseToolWidget.d.ts +11 -0
  279. package/dist/{src/toolbar/widgets/BaseToolWidget.js → mjs/src/toolbar/widgets/BaseToolWidget.mjs} +2 -2
  280. package/dist/mjs/src/toolbar/widgets/BaseWidget.d.ts +72 -0
  281. package/dist/{src/toolbar/widgets/BaseWidget.js → mjs/src/toolbar/widgets/BaseWidget.mjs} +3 -3
  282. package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.d.ts +18 -0
  283. package/dist/{src/toolbar/widgets/DocumentPropertiesWidget.js → mjs/src/toolbar/widgets/DocumentPropertiesWidget.mjs} +6 -6
  284. package/dist/mjs/src/toolbar/widgets/EraserToolWidget.d.ts +17 -0
  285. package/dist/{src/toolbar/widgets/EraserToolWidget.js → mjs/src/toolbar/widgets/EraserToolWidget.mjs} +3 -3
  286. package/dist/mjs/src/toolbar/widgets/HandToolWidget.d.ts +17 -0
  287. package/dist/{src/toolbar/widgets/HandToolWidget.js → mjs/src/toolbar/widgets/HandToolWidget.mjs} +7 -7
  288. package/dist/mjs/src/toolbar/widgets/InsertImageWidget.d.ts +19 -0
  289. package/dist/{src/toolbar/widgets/InsertImageWidget.js → mjs/src/toolbar/widgets/InsertImageWidget.mjs} +8 -8
  290. package/dist/mjs/src/toolbar/widgets/OverflowWidget.d.ts +25 -0
  291. package/dist/{src/toolbar/widgets/OverflowWidget.js → mjs/src/toolbar/widgets/OverflowWidget.mjs} +1 -1
  292. package/dist/mjs/src/toolbar/widgets/PenToolWidget.d.ts +27 -0
  293. package/dist/{src/toolbar/widgets/PenToolWidget.js → mjs/src/toolbar/widgets/PenToolWidget.mjs} +10 -10
  294. package/dist/mjs/src/toolbar/widgets/SelectionToolWidget.d.ts +13 -0
  295. package/dist/{src/toolbar/widgets/SelectionToolWidget.js → mjs/src/toolbar/widgets/SelectionToolWidget.mjs} +8 -8
  296. package/dist/mjs/src/toolbar/widgets/TextToolWidget.d.ts +16 -0
  297. package/dist/{src/toolbar/widgets/TextToolWidget.js → mjs/src/toolbar/widgets/TextToolWidget.mjs} +5 -5
  298. package/dist/mjs/src/toolbar/widgets/lib.mjs +10 -0
  299. package/dist/mjs/src/tools/BaseTool.d.ts +22 -0
  300. package/dist/{src/tools/BaseTool.js → mjs/src/tools/BaseTool.mjs} +1 -1
  301. package/dist/mjs/src/tools/Eraser.d.ts +23 -0
  302. package/dist/{src/tools/Eraser.js → mjs/src/tools/Eraser.mjs} +8 -8
  303. package/dist/mjs/src/tools/FindTool.d.ts +21 -0
  304. package/dist/{src/tools/FindTool.js → mjs/src/tools/FindTool.mjs} +2 -2
  305. package/dist/mjs/src/tools/PanZoom.d.ts +52 -0
  306. package/dist/{src/tools/PanZoom.js → mjs/src/tools/PanZoom.mjs} +8 -8
  307. package/dist/mjs/src/tools/PasteHandler.d.ts +23 -0
  308. package/dist/{src/tools/PasteHandler.js → mjs/src/tools/PasteHandler.mjs} +7 -7
  309. package/dist/mjs/src/tools/Pen.d.ts +39 -0
  310. package/dist/{src/tools/Pen.js → mjs/src/tools/Pen.mjs} +5 -5
  311. package/dist/mjs/src/tools/PipetteTool.d.ts +18 -0
  312. package/dist/{src/tools/PipetteTool.js → mjs/src/tools/PipetteTool.mjs} +1 -1
  313. package/dist/mjs/src/tools/SelectionTool/SelectAllShortcutHandler.d.ts +8 -0
  314. package/dist/{src/tools/SelectionTool/SelectAllShortcutHandler.js → mjs/src/tools/SelectionTool/SelectAllShortcutHandler.mjs} +2 -2
  315. package/dist/mjs/src/tools/SelectionTool/Selection.d.ts +64 -0
  316. package/dist/{src/tools/SelectionTool/Selection.js → mjs/src/tools/SelectionTool/Selection.mjs} +12 -12
  317. package/dist/mjs/src/tools/SelectionTool/SelectionHandle.d.ts +38 -0
  318. package/dist/{src/tools/SelectionTool/SelectionHandle.js → mjs/src/tools/SelectionTool/SelectionHandle.mjs} +3 -3
  319. package/dist/mjs/src/tools/SelectionTool/SelectionTool.d.ts +36 -0
  320. package/dist/{src/tools/SelectionTool/SelectionTool.js → mjs/src/tools/SelectionTool/SelectionTool.mjs} +8 -8
  321. package/dist/mjs/src/tools/SelectionTool/TransformMode.d.ts +34 -0
  322. package/dist/{src/tools/SelectionTool/TransformMode.js → mjs/src/tools/SelectionTool/TransformMode.mjs} +4 -4
  323. package/dist/mjs/src/tools/SelectionTool/types.d.ts +9 -0
  324. package/dist/mjs/src/tools/TextTool.d.ts +33 -0
  325. package/dist/{src/tools/TextTool.js → mjs/src/tools/TextTool.mjs} +11 -11
  326. package/dist/mjs/src/tools/ToolController.d.ts +18 -0
  327. package/dist/{src/tools/ToolController.js → mjs/src/tools/ToolController.mjs} +16 -16
  328. package/dist/mjs/src/tools/ToolEnabledGroup.d.ts +6 -0
  329. package/dist/mjs/src/tools/ToolSwitcherShortcut.d.ts +16 -0
  330. package/dist/{src/tools/ToolSwitcherShortcut.js → mjs/src/tools/ToolSwitcherShortcut.mjs} +1 -1
  331. package/dist/mjs/src/tools/ToolbarShortcutHandler.d.ts +12 -0
  332. package/dist/{src/tools/ToolbarShortcutHandler.js → mjs/src/tools/ToolbarShortcutHandler.mjs} +1 -1
  333. package/dist/mjs/src/tools/UndoRedoShortcut.d.ts +8 -0
  334. package/dist/{src/tools/UndoRedoShortcut.js → mjs/src/tools/UndoRedoShortcut.mjs} +1 -1
  335. package/dist/{src/tools/lib.js → mjs/src/tools/lib.d.ts} +1 -1
  336. package/dist/mjs/src/tools/lib.mjs +16 -0
  337. package/dist/mjs/src/tools/localization.d.ts +28 -0
  338. package/dist/mjs/src/types.d.ts +151 -0
  339. package/dist/mjs/src/util/assertions.d.ts +23 -0
  340. package/dist/mjs/src/util/fileToBase64.d.ts +3 -0
  341. package/dist/mjs/src/util/untilNextAnimationFrame.d.ts +3 -0
  342. package/dist/mjs/src/util/waitForTimeout.d.ts +2 -0
  343. package/package.json +34 -33
  344. package/src/Color4.ts +2 -0
  345. package/tsconfig.json +3 -2
  346. package/tsconfig.mjs.json +9 -0
  347. /package/dist/{build_tools → cjs/build_tools}/BundledFile.d.ts +0 -0
  348. /package/dist/{build_tools → cjs/build_tools}/buildTranslationTemplate.d.ts +0 -0
  349. /package/dist/{build_tools → cjs/build_tools}/bundle.d.ts +0 -0
  350. /package/dist/{src/components/builders/types.js → cjs/build_tools/postDist.d.ts} +0 -0
  351. /package/dist/{src → cjs/src}/Editor.d.ts +0 -0
  352. /package/dist/{src → cjs/src}/EditorImage.d.ts +0 -0
  353. /package/dist/{src → cjs/src}/EventDispatcher.d.ts +0 -0
  354. /package/dist/{src → cjs/src}/Pointer.d.ts +0 -0
  355. /package/dist/{src → cjs/src}/SVGLoader.d.ts +0 -0
  356. /package/dist/{src → cjs/src}/UndoRedoHistory.d.ts +0 -0
  357. /package/dist/{src → cjs/src}/Viewport.d.ts +0 -0
  358. /package/dist/{src → cjs/src}/bundle/bundled.d.ts +0 -0
  359. /package/dist/{src → cjs/src}/commands/Command.d.ts +0 -0
  360. /package/dist/{src → cjs/src}/commands/Duplicate.d.ts +0 -0
  361. /package/dist/{src → cjs/src}/commands/Erase.d.ts +0 -0
  362. /package/dist/{src → cjs/src}/commands/SerializableCommand.d.ts +0 -0
  363. /package/dist/{src → cjs/src}/commands/UnresolvedCommand.d.ts +0 -0
  364. /package/dist/{src → cjs/src}/commands/invertCommand.d.ts +0 -0
  365. /package/dist/{src → cjs/src}/commands/lib.d.ts +0 -0
  366. /package/dist/{src → cjs/src}/commands/localization.d.ts +0 -0
  367. /package/dist/{src → cjs/src}/commands/uniteCommands.d.ts +0 -0
  368. /package/dist/{src → cjs/src}/components/AbstractComponent.d.ts +0 -0
  369. /package/dist/{src → cjs/src}/components/ImageBackground.d.ts +0 -0
  370. /package/dist/{src → cjs/src}/components/ImageComponent.d.ts +0 -0
  371. /package/dist/{src → cjs/src}/components/RestylableComponent.d.ts +0 -0
  372. /package/dist/{src → cjs/src}/components/SVGGlobalAttributesObject.d.ts +0 -0
  373. /package/dist/{src → cjs/src}/components/Stroke.d.ts +0 -0
  374. /package/dist/{src → cjs/src}/components/TextComponent.d.ts +0 -0
  375. /package/dist/{src → cjs/src}/components/UnknownSVGObject.d.ts +0 -0
  376. /package/dist/{src → cjs/src}/components/builders/ArrowBuilder.d.ts +0 -0
  377. /package/dist/{src → cjs/src}/components/builders/FreehandLineBuilder.d.ts +0 -0
  378. /package/dist/{src → cjs/src}/components/builders/LineBuilder.d.ts +0 -0
  379. /package/dist/{src → cjs/src}/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +0 -0
  380. /package/dist/{src → cjs/src}/components/builders/RectangleBuilder.d.ts +0 -0
  381. /package/dist/{src → cjs/src}/components/builders/types.d.ts +0 -0
  382. /package/dist/{src → cjs/src}/components/lib.d.ts +0 -0
  383. /package/dist/{src → cjs/src}/components/localization.d.ts +0 -0
  384. /package/dist/{src → cjs/src}/components/util/StrokeSmoother.d.ts +0 -0
  385. /package/dist/{src → cjs/src}/components/util/describeComponentList.d.ts +0 -0
  386. /package/dist/{src → cjs/src}/lib.d.ts +0 -0
  387. /package/dist/{src → cjs/src}/localization.d.ts +0 -0
  388. /package/dist/{src → cjs/src}/localizations/de.d.ts +0 -0
  389. /package/dist/{src → cjs/src}/localizations/en.d.ts +0 -0
  390. /package/dist/{src → cjs/src}/localizations/es.d.ts +0 -0
  391. /package/dist/{src → cjs/src}/localizations/getLocalizationTable.d.ts +0 -0
  392. /package/dist/{src → cjs/src}/math/LineSegment2.d.ts +0 -0
  393. /package/dist/{src → cjs/src}/math/Mat33.d.ts +0 -0
  394. /package/dist/{src → cjs/src}/math/Path.d.ts +0 -0
  395. /package/dist/{src → cjs/src}/math/Rect2.d.ts +0 -0
  396. /package/dist/{src → cjs/src}/math/Triangle.d.ts +0 -0
  397. /package/dist/{src → cjs/src}/math/Vec2.d.ts +0 -0
  398. /package/dist/{src → cjs/src}/math/Vec3.d.ts +0 -0
  399. /package/dist/{src → cjs/src}/math/lib.d.ts +0 -0
  400. /package/dist/{src → cjs/src}/math/rounding.d.ts +0 -0
  401. /package/dist/{src → cjs/src}/rendering/Display.d.ts +0 -0
  402. /package/dist/{src → cjs/src}/rendering/RenderingStyle.d.ts +0 -0
  403. /package/dist/{src → cjs/src}/rendering/TextRenderingStyle.d.ts +0 -0
  404. /package/dist/{src → cjs/src}/rendering/caching/CacheRecord.d.ts +0 -0
  405. /package/dist/{src → cjs/src}/rendering/caching/CacheRecordManager.d.ts +0 -0
  406. /package/dist/{src → cjs/src}/rendering/caching/RenderingCache.d.ts +0 -0
  407. /package/dist/{src → cjs/src}/rendering/caching/RenderingCacheNode.d.ts +0 -0
  408. /package/dist/{src → cjs/src}/rendering/caching/testUtils.d.ts +0 -0
  409. /package/dist/{src → cjs/src}/rendering/caching/types.d.ts +0 -0
  410. /package/dist/{src → cjs/src}/rendering/lib.d.ts +0 -0
  411. /package/dist/{src → cjs/src}/rendering/localization.d.ts +0 -0
  412. /package/dist/{src → cjs/src}/rendering/renderers/AbstractRenderer.d.ts +0 -0
  413. /package/dist/{src → cjs/src}/rendering/renderers/CanvasRenderer.d.ts +0 -0
  414. /package/dist/{src → cjs/src}/rendering/renderers/DummyRenderer.d.ts +0 -0
  415. /package/dist/{src → cjs/src}/rendering/renderers/SVGRenderer.d.ts +0 -0
  416. /package/dist/{src → cjs/src}/rendering/renderers/TextOnlyRenderer.d.ts +0 -0
  417. /package/dist/{src → cjs/src}/testing/beforeEachFile.d.ts +0 -0
  418. /package/dist/{src → cjs/src}/testing/createEditor.d.ts +0 -0
  419. /package/dist/{src → cjs/src}/testing/lib.d.ts +0 -0
  420. /package/dist/{src → cjs/src}/testing/loadExpectExtensions.d.ts +0 -0
  421. /package/dist/{src → cjs/src}/testing/sendPenEvent.d.ts +0 -0
  422. /package/dist/{src → cjs/src}/testing/sendTouchEvent.d.ts +0 -0
  423. /package/dist/{src → cjs/src}/toolbar/HTMLToolbar.d.ts +0 -0
  424. /package/dist/{src → cjs/src}/toolbar/IconProvider.d.ts +0 -0
  425. /package/dist/{src → cjs/src}/toolbar/lib.d.ts +0 -0
  426. /package/dist/{src → cjs/src}/toolbar/localization.d.ts +0 -0
  427. /package/dist/{src → cjs/src}/toolbar/makeColorInput.d.ts +0 -0
  428. /package/dist/{src → cjs/src}/toolbar/types.d.ts +0 -0
  429. /package/dist/{src → cjs/src}/toolbar/widgets/ActionButtonWidget.d.ts +0 -0
  430. /package/dist/{src → cjs/src}/toolbar/widgets/BaseToolWidget.d.ts +0 -0
  431. /package/dist/{src → cjs/src}/toolbar/widgets/BaseWidget.d.ts +0 -0
  432. /package/dist/{src → cjs/src}/toolbar/widgets/DocumentPropertiesWidget.d.ts +0 -0
  433. /package/dist/{src → cjs/src}/toolbar/widgets/EraserToolWidget.d.ts +0 -0
  434. /package/dist/{src → cjs/src}/toolbar/widgets/HandToolWidget.d.ts +0 -0
  435. /package/dist/{src → cjs/src}/toolbar/widgets/InsertImageWidget.d.ts +0 -0
  436. /package/dist/{src → cjs/src}/toolbar/widgets/OverflowWidget.d.ts +0 -0
  437. /package/dist/{src → cjs/src}/toolbar/widgets/PenToolWidget.d.ts +0 -0
  438. /package/dist/{src → cjs/src}/toolbar/widgets/SelectionToolWidget.d.ts +0 -0
  439. /package/dist/{src → cjs/src}/toolbar/widgets/TextToolWidget.d.ts +0 -0
  440. /package/dist/{src → cjs/src}/toolbar/widgets/lib.d.ts +0 -0
  441. /package/dist/{src → cjs/src}/tools/BaseTool.d.ts +0 -0
  442. /package/dist/{src → cjs/src}/tools/Eraser.d.ts +0 -0
  443. /package/dist/{src → cjs/src}/tools/FindTool.d.ts +0 -0
  444. /package/dist/{src → cjs/src}/tools/PanZoom.d.ts +0 -0
  445. /package/dist/{src → cjs/src}/tools/PasteHandler.d.ts +0 -0
  446. /package/dist/{src → cjs/src}/tools/Pen.d.ts +0 -0
  447. /package/dist/{src → cjs/src}/tools/PipetteTool.d.ts +0 -0
  448. /package/dist/{src → cjs/src}/tools/SelectionTool/SelectAllShortcutHandler.d.ts +0 -0
  449. /package/dist/{src → cjs/src}/tools/SelectionTool/Selection.d.ts +0 -0
  450. /package/dist/{src → cjs/src}/tools/SelectionTool/SelectionHandle.d.ts +0 -0
  451. /package/dist/{src → cjs/src}/tools/SelectionTool/SelectionTool.d.ts +0 -0
  452. /package/dist/{src → cjs/src}/tools/SelectionTool/TransformMode.d.ts +0 -0
  453. /package/dist/{src → cjs/src}/tools/SelectionTool/types.d.ts +0 -0
  454. /package/dist/{src → cjs/src}/tools/TextTool.d.ts +0 -0
  455. /package/dist/{src → cjs/src}/tools/ToolController.d.ts +0 -0
  456. /package/dist/{src → cjs/src}/tools/ToolEnabledGroup.d.ts +0 -0
  457. /package/dist/{src → cjs/src}/tools/ToolSwitcherShortcut.d.ts +0 -0
  458. /package/dist/{src → cjs/src}/tools/ToolbarShortcutHandler.d.ts +0 -0
  459. /package/dist/{src → cjs/src}/tools/UndoRedoShortcut.d.ts +0 -0
  460. /package/dist/{src → cjs/src}/tools/lib.d.ts +0 -0
  461. /package/dist/{src → cjs/src}/tools/localization.d.ts +0 -0
  462. /package/dist/{src → cjs/src}/types.d.ts +0 -0
  463. /package/dist/{src → cjs/src}/util/assertions.d.ts +0 -0
  464. /package/dist/{src → cjs/src}/util/fileToBase64.d.ts +0 -0
  465. /package/dist/{src → cjs/src}/util/untilNextAnimationFrame.d.ts +0 -0
  466. /package/dist/{src → cjs/src}/util/waitForTimeout.d.ts +0 -0
  467. /package/dist/{build_tools/BundledFile.js → mjs/build_tools/BundledFile.mjs} +0 -0
  468. /package/dist/{src/rendering/caching/types.js → mjs/build_tools/buildTranslationTemplate.d.ts} +0 -0
  469. /package/dist/{src/toolbar/types.js → mjs/build_tools/bundle.d.ts} +0 -0
  470. /package/dist/{src/EventDispatcher.js → mjs/src/EventDispatcher.mjs} +0 -0
  471. /package/dist/{src/commands/Command.js → mjs/src/commands/Command.mjs} +0 -0
  472. /package/dist/{src/commands/lib.js → mjs/src/commands/lib.d.ts} +0 -0
  473. /package/dist/{src/commands/localization.js → mjs/src/commands/localization.mjs} +0 -0
  474. /package/dist/{src/components/localization.js → mjs/src/components/localization.mjs} +0 -0
  475. /package/dist/{src/components/util/describeComponentList.js → mjs/src/components/util/describeComponentList.mjs} +0 -0
  476. /package/dist/{src/math/Triangle.js → mjs/src/math/Triangle.mjs} +0 -0
  477. /package/dist/{src/math/Vec3.js → mjs/src/math/Vec3.mjs} +0 -0
  478. /package/dist/{src/math/lib.js → mjs/src/math/lib.d.ts} +0 -0
  479. /package/dist/{src/math/rounding.js → mjs/src/math/rounding.mjs} +0 -0
  480. /package/dist/{src/rendering/lib.js → mjs/src/rendering/lib.d.ts} +0 -0
  481. /package/dist/{src/rendering/localization.js → mjs/src/rendering/localization.mjs} +0 -0
  482. /package/dist/{src/testing/lib.js → mjs/src/testing/lib.d.ts} +0 -0
  483. /package/dist/{src/testing/loadExpectExtensions.js → mjs/src/testing/loadExpectExtensions.mjs} +0 -0
  484. /package/dist/{src/toolbar/lib.js → mjs/src/toolbar/lib.d.ts} +0 -0
  485. /package/dist/{src/toolbar/localization.js → mjs/src/toolbar/localization.mjs} +0 -0
  486. /package/dist/{src/toolbar/widgets/lib.js → mjs/src/toolbar/widgets/lib.d.ts} +0 -0
  487. /package/dist/{src/tools/SelectionTool/types.js → mjs/src/tools/SelectionTool/types.mjs} +0 -0
  488. /package/dist/{src/tools/ToolEnabledGroup.js → mjs/src/tools/ToolEnabledGroup.mjs} +0 -0
  489. /package/dist/{src/tools/localization.js → mjs/src/tools/localization.mjs} +0 -0
  490. /package/dist/{src/types.js → mjs/src/types.mjs} +0 -0
  491. /package/dist/{src/util/assertions.js → mjs/src/util/assertions.mjs} +0 -0
  492. /package/dist/{src/util/fileToBase64.js → mjs/src/util/fileToBase64.mjs} +0 -0
  493. /package/dist/{src/util/untilNextAnimationFrame.js → mjs/src/util/untilNextAnimationFrame.mjs} +0 -0
  494. /package/dist/{src/util/waitForTimeout.js → mjs/src/util/waitForTimeout.mjs} +0 -0
@@ -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,187 @@
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
+ class ToolController {
46
+ /** @internal */
47
+ constructor(editor, localization) {
48
+ this.activeTool = null;
49
+ const primaryToolGroup = new ToolEnabledGroup_1.default();
50
+ this.primaryToolGroup = primaryToolGroup;
51
+ const panZoomTool = new PanZoom_1.default(editor, PanZoom_1.PanZoomMode.TwoFingerTouchGestures | PanZoom_1.PanZoomMode.RightClickDrags, localization.touchPanTool);
52
+ const keyboardPanZoomTool = new PanZoom_1.default(editor, PanZoom_1.PanZoomMode.Keyboard, localization.keyboardPanZoom);
53
+ const primaryPenTool = new Pen_1.default(editor, localization.penTool(1), { color: Color4_1.default.purple, thickness: 8 });
54
+ const primaryTools = [
55
+ // Three pens
56
+ primaryPenTool,
57
+ new Pen_1.default(editor, localization.penTool(2), { color: Color4_1.default.clay, thickness: 4 }),
58
+ // Highlighter-like pen with width=40
59
+ new Pen_1.default(editor, localization.penTool(3), { color: Color4_1.default.ofRGBA(1, 1, 0, 0.5), thickness: 40 }, PressureSensitiveFreehandLineBuilder_1.makePressureSensitiveFreehandLineBuilder),
60
+ new Eraser_1.default(editor, localization.eraserTool),
61
+ new SelectionTool_1.default(editor, localization.selectionTool),
62
+ new TextTool_1.default(editor, localization.textTool, localization),
63
+ new PanZoom_1.default(editor, PanZoom_1.PanZoomMode.SinglePointerGestures, localization.anyDevicePanning)
64
+ ];
65
+ this.tools = [
66
+ new PipetteTool_1.default(editor, localization.pipetteTool),
67
+ panZoomTool,
68
+ ...primaryTools,
69
+ keyboardPanZoomTool,
70
+ new UndoRedoShortcut_1.default(editor),
71
+ new ToolbarShortcutHandler_1.default(editor),
72
+ new ToolSwitcherShortcut_1.default(editor),
73
+ new FindTool_1.default(editor),
74
+ new PasteHandler_1.default(editor),
75
+ new SelectAllShortcutHandler_1.default(editor),
76
+ ];
77
+ primaryTools.forEach(tool => tool.setToolGroup(primaryToolGroup));
78
+ panZoomTool.setEnabled(true);
79
+ primaryPenTool.setEnabled(true);
80
+ editor.notifier.on(types_1.EditorEventType.ToolEnabled, event => {
81
+ if (event.kind === types_1.EditorEventType.ToolEnabled) {
82
+ editor.announceForAccessibility(localization.toolEnabledAnnouncement(event.tool.description));
83
+ }
84
+ });
85
+ editor.notifier.on(types_1.EditorEventType.ToolDisabled, event => {
86
+ if (event.kind === types_1.EditorEventType.ToolDisabled) {
87
+ editor.announceForAccessibility(localization.toolDisabledAnnouncement(event.tool.description));
88
+ }
89
+ });
90
+ this.activeTool = null;
91
+ }
92
+ // Replaces the current set of tools with `tools`. This should only be done before
93
+ // the creation of the app's toolbar (if using `HTMLToolbar`).
94
+ setTools(tools, primaryToolGroup) {
95
+ this.tools = tools;
96
+ this.primaryToolGroup = primaryToolGroup !== null && primaryToolGroup !== void 0 ? primaryToolGroup : new ToolEnabledGroup_1.default();
97
+ }
98
+ // Add a tool that acts like one of the primary tools (only one primary tool can be enabled at a time).
99
+ // This should be called before creating the app's toolbar.
100
+ addPrimaryTool(tool) {
101
+ tool.setToolGroup(this.primaryToolGroup);
102
+ if (tool.isEnabled()) {
103
+ this.primaryToolGroup.notifyEnabled(tool);
104
+ }
105
+ this.addTool(tool);
106
+ }
107
+ getPrimaryTools() {
108
+ return this.tools.filter(tool => {
109
+ return tool.getToolGroup() === this.primaryToolGroup;
110
+ });
111
+ }
112
+ // Add a tool to the end of this' tool list (the added tool receives events after tools already added to this).
113
+ // This should be called before creating the app's toolbar.
114
+ addTool(tool) {
115
+ this.tools.push(tool);
116
+ }
117
+ // Returns true if the event was handled
118
+ dispatchInputEvent(event) {
119
+ var _a, _b;
120
+ let handled = false;
121
+ if (event.kind === types_1.InputEvtType.PointerDownEvt) {
122
+ for (const tool of this.tools) {
123
+ if (tool.isEnabled() && tool.onPointerDown(event)) {
124
+ if (this.activeTool !== tool) {
125
+ (_a = this.activeTool) === null || _a === void 0 ? void 0 : _a.onGestureCancel();
126
+ }
127
+ this.activeTool = tool;
128
+ handled = true;
129
+ break;
130
+ }
131
+ }
132
+ }
133
+ else if (event.kind === types_1.InputEvtType.PointerUpEvt) {
134
+ (_b = this.activeTool) === null || _b === void 0 ? void 0 : _b.onPointerUp(event);
135
+ this.activeTool = null;
136
+ handled = true;
137
+ }
138
+ else if (event.kind === types_1.InputEvtType.PointerMoveEvt) {
139
+ if (this.activeTool !== null) {
140
+ this.activeTool.onPointerMove(event);
141
+ handled = true;
142
+ }
143
+ }
144
+ else if (event.kind === types_1.InputEvtType.GestureCancelEvt) {
145
+ if (this.activeTool !== null) {
146
+ this.activeTool.onGestureCancel();
147
+ this.activeTool = null;
148
+ }
149
+ }
150
+ else {
151
+ let allCasesHandledGuard;
152
+ for (const tool of this.tools) {
153
+ if (!tool.isEnabled()) {
154
+ continue;
155
+ }
156
+ switch (event.kind) {
157
+ case types_1.InputEvtType.KeyPressEvent:
158
+ handled = tool.onKeyPress(event);
159
+ break;
160
+ case types_1.InputEvtType.KeyUpEvent:
161
+ handled = tool.onKeyUp(event);
162
+ break;
163
+ case types_1.InputEvtType.WheelEvt:
164
+ handled = tool.onWheel(event);
165
+ break;
166
+ case types_1.InputEvtType.CopyEvent:
167
+ handled = tool.onCopy(event);
168
+ break;
169
+ case types_1.InputEvtType.PasteEvent:
170
+ handled = tool.onPaste(event);
171
+ break;
172
+ default:
173
+ allCasesHandledGuard = event;
174
+ return allCasesHandledGuard;
175
+ }
176
+ if (handled) {
177
+ break;
178
+ }
179
+ }
180
+ }
181
+ return handled;
182
+ }
183
+ getMatchingTools(type) {
184
+ return this.tools.filter(tool => tool instanceof type);
185
+ }
186
+ }
187
+ exports.default = ToolController;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ // Connects a group of tools -- at most one tool in the group can be enabled.
4
+ class ToolEnabledGroup {
5
+ constructor() { }
6
+ notifyEnabled(tool) {
7
+ var _a;
8
+ if (tool !== this.activeTool) {
9
+ (_a = this.activeTool) === null || _a === void 0 ? void 0 : _a.setEnabled(false);
10
+ this.activeTool = tool;
11
+ }
12
+ }
13
+ }
14
+ exports.default = ToolEnabledGroup;
@@ -0,0 +1,38 @@
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 BaseTool_1 = __importDefault(require("./BaseTool"));
7
+ /**
8
+ * Handles keyboard events used, by default, to select tools. By default,
9
+ * 1 maps to the first primary tool, 2 to the second primary tool, ... .
10
+ *
11
+ * This is in the default set of {@link ToolController} tools.
12
+ *
13
+ * @deprecated This may be replaced in the future.
14
+ */
15
+ class ToolSwitcherShortcut extends BaseTool_1.default {
16
+ constructor(editor) {
17
+ super(editor.notifier, editor.localization.changeTool);
18
+ this.editor = editor;
19
+ }
20
+ // @internal
21
+ onKeyPress({ key }) {
22
+ const toolController = this.editor.toolController;
23
+ const primaryTools = toolController.getPrimaryTools();
24
+ // Map keys 0-9 to primary tools.
25
+ const keyMatch = /^[0-9]$/.exec(key);
26
+ let targetTool;
27
+ if (keyMatch) {
28
+ const targetIdx = parseInt(keyMatch[0], 10) - 1;
29
+ targetTool = primaryTools[targetIdx];
30
+ }
31
+ if (targetTool) {
32
+ targetTool.setEnabled(true);
33
+ return true;
34
+ }
35
+ return false;
36
+ }
37
+ }
38
+ exports.default = ToolSwitcherShortcut;
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ // Allows the toolbar to register keyboard events.
3
+ // @packageDocumentation
4
+ var __importDefault = (this && this.__importDefault) || function (mod) {
5
+ return (mod && mod.__esModule) ? mod : { "default": mod };
6
+ };
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ const BaseTool_1 = __importDefault(require("./BaseTool"));
9
+ class ToolbarShortcutHandler extends BaseTool_1.default {
10
+ constructor(editor) {
11
+ super(editor.notifier, editor.localization.changeTool);
12
+ this.listeners = new Set([]);
13
+ }
14
+ registerListener(listener) {
15
+ this.listeners.add(listener);
16
+ }
17
+ removeListener(listener) {
18
+ this.listeners.delete(listener);
19
+ }
20
+ onKeyPress(event) {
21
+ for (const listener of this.listeners) {
22
+ if (listener(event)) {
23
+ return true;
24
+ }
25
+ }
26
+ return false;
27
+ }
28
+ }
29
+ exports.default = ToolbarShortcutHandler;
@@ -0,0 +1,28 @@
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 BaseTool_1 = __importDefault(require("./BaseTool"));
7
+ // Handles ctrl+Z, ctrl+Shift+Z keyboard shortcuts.
8
+ class UndoRedoShortcut extends BaseTool_1.default {
9
+ constructor(editor) {
10
+ super(editor.notifier, editor.localization.undoRedoTool);
11
+ this.editor = editor;
12
+ }
13
+ // @internal
14
+ onKeyPress({ key, ctrlKey }) {
15
+ if (ctrlKey) {
16
+ if (key === 'z') {
17
+ this.editor.history.undo();
18
+ return true;
19
+ }
20
+ else if (key === 'Z') {
21
+ this.editor.history.redo();
22
+ return true;
23
+ }
24
+ }
25
+ return false;
26
+ }
27
+ }
28
+ exports.default = UndoRedoShortcut;
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ /**
3
+ * @packageDocumentation
4
+ */
5
+ var __importDefault = (this && this.__importDefault) || function (mod) {
6
+ return (mod && mod.__esModule) ? mod : { "default": mod };
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.ToolbarShortcutHandler = exports.PasteHandler = exports.EraserTool = exports.SelectAllShortcutHandler = exports.SelectionTool = exports.TextTool = exports.PenTool = exports.PanZoomMode = exports.PanZoomTool = exports.ToolSwitcherShortcut = exports.UndoRedoShortcut = exports.ToolEnabledGroup = exports.ToolController = exports.BaseTool = void 0;
10
+ var BaseTool_1 = require("./BaseTool");
11
+ Object.defineProperty(exports, "BaseTool", { enumerable: true, get: function () { return __importDefault(BaseTool_1).default; } });
12
+ var ToolController_1 = require("./ToolController");
13
+ Object.defineProperty(exports, "ToolController", { enumerable: true, get: function () { return __importDefault(ToolController_1).default; } });
14
+ var ToolEnabledGroup_1 = require("./ToolEnabledGroup");
15
+ Object.defineProperty(exports, "ToolEnabledGroup", { enumerable: true, get: function () { return __importDefault(ToolEnabledGroup_1).default; } });
16
+ var UndoRedoShortcut_1 = require("./UndoRedoShortcut");
17
+ Object.defineProperty(exports, "UndoRedoShortcut", { enumerable: true, get: function () { return __importDefault(UndoRedoShortcut_1).default; } });
18
+ var ToolSwitcherShortcut_1 = require("./ToolSwitcherShortcut");
19
+ Object.defineProperty(exports, "ToolSwitcherShortcut", { enumerable: true, get: function () { return __importDefault(ToolSwitcherShortcut_1).default; } });
20
+ var PanZoom_1 = require("./PanZoom");
21
+ Object.defineProperty(exports, "PanZoomTool", { enumerable: true, get: function () { return __importDefault(PanZoom_1).default; } });
22
+ Object.defineProperty(exports, "PanZoomMode", { enumerable: true, get: function () { return PanZoom_1.PanZoomMode; } });
23
+ var Pen_1 = require("./Pen");
24
+ Object.defineProperty(exports, "PenTool", { enumerable: true, get: function () { return __importDefault(Pen_1).default; } });
25
+ var TextTool_1 = require("./TextTool");
26
+ Object.defineProperty(exports, "TextTool", { enumerable: true, get: function () { return __importDefault(TextTool_1).default; } });
27
+ var SelectionTool_1 = require("./SelectionTool/SelectionTool");
28
+ Object.defineProperty(exports, "SelectionTool", { enumerable: true, get: function () { return __importDefault(SelectionTool_1).default; } });
29
+ var SelectAllShortcutHandler_1 = require("./SelectionTool/SelectAllShortcutHandler");
30
+ Object.defineProperty(exports, "SelectAllShortcutHandler", { enumerable: true, get: function () { return __importDefault(SelectAllShortcutHandler_1).default; } });
31
+ var Eraser_1 = require("./Eraser");
32
+ Object.defineProperty(exports, "EraserTool", { enumerable: true, get: function () { return __importDefault(Eraser_1).default; } });
33
+ var PasteHandler_1 = require("./PasteHandler");
34
+ Object.defineProperty(exports, "PasteHandler", { enumerable: true, get: function () { return __importDefault(PasteHandler_1).default; } });
35
+ var ToolbarShortcutHandler_1 = require("./ToolbarShortcutHandler");
36
+ Object.defineProperty(exports, "ToolbarShortcutHandler", { enumerable: true, get: function () { return __importDefault(ToolbarShortcutHandler_1).default; } });
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.defaultToolLocalization = void 0;
4
+ exports.defaultToolLocalization = {
5
+ penTool: (penId) => `Pen ${penId}`,
6
+ selectionTool: 'Selection',
7
+ selectAllTool: 'Select all shortcut',
8
+ eraserTool: 'Eraser',
9
+ touchPanTool: 'Touch panning',
10
+ twoFingerPanZoomTool: 'Panning and zooming',
11
+ undoRedoTool: 'Undo/Redo',
12
+ rightClickDragPanTool: 'Right-click drag',
13
+ pipetteTool: 'Pick color from screen',
14
+ keyboardPanZoom: 'Keyboard pan/zoom shortcuts',
15
+ textTool: 'Text',
16
+ enterTextToInsert: 'Text to insert',
17
+ changeTool: 'Change tool',
18
+ pasteHandler: 'Copy paste handler',
19
+ findLabel: 'Find',
20
+ toNextMatch: 'Next',
21
+ closeFindDialog: 'Close',
22
+ findDialogShown: 'Find dialog shown',
23
+ findDialogHidden: 'Find dialog hidden',
24
+ focusedFoundText: (matchIdx, totalMatches) => `Viewing match ${matchIdx} of ${totalMatches}`,
25
+ anyDevicePanning: 'Any device panning',
26
+ copied: (count, description) => `Copied ${count} ${description}`,
27
+ pasted: (count, description) => `Pasted ${count} ${description}`,
28
+ toolEnabledAnnouncement: (toolName) => `${toolName} enabled`,
29
+ toolDisabledAnnouncement: (toolName) => `${toolName} disabled`,
30
+ };
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ // Types related to the image editor
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.UndoEventType = exports.EditorEventType = exports.InputEvtType = void 0;
5
+ var InputEvtType;
6
+ (function (InputEvtType) {
7
+ InputEvtType[InputEvtType["PointerDownEvt"] = 0] = "PointerDownEvt";
8
+ InputEvtType[InputEvtType["PointerMoveEvt"] = 1] = "PointerMoveEvt";
9
+ InputEvtType[InputEvtType["PointerUpEvt"] = 2] = "PointerUpEvt";
10
+ InputEvtType[InputEvtType["GestureCancelEvt"] = 3] = "GestureCancelEvt";
11
+ InputEvtType[InputEvtType["WheelEvt"] = 4] = "WheelEvt";
12
+ InputEvtType[InputEvtType["KeyPressEvent"] = 5] = "KeyPressEvent";
13
+ InputEvtType[InputEvtType["KeyUpEvent"] = 6] = "KeyUpEvent";
14
+ InputEvtType[InputEvtType["CopyEvent"] = 7] = "CopyEvent";
15
+ InputEvtType[InputEvtType["PasteEvent"] = 8] = "PasteEvent";
16
+ })(InputEvtType = exports.InputEvtType || (exports.InputEvtType = {}));
17
+ var EditorEventType;
18
+ (function (EditorEventType) {
19
+ EditorEventType[EditorEventType["ToolEnabled"] = 0] = "ToolEnabled";
20
+ EditorEventType[EditorEventType["ToolDisabled"] = 1] = "ToolDisabled";
21
+ EditorEventType[EditorEventType["ToolUpdated"] = 2] = "ToolUpdated";
22
+ EditorEventType[EditorEventType["UndoRedoStackUpdated"] = 3] = "UndoRedoStackUpdated";
23
+ EditorEventType[EditorEventType["CommandDone"] = 4] = "CommandDone";
24
+ EditorEventType[EditorEventType["CommandUndone"] = 5] = "CommandUndone";
25
+ EditorEventType[EditorEventType["ObjectAdded"] = 6] = "ObjectAdded";
26
+ EditorEventType[EditorEventType["ViewportChanged"] = 7] = "ViewportChanged";
27
+ EditorEventType[EditorEventType["DisplayResized"] = 8] = "DisplayResized";
28
+ EditorEventType[EditorEventType["ColorPickerToggled"] = 9] = "ColorPickerToggled";
29
+ EditorEventType[EditorEventType["ColorPickerColorSelected"] = 10] = "ColorPickerColorSelected";
30
+ EditorEventType[EditorEventType["ToolbarDropdownShown"] = 11] = "ToolbarDropdownShown";
31
+ })(EditorEventType = exports.EditorEventType || (exports.EditorEventType = {}));
32
+ // Types of `EditorUndoStackUpdated` events.
33
+ var UndoEventType;
34
+ (function (UndoEventType) {
35
+ UndoEventType[UndoEventType["CommandDone"] = 0] = "CommandDone";
36
+ UndoEventType[UndoEventType["CommandUndone"] = 1] = "CommandUndone";
37
+ UndoEventType[UndoEventType["CommandRedone"] = 2] = "CommandRedone";
38
+ })(UndoEventType = exports.UndoEventType || (exports.UndoEventType = {}));