@tldraw/editor 3.14.0-canary.d8a1c8c23469 → 3.14.0-canary.db789786fb06

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 (242) hide show
  1. package/dist-cjs/index.d.ts +220 -117
  2. package/dist-cjs/index.js +11 -8
  3. package/dist-cjs/index.js.map +2 -2
  4. package/dist-cjs/lib/config/TLSessionStateSnapshot.js +1 -12
  5. package/dist-cjs/lib/config/TLSessionStateSnapshot.js.map +3 -3
  6. package/dist-cjs/lib/editor/Editor.js +132 -101
  7. package/dist-cjs/lib/editor/Editor.js.map +2 -2
  8. package/dist-cjs/lib/editor/bindings/BindingUtil.js.map +2 -2
  9. package/dist-cjs/lib/editor/derivations/bindingsIndex.js +22 -22
  10. package/dist-cjs/lib/editor/derivations/bindingsIndex.js.map +2 -2
  11. package/dist-cjs/lib/editor/derivations/notVisibleShapes.js +16 -20
  12. package/dist-cjs/lib/editor/derivations/notVisibleShapes.js.map +3 -3
  13. package/dist-cjs/lib/editor/derivations/parentsToChildren.js +16 -16
  14. package/dist-cjs/lib/editor/derivations/parentsToChildren.js.map +2 -2
  15. package/dist-cjs/lib/editor/managers/{ClickManager.js → ClickManager/ClickManager.js} +1 -1
  16. package/dist-cjs/lib/editor/managers/ClickManager/ClickManager.js.map +7 -0
  17. package/dist-cjs/lib/editor/managers/{EdgeScrollManager.js → EdgeScrollManager/EdgeScrollManager.js} +2 -2
  18. package/dist-cjs/lib/editor/managers/EdgeScrollManager/EdgeScrollManager.js.map +7 -0
  19. package/dist-cjs/lib/editor/managers/FocusManager/FocusManager.js.map +7 -0
  20. package/dist-cjs/lib/editor/managers/{FontManager.js → FontManager/FontManager.js} +4 -1
  21. package/dist-cjs/lib/editor/managers/FontManager/FontManager.js.map +7 -0
  22. package/dist-cjs/lib/editor/managers/{HistoryManager.js → HistoryManager/HistoryManager.js} +67 -7
  23. package/dist-cjs/lib/editor/managers/HistoryManager/HistoryManager.js.map +7 -0
  24. package/dist-cjs/lib/editor/managers/{ScribbleManager.js → ScribbleManager/ScribbleManager.js} +1 -1
  25. package/dist-cjs/lib/editor/managers/ScribbleManager/ScribbleManager.js.map +7 -0
  26. package/dist-cjs/lib/editor/managers/{TextManager.js → TextManager/TextManager.js} +73 -42
  27. package/dist-cjs/lib/editor/managers/TextManager/TextManager.js.map +7 -0
  28. package/dist-cjs/lib/editor/managers/{TickManager.js → TickManager/TickManager.js} +1 -1
  29. package/dist-cjs/lib/editor/managers/TickManager/TickManager.js.map +7 -0
  30. package/dist-cjs/lib/editor/managers/{UserPreferencesManager.js → UserPreferencesManager/UserPreferencesManager.js} +1 -1
  31. package/dist-cjs/lib/editor/managers/UserPreferencesManager/UserPreferencesManager.js.map +7 -0
  32. package/dist-cjs/lib/editor/shapes/ShapeUtil.js +8 -10
  33. package/dist-cjs/lib/editor/shapes/ShapeUtil.js.map +2 -2
  34. package/dist-cjs/lib/editor/shapes/group/GroupShapeUtil.js +6 -0
  35. package/dist-cjs/lib/editor/shapes/group/GroupShapeUtil.js.map +2 -2
  36. package/dist-cjs/lib/editor/tools/BaseBoxShapeTool/children/Pointing.js +10 -6
  37. package/dist-cjs/lib/editor/tools/BaseBoxShapeTool/children/Pointing.js.map +3 -3
  38. package/dist-cjs/lib/editor/tools/StateNode.js +3 -3
  39. package/dist-cjs/lib/editor/tools/StateNode.js.map +2 -2
  40. package/dist-cjs/lib/editor/types/emit-types.js.map +1 -1
  41. package/dist-cjs/lib/editor/types/external-content.js.map +1 -1
  42. package/dist-cjs/lib/exports/getSvgJsx.js.map +1 -1
  43. package/dist-cjs/lib/hooks/useCanvasEvents.js +1 -2
  44. package/dist-cjs/lib/hooks/useCanvasEvents.js.map +2 -2
  45. package/dist-cjs/lib/primitives/Box.js +33 -33
  46. package/dist-cjs/lib/primitives/Box.js.map +2 -2
  47. package/dist-cjs/lib/primitives/Vec.js +13 -8
  48. package/dist-cjs/lib/primitives/Vec.js.map +2 -2
  49. package/dist-cjs/lib/primitives/geometry/Arc2d.js +41 -21
  50. package/dist-cjs/lib/primitives/geometry/Arc2d.js.map +2 -2
  51. package/dist-cjs/lib/primitives/geometry/Circle2d.js +11 -11
  52. package/dist-cjs/lib/primitives/geometry/Circle2d.js.map +2 -2
  53. package/dist-cjs/lib/primitives/geometry/CubicBezier2d.js +13 -16
  54. package/dist-cjs/lib/primitives/geometry/CubicBezier2d.js.map +2 -2
  55. package/dist-cjs/lib/primitives/geometry/CubicSpline2d.js +4 -4
  56. package/dist-cjs/lib/primitives/geometry/CubicSpline2d.js.map +2 -2
  57. package/dist-cjs/lib/primitives/geometry/Edge2d.js +14 -17
  58. package/dist-cjs/lib/primitives/geometry/Edge2d.js.map +2 -2
  59. package/dist-cjs/lib/primitives/geometry/Ellipse2d.js +10 -10
  60. package/dist-cjs/lib/primitives/geometry/Ellipse2d.js.map +2 -2
  61. package/dist-cjs/lib/primitives/geometry/Geometry2d.js +6 -2
  62. package/dist-cjs/lib/primitives/geometry/Geometry2d.js.map +2 -2
  63. package/dist-cjs/lib/primitives/geometry/Point2d.js +6 -6
  64. package/dist-cjs/lib/primitives/geometry/Point2d.js.map +2 -2
  65. package/dist-cjs/lib/primitives/geometry/Polygon2d.js +3 -0
  66. package/dist-cjs/lib/primitives/geometry/Polygon2d.js.map +2 -2
  67. package/dist-cjs/lib/primitives/geometry/Polyline2d.js +8 -5
  68. package/dist-cjs/lib/primitives/geometry/Polyline2d.js.map +2 -2
  69. package/dist-cjs/lib/primitives/geometry/Rectangle2d.js +22 -11
  70. package/dist-cjs/lib/primitives/geometry/Rectangle2d.js.map +2 -2
  71. package/dist-cjs/lib/primitives/geometry/Stadium2d.js +22 -22
  72. package/dist-cjs/lib/primitives/geometry/Stadium2d.js.map +2 -2
  73. package/dist-cjs/lib/utils/reorderShapes.js +11 -10
  74. package/dist-cjs/lib/utils/reorderShapes.js.map +2 -2
  75. package/dist-cjs/lib/utils/reparenting.js +232 -0
  76. package/dist-cjs/lib/utils/reparenting.js.map +7 -0
  77. package/dist-cjs/lib/utils/richText.js +7 -2
  78. package/dist-cjs/lib/utils/richText.js.map +2 -2
  79. package/dist-cjs/version.js +3 -3
  80. package/dist-cjs/version.js.map +1 -1
  81. package/dist-esm/index.d.mts +220 -117
  82. package/dist-esm/index.mjs +15 -8
  83. package/dist-esm/index.mjs.map +2 -2
  84. package/dist-esm/lib/config/TLSessionStateSnapshot.mjs +1 -1
  85. package/dist-esm/lib/config/TLSessionStateSnapshot.mjs.map +2 -2
  86. package/dist-esm/lib/editor/Editor.mjs +132 -101
  87. package/dist-esm/lib/editor/Editor.mjs.map +2 -2
  88. package/dist-esm/lib/editor/bindings/BindingUtil.mjs.map +2 -2
  89. package/dist-esm/lib/editor/derivations/bindingsIndex.mjs +22 -22
  90. package/dist-esm/lib/editor/derivations/bindingsIndex.mjs.map +2 -2
  91. package/dist-esm/lib/editor/derivations/notVisibleShapes.mjs +16 -20
  92. package/dist-esm/lib/editor/derivations/notVisibleShapes.mjs.map +3 -3
  93. package/dist-esm/lib/editor/derivations/parentsToChildren.mjs +16 -16
  94. package/dist-esm/lib/editor/derivations/parentsToChildren.mjs.map +2 -2
  95. package/dist-esm/lib/editor/managers/{ClickManager.mjs → ClickManager/ClickManager.mjs} +1 -1
  96. package/dist-esm/lib/editor/managers/ClickManager/ClickManager.mjs.map +7 -0
  97. package/dist-esm/lib/editor/managers/{EdgeScrollManager.mjs → EdgeScrollManager/EdgeScrollManager.mjs} +2 -2
  98. package/dist-esm/lib/editor/managers/EdgeScrollManager/EdgeScrollManager.mjs.map +7 -0
  99. package/dist-esm/lib/editor/managers/FocusManager/FocusManager.mjs.map +7 -0
  100. package/dist-esm/lib/editor/managers/{FontManager.mjs → FontManager/FontManager.mjs} +4 -1
  101. package/dist-esm/lib/editor/managers/FontManager/FontManager.mjs.map +7 -0
  102. package/dist-esm/lib/editor/managers/{HistoryManager.mjs → HistoryManager/HistoryManager.mjs} +63 -3
  103. package/dist-esm/lib/editor/managers/HistoryManager/HistoryManager.mjs.map +7 -0
  104. package/dist-esm/lib/editor/managers/{ScribbleManager.mjs → ScribbleManager/ScribbleManager.mjs} +1 -1
  105. package/dist-esm/lib/editor/managers/ScribbleManager/ScribbleManager.mjs.map +7 -0
  106. package/dist-esm/lib/editor/managers/{TextManager.mjs → TextManager/TextManager.mjs} +73 -42
  107. package/dist-esm/lib/editor/managers/TextManager/TextManager.mjs.map +7 -0
  108. package/dist-esm/lib/editor/managers/{TickManager.mjs → TickManager/TickManager.mjs} +1 -1
  109. package/dist-esm/lib/editor/managers/TickManager/TickManager.mjs.map +7 -0
  110. package/dist-esm/lib/editor/managers/{UserPreferencesManager.mjs → UserPreferencesManager/UserPreferencesManager.mjs} +1 -1
  111. package/dist-esm/lib/editor/managers/UserPreferencesManager/UserPreferencesManager.mjs.map +7 -0
  112. package/dist-esm/lib/editor/shapes/ShapeUtil.mjs +8 -10
  113. package/dist-esm/lib/editor/shapes/ShapeUtil.mjs.map +2 -2
  114. package/dist-esm/lib/editor/shapes/group/GroupShapeUtil.mjs +6 -0
  115. package/dist-esm/lib/editor/shapes/group/GroupShapeUtil.mjs.map +2 -2
  116. package/dist-esm/lib/editor/tools/BaseBoxShapeTool/children/Pointing.mjs +10 -6
  117. package/dist-esm/lib/editor/tools/BaseBoxShapeTool/children/Pointing.mjs.map +3 -3
  118. package/dist-esm/lib/editor/tools/StateNode.mjs +3 -3
  119. package/dist-esm/lib/editor/tools/StateNode.mjs.map +2 -2
  120. package/dist-esm/lib/exports/getSvgJsx.mjs.map +1 -1
  121. package/dist-esm/lib/hooks/useCanvasEvents.mjs +1 -2
  122. package/dist-esm/lib/hooks/useCanvasEvents.mjs.map +2 -2
  123. package/dist-esm/lib/primitives/Box.mjs +33 -33
  124. package/dist-esm/lib/primitives/Box.mjs.map +2 -2
  125. package/dist-esm/lib/primitives/Vec.mjs +13 -8
  126. package/dist-esm/lib/primitives/Vec.mjs.map +2 -2
  127. package/dist-esm/lib/primitives/geometry/Arc2d.mjs +41 -21
  128. package/dist-esm/lib/primitives/geometry/Arc2d.mjs.map +2 -2
  129. package/dist-esm/lib/primitives/geometry/Circle2d.mjs +11 -11
  130. package/dist-esm/lib/primitives/geometry/Circle2d.mjs.map +2 -2
  131. package/dist-esm/lib/primitives/geometry/CubicBezier2d.mjs +13 -16
  132. package/dist-esm/lib/primitives/geometry/CubicBezier2d.mjs.map +2 -2
  133. package/dist-esm/lib/primitives/geometry/CubicSpline2d.mjs +4 -4
  134. package/dist-esm/lib/primitives/geometry/CubicSpline2d.mjs.map +2 -2
  135. package/dist-esm/lib/primitives/geometry/Edge2d.mjs +14 -17
  136. package/dist-esm/lib/primitives/geometry/Edge2d.mjs.map +2 -2
  137. package/dist-esm/lib/primitives/geometry/Ellipse2d.mjs +11 -11
  138. package/dist-esm/lib/primitives/geometry/Ellipse2d.mjs.map +2 -2
  139. package/dist-esm/lib/primitives/geometry/Geometry2d.mjs +6 -2
  140. package/dist-esm/lib/primitives/geometry/Geometry2d.mjs.map +2 -2
  141. package/dist-esm/lib/primitives/geometry/Point2d.mjs +6 -6
  142. package/dist-esm/lib/primitives/geometry/Point2d.mjs.map +2 -2
  143. package/dist-esm/lib/primitives/geometry/Polygon2d.mjs +3 -0
  144. package/dist-esm/lib/primitives/geometry/Polygon2d.mjs.map +2 -2
  145. package/dist-esm/lib/primitives/geometry/Polyline2d.mjs +8 -5
  146. package/dist-esm/lib/primitives/geometry/Polyline2d.mjs.map +2 -2
  147. package/dist-esm/lib/primitives/geometry/Rectangle2d.mjs +22 -11
  148. package/dist-esm/lib/primitives/geometry/Rectangle2d.mjs.map +2 -2
  149. package/dist-esm/lib/primitives/geometry/Stadium2d.mjs +22 -22
  150. package/dist-esm/lib/primitives/geometry/Stadium2d.mjs.map +2 -2
  151. package/dist-esm/lib/utils/reorderShapes.mjs +11 -10
  152. package/dist-esm/lib/utils/reorderShapes.mjs.map +2 -2
  153. package/dist-esm/lib/utils/reparenting.mjs +216 -0
  154. package/dist-esm/lib/utils/reparenting.mjs.map +7 -0
  155. package/dist-esm/lib/utils/richText.mjs +8 -3
  156. package/dist-esm/lib/utils/richText.mjs.map +2 -2
  157. package/dist-esm/version.mjs +3 -3
  158. package/dist-esm/version.mjs.map +1 -1
  159. package/editor.css +442 -492
  160. package/package.json +8 -9
  161. package/src/index.ts +20 -7
  162. package/src/lib/config/TLSessionStateSnapshot.ts +1 -1
  163. package/src/lib/editor/Editor.test.ts +252 -3
  164. package/src/lib/editor/Editor.ts +150 -109
  165. package/src/lib/editor/bindings/BindingUtil.ts +6 -0
  166. package/src/lib/editor/derivations/bindingsIndex.ts +27 -26
  167. package/src/lib/editor/derivations/notVisibleShapes.ts +24 -25
  168. package/src/lib/editor/derivations/parentsToChildren.ts +28 -25
  169. package/src/lib/editor/managers/ClickManager/ClickManager.test.ts +442 -0
  170. package/src/lib/editor/managers/{ClickManager.ts → ClickManager/ClickManager.ts} +3 -3
  171. package/src/lib/editor/managers/EdgeScrollManager/EdgeScrollManager.test.ts +374 -0
  172. package/src/lib/editor/managers/{EdgeScrollManager.ts → EdgeScrollManager/EdgeScrollManager.ts} +3 -3
  173. package/src/lib/editor/managers/FocusManager/FocusManager.test.ts +455 -0
  174. package/src/lib/editor/managers/{FocusManager.ts → FocusManager/FocusManager.ts} +1 -1
  175. package/src/lib/editor/managers/FontManager/FontManager.test.ts +263 -0
  176. package/src/lib/editor/managers/{FontManager.ts → FontManager/FontManager.ts} +5 -2
  177. package/src/lib/editor/managers/{HistoryManager.test.ts → HistoryManager/HistoryManager.test.ts} +388 -1
  178. package/src/lib/editor/managers/{HistoryManager.ts → HistoryManager/HistoryManager.ts} +76 -3
  179. package/src/lib/editor/managers/ScribbleManager/ScribbleManager.test.ts +624 -0
  180. package/src/lib/editor/managers/{ScribbleManager.ts → ScribbleManager/ScribbleManager.ts} +2 -2
  181. package/src/lib/editor/managers/SnapManager/SnapManager.test.ts +485 -0
  182. package/src/lib/editor/managers/TextManager/TextManager.test.ts +407 -0
  183. package/src/lib/editor/managers/{TextManager.ts → TextManager/TextManager.ts} +119 -87
  184. package/src/lib/editor/managers/TickManager/TickManager.test.ts +314 -0
  185. package/src/lib/editor/managers/{TickManager.ts → TickManager/TickManager.ts} +2 -2
  186. package/src/lib/editor/managers/UserPreferencesManager/UserPreferencesManager.test.ts +591 -0
  187. package/src/lib/editor/managers/{UserPreferencesManager.ts → UserPreferencesManager/UserPreferencesManager.ts} +2 -2
  188. package/src/lib/editor/shapes/ShapeUtil.ts +57 -16
  189. package/src/lib/editor/shapes/group/GroupShapeUtil.tsx +8 -0
  190. package/src/lib/editor/tools/BaseBoxShapeTool/children/Pointing.ts +22 -17
  191. package/src/lib/editor/tools/StateNode.ts +3 -3
  192. package/src/lib/editor/types/emit-types.ts +4 -0
  193. package/src/lib/editor/types/external-content.ts +11 -2
  194. package/src/lib/exports/getSvgJsx.tsx +1 -1
  195. package/src/lib/hooks/useCanvasEvents.ts +0 -1
  196. package/src/lib/primitives/Box.test.ts +588 -7
  197. package/src/lib/primitives/Box.ts +33 -33
  198. package/src/lib/primitives/Vec.test.ts +2 -2
  199. package/src/lib/primitives/Vec.ts +13 -8
  200. package/src/lib/primitives/geometry/Arc2d.ts +42 -23
  201. package/src/lib/primitives/geometry/Circle2d.ts +12 -12
  202. package/src/lib/primitives/geometry/CubicBezier2d.test.ts +5 -0
  203. package/src/lib/primitives/geometry/CubicBezier2d.ts +13 -17
  204. package/src/lib/primitives/geometry/CubicSpline2d.ts +5 -5
  205. package/src/lib/primitives/geometry/Edge2d.ts +14 -18
  206. package/src/lib/primitives/geometry/Ellipse2d.ts +12 -13
  207. package/src/lib/primitives/geometry/Geometry2d.ts +7 -2
  208. package/src/lib/primitives/geometry/Point2d.ts +6 -6
  209. package/src/lib/primitives/geometry/Polygon2d.ts +4 -0
  210. package/src/lib/primitives/geometry/Polyline2d.ts +10 -7
  211. package/src/lib/primitives/geometry/Rectangle2d.ts +24 -11
  212. package/src/lib/primitives/geometry/Stadium2d.ts +22 -23
  213. package/src/lib/utils/reorderShapes.ts +10 -13
  214. package/src/lib/utils/reparenting.ts +383 -0
  215. package/src/lib/utils/richText.ts +10 -4
  216. package/src/version.ts +3 -3
  217. package/dist-cjs/lib/editor/managers/ClickManager.js.map +0 -7
  218. package/dist-cjs/lib/editor/managers/EdgeScrollManager.js.map +0 -7
  219. package/dist-cjs/lib/editor/managers/FocusManager.js.map +0 -7
  220. package/dist-cjs/lib/editor/managers/FontManager.js.map +0 -7
  221. package/dist-cjs/lib/editor/managers/HistoryManager.js.map +0 -7
  222. package/dist-cjs/lib/editor/managers/ScribbleManager.js.map +0 -7
  223. package/dist-cjs/lib/editor/managers/Stack.js +0 -82
  224. package/dist-cjs/lib/editor/managers/Stack.js.map +0 -7
  225. package/dist-cjs/lib/editor/managers/TextManager.js.map +0 -7
  226. package/dist-cjs/lib/editor/managers/TickManager.js.map +0 -7
  227. package/dist-cjs/lib/editor/managers/UserPreferencesManager.js.map +0 -7
  228. package/dist-esm/lib/editor/managers/ClickManager.mjs.map +0 -7
  229. package/dist-esm/lib/editor/managers/EdgeScrollManager.mjs.map +0 -7
  230. package/dist-esm/lib/editor/managers/FocusManager.mjs.map +0 -7
  231. package/dist-esm/lib/editor/managers/FontManager.mjs.map +0 -7
  232. package/dist-esm/lib/editor/managers/HistoryManager.mjs.map +0 -7
  233. package/dist-esm/lib/editor/managers/ScribbleManager.mjs.map +0 -7
  234. package/dist-esm/lib/editor/managers/Stack.mjs +0 -62
  235. package/dist-esm/lib/editor/managers/Stack.mjs.map +0 -7
  236. package/dist-esm/lib/editor/managers/TextManager.mjs.map +0 -7
  237. package/dist-esm/lib/editor/managers/TickManager.mjs.map +0 -7
  238. package/dist-esm/lib/editor/managers/UserPreferencesManager.mjs.map +0 -7
  239. package/src/lib/editor/managers/ScribbleManager.test.ts +0 -32
  240. package/src/lib/editor/managers/Stack.ts +0 -71
  241. /package/dist-cjs/lib/editor/managers/{FocusManager.js → FocusManager/FocusManager.js} +0 -0
  242. /package/dist-esm/lib/editor/managers/{FocusManager.mjs → FocusManager/FocusManager.mjs} +0 -0
