@tldraw/editor 3.16.0-canary.1647ca5bba28 → 3.16.0-canary.1e91d2e19e07

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 (66) hide show
  1. package/dist-cjs/index.d.ts +17 -0
  2. package/dist-cjs/index.js +3 -1
  3. package/dist-cjs/index.js.map +2 -2
  4. package/dist-cjs/lib/TldrawEditor.js +1 -1
  5. package/dist-cjs/lib/TldrawEditor.js.map +2 -2
  6. package/dist-cjs/lib/editor/Editor.js +3 -2
  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/hooks/usePassThroughMouseOverEvents.js +4 -1
  13. package/dist-cjs/lib/hooks/usePassThroughMouseOverEvents.js.map +2 -2
  14. package/dist-cjs/lib/license/LicenseManager.js +128 -35
  15. package/dist-cjs/lib/license/LicenseManager.js.map +2 -2
  16. package/dist-cjs/lib/license/LicenseProvider.js +36 -3
  17. package/dist-cjs/lib/license/LicenseProvider.js.map +2 -2
  18. package/dist-cjs/lib/license/Watermark.js +68 -6
  19. package/dist-cjs/lib/license/Watermark.js.map +3 -3
  20. package/dist-cjs/lib/primitives/geometry/Geometry2d.js +24 -2
  21. package/dist-cjs/lib/primitives/geometry/Geometry2d.js.map +2 -2
  22. package/dist-cjs/lib/primitives/geometry/Group2d.js +5 -1
  23. package/dist-cjs/lib/primitives/geometry/Group2d.js.map +2 -2
  24. package/dist-cjs/version.js +3 -3
  25. package/dist-cjs/version.js.map +1 -1
  26. package/dist-esm/index.d.mts +17 -0
  27. package/dist-esm/index.mjs +3 -1
  28. package/dist-esm/index.mjs.map +2 -2
  29. package/dist-esm/lib/TldrawEditor.mjs +1 -1
  30. package/dist-esm/lib/TldrawEditor.mjs.map +2 -2
  31. package/dist-esm/lib/editor/Editor.mjs +3 -2
  32. package/dist-esm/lib/editor/Editor.mjs.map +2 -2
  33. package/dist-esm/lib/editor/derivations/notVisibleShapes.mjs +4 -0
  34. package/dist-esm/lib/editor/derivations/notVisibleShapes.mjs.map +2 -2
  35. package/dist-esm/lib/editor/shapes/ShapeUtil.mjs +10 -0
  36. package/dist-esm/lib/editor/shapes/ShapeUtil.mjs.map +2 -2
  37. package/dist-esm/lib/hooks/usePassThroughMouseOverEvents.mjs +4 -1
  38. package/dist-esm/lib/hooks/usePassThroughMouseOverEvents.mjs.map +2 -2
  39. package/dist-esm/lib/license/LicenseManager.mjs +129 -36
  40. package/dist-esm/lib/license/LicenseManager.mjs.map +2 -2
  41. package/dist-esm/lib/license/LicenseProvider.mjs +36 -4
  42. package/dist-esm/lib/license/LicenseProvider.mjs.map +2 -2
  43. package/dist-esm/lib/license/Watermark.mjs +68 -6
  44. package/dist-esm/lib/license/Watermark.mjs.map +3 -3
  45. package/dist-esm/lib/primitives/geometry/Geometry2d.mjs +24 -2
  46. package/dist-esm/lib/primitives/geometry/Geometry2d.mjs.map +2 -2
  47. package/dist-esm/lib/primitives/geometry/Group2d.mjs +5 -1
  48. package/dist-esm/lib/primitives/geometry/Group2d.mjs.map +2 -2
  49. package/dist-esm/version.mjs +3 -3
  50. package/dist-esm/version.mjs.map +1 -1
  51. package/editor.css +8 -3
  52. package/package.json +7 -7
  53. package/src/index.ts +1 -0
  54. package/src/lib/TldrawEditor.tsx +1 -2
  55. package/src/lib/editor/Editor.ts +4 -2
  56. package/src/lib/editor/derivations/notVisibleShapes.ts +6 -0
  57. package/src/lib/editor/shapes/ShapeUtil.ts +11 -0
  58. package/src/lib/hooks/usePassThroughMouseOverEvents.ts +4 -1
  59. package/src/lib/license/LicenseManager.test.ts +687 -387
  60. package/src/lib/license/LicenseManager.ts +180 -44
  61. package/src/lib/license/LicenseProvider.tsx +69 -5
  62. package/src/lib/license/Watermark.tsx +73 -6
  63. package/src/lib/primitives/geometry/Geometry2d.test.ts +420 -0
  64. package/src/lib/primitives/geometry/Geometry2d.ts +29 -2
  65. package/src/lib/primitives/geometry/Group2d.ts +6 -1
  66. package/src/version.ts +3 -3
@@ -1,6 +1,7 @@
1
1
  import { MigrationSequence, Store } from '@tldraw/store'
2
2
  import { TLShape, TLStore, TLStoreSnapshot } from '@tldraw/tlschema'
3
3
  import { annotateError, Required } from '@tldraw/utils'
4
+ import classNames from 'classnames'
4
5
  import React, {
5
6
  memo,
6
7
  ReactNode,
@@ -12,8 +13,6 @@ import React, {
12
13
  useState,
13
14
  useSyncExternalStore,
14
15
  } from 'react'
15
-
16
- import classNames from 'classnames'
17
16
  import { version } from '../version'
18
17
  import { DefaultErrorFallback } from './components/default-components/DefaultErrorFallback'
19
18
  import { OptionalErrorBoundary } from './components/ErrorBoundary'
@@ -4680,8 +4680,10 @@ export class Editor extends EventEmitter<TLEventMap> {
4680
4680
  return this.store.createComputedCache<Box, TLShape>('pageBoundsCache', (shape) => {
4681
4681
  const pageTransform = this.getShapePageTransform(shape)
4682
4682
  if (!pageTransform) return undefined
4683
- const geometry = this.getShapeGeometry(shape)
4684
- return Box.FromPoints(pageTransform.applyToPoints(geometry.vertices))
4683
+
4684
+ return Box.FromPoints(
4685
+ pageTransform.applyToPoints(this.getShapeGeometry(shape).boundsVertices)
4686
+ )
4685
4687
  })
4686
4688
  }
4687
4689
 
@@ -7,6 +7,12 @@ function fromScratch(editor: Editor): Set<TLShapeId> {
7
7
  const viewportPageBounds = editor.getViewportPageBounds()
8
8
  const notVisibleShapes = new Set<TLShapeId>()
9
9
  shapesIds.forEach((id) => {
10
+ const shape = editor.getShape(id)
11
+ if (!shape) return
12
+
13
+ const canCull = editor.getShapeUtil(shape.type).canCull(shape)
14
+ if (!canCull) return
15
+
10
16
  // If the shape is fully outside of the viewport page bounds, add it to the set.
11
17
  // We'll ignore masks here, since they're more expensive to compute and the overhead is not worth it.
12
18
  const pageBounds = editor.getShapePageBounds(id)
@@ -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
@@ -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
  }