@tldraw/editor 3.16.0-canary.2c80b8690ff1 → 3.16.0-canary.2d1a57ea21b2

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 (80) hide show
  1. package/dist-cjs/index.d.ts +34 -101
  2. package/dist-cjs/index.js +3 -5
  3. package/dist-cjs/index.js.map +2 -2
  4. package/dist-cjs/lib/TldrawEditor.js +1 -5
  5. package/dist-cjs/lib/TldrawEditor.js.map +2 -2
  6. package/dist-cjs/lib/editor/Editor.js +14 -109
  7. package/dist-cjs/lib/editor/Editor.js.map +2 -2
  8. package/dist-cjs/lib/editor/derivations/notVisibleShapes.js +4 -0
  9. package/dist-cjs/lib/editor/derivations/notVisibleShapes.js.map +2 -2
  10. package/dist-cjs/lib/editor/shapes/ShapeUtil.js +10 -0
  11. package/dist-cjs/lib/editor/shapes/ShapeUtil.js.map +2 -2
  12. package/dist-cjs/lib/editor/types/misc-types.js.map +1 -1
  13. package/dist-cjs/lib/hooks/usePassThroughMouseOverEvents.js +4 -1
  14. package/dist-cjs/lib/hooks/usePassThroughMouseOverEvents.js.map +2 -2
  15. package/dist-cjs/lib/license/LicenseManager.js +120 -50
  16. package/dist-cjs/lib/license/LicenseManager.js.map +2 -2
  17. package/dist-cjs/lib/license/LicenseProvider.js +39 -1
  18. package/dist-cjs/lib/license/LicenseProvider.js.map +2 -2
  19. package/dist-cjs/lib/license/Watermark.js +68 -6
  20. package/dist-cjs/lib/license/Watermark.js.map +3 -3
  21. package/dist-cjs/lib/license/useLicenseManagerState.js.map +2 -2
  22. package/dist-cjs/lib/primitives/Vec.js +0 -4
  23. package/dist-cjs/lib/primitives/Vec.js.map +2 -2
  24. package/dist-cjs/lib/primitives/geometry/Geometry2d.js +26 -18
  25. package/dist-cjs/lib/primitives/geometry/Geometry2d.js.map +2 -2
  26. package/dist-cjs/lib/primitives/geometry/Group2d.js +3 -0
  27. package/dist-cjs/lib/primitives/geometry/Group2d.js.map +2 -2
  28. package/dist-cjs/lib/utils/reparenting.js +2 -35
  29. package/dist-cjs/lib/utils/reparenting.js.map +3 -3
  30. package/dist-cjs/version.js +3 -3
  31. package/dist-cjs/version.js.map +1 -1
  32. package/dist-esm/index.d.mts +34 -101
  33. package/dist-esm/index.mjs +3 -5
  34. package/dist-esm/index.mjs.map +2 -2
  35. package/dist-esm/lib/TldrawEditor.mjs +1 -5
  36. package/dist-esm/lib/TldrawEditor.mjs.map +2 -2
  37. package/dist-esm/lib/editor/Editor.mjs +14 -109
  38. package/dist-esm/lib/editor/Editor.mjs.map +2 -2
  39. package/dist-esm/lib/editor/derivations/notVisibleShapes.mjs +4 -0
  40. package/dist-esm/lib/editor/derivations/notVisibleShapes.mjs.map +2 -2
  41. package/dist-esm/lib/editor/shapes/ShapeUtil.mjs +10 -0
  42. package/dist-esm/lib/editor/shapes/ShapeUtil.mjs.map +2 -2
  43. package/dist-esm/lib/hooks/usePassThroughMouseOverEvents.mjs +4 -1
  44. package/dist-esm/lib/hooks/usePassThroughMouseOverEvents.mjs.map +2 -2
  45. package/dist-esm/lib/license/LicenseManager.mjs +121 -51
  46. package/dist-esm/lib/license/LicenseManager.mjs.map +2 -2
  47. package/dist-esm/lib/license/LicenseProvider.mjs +39 -2
  48. package/dist-esm/lib/license/LicenseProvider.mjs.map +2 -2
  49. package/dist-esm/lib/license/Watermark.mjs +68 -6
  50. package/dist-esm/lib/license/Watermark.mjs.map +3 -3
  51. package/dist-esm/lib/license/useLicenseManagerState.mjs.map +2 -2
  52. package/dist-esm/lib/primitives/Vec.mjs +0 -4
  53. package/dist-esm/lib/primitives/Vec.mjs.map +2 -2
  54. package/dist-esm/lib/primitives/geometry/Geometry2d.mjs +29 -19
  55. package/dist-esm/lib/primitives/geometry/Geometry2d.mjs.map +2 -2
  56. package/dist-esm/lib/primitives/geometry/Group2d.mjs +3 -0
  57. package/dist-esm/lib/primitives/geometry/Group2d.mjs.map +2 -2
  58. package/dist-esm/lib/utils/reparenting.mjs +3 -40
  59. package/dist-esm/lib/utils/reparenting.mjs.map +2 -2
  60. package/dist-esm/version.mjs +3 -3
  61. package/dist-esm/version.mjs.map +1 -1
  62. package/editor.css +8 -3
  63. package/package.json +7 -7
  64. package/src/index.ts +2 -9
  65. package/src/lib/TldrawEditor.tsx +1 -13
  66. package/src/lib/editor/Editor.ts +20 -146
  67. package/src/lib/editor/derivations/notVisibleShapes.ts +6 -0
  68. package/src/lib/editor/shapes/ShapeUtil.ts +32 -0
  69. package/src/lib/editor/types/misc-types.ts +0 -6
  70. package/src/lib/hooks/usePassThroughMouseOverEvents.ts +4 -1
  71. package/src/lib/license/LicenseManager.test.ts +645 -382
  72. package/src/lib/license/LicenseManager.ts +173 -53
  73. package/src/lib/license/LicenseProvider.tsx +74 -2
  74. package/src/lib/license/Watermark.tsx +73 -6
  75. package/src/lib/license/useLicenseManagerState.ts +2 -2
  76. package/src/lib/primitives/Vec.ts +0 -5
  77. package/src/lib/primitives/geometry/Geometry2d.ts +49 -19
  78. package/src/lib/primitives/geometry/Group2d.ts +4 -0
  79. package/src/lib/utils/reparenting.ts +3 -69
  80. package/src/version.ts +3 -3