@@ -4,18 +4,21 @@ import { LegacyMigrations, MigrationSequence } from '@tldraw/store'
4
4
  import {
5
5
  RecordProps,
6
6
  TLHandle,
7
+ TLParentId,
7
8
  TLPropsMigrations,
8
9
  TLShape,
9
10
  TLShapeCrop,
11
+ TLShapeId,
10
12
  TLShapePartial,
11
13
  TLUnknownShape,
12
14
  } from '@tldraw/tlschema'
15
+ import { IndexKey } from '@tldraw/utils'
13
16
  import { ReactElement } from 'react'
14
17
  import { Box, SelectionHandle } from '../../primitives/Box'
15
18
  import { Vec } from '../../primitives/Vec'
16
19
  import { Geometry2d } from '../../primitives/geometry/Geometry2d'
17
20
  import type { Editor } from '../Editor'
18
- import { TLFontFace } from '../managers/FontManager'
21
+ import { TLFontFace } from '../managers/FontManager/FontManager'
19
22
  import { BoundsSnapGeometry } from '../managers/SnapManager/BoundsSnaps'
20
23
  import { HandleSnapGeometry } from '../managers/SnapManager/HandleSnaps'
21
24
  import { SvgExportContext } from '../types/SvgExportContext'
@@ -240,6 +243,15 @@ export abstract class ShapeUtil<Shape extends TLUnknownShape = TLUnknownShape> {
240
243
  return true
241
244
  }
