js-draw 0.18.2 → 0.20.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 (269) hide show
  1. package/.eslintrc.js +1 -0
  2. package/CHANGELOG.md +10 -0
  3. package/dist/bundle.js +2 -2
  4. package/dist/bundledStyles.js +1 -0
  5. package/dist/cjs/src/Color4.d.ts +8 -0
  6. package/dist/cjs/src/Color4.js +67 -0
  7. package/dist/cjs/src/Editor.d.ts +2 -2
  8. package/dist/cjs/src/Editor.js +7 -7
  9. package/dist/cjs/src/SVGLoader.js +77 -12
  10. package/dist/cjs/src/Viewport.d.ts +2 -0
  11. package/dist/cjs/src/Viewport.js +6 -2
  12. package/dist/cjs/src/components/AbstractComponent.d.ts +2 -2
  13. package/dist/cjs/src/components/AbstractComponent.js +3 -3
  14. package/dist/cjs/src/components/{ImageBackground.d.ts → BackgroundComponent.d.ts} +23 -3
  15. package/dist/cjs/src/components/BackgroundComponent.js +309 -0
  16. package/dist/cjs/src/components/RestylableComponent.d.ts +21 -2
  17. package/dist/cjs/src/components/Stroke.d.ts +35 -0
  18. package/dist/cjs/src/components/Stroke.js +37 -3
  19. package/dist/cjs/src/components/TextComponent.d.ts +27 -17
  20. package/dist/cjs/src/components/TextComponent.js +23 -1
  21. package/dist/cjs/src/components/lib.d.ts +4 -3
  22. package/dist/cjs/src/components/lib.js +2 -2
  23. package/dist/cjs/src/components/util/StrokeSmoother.js +25 -15
  24. package/dist/cjs/src/lib.d.ts +30 -0
  25. package/dist/cjs/src/lib.js +30 -0
  26. package/dist/cjs/src/localizations/de.js +1 -1
  27. package/dist/cjs/src/localizations/es.js +1 -1
  28. package/dist/cjs/src/math/Path.js +1 -1
  29. package/dist/cjs/src/math/polynomial/QuadraticBezier.d.ts +28 -0
  30. package/dist/cjs/src/math/polynomial/QuadraticBezier.js +115 -0
  31. package/dist/cjs/src/math/polynomial/solveQuadratic.d.ts +6 -0
  32. package/dist/cjs/src/math/polynomial/solveQuadratic.js +36 -0
  33. package/dist/cjs/src/rendering/RenderingStyle.d.ts +4 -4
  34. package/dist/cjs/src/rendering/TextRenderingStyle.d.ts +10 -10
  35. package/dist/cjs/src/rendering/lib.d.ts +2 -0
  36. package/dist/cjs/src/rendering/renderers/AbstractRenderer.d.ts +2 -2
  37. package/dist/cjs/src/rendering/renderers/CanvasRenderer.d.ts +2 -2
  38. package/dist/cjs/src/rendering/renderers/CanvasRenderer.js +5 -3
  39. package/dist/cjs/src/rendering/renderers/DummyRenderer.d.ts +2 -2
  40. package/dist/cjs/src/rendering/renderers/SVGRenderer.d.ts +2 -2
  41. package/dist/cjs/src/rendering/renderers/SVGRenderer.js +15 -6
  42. package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.d.ts +2 -2
  43. package/dist/cjs/src/toolbar/IconProvider.d.ts +2 -2
  44. package/dist/cjs/src/toolbar/localization.d.ts +2 -1
  45. package/dist/cjs/src/toolbar/localization.js +3 -2
  46. package/dist/cjs/src/toolbar/widgets/BaseWidget.js +1 -1
  47. package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.d.ts +5 -0
  48. package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.js +77 -2
  49. package/dist/cjs/src/toolbar/widgets/PenToolWidget.js +1 -1
  50. package/dist/cjs/src/tools/FindTool.js +1 -1
  51. package/dist/cjs/src/tools/SoundUITool.d.ts +24 -0
  52. package/dist/cjs/src/tools/SoundUITool.js +164 -0
  53. package/dist/cjs/src/tools/TextTool.d.ts +2 -2
  54. package/dist/cjs/src/tools/ToolController.js +6 -1
  55. package/dist/cjs/src/tools/lib.d.ts +1 -0
  56. package/dist/cjs/src/tools/lib.js +3 -1
  57. package/dist/cjs/src/tools/localization.d.ts +3 -0
  58. package/dist/cjs/src/tools/localization.js +3 -0
  59. package/dist/mjs/src/Color4.d.ts +8 -0
  60. package/dist/mjs/src/Color4.mjs +64 -0
  61. package/dist/mjs/src/Editor.d.ts +2 -2
  62. package/dist/mjs/src/Editor.mjs +6 -6
  63. package/dist/mjs/src/SVGLoader.mjs +76 -11
  64. package/dist/mjs/src/Viewport.d.ts +2 -0
  65. package/dist/mjs/src/Viewport.mjs +6 -2
  66. package/dist/mjs/src/components/AbstractComponent.d.ts +2 -2
  67. package/dist/mjs/src/components/AbstractComponent.mjs +3 -3
  68. package/dist/mjs/src/components/{ImageBackground.d.ts → BackgroundComponent.d.ts} +23 -3
  69. package/dist/mjs/src/components/BackgroundComponent.mjs +279 -0
  70. package/dist/mjs/src/components/RestylableComponent.d.ts +21 -2
  71. package/dist/mjs/src/components/Stroke.d.ts +35 -0
  72. package/dist/mjs/src/components/Stroke.mjs +37 -3
  73. package/dist/mjs/src/components/TextComponent.d.ts +27 -17
  74. package/dist/mjs/src/components/TextComponent.mjs +23 -1
  75. package/dist/mjs/src/components/lib.d.ts +4 -3
  76. package/dist/mjs/src/components/lib.mjs +2 -2
  77. package/dist/mjs/src/components/util/StrokeSmoother.mjs +25 -15
  78. package/dist/mjs/src/lib.d.ts +30 -0
  79. package/dist/mjs/src/lib.mjs +30 -0
  80. package/dist/mjs/src/localizations/de.mjs +1 -1
  81. package/dist/mjs/src/localizations/es.mjs +1 -1
  82. package/dist/mjs/src/math/Path.mjs +1 -1
  83. package/dist/mjs/src/math/polynomial/QuadraticBezier.d.ts +28 -0
  84. package/dist/mjs/src/math/polynomial/QuadraticBezier.mjs +109 -0
  85. package/dist/mjs/src/math/polynomial/solveQuadratic.d.ts +6 -0
  86. package/dist/mjs/src/math/polynomial/solveQuadratic.mjs +34 -0
  87. package/dist/mjs/src/rendering/RenderingStyle.d.ts +4 -4
  88. package/dist/mjs/src/rendering/TextRenderingStyle.d.ts +10 -10
  89. package/dist/mjs/src/rendering/lib.d.ts +2 -0
  90. package/dist/mjs/src/rendering/renderers/AbstractRenderer.d.ts +2 -2
  91. package/dist/mjs/src/rendering/renderers/CanvasRenderer.d.ts +2 -2
  92. package/dist/mjs/src/rendering/renderers/CanvasRenderer.mjs +5 -3
  93. package/dist/mjs/src/rendering/renderers/DummyRenderer.d.ts +2 -2
  94. package/dist/mjs/src/rendering/renderers/SVGRenderer.d.ts +2 -2
  95. package/dist/mjs/src/rendering/renderers/SVGRenderer.mjs +15 -6
  96. package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.d.ts +2 -2
  97. package/dist/mjs/src/toolbar/IconProvider.d.ts +2 -2
  98. package/dist/mjs/src/toolbar/localization.d.ts +2 -1
  99. package/dist/mjs/src/toolbar/localization.mjs +3 -2
  100. package/dist/mjs/src/toolbar/widgets/BaseWidget.mjs +1 -1
  101. package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.d.ts +5 -0
  102. package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.mjs +54 -2
  103. package/dist/mjs/src/toolbar/widgets/PenToolWidget.mjs +1 -1
  104. package/dist/mjs/src/tools/FindTool.mjs +1 -1
  105. package/dist/mjs/src/tools/SoundUITool.d.ts +24 -0
  106. package/dist/mjs/src/tools/SoundUITool.mjs +158 -0
  107. package/dist/mjs/src/tools/TextTool.d.ts +2 -2
  108. package/dist/mjs/src/tools/ToolController.mjs +6 -1
  109. package/dist/mjs/src/tools/lib.d.ts +1 -0
  110. package/dist/mjs/src/tools/lib.mjs +1 -0
  111. package/dist/mjs/src/tools/localization.d.ts +3 -0
  112. package/dist/mjs/src/tools/localization.mjs +3 -0
  113. package/jest.config.js +1 -1
  114. package/package.json +19 -17
  115. package/src/Editor.css +2 -2
  116. package/src/tools/SoundUITool.css +15 -0
  117. package/src/tools/tools.css +4 -0
  118. package/dist/cjs/src/components/ImageBackground.js +0 -146
  119. package/dist/mjs/src/components/ImageBackground.mjs +0 -139
  120. package/src/Color4.test.ts +0 -40
  121. package/src/Color4.ts +0 -236
  122. package/src/Editor.loadFrom.test.ts +0 -24
  123. package/src/Editor.toSVG.test.ts +0 -111
  124. package/src/Editor.ts +0 -1122
  125. package/src/EditorImage.test.ts +0 -120
  126. package/src/EditorImage.ts +0 -603
  127. package/src/EventDispatcher.test.ts +0 -123
  128. package/src/EventDispatcher.ts +0 -71
  129. package/src/Pointer.ts +0 -127
  130. package/src/SVGLoader.test.ts +0 -114
  131. package/src/SVGLoader.ts +0 -511
  132. package/src/UndoRedoHistory.test.ts +0 -33
  133. package/src/UndoRedoHistory.ts +0 -102
  134. package/src/Viewport.ts +0 -319
  135. package/src/bundle/bundled.ts +0 -7
  136. package/src/commands/Command.ts +0 -45
  137. package/src/commands/Duplicate.ts +0 -48
  138. package/src/commands/Erase.ts +0 -74
  139. package/src/commands/SerializableCommand.ts +0 -49
  140. package/src/commands/UnresolvedCommand.ts +0 -37
  141. package/src/commands/invertCommand.ts +0 -51
  142. package/src/commands/lib.ts +0 -16
  143. package/src/commands/localization.ts +0 -47
  144. package/src/commands/uniteCommands.test.ts +0 -23
  145. package/src/commands/uniteCommands.ts +0 -135
  146. package/src/components/AbstractComponent.transformBy.test.ts +0 -22
  147. package/src/components/AbstractComponent.ts +0 -364
  148. package/src/components/ImageBackground.test.ts +0 -35
  149. package/src/components/ImageBackground.ts +0 -176
  150. package/src/components/ImageComponent.ts +0 -171
  151. package/src/components/RestylableComponent.ts +0 -142
  152. package/src/components/SVGGlobalAttributesObject.ts +0 -81
  153. package/src/components/Stroke.test.ts +0 -139
  154. package/src/components/Stroke.ts +0 -245
  155. package/src/components/TextComponent.test.ts +0 -99
  156. package/src/components/TextComponent.ts +0 -315
  157. package/src/components/UnknownSVGObject.test.ts +0 -10
  158. package/src/components/UnknownSVGObject.ts +0 -60
  159. package/src/components/builders/ArrowBuilder.ts +0 -107
  160. package/src/components/builders/FreehandLineBuilder.ts +0 -212
  161. package/src/components/builders/LineBuilder.ts +0 -77
  162. package/src/components/builders/PressureSensitiveFreehandLineBuilder.ts +0 -454
  163. package/src/components/builders/RectangleBuilder.ts +0 -74
  164. package/src/components/builders/types.ts +0 -15
  165. package/src/components/lib.ts +0 -25
  166. package/src/components/localization.ts +0 -22
  167. package/src/components/util/StrokeSmoother.ts +0 -293
  168. package/src/components/util/describeComponentList.ts +0 -18
  169. package/src/lib.ts +0 -37
  170. package/src/localization.ts +0 -34
  171. package/src/localizations/de.ts +0 -98
  172. package/src/localizations/en.ts +0 -8
  173. package/src/localizations/es.ts +0 -74
  174. package/src/localizations/getLocalizationTable.test.ts +0 -27
  175. package/src/localizations/getLocalizationTable.ts +0 -55
  176. package/src/math/LineSegment2.test.ts +0 -99
  177. package/src/math/LineSegment2.ts +0 -160
  178. package/src/math/Mat33.test.ts +0 -244
  179. package/src/math/Mat33.ts +0 -437
  180. package/src/math/Path.fromString.test.ts +0 -223
  181. package/src/math/Path.test.ts +0 -198
  182. package/src/math/Path.toString.test.ts +0 -77
  183. package/src/math/Path.ts +0 -790
  184. package/src/math/Rect2.test.ts +0 -204
  185. package/src/math/Rect2.ts +0 -315
  186. package/src/math/Triangle.ts +0 -29
  187. package/src/math/Vec2.test.ts +0 -30
  188. package/src/math/Vec2.ts +0 -18
  189. package/src/math/Vec3.test.ts +0 -44
  190. package/src/math/Vec3.ts +0 -218
  191. package/src/math/lib.ts +0 -15
  192. package/src/math/rounding.test.ts +0 -65
  193. package/src/math/rounding.ts +0 -156
  194. package/src/rendering/Display.ts +0 -249
  195. package/src/rendering/RenderingStyle.test.ts +0 -68
  196. package/src/rendering/RenderingStyle.ts +0 -55
  197. package/src/rendering/TextRenderingStyle.ts +0 -45
  198. package/src/rendering/caching/CacheRecord.test.ts +0 -49
  199. package/src/rendering/caching/CacheRecord.ts +0 -77
  200. package/src/rendering/caching/CacheRecordManager.ts +0 -71
  201. package/src/rendering/caching/RenderingCache.test.ts +0 -44
  202. package/src/rendering/caching/RenderingCache.ts +0 -66
  203. package/src/rendering/caching/RenderingCacheNode.ts +0 -405
  204. package/src/rendering/caching/testUtils.ts +0 -35
  205. package/src/rendering/caching/types.ts +0 -34
  206. package/src/rendering/lib.ts +0 -6
  207. package/src/rendering/localization.ts +0 -20
  208. package/src/rendering/renderers/AbstractRenderer.ts +0 -222
  209. package/src/rendering/renderers/CanvasRenderer.ts +0 -296
  210. package/src/rendering/renderers/DummyRenderer.test.ts +0 -42
  211. package/src/rendering/renderers/DummyRenderer.ts +0 -136
  212. package/src/rendering/renderers/SVGRenderer.ts +0 -354
  213. package/src/rendering/renderers/TextOnlyRenderer.ts +0 -70
  214. package/src/testing/beforeEachFile.ts +0 -8
  215. package/src/testing/createEditor.ts +0 -11
  216. package/src/testing/global.d.ts +0 -17
  217. package/src/testing/lib.ts +0 -3
  218. package/src/testing/loadExpectExtensions.ts +0 -25
  219. package/src/testing/sendPenEvent.ts +0 -31
  220. package/src/testing/sendTouchEvent.ts +0 -78
  221. package/src/toolbar/HTMLToolbar.ts +0 -492
  222. package/src/toolbar/IconProvider.ts +0 -736
  223. package/src/toolbar/lib.ts +0 -4
  224. package/src/toolbar/localization.ts +0 -106
  225. package/src/toolbar/makeColorInput.ts +0 -145
  226. package/src/toolbar/types.ts +0 -5
  227. package/src/toolbar/widgets/ActionButtonWidget.ts +0 -39
  228. package/src/toolbar/widgets/BaseToolWidget.ts +0 -56
  229. package/src/toolbar/widgets/BaseWidget.ts +0 -377
  230. package/src/toolbar/widgets/DocumentPropertiesWidget.ts +0 -167
  231. package/src/toolbar/widgets/EraserToolWidget.ts +0 -85
  232. package/src/toolbar/widgets/HandToolWidget.ts +0 -250
  233. package/src/toolbar/widgets/InsertImageWidget.ts +0 -223
  234. package/src/toolbar/widgets/OverflowWidget.ts +0 -92
  235. package/src/toolbar/widgets/PenToolWidget.ts +0 -288
  236. package/src/toolbar/widgets/SelectionToolWidget.ts +0 -190
  237. package/src/toolbar/widgets/TextToolWidget.ts +0 -145
  238. package/src/toolbar/widgets/lib.ts +0 -13
  239. package/src/tools/BaseTool.ts +0 -76
  240. package/src/tools/Eraser.test.ts +0 -103
  241. package/src/tools/Eraser.ts +0 -139
  242. package/src/tools/FindTool.ts +0 -152
  243. package/src/tools/PanZoom.test.ts +0 -310
  244. package/src/tools/PanZoom.ts +0 -520
  245. package/src/tools/PasteHandler.ts +0 -95
  246. package/src/tools/Pen.test.ts +0 -194
  247. package/src/tools/Pen.ts +0 -226
  248. package/src/tools/PipetteTool.ts +0 -55
  249. package/src/tools/SelectionTool/SelectAllShortcutHandler.ts +0 -28
  250. package/src/tools/SelectionTool/Selection.ts +0 -607
  251. package/src/tools/SelectionTool/SelectionHandle.ts +0 -108
  252. package/src/tools/SelectionTool/SelectionTool.test.ts +0 -261
  253. package/src/tools/SelectionTool/SelectionTool.ts +0 -480
  254. package/src/tools/SelectionTool/TransformMode.ts +0 -114
  255. package/src/tools/SelectionTool/types.ts +0 -11
  256. package/src/tools/TextTool.ts +0 -326
  257. package/src/tools/ToolController.ts +0 -178
  258. package/src/tools/ToolEnabledGroup.ts +0 -14
  259. package/src/tools/ToolSwitcherShortcut.ts +0 -39
  260. package/src/tools/ToolbarShortcutHandler.ts +0 -34
  261. package/src/tools/UndoRedoShortcut.test.ts +0 -56
  262. package/src/tools/UndoRedoShortcut.ts +0 -25
  263. package/src/tools/lib.ts +0 -21
  264. package/src/tools/localization.ts +0 -66
  265. package/src/types.ts +0 -234
  266. package/src/util/assertions.ts +0 -55
  267. package/src/util/fileToBase64.ts +0 -18
  268. package/src/util/untilNextAnimationFrame.ts +0 -9
  269. package/src/util/waitForTimeout.ts +0 -9