@@ -283,6 +283,17 @@ export abstract class ShapeUtil<Shape extends TLUnknownShape = TLUnknownShape> {
283
283
  return true
284
284
  }
285
285
 
286
+ /**
287
+ * Whether this shape can be culled. By default, shapes are culled for
288
+ * performance reasons when they are outside of the viewport. Culled shapes are still rendered
289
+ * to the DOM, but have their `display` property set to `none`.
290
+ *
291
+ * @param shape - The shape.
292
+ */
293
+ canCull(_shape: Shape): boolean {
294
+ return true
295
+ }
296
+
286
297
  /**
287
298
  * Does this shape provide a background for its children? If this is true,
288
299
  * then any children with a `renderBackground` method will have their
@@ -296,6 +307,27 @@ export abstract class ShapeUtil<Shape extends TLUnknownShape = TLUnknownShape> {
296
307
  return false
297
308
  }
298
309
 
310
+ /**
311
+ * Get the clip path to apply to this shape's children.
312
+ *
313
+ * @param shape - The shape to get the clip path for
314
+ * @returns Array of points defining the clipping polygon in local coordinates, or undefined if no clipping
315
+ * @public
316
+ */
317
+ getClipPath?(shape: Shape): Vec[] | undefined
318
+
319
+ /**
320
+ * Whether a specific child shape should be clipped by this shape.
321
+ * Only called if getClipPath returns a valid polygon.
322
+ *
323
+ * If not defined, the default behavior is to clip all children.
324
+ *
325
+ * @param child - The child shape to check
326
+ * @returns boolean indicating if this child should be clipped
327
+ * @public
328
+ */
329
+ shouldClipChild?(child: TLShape): boolean
330
+
299
331
  /**
300
332
  * Whether the shape should hide its resize handles when selected.
301
333
  *
@@ -72,12 +72,6 @@ export interface TLImageExportOptions extends TLSvgExportOptions {
72
72
  format?: TLExportType
73
73
  }
74
74
 
75
- /**
76
- * @public
77
- * @deprecated use {@link TLImageExportOptions} instead
78
- */
79
- export type TLSvgOptions = TLImageExportOptions
80
-
81
75
  /** @public */
82
76
  export interface TLCameraMoveOptions {
83
77
  /** Whether to move the camera immediately, rather than on the next tick. */
@@ -1,14 +1,17 @@
1
1
  import { RefObject, useEffect } from 'react'
2
2
  import { preventDefault } from '../utils/dom'
3
3
  import { useContainer } from './useContainer'
4
+ import { useMaybeEditor } from './useEditor'
4
5
 
5
6
  /** @public */
6
7
  export function usePassThroughMouseOverEvents(ref: RefObject<HTMLElement>) {
7
8
  if (!ref) throw Error('usePassThroughWheelEvents must be passed a ref')
8
9
  const container = useContainer()
10
+ const editor = useMaybeEditor()
9
11
 
10
12
  useEffect(() => {
11
13
  function onMouseOver(e: MouseEvent) {
14
+ if (!editor?.getInstanceState().isFocused) return
12
15
  if ((e as any).isSpecialRedispatchedEvent) return
13
16
  preventDefault(e)
14
17
  const cvs = container.querySelector('.tl-canvas')
@@ -25,5 +28,5 @@ export function usePassThroughMouseOverEvents(ref: RefObject<HTMLElement>) {
25
28
  return () => {
26
29
  elm.removeEventListener('mouseover', onMouseOver)
27
30
  }
28
- }, [container, ref])
31
+ }, [container, editor, ref])
29
32
  }