242
245
 
246
+ /**
247
+ * When the shape is resized, whether the shape's children should also be resized.
248
+ *
249
+ * @public
250
+ */
251
+ canResizeChildren(_shape: Shape): boolean {
252
+ return true
253
+ }
254
+
243
255
  /**
244
256
  * Whether the shape can be edited in read-only mode.
245
257
  *
@@ -378,17 +390,6 @@ export abstract class ShapeUtil<Shape extends TLUnknownShape = TLUnknownShape> {
378
390
  return false
379
391
  }
380
392
 
381
- /**
382
- * Get whether the shape can receive children of a given type.
383
- *
384
- * @param shape - The shape type.
385
- * @param shapes - The shapes that are being dropped.
386
- * @public
387
- */
388
- canDropShapes(_shape: Shape, _shapes: TLShape[]) {
389
- return false
390
- }
391
-
392
393
  /**
393
394
  * Get the shape as an SVG object.
394
395
  *
@@ -508,7 +509,16 @@ export abstract class ShapeUtil<Shape extends TLUnknownShape = TLUnknownShape> {
508
509
  ): Omit<TLShapePartial<Shape>, 'id' | 'type'> | undefined | void
509
510
 
510
511
  /**
511
- * A callback called when some other shapes are dragged over this one.
512
+ * A callback called when some other shapes are dragged into this one. This fires when the shapes are dragged over the shape for the first time.
513
+ *
514
+ * @param shape - The shape.
515
+ * @param shapes - The shapes that are being dragged in.
516
+ * @public
517
+ */
518
+ onDragShapesIn?(shape: Shape, shapes: TLShape[], info: TLDragShapesInInfo): void
519
+
520
+ /**
521
+ * A callback called when some other shapes are dragged over this one. This fires when the shapes are dragged over the shape for the first time (after the onDragShapesIn callback), and again on every update while the shapes are being dragged.
512
522
  *
513
523
  * @example
514
524
  *
@@ -522,7 +532,7 @@ export abstract class ShapeUtil<Shape extends TLUnknownShape = TLUnknownShape> {
522
532
  * @param shapes - The shapes that are being dragged over this one.
523
533
  * @public
524
534
  */