@@ -1,66 +0,0 @@
1
-
2
- export interface ToolLocalization {
3
- keyboardPanZoom: string;
4
- penTool: (penId: number)=>string;
5
- selectionTool: string;
6
- selectAllTool: string;
7
- eraserTool: string;
8
- touchPanTool: string;
9
- twoFingerPanZoomTool: string;
10
- undoRedoTool: string;
11
- pipetteTool: string;
12
- rightClickDragPanTool: string;
13
-
14
- textTool: string;
15
- enterTextToInsert: string;
16
- changeTool: string;
17
- pasteHandler: string;
18
-
19
- findLabel: string;
20
- toNextMatch: string;
21
- closeFindDialog: string;
22
- findDialogShown: string;
23
- findDialogHidden: string;
24
- focusedFoundText: (currentMatchNumber: number, totalMatches: number)=> string;
25
-
26
- anyDevicePanning: string;
27
-
28
- copied: (count: number, description: string) => string;
29
- pasted: (count: number, description: string) => string;
30
-
31
- toolEnabledAnnouncement: (toolName: string) => string;
32
- toolDisabledAnnouncement: (toolName: string) => string;
33
- }
34
-
35
- export const defaultToolLocalization: ToolLocalization = {
36
- penTool: (penId) => `Pen ${penId}`,
37
- selectionTool: 'Selection',
38
- selectAllTool: 'Select all shortcut',
39
- eraserTool: 'Eraser',
40
- touchPanTool: 'Touch panning',
41
- twoFingerPanZoomTool: 'Panning and zooming',
42
- undoRedoTool: 'Undo/Redo',
43
- rightClickDragPanTool: 'Right-click drag',
44
- pipetteTool: 'Pick color from screen',
45
- keyboardPanZoom: 'Keyboard pan/zoom shortcuts',
46
-
47
- textTool: 'Text',
48
- enterTextToInsert: 'Text to insert',
49
- changeTool: 'Change tool',
50
- pasteHandler: 'Copy paste handler',
51
-
52
- findLabel: 'Find',
53
- toNextMatch: 'Next',
54
- closeFindDialog: 'Close',
55
- findDialogShown: 'Find dialog shown',
56
- findDialogHidden: 'Find dialog hidden',
57
- focusedFoundText: (matchIdx: number, totalMatches: number) => `Viewing match ${matchIdx} of ${totalMatches}`,
58
-
59
- anyDevicePanning: 'Any device panning',
60
-
61
- copied: (count: number, description: string) => `Copied ${count} ${description}`,
62
- pasted: (count: number, description: string) => `Pasted ${count} ${description}`,
63
-
64
- toolEnabledAnnouncement: (toolName) => `${toolName} enabled`,
65
- toolDisabledAnnouncement: (toolName) => `${toolName} disabled`,
66
- };
package/src/types.ts DELETED
@@ -1,234 +0,0 @@
1
- // Types related to the image editor
2
-
3
- import EventDispatcher from './EventDispatcher';
4
- import Mat33 from './math/Mat33';
5
- import { Point2, Vec2 } from './math/Vec2';
6
- import Vec3 from './math/Vec3';
7
- import BaseTool from './tools/BaseTool';
8
- import AbstractComponent from './components/AbstractComponent';
9
- import Rect2 from './math/Rect2';
10
- import Pointer from './Pointer';
11
- import Color4 from './Color4';
12
- import Command from './commands/Command';
13
- import BaseWidget from './toolbar/widgets/BaseWidget';
14
-
15
-
16
- export interface PointerEvtListener {
17
- onPointerDown(event: PointerEvt): boolean;
18
- onPointerMove(event: PointerEvt): void;
19
- onPointerUp(event: PointerEvt): void;
20
-
21
- // Called if a pointer that has been captured by this listener (by returning
22
- // `true` from `onPointerDown`) is re-captured by another listener.
23
- //
24
- // When called, this method should cancel any changes being made by the current
25
- // gesture.
26
- onGestureCancel(): void;
27
- }
28
-
29
-
30
- export enum InputEvtType {
31
- PointerDownEvt,
32
- PointerMoveEvt,
33
- PointerUpEvt,
34
- GestureCancelEvt,
35
-
36
- WheelEvt,
37
- KeyPressEvent,
38
- KeyUpEvent,
39
-
40
- CopyEvent,
41
- PasteEvent,
42
- }
43
-
44
- // [delta.x] is horizontal scroll,
45
- // [delta.y] is vertical scroll,
46
- // [delta.z] is zoom scroll (ctrl+scroll or pinch zoom)
47
- export interface WheelEvt {
48
- readonly kind: InputEvtType.WheelEvt;
49
- readonly delta: Vec3;
50
- readonly screenPos: Point2;
51
- }
52
-
53
- export interface KeyPressEvent {
54
- readonly kind: InputEvtType.KeyPressEvent;
55
-
56
- // key, as given by an HTML `KeyboardEvent`
57
- readonly key: string;
58
-
59
- // If `ctrlKey` is undefined, that is equivalent to `ctrlKey = false`.
60
- readonly ctrlKey: boolean|undefined;
61
-
62
- // If falsey, the `alt` key is not pressed.
63
- readonly altKey: boolean|undefined;
64
- }
65
-
66
- export interface KeyUpEvent {
67
- readonly kind: InputEvtType.KeyUpEvent;
68
- readonly key: string;
69
-
70
- // As in `KeyPressEvent, if `ctrlKey` is undefined, that is equivalent to
71
- // `ctrlKey = false`.
72
- readonly ctrlKey: boolean|undefined;
73
- readonly altKey: boolean|undefined;
74
- }
75
-
76
- export interface CopyEvent {
77
- readonly kind: InputEvtType.CopyEvent;
78
- setData(mime: string, data: string): void;
79
- }
80
-
81
- export interface PasteEvent {
82
- readonly kind: InputEvtType.PasteEvent;
83
- readonly data: string;
84
- readonly mime: string;
85
- }
86
-
87
- // Event triggered when pointer capture is taken by a different [PointerEvtListener].
88
- export interface GestureCancelEvt {
89
- readonly kind: InputEvtType.GestureCancelEvt;
90
- }
91
-
92
- interface PointerEvtBase {
93
- readonly current: Pointer;
94
- readonly allPointers: Pointer[];
95
- }
96
-
97
- export interface PointerDownEvt extends PointerEvtBase {
98
- readonly kind: InputEvtType.PointerDownEvt;
99
- }
100
-
101
- export interface PointerMoveEvt extends PointerEvtBase {
102
- readonly kind: InputEvtType.PointerMoveEvt;
103
- }
104
-
105
- export interface PointerUpEvt extends PointerEvtBase {
106
- readonly kind: InputEvtType.PointerUpEvt;
107
- }
108
-
109
- export type PointerEvt = PointerDownEvt | PointerMoveEvt | PointerUpEvt;
110
- export type InputEvt = KeyPressEvent | KeyUpEvent | WheelEvt | GestureCancelEvt | PointerEvt | CopyEvent | PasteEvent;
111
-
112
- export type EditorNotifier = EventDispatcher<EditorEventType, EditorEventDataType>;
113
-
114
- export enum EditorEventType {
115
- ToolEnabled,
116
- ToolDisabled,
117
- ToolUpdated,
118
-
119
- UndoRedoStackUpdated,
120
- CommandDone,
121
- CommandUndone,
122
- ObjectAdded,
123
-
124
- ViewportChanged,
125
- DisplayResized,
126
-
127
- ColorPickerToggled,
128
- ColorPickerColorSelected,
129
- ToolbarDropdownShown,
130
- }
131
-
132
- // Types of `EditorUndoStackUpdated` events.
133
- export enum UndoEventType {
134
- CommandDone,
135
- CommandUndone,
136
- CommandRedone,
137
- }
138
-
139
- type EditorToolEventType = EditorEventType.ToolEnabled
140
- | EditorEventType.ToolDisabled
141
- | EditorEventType.ToolUpdated;
142
-
143
- export interface EditorToolEvent {
144
- readonly kind: EditorToolEventType;
145
- readonly tool: BaseTool;
146
- }
147
-
148
- export interface EditorObjectEvent {
149
- readonly kind: EditorEventType.ObjectAdded;
150
- readonly object: AbstractComponent;
151
- }
152
-
153
- export interface EditorViewportChangedEvent {
154
- readonly kind: EditorEventType.ViewportChanged;
155
-
156
- // Canvas -> screen transform
157
- readonly newTransform: Mat33;
158
- readonly oldTransform: Mat33;
159
- }
160
-
161
- export interface DisplayResizedEvent {
162
- readonly kind: EditorEventType.DisplayResized;
163
- readonly newSize: Vec2;
164
- }
165
-
166
- export interface EditorUndoStackUpdated {
167
- readonly kind: EditorEventType.UndoRedoStackUpdated;
168
-
169
- readonly undoStackSize: number;
170
- readonly redoStackSize: number;
171
-
172
- readonly command?: Command;
173
- readonly stackUpdateType: UndoEventType;
174
- }
175
-
176
- export interface CommandDoneEvent {
177
- readonly kind: EditorEventType.CommandDone;
178
- readonly command: Command;
179
- }
180
-
181
- export interface CommandUndoneEvent {
182
- readonly kind: EditorEventType.CommandUndone;
183
- readonly command: Command;
184
- }
185
-
186
- export interface ColorPickerToggled {
187
- readonly kind: EditorEventType.ColorPickerToggled;
188
- readonly open: boolean;
189
- }
190
-
191
- export interface ColorPickerColorSelected {
192
- readonly kind: EditorEventType.ColorPickerColorSelected;
193
- readonly color: Color4;
194
- }
195
-
196
- export interface ToolbarDropdownShownEvent {
197
- readonly kind: EditorEventType.ToolbarDropdownShown;
198
- readonly parentWidget: BaseWidget;
199
- }
200
-
201
- export type EditorEventDataType = EditorToolEvent | EditorObjectEvent
202
- | EditorViewportChangedEvent | DisplayResizedEvent
203
- | EditorUndoStackUpdated | CommandDoneEvent | CommandUndoneEvent
204
- | ColorPickerToggled | ColorPickerColorSelected
205
- | ToolbarDropdownShownEvent;
206
-
207
-
208
- // Returns a Promise to indicate that the event source should pause until the Promise resolves.
209
- // Returns null to continue loading without pause.
210
- // [totalToProcess] can be an estimate and may change if a better estimate becomes available.
211
- export type OnProgressListener =
212
- (amountProcessed: number, totalToProcess: number)=> Promise<void>|null|void;
213
-
214
- export type ComponentAddedListener = (component: AbstractComponent)=> Promise<void>|void;
215
-
216
- // Called when a new estimate for the import/export rect has been generated. This can be called multiple times.
217
- // Only the last call to this listener must be accurate.
218
- // The import/export rect is also returned by [start].
219
- export type OnDetermineExportRectListener = (exportRect: Rect2)=> void;
220
-
221
- export interface ImageLoader {
222
- start(
223
- onAddComponent: ComponentAddedListener,
224
- onProgressListener: OnProgressListener,
225
- onDetermineExportRect?: OnDetermineExportRectListener,
226
- ): Promise<void>;
227
- }
228
-
229
- export interface StrokeDataPoint {
230
- pos: Point2;
231
- width: number;
232
- time: number;
233
- color: Color4;
234
- }
@@ -1,55 +0,0 @@
1
-
2
- /**
3
- * Compile-time assertion that a branch of code is unreachable.
4
- * @internal
5
- */
6
- export const assertUnreachable = (key: never): never => {
7
- // See https://stackoverflow.com/a/39419171/17055750
8
- throw new Error(`Should be unreachable. Key: ${key}.`);
9
- };
10
-
11
-
12
- /**
13
- * Throws an exception if the typeof given value is not a number or `value` is NaN.
14
- *
15
- * @example
16
- * ```ts
17
- * const foo: unknown = 3;
18
- * assertIsNumber(foo);
19
- *
20
- * assertIsNumber('hello, world'); // throws an Error.
21
- * ```
22
- *
23
- *
24
- */
25
- export const assertIsNumber = (value: any, allowNaN: boolean = false): value is number => {
26
- if (typeof value !== 'number' || (!allowNaN && isNaN(value))) {
27
- throw new Error('Given value is not a number');
28
- // return false;
29
- }
30
-
31
- return true;
32
- };
33
-
34
- /**
35
- * Throws if any of `values` is not of type number.
36
- */
37
- export const assertIsNumberArray = (
38
- values: any[], allowNaN: boolean = false
39
- ): values is number[] => {
40
- if (typeof values !== 'object') {
41
- throw new Error('Asserting isNumberArray: Given entity is not an array');
42
- }
43
-
44
- if (!assertIsNumber(values['length'])) {
45
- return false;
46
- }
47
-
48
- for (const value of values) {
49
- if (!assertIsNumber(value, allowNaN)) {
50
- return false;
51
- }
52
- }
53
-
54
- return true;
55
- };
@@ -1,18 +0,0 @@
1
-
2
- type ProgressListener = (evt: ProgressEvent<FileReader>)=> void;
3
- const fileToBase64 = (file: File, onprogress?: ProgressListener): Promise<string|null> => {
4
- const reader = new FileReader();
5
-
6
- return new Promise((resolve: (result: string|null)=>void, reject) => {
7
- reader.onload = () => resolve(reader.result as string|null);
8
- reader.onerror = reject;
9
- reader.onabort = reject;
10
- reader.onprogress = (evt) => {
11
- onprogress?.(evt);
12
- };
13
-
14
- reader.readAsDataURL(file);
15
- });
16
- };
17
-
18
- export default fileToBase64;
@@ -1,9 +0,0 @@
1
-
2
- /** @internal */
3
- const untilNextAnimationFrame = (): Promise<void> => {
4
- return new Promise((resolve) => {
5
- requestAnimationFrame(() => resolve());
6
- });
7
- };
8
-
9
- export default untilNextAnimationFrame;
@@ -1,9 +0,0 @@
1
-
2
- // Returns a promise that resolves after `timeout` milliseconds.
3
- const waitForTimeout = (timeout: number): Promise<void> => {
4
- return new Promise(resolve => {
5
- setTimeout(() => resolve(), timeout);
6
- });
7
- };
8
-
9
- export default waitForTimeout;