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,488 @@
1
+ "use strict";
2
+ /**
3
+ * @internal
4
+ * @packageDocumentation
5
+ */
6
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
7
+ if (k2 === undefined) k2 = k;
8
+ var desc = Object.getOwnPropertyDescriptor(m, k);
9
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
10
+ desc = { enumerable: true, get: function() { return m[k]; } };
11
+ }
12
+ Object.defineProperty(o, k2, desc);
13
+ }) : (function(o, m, k, k2) {
14
+ if (k2 === undefined) k2 = k;
15
+ o[k2] = m[k];
16
+ }));
17
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
18
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
19
+ }) : function(o, v) {
20
+ o["default"] = v;
21
+ });
22
+ var __importStar = (this && this.__importStar) || function (mod) {
23
+ if (mod && mod.__esModule) return mod;
24
+ var result = {};
25
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
26
+ __setModuleDefault(result, mod);
27
+ return result;
28
+ };
29
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
30
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
31
+ return new (P || (P = Promise))(function (resolve, reject) {
32
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
33
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
34
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
35
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
36
+ });
37
+ };
38
+ var __importDefault = (this && this.__importDefault) || function (mod) {
39
+ return (mod && mod.__esModule) ? mod : { "default": mod };
40
+ };
41
+ var _a;
42
+ Object.defineProperty(exports, "__esModule", { value: true });
43
+ const SerializableCommand_1 = __importDefault(require("../../commands/SerializableCommand"));
44
+ const Mat33_1 = __importDefault(require("../../math/Mat33"));
45
+ const Rect2_1 = __importDefault(require("../../math/Rect2"));
46
+ const Vec2_1 = require("../../math/Vec2");
47
+ const SelectionHandle_1 = __importStar(require("./SelectionHandle"));
48
+ const SelectionTool_1 = require("./SelectionTool");
49
+ const Viewport_1 = __importDefault(require("../../Viewport"));
50
+ const Erase_1 = __importDefault(require("../../commands/Erase"));
51
+ const Duplicate_1 = __importDefault(require("../../commands/Duplicate"));
52
+ const TransformMode_1 = require("./TransformMode");
53
+ const types_1 = require("./types");
54
+ const EditorImage_1 = __importDefault(require("../../EditorImage"));
55
+ const updateChunkSize = 100;
56
+ const maxPreviewElemCount = 500;
57
+ // @internal
58
+ class Selection {
59
+ constructor(startPoint, editor) {
60
+ this.editor = editor;
61
+ this.transform = Mat33_1.default.identity;
62
+ this.selectedElems = [];
63
+ this.hasParent = true;
64
+ // Maps IDs to whether we removed the component from the image
65
+ this.removedFromImage = {};
66
+ this.targetHandle = null;
67
+ this.backgroundDragging = false;
68
+ this.originalRegion = new Rect2_1.default(startPoint.x, startPoint.y, 0, 0);
69
+ this.transformers = {
70
+ drag: new TransformMode_1.DragTransformer(editor, this),
71
+ resize: new TransformMode_1.ResizeTransformer(editor, this),
72
+ rotate: new TransformMode_1.RotateTransformer(editor, this),
73
+ };
74
+ this.container = document.createElement('div');
75
+ this.backgroundElem = document.createElement('div');
76
+ this.backgroundElem.classList.add(`${SelectionTool_1.cssPrefix}selection-background`);
77
+ this.container.appendChild(this.backgroundElem);
78
+ const resizeHorizontalHandle = new SelectionHandle_1.default(SelectionHandle_1.HandleShape.Square, Vec2_1.Vec2.of(1, 0.5), this, (startPoint) => this.transformers.resize.onDragStart(startPoint, types_1.ResizeMode.HorizontalOnly), (currentPoint) => this.transformers.resize.onDragUpdate(currentPoint), () => this.transformers.resize.onDragEnd());
79
+ const resizeVerticalHandle = new SelectionHandle_1.default(SelectionHandle_1.HandleShape.Square, Vec2_1.Vec2.of(0.5, 1), this, (startPoint) => this.transformers.resize.onDragStart(startPoint, types_1.ResizeMode.VerticalOnly), (currentPoint) => this.transformers.resize.onDragUpdate(currentPoint), () => this.transformers.resize.onDragEnd());
80
+ const resizeBothHandle = new SelectionHandle_1.default(SelectionHandle_1.HandleShape.Square, Vec2_1.Vec2.of(1, 1), this, (startPoint) => this.transformers.resize.onDragStart(startPoint, types_1.ResizeMode.Both), (currentPoint) => this.transformers.resize.onDragUpdate(currentPoint), () => this.transformers.resize.onDragEnd());
81
+ const rotationHandle = new SelectionHandle_1.default(SelectionHandle_1.HandleShape.Circle, Vec2_1.Vec2.of(0.5, 0), this, (startPoint) => this.transformers.rotate.onDragStart(startPoint), (currentPoint) => this.transformers.rotate.onDragUpdate(currentPoint), () => this.transformers.rotate.onDragEnd());
82
+ this.handles = [
83
+ resizeBothHandle,
84
+ resizeHorizontalHandle,
85
+ resizeVerticalHandle,
86
+ rotationHandle,
87
+ ];
88
+ for (const handle of this.handles) {
89
+ handle.addTo(this.backgroundElem);
90
+ }
91
+ }
92
+ // @internal Intended for unit tests
93
+ getBackgroundElem() {
94
+ return this.backgroundElem;
95
+ }
96
+ getTransform() {
97
+ return this.transform;
98
+ }
99
+ get preTransformRegion() {
100
+ return this.originalRegion;
101
+ }
102
+ get region() {
103
+ // TODO: This currently assumes that the region rotates about its center.
104
+ // This may not be true.
105
+ const rotationMatrix = Mat33_1.default.zRotation(this.regionRotation, this.originalRegion.center);
106
+ const scaleAndTranslateMat = this.transform.rightMul(rotationMatrix.inverse());
107
+ return this.originalRegion.transformedBoundingBox(scaleAndTranslateMat);
108
+ }
109
+ /**
110
+ * Computes and returns the bounding box of the selection without
111
+ * any additional padding. Computes directly from the elements that are selected.
112
+ * @internal
113
+ */
114
+ computeTightBoundingBox() {
115
+ const bbox = this.selectedElems.reduce((accumulator, elem) => {
116
+ return (accumulator !== null && accumulator !== void 0 ? accumulator : elem.getBBox()).union(elem.getBBox());
117
+ }, null);
118
+ return bbox !== null && bbox !== void 0 ? bbox : Rect2_1.default.empty;
119
+ }
120
+ get regionRotation() {
121
+ return this.transform.transformVec3(Vec2_1.Vec2.unitX).angle();
122
+ }
123
+ get preTransformedScreenRegion() {
124
+ const toScreen = (vec) => this.editor.viewport.canvasToScreen(vec);
125
+ return Rect2_1.default.fromCorners(toScreen(this.preTransformRegion.topLeft), toScreen(this.preTransformRegion.bottomRight));
126
+ }
127
+ get preTransformedScreenRegionRotation() {
128
+ return this.editor.viewport.getRotationAngle();
129
+ }
130
+ get screenRegion() {
131
+ const toScreen = this.editor.viewport.canvasToScreenTransform;
132
+ const scaleFactor = this.editor.viewport.getScaleFactor();
133
+ const screenCenter = toScreen.transformVec2(this.region.center);
134
+ return new Rect2_1.default(screenCenter.x, screenCenter.y, scaleFactor * this.region.width, scaleFactor * this.region.height).translatedBy(this.region.size.times(-scaleFactor / 2));
135
+ }
136
+ get screenRegionRotation() {
137
+ return this.regionRotation + this.editor.viewport.getRotationAngle();
138
+ }
139
+ // Applies, previews, but doesn't finalize the given transformation.
140
+ setTransform(transform, preview = true) {
141
+ this.transform = transform;
142
+ if (preview && this.hasParent) {
143
+ this.scrollTo();
144
+ this.previewTransformCmds();
145
+ }
146
+ }
147
+ // Applies the current transformation to the selection
148
+ finalizeTransform() {
149
+ const fullTransform = this.transform;
150
+ const selectedElems = this.selectedElems;
151
+ // Reset for the next drag
152
+ this.originalRegion = this.originalRegion.transformedBoundingBox(this.transform);
153
+ this.transform = Mat33_1.default.identity;
154
+ // Make the commands undo-able
155
+ this.editor.dispatch(new Selection.ApplyTransformationCommand(this, selectedElems, fullTransform));
156
+ }
157
+ // Preview the effects of the current transformation on the selection
158
+ previewTransformCmds() {
159
+ // Don't render what we're moving if it's likely to be slow.
160
+ if (this.selectedElems.length > maxPreviewElemCount) {
161
+ this.updateUI();
162
+ return;
163
+ }
164
+ const wetInkRenderer = this.editor.display.getWetInkRenderer();
165
+ wetInkRenderer.clear();
166
+ wetInkRenderer.pushTransform(this.transform);
167
+ const viewportVisibleRect = this.editor.viewport.visibleRect;
168
+ const visibleRect = viewportVisibleRect.transformedBoundingBox(this.transform.inverse());
169
+ for (const elem of this.selectedElems) {
170
+ elem.render(wetInkRenderer, visibleRect);
171
+ }
172
+ wetInkRenderer.popTransform();
173
+ this.updateUI();
174
+ }
175
+ // Find the objects corresponding to this in the document,
176
+ // select them.
177
+ // Returns false iff nothing was selected.
178
+ resolveToObjects() {
179
+ let singleItemSelectionMode = false;
180
+ this.transform = Mat33_1.default.identity;
181
+ // Grow the rectangle, if necessary
182
+ if (this.region.w === 0 || this.region.h === 0) {
183
+ const padding = this.editor.viewport.visibleRect.maxDimension / 200;
184
+ this.originalRegion = Rect2_1.default.bboxOf(this.region.corners, padding);
185
+ // Only select one item if the rectangle was very small.
186
+ singleItemSelectionMode = true;
187
+ }
188
+ this.selectedElems = this.editor.image.getElementsIntersectingRegion(this.region).filter(elem => {
189
+ return elem.intersectsRect(this.region) && elem.isSelectable();
190
+ });
191
+ if (singleItemSelectionMode && this.selectedElems.length > 0) {
192
+ this.selectedElems = [this.selectedElems[this.selectedElems.length - 1]];
193
+ }
194
+ // Find the bounding box of all selected elements.
195
+ if (!this.recomputeRegion()) {
196
+ return false;
197
+ }
198
+ this.updateUI();
199
+ return true;
200
+ }
201
+ // Recompute this' region from the selected elements.
202
+ // Returns false if the selection is empty.
203
+ recomputeRegion() {
204
+ const newRegion = this.computeTightBoundingBox();
205
+ if (!newRegion) {
206
+ this.cancelSelection();
207
+ return false;
208
+ }
209
+ this.originalRegion = newRegion;
210
+ const minSize = this.getMinCanvasSize();
211
+ if (this.originalRegion.w < minSize || this.originalRegion.h < minSize) {
212
+ // Add padding
213
+ const padding = minSize / 2;
214
+ this.originalRegion = Rect2_1.default.bboxOf(this.originalRegion.corners, padding);
215
+ }
216
+ return true;
217
+ }
218
+ getMinCanvasSize() {
219
+ const canvasHandleSize = SelectionHandle_1.handleSize / this.editor.viewport.getScaleFactor();
220
+ return canvasHandleSize * 2;
221
+ }
222
+ getSelectedItemCount() {
223
+ return this.selectedElems.length;
224
+ }
225
+ // @internal
226
+ updateUI() {
227
+ // Don't update old selections.
228
+ if (!this.hasParent) {
229
+ return;
230
+ }
231
+ // marginLeft, marginTop: Display relative to the top left of the selection overlay.
232
+ // left, top don't work for this.
233
+ this.backgroundElem.style.marginLeft = `${this.screenRegion.topLeft.x}px`;
234
+ this.backgroundElem.style.marginTop = `${this.screenRegion.topLeft.y}px`;
235
+ this.backgroundElem.style.width = `${this.screenRegion.width}px`;
236
+ this.backgroundElem.style.height = `${this.screenRegion.height}px`;
237
+ const rotationDeg = this.screenRegionRotation * 180 / Math.PI;
238
+ this.backgroundElem.style.transform = `rotate(${rotationDeg}deg)`;
239
+ this.backgroundElem.style.transformOrigin = 'center';
240
+ for (const handle of this.handles) {
241
+ handle.updatePosition();
242
+ }
243
+ }
244
+ // Add/remove the contents of this' seleciton from the editor.
245
+ // Used to prevent previewed content from looking like duplicate content
246
+ // while dragging.
247
+ //
248
+ // Does nothing if a large number of elements are selected (and so modifying
249
+ // the editor image is likely to be slow.)
250
+ //
251
+ // If removed from the image, selected elements are drawn as wet ink.
252
+ addRemoveSelectionFromImage(inImage) {
253
+ // Don't hide elements if doing so will be slow.
254
+ if (!inImage && this.selectedElems.length > maxPreviewElemCount) {
255
+ return;
256
+ }
257
+ for (const elem of this.selectedElems) {
258
+ const parent = this.editor.image.findParent(elem);
259
+ if (!inImage && parent) {
260
+ this.removedFromImage[elem.getId()] = true;
261
+ parent.remove();
262
+ }
263
+ // If we're making things visible and the selected object wasn't previously
264
+ // visible,
265
+ else if (!parent && this.removedFromImage[elem.getId()]) {
266
+ EditorImage_1.default.addElement(elem).apply(this.editor);
267
+ this.removedFromImage[elem.getId()] = false;
268
+ delete this.removedFromImage[elem.getId()];
269
+ }
270
+ }
271
+ // Don't await queueRerender. If we're running in a test, the re-render might never
272
+ // happen.
273
+ this.editor.queueRerender().then(() => {
274
+ if (!inImage) {
275
+ this.previewTransformCmds();
276
+ }
277
+ });
278
+ }
279
+ removeDeletedElemsFromSelection() {
280
+ // Remove any deleted elements from the selection.
281
+ this.selectedElems = this.selectedElems.filter(elem => {
282
+ const hasParent = !!this.editor.image.findParent(elem);
283
+ // If we removed the element and haven't added it back yet, don't remove it
284
+ // from the selection.
285
+ const weRemoved = this.removedFromImage[elem.getId()];
286
+ return hasParent || weRemoved;
287
+ });
288
+ }
289
+ onDragStart(pointer, target) {
290
+ this.removeDeletedElemsFromSelection();
291
+ this.addRemoveSelectionFromImage(false);
292
+ for (const handle of this.handles) {
293
+ if (handle.isTarget(target)) {
294
+ handle.handleDragStart(pointer);
295
+ this.targetHandle = handle;
296
+ return true;
297
+ }
298
+ }
299
+ if (this.backgroundElem === target) {
300
+ this.backgroundDragging = true;
301
+ this.transformers.drag.onDragStart(pointer.canvasPos);
302
+ return true;
303
+ }
304
+ return false;
305
+ }
306
+ onDragUpdate(pointer) {
307
+ if (this.backgroundDragging) {
308
+ this.transformers.drag.onDragUpdate(pointer.canvasPos);
309
+ }
310
+ if (this.targetHandle) {
311
+ this.targetHandle.handleDragUpdate(pointer);
312
+ }
313
+ }
314
+ onDragEnd() {
315
+ if (this.backgroundDragging) {
316
+ this.transformers.drag.onDragEnd();
317
+ }
318
+ else if (this.targetHandle) {
319
+ this.targetHandle.handleDragEnd();
320
+ }
321
+ this.addRemoveSelectionFromImage(true);
322
+ this.backgroundDragging = false;
323
+ this.targetHandle = null;
324
+ this.updateUI();
325
+ }
326
+ onDragCancel() {
327
+ this.backgroundDragging = false;
328
+ this.targetHandle = null;
329
+ this.setTransform(Mat33_1.default.identity);
330
+ this.addRemoveSelectionFromImage(true);
331
+ }
332
+ // Scroll the viewport to this. Does not zoom
333
+ scrollTo() {
334
+ return __awaiter(this, void 0, void 0, function* () {
335
+ if (this.selectedElems.length === 0) {
336
+ return;
337
+ }
338
+ const screenRect = new Rect2_1.default(0, 0, this.editor.display.width, this.editor.display.height);
339
+ if (!screenRect.containsPoint(this.screenRegion.center)) {
340
+ const closestPoint = screenRect.getClosestPointOnBoundaryTo(this.screenRegion.center);
341
+ const screenDelta = this.screenRegion.center.minus(closestPoint);
342
+ const delta = this.editor.viewport.screenToCanvasTransform.transformVec3(screenDelta);
343
+ yield this.editor.dispatchNoAnnounce(Viewport_1.default.transformBy(Mat33_1.default.translation(delta.times(-1))), false);
344
+ // Re-renders clear wet ink, so we need to re-draw the preview
345
+ // after the full re-render.
346
+ yield this.editor.queueRerender();
347
+ this.previewTransformCmds();
348
+ }
349
+ });
350
+ }
351
+ deleteSelectedObjects() {
352
+ if (this.backgroundDragging || this.targetHandle) {
353
+ this.onDragEnd();
354
+ }
355
+ return new Erase_1.default(this.selectedElems);
356
+ }
357
+ duplicateSelectedObjects() {
358
+ return __awaiter(this, void 0, void 0, function* () {
359
+ const wasTransforming = this.backgroundDragging || this.targetHandle;
360
+ let tmpApplyCommand = null;
361
+ if (wasTransforming) {
362
+ // Don't update the selection's focus when redoing/undoing
363
+ const selectionToUpdate = null;
364
+ tmpApplyCommand = new Selection.ApplyTransformationCommand(selectionToUpdate, this.selectedElems, this.transform);
365
+ // Transform to ensure that the duplicates are in the correct location
366
+ yield tmpApplyCommand.apply(this.editor);
367
+ // Show items again
368
+ this.addRemoveSelectionFromImage(true);
369
+ }
370
+ const duplicateCommand = new Duplicate_1.default(this.selectedElems);
371
+ if (wasTransforming) {
372
+ // Move the selected objects back to the correct location.
373
+ yield (tmpApplyCommand === null || tmpApplyCommand === void 0 ? void 0 : tmpApplyCommand.unapply(this.editor));
374
+ this.addRemoveSelectionFromImage(false);
375
+ this.previewTransformCmds();
376
+ this.updateUI();
377
+ }
378
+ return duplicateCommand;
379
+ });
380
+ }
381
+ addTo(elem) {
382
+ if (this.container.parentElement) {
383
+ this.container.remove();
384
+ }
385
+ elem.appendChild(this.container);
386
+ this.hasParent = true;
387
+ }
388
+ setToPoint(point) {
389
+ this.originalRegion = this.originalRegion.grownToPoint(point);
390
+ this.updateUI();
391
+ }
392
+ cancelSelection() {
393
+ if (this.container.parentElement) {
394
+ this.container.remove();
395
+ }
396
+ this.originalRegion = Rect2_1.default.empty;
397
+ this.hasParent = false;
398
+ }
399
+ setSelectedObjects(objects, bbox) {
400
+ this.addRemoveSelectionFromImage(true);
401
+ this.originalRegion = bbox;
402
+ this.selectedElems = objects.filter(object => object.isSelectable());
403
+ this.updateUI();
404
+ }
405
+ getSelectedObjects() {
406
+ return this.selectedElems;
407
+ }
408
+ }
409
+ exports.default = Selection;
410
+ _a = Selection;
411
+ (() => {
412
+ SerializableCommand_1.default.register('selection-tool-transform', (json, _editor) => {
413
+ var _b;
414
+ // The selection box is lost when serializing/deserializing. No need to store box rotation
415
+ const fullTransform = new Mat33_1.default(...json.transform);
416
+ const elemIds = ((_b = json.elems) !== null && _b !== void 0 ? _b : []);
417
+ return new _a.ApplyTransformationCommand(null, elemIds, fullTransform);
418
+ });
419
+ })();
420
+ Selection.ApplyTransformationCommand = class extends SerializableCommand_1.default {
421
+ constructor(selection,
422
+ // If a `string[]`, selectedElems is a list of element IDs.
423
+ selectedElems,
424
+ // Full transformation used to transform elements.
425
+ fullTransform) {
426
+ super('selection-tool-transform');
427
+ this.selection = selection;
428
+ this.fullTransform = fullTransform;
429
+ const isIDList = (arr) => {
430
+ return typeof arr[0] === 'string';
431
+ };
432
+ // If a list of element IDs,
433
+ if (isIDList(selectedElems)) {
434
+ this.selectedElemIds = selectedElems;
435
+ }
436
+ else {
437
+ this.selectedElemIds = selectedElems.map(elem => elem.getId());
438
+ this.transformCommands = selectedElems.map(elem => {
439
+ return elem.transformBy(this.fullTransform);
440
+ });
441
+ }
442
+ }
443
+ resolveToElems(editor) {
444
+ if (this.transformCommands) {
445
+ return;
446
+ }
447
+ this.transformCommands = this.selectedElemIds.map(id => {
448
+ const elem = editor.image.lookupElement(id);
449
+ if (!elem) {
450
+ throw new Error(`Unable to find element with ID, ${id}.`);
451
+ }
452
+ return elem.transformBy(this.fullTransform);
453
+ });
454
+ }
455
+ apply(editor) {
456
+ var _b, _c, _d, _e, _f;
457
+ return __awaiter(this, void 0, void 0, function* () {
458
+ this.resolveToElems(editor);
459
+ (_b = this.selection) === null || _b === void 0 ? void 0 : _b.setTransform(this.fullTransform, false);
460
+ (_c = this.selection) === null || _c === void 0 ? void 0 : _c.updateUI();
461
+ yield editor.asyncApplyCommands(this.transformCommands, updateChunkSize);
462
+ (_d = this.selection) === null || _d === void 0 ? void 0 : _d.setTransform(Mat33_1.default.identity, false);
463
+ (_e = this.selection) === null || _e === void 0 ? void 0 : _e.recomputeRegion();
464
+ (_f = this.selection) === null || _f === void 0 ? void 0 : _f.updateUI();
465
+ });
466
+ }
467
+ unapply(editor) {
468
+ var _b, _c, _d, _e, _f;
469
+ return __awaiter(this, void 0, void 0, function* () {
470
+ this.resolveToElems(editor);
471
+ (_b = this.selection) === null || _b === void 0 ? void 0 : _b.setTransform(this.fullTransform.inverse(), false);
472
+ (_c = this.selection) === null || _c === void 0 ? void 0 : _c.updateUI();
473
+ yield editor.asyncUnapplyCommands(this.transformCommands, updateChunkSize, true);
474
+ (_d = this.selection) === null || _d === void 0 ? void 0 : _d.setTransform(Mat33_1.default.identity);
475
+ (_e = this.selection) === null || _e === void 0 ? void 0 : _e.recomputeRegion();
476
+ (_f = this.selection) === null || _f === void 0 ? void 0 : _f.updateUI();
477
+ });
478
+ }
479
+ serializeToJSON() {
480
+ return {
481
+ elems: this.selectedElemIds,
482
+ transform: this.fullTransform.toArray(),
483
+ };
484
+ }
485
+ description(_editor, localizationTable) {
486
+ return localizationTable.transformedElements(this.selectedElemIds.length);
487
+ }
488
+ };
@@ -0,0 +1,38 @@
1
+ import { Point2, Vec2 } from '../../math/Vec2';
2
+ import Selection from './Selection';
3
+ import Pointer from '../../Pointer';
4
+ export declare enum HandleShape {
5
+ Circle = 0,
6
+ Square = 1
7
+ }
8
+ export declare const handleSize = 30;
9
+ export type DragStartCallback = (startPoint: Point2) => void;
10
+ export type DragUpdateCallback = (canvasPoint: Point2) => void;
11
+ export type DragEndCallback = () => void;
12
+ export default class SelectionHandle {
13
+ readonly shape: HandleShape;
14
+ private readonly parentSide;
15
+ private readonly parent;
16
+ private readonly onDragStart;
17
+ private readonly onDragUpdate;
18
+ private readonly onDragEnd;
19
+ private element;
20
+ private snapToGrid;
21
+ constructor(shape: HandleShape, parentSide: Vec2, parent: Selection, onDragStart: DragStartCallback, onDragUpdate: DragUpdateCallback, onDragEnd: DragEndCallback);
22
+ /**
23
+ * Adds this to `container`, where `conatiner` should be the background/selection
24
+ * element visible on the screen.
25
+ */
26
+ addTo(container: HTMLElement): void;
27
+ updatePosition(): void;
28
+ /**
29
+ * @returns `true` if the given `EventTarget` matches this.
30
+ */
31
+ isTarget(target: EventTarget): boolean;
32
+ private dragLastPos;
33
+ handleDragStart(pointer: Pointer): void;
34
+ handleDragUpdate(pointer: Pointer): void;
35
+ handleDragEnd(): void;
36
+ setSnapToGrid(snap: boolean): void;
37
+ isSnappingToGrid(): boolean;
38
+ }
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.handleSize = exports.HandleShape = void 0;
4
+ const assertions_1 = require("../../util/assertions");
5
+ const Vec2_1 = require("../../math/Vec2");
6
+ const SelectionTool_1 = require("./SelectionTool");
7
+ var HandleShape;
8
+ (function (HandleShape) {
9
+ HandleShape[HandleShape["Circle"] = 0] = "Circle";
10
+ HandleShape[HandleShape["Square"] = 1] = "Square";
11
+ })(HandleShape = exports.HandleShape || (exports.HandleShape = {}));
12
+ exports.handleSize = 30;
13
+ class SelectionHandle {
14
+ // Bounding box in screen coordinates.
15
+ constructor(shape, parentSide, parent, onDragStart, onDragUpdate, onDragEnd) {
16
+ this.shape = shape;
17
+ this.parentSide = parentSide;
18
+ this.parent = parent;
19
+ this.onDragStart = onDragStart;
20
+ this.onDragUpdate = onDragUpdate;
21
+ this.onDragEnd = onDragEnd;
22
+ this.dragLastPos = null;
23
+ this.element = document.createElement('div');
24
+ this.element.classList.add(`${SelectionTool_1.cssPrefix}handle`);
25
+ switch (shape) {
26
+ case HandleShape.Circle:
27
+ this.element.classList.add(`${SelectionTool_1.cssPrefix}circle`);
28
+ break;
29
+ case HandleShape.Square:
30
+ this.element.classList.add(`${SelectionTool_1.cssPrefix}square`);
31
+ break;
32
+ default:
33
+ (0, assertions_1.assertUnreachable)(shape);
34
+ }
35
+ this.updatePosition();
36
+ }
37
+ /**
38
+ * Adds this to `container`, where `conatiner` should be the background/selection
39
+ * element visible on the screen.
40
+ */
41
+ addTo(container) {
42
+ container.appendChild(this.element);
43
+ }
44
+ updatePosition() {
45
+ const parentRect = this.parent.screenRegion;
46
+ const size = Vec2_1.Vec2.of(exports.handleSize, exports.handleSize);
47
+ const topLeft = parentRect.size.scale(this.parentSide)
48
+ // Center
49
+ .minus(size.times(1 / 2));
50
+ // Position within the selection box.
51
+ this.element.style.marginLeft = `${topLeft.x}px`;
52
+ this.element.style.marginTop = `${topLeft.y}px`;
53
+ this.element.style.width = `${size.x}px`;
54
+ this.element.style.height = `${size.y}px`;
55
+ }
56
+ /**
57
+ * @returns `true` if the given `EventTarget` matches this.
58
+ */
59
+ isTarget(target) {
60
+ return target === this.element;
61
+ }
62
+ handleDragStart(pointer) {
63
+ this.onDragStart(pointer.canvasPos);
64
+ this.dragLastPos = pointer.canvasPos;
65
+ }
66
+ handleDragUpdate(pointer) {
67
+ if (!this.dragLastPos) {
68
+ return;
69
+ }
70
+ this.onDragUpdate(pointer.canvasPos);
71
+ }
72
+ handleDragEnd() {
73
+ if (!this.dragLastPos) {
74
+ return;
75
+ }
76
+ this.onDragEnd();
77
+ }
78
+ setSnapToGrid(snap) {
79
+ this.snapToGrid = snap;
80
+ }
81
+ isSnappingToGrid() {
82
+ return this.snapToGrid;
83
+ }
84
+ }
85
+ exports.default = SelectionHandle;
@@ -0,0 +1,36 @@
1
+ import AbstractComponent from '../../components/AbstractComponent';
2
+ import Editor from '../../Editor';
3
+ import { CopyEvent, KeyPressEvent, KeyUpEvent, PointerEvt } from '../../types';
4
+ import BaseTool from '../BaseTool';
5
+ import Selection from './Selection';
6
+ export declare const cssPrefix = "selection-tool-";
7
+ export default class SelectionTool extends BaseTool {
8
+ private editor;
9
+ private handleOverlay;
10
+ private prevSelectionBox;
11
+ private selectionBox;
12
+ private lastEvtTarget;
13
+ private expandingSelectionBox;
14
+ private shiftKeyPressed;
15
+ private ctrlKeyPressed;
16
+ constructor(editor: Editor, description: string);
17
+ private makeSelectionBox;
18
+ private snapSelectionToGrid;
19
+ private selectionBoxHandlingEvt;
20
+ onPointerDown({ allPointers, current }: PointerEvt): boolean;
21
+ onPointerMove(event: PointerEvt): void;
22
+ private onSelectionUpdated;
23
+ private onGestureEnd;
24
+ private zoomToSelection;
25
+ onPointerUp(event: PointerEvt): void;
26
+ onGestureCancel(): void;
27
+ private static handleableKeys;
28
+ onKeyPress(event: KeyPressEvent): boolean;
29
+ onKeyUp(evt: KeyUpEvent): boolean;
30
+ onCopy(event: CopyEvent): boolean;
31
+ setEnabled(enabled: boolean): void;
32
+ getSelection(): Selection | null;
33
+ getSelectedObjects(): AbstractComponent[];
34
+ setSelection(objects: AbstractComponent[]): void;
35
+ clearSelection(): void;
36
+ }