525
- onDragShapesOver?(shape: Shape, shapes: TLShape[]): void
535
+ onDragShapesOver?(shape: Shape, shapes: TLShape[], info: TLDragShapesOverInfo): void
526
536
 
527
537
  /**
528
538
  * A callback called when some other shapes are dragged out of this one.
@@ -531,7 +541,7 @@ export abstract class ShapeUtil<Shape extends TLUnknownShape = TLUnknownShape> {
531
541
  * @param shapes - The shapes that are being dragged out.
532
542
  * @public
533
543
  */
534
- onDragShapesOut?(shape: Shape, shapes: TLShape[]): void
544
+ onDragShapesOut?(shape: Shape, shapes: TLShape[], info: TLDragShapesOutInfo): void
535
545
 
536
546
  /**
537
547
  * A callback called when some other shapes are dropped over this one.
@@ -540,7 +550,7 @@ export abstract class ShapeUtil<Shape extends TLUnknownShape = TLUnknownShape> {
540
550
  * @param shapes - The shapes that are being dropped over this one.
541
551
  * @public
542
552
  */
543
- onDropShapesOver?(shape: Shape, shapes: TLShape[]): void
553
+ onDropShapesOver?(shape: Shape, shapes: TLShape[], info: TLDropShapesOverInfo): void
544
554
 
545
555
  /**
546
556
  * A callback called when a shape starts being resized.
@@ -736,6 +746,37 @@ export interface TLCropInfo<T extends TLShape> {
736
746
  crop: TLShapeCrop
737
747
  uncroppedSize: { w: number; h: number }
738
748
  initialShape: T
749
+ aspectRatioLocked?: boolean
750
+ }
751
+
752
+ /** @public */
753
+ export interface TLDragShapesInInfo {
754
+ initialDraggingOverShapeId: TLShapeId | null
755
+ prevDraggingOverShapeId: TLShapeId | null
756
+ initialParentIds: Map<TLShapeId, TLParentId>
757
+ initialIndices: Map<TLShapeId, IndexKey>
758
+ }
759
+
760
+ /** @public */
761
+ export interface TLDragShapesOverInfo {
762
+ initialDraggingOverShapeId: TLShapeId | null
763
+ initialParentIds: Map<TLShapeId, TLParentId>
764
+ initialIndices: Map<TLShapeId, IndexKey>
765
+ }
766
+
767
+ /** @public */
768
+ export interface TLDragShapesOutInfo {
769
+ nextDraggingOverShapeId: TLShapeId | null
770
+ initialDraggingOverShapeId: TLShapeId | null
771
+ initialParentIds: Map<TLShapeId, TLParentId>
772
+ initialIndices: Map<TLShapeId, IndexKey>
773
+ }
774
+
775
+ /** @public */
776
+ export interface TLDropShapesOverInfo {
777
+ initialDraggingOverShapeId: TLShapeId | null
778
+ initialParentIds: Map<TLShapeId, TLParentId>
779
+ initialIndices: Map<TLShapeId, IndexKey>
739
780
  }
740
781
 
741
782
  /**
@@ -20,6 +20,14 @@ export class GroupShapeUtil extends ShapeUtil<TLGroupShape> {
20
20
  return false
21
21
  }
22
22
 
23
+ canResize() {
24
+ return true
25
+ }
26
+
27
+ canResizeChildren() {
28
+ return true
29
+ }
30
+
23
31
  getDefaultProps(): TLGroupShape['props'] {
24
32
  return {}
25
33
  }
@@ -11,29 +11,33 @@ export class Pointing extends StateNode {
11
11
  static override id = 'pointing'
12
12
 
13
13
  override onPointerMove(info: TLPointerEventInfo) {
14
- if (this.editor.inputs.isDragging) {
15
- const { originPagePoint } = this.editor.inputs
14
+ const { editor } = this
15
+ if (editor.inputs.isDragging) {
16
+ const { originPagePoint } = editor.inputs
16
17
 
17
18
  const shapeType = (this.parent as BaseBoxShapeTool)!.shapeType
18
19
 
19
20
  const id = createShapeId()
20
21
 
21
- const creatingMarkId = this.editor.markHistoryStoppingPoint(`creating_box:${id}`)
22
- const newPoint = maybeSnapToGrid(originPagePoint, this.editor)
23
- this.editor
24
- .createShapes<TLBaseBoxShape>([
25
- {
26
- id,
27
- type: shapeType,
28
- x: newPoint.x,
29
- y: newPoint.y,
30
- props: {
31
- w: 1,
32
- h: 1,
33
- },
22
+ const creatingMarkId = editor.markHistoryStoppingPoint(`creating_box:${id}`)
23
+ const newPoint = maybeSnapToGrid(originPagePoint, editor)
24
+
25
+ // Allow this to trigger the max shapes reached alert
26
+ this.editor.createShapes<TLBaseBoxShape>([
27
+ {
28
+ id,
29
+ type: shapeType,
30
+ x: newPoint.x,
31
+ y: newPoint.y,
32
+ props: {
33
+ w: 1,
34
+ h: 1,
34
35
  },
35
- ])
36
- .select(id)
36
+ },
37
+ ])
38
+ const shape = editor.getShape(id)
39
+ if (!shape) this.cancel()
40
+ editor.select(id)
37
41
 
38
42
  const parent = this.parent as BaseBoxShapeTool
39
43
  this.editor.setCurrentTool(
@@ -79,6 +83,7 @@ export class Pointing extends StateNode {
79
83
 
80
84
  this.editor.markHistoryStoppingPoint(`creating_box:${id}`)
81
85
 
86
+ // Allow this to trigger the max shapes reached alert
82
87
  // todo: add scale here when dynamic size is enabled (is this still needed?)
83
88
  this.editor.createShapes<TLBaseBoxShape>([
84
89
  {
@@ -206,15 +206,15 @@ export abstract class StateNode implements Partial<TLEventHandlers> {
206
206
  }
207
207
 
208
208
  // todo: move this logic into transition
209
- exit(info: any, from: string) {
209
+ exit(info: any, to: string) {
210
210
  if (debugFlags.measurePerformance.get() && this.performanceTracker.isStarted()) {
211
211
  this.performanceTracker.stop()
212
212
  }
213
213
  this._isActive.set(false)
214
- this.onExit?.(info, from)
214
+ this.onExit?.(info, to)
215
215
 
216
216
  if (!this.getIsActive()) {
217
- this.getCurrent()?.exit(info, from)
217
+ this.getCurrent()?.exit(info, to)
218
218
  }
219
219
  }
220
220
 
@@ -18,6 +18,10 @@ export interface TLEventMap {
18
18
  frame: [number]
19
19
  'select-all-text': [{ shapeId: TLShapeId }]
20
20
  'place-caret': [{ shapeId: TLShapeId; point: { x: number; y: number } }]
21
+ 'created-shapes': [TLRecord[]]
22
+ 'edited-shapes': [TLRecord[]]
23
+ 'deleted-shapes': [TLShapeId[]]
24
+ edit: []
21
25
  }
22
26
 
23
27
  /** @public */
@@ -1,4 +1,4 @@
1
- import { TLAssetId } from '@tldraw/tlschema'
1
+ import { TLAssetId, TLShapeId } from '@tldraw/tlschema'
2
2
  import { VecLike } from '../../primitives/Vec'
3
3
  import { TLContent } from './clipboard-types'
4
4
 
@@ -52,7 +52,15 @@ export interface TLTextExternalContent extends TLBaseExternalContent {
52
52
  export interface TLFilesExternalContent extends TLBaseExternalContent {
53
53
  type: 'files'
54
54
  files: File[]
55
- ignoreParent: boolean
55
+ ignoreParent?: boolean
56
+ }
57
+
58
+ /** @public */
59
+ export interface TLFileReplaceExternalContent extends TLBaseExternalContent {
60
+ type: 'file-replace'
61
+ file: File
62
+ shapeId: TLShapeId
63
+ isImage: boolean
56
64
  }
57
65
 
58
66
  /** @public */
@@ -90,6 +98,7 @@ export interface TLExcalidrawExternalContent extends TLBaseExternalContent {
90
98
  export type TLExternalContent<EmbedDefinition> =
91
99
  | TLTextExternalContent
92
100
  | TLFilesExternalContent
101
+ | TLFileReplaceExternalContent
93
102
  | TLUrlExternalContent
94
103
  | TLSvgTextExternalContent
95
104
  | TLEmbedExternalContent<EmbedDefinition>
@@ -21,7 +21,7 @@ import { flushSync } from 'react-dom'
21
21
  import { ErrorBoundary } from '../components/ErrorBoundary'
22
22
  import { InnerShape, InnerShapeBackground } from '../components/Shape'
23
23
  import { Editor, TLRenderingShape } from '../editor/Editor'
24
- import { TLFontFace } from '../editor/managers/FontManager'
24
+ import { TLFontFace } from '../editor/managers/FontManager/FontManager'
25
25
  import { ShapeUtil } from '../editor/shapes/ShapeUtil'
26
26
  import {
27
27
  SvgExportContext,
@@ -137,7 +137,6 @@ export function useCanvasEvents() {
137
137
  type: 'files',
138
138
  files,
139
139
  point: editor.screenToPage({ x: e.clientX, y: e.clientY }),
140
- ignoreParent: false,
141
140
  })
142
141
  return
143
142
  }