@tldraw/editor 3.15.0-canary.22a03ce9c171 → 3.15.0-canary.24182c470c85

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 (131) hide show
  1. package/dist-cjs/index.d.ts +103 -7
  2. package/dist-cjs/index.js +3 -1
  3. package/dist-cjs/index.js.map +2 -2
  4. package/dist-cjs/lib/components/SVGContainer.js +1 -1
  5. package/dist-cjs/lib/components/SVGContainer.js.map +2 -2
  6. package/dist-cjs/lib/components/default-components/DefaultBrush.js +1 -1
  7. package/dist-cjs/lib/components/default-components/DefaultBrush.js.map +2 -2
  8. package/dist-cjs/lib/components/default-components/DefaultCanvas.js +1 -1
  9. package/dist-cjs/lib/components/default-components/DefaultCanvas.js.map +2 -2
  10. package/dist-cjs/lib/components/default-components/DefaultCollaboratorHint.js +1 -1
  11. package/dist-cjs/lib/components/default-components/DefaultCollaboratorHint.js.map +2 -2
  12. package/dist-cjs/lib/components/default-components/DefaultCursor.js +1 -1
  13. package/dist-cjs/lib/components/default-components/DefaultCursor.js.map +2 -2
  14. package/dist-cjs/lib/components/default-components/DefaultGrid.js +1 -1
  15. package/dist-cjs/lib/components/default-components/DefaultGrid.js.map +2 -2
  16. package/dist-cjs/lib/components/default-components/DefaultHandles.js +1 -1
  17. package/dist-cjs/lib/components/default-components/DefaultHandles.js.map +2 -2
  18. package/dist-cjs/lib/components/default-components/DefaultShapeIndicator.js +1 -1
  19. package/dist-cjs/lib/components/default-components/DefaultShapeIndicator.js.map +2 -2
  20. package/dist-cjs/lib/components/default-components/DefaultSnapIndictor.js +1 -1
  21. package/dist-cjs/lib/components/default-components/DefaultSnapIndictor.js.map +2 -2
  22. package/dist-cjs/lib/components/default-components/DefaultSpinner.js +27 -15
  23. package/dist-cjs/lib/components/default-components/DefaultSpinner.js.map +3 -3
  24. package/dist-cjs/lib/editor/Editor.js +88 -43
  25. package/dist-cjs/lib/editor/Editor.js.map +2 -2
  26. package/dist-cjs/lib/editor/managers/TextManager/TextManager.js +96 -101
  27. package/dist-cjs/lib/editor/managers/TextManager/TextManager.js.map +2 -2
  28. package/dist-cjs/lib/editor/shapes/ShapeUtil.js.map +2 -2
  29. package/dist-cjs/lib/editor/tools/StateNode.js +20 -1
  30. package/dist-cjs/lib/editor/tools/StateNode.js.map +2 -2
  31. package/dist-cjs/lib/editor/types/misc-types.js.map +1 -1
  32. package/dist-cjs/lib/hooks/useEditorComponents.js.map +1 -1
  33. package/dist-cjs/lib/license/Watermark.js +2 -2
  34. package/dist-cjs/lib/license/Watermark.js.map +2 -2
  35. package/dist-cjs/lib/primitives/geometry/Arc2d.js +1 -1
  36. package/dist-cjs/lib/primitives/geometry/Arc2d.js.map +2 -2
  37. package/dist-cjs/lib/primitives/geometry/Circle2d.js +1 -1
  38. package/dist-cjs/lib/primitives/geometry/Circle2d.js.map +2 -2
  39. package/dist-cjs/lib/primitives/geometry/CubicBezier2d.js +3 -1
  40. package/dist-cjs/lib/primitives/geometry/CubicBezier2d.js.map +2 -2
  41. package/dist-cjs/lib/primitives/geometry/Ellipse2d.js +1 -1
  42. package/dist-cjs/lib/primitives/geometry/Ellipse2d.js.map +2 -2
  43. package/dist-cjs/lib/primitives/geometry/geometry-constants.js +2 -2
  44. package/dist-cjs/lib/primitives/geometry/geometry-constants.js.map +2 -2
  45. package/dist-cjs/lib/primitives/intersect.js +4 -4
  46. package/dist-cjs/lib/primitives/intersect.js.map +2 -2
  47. package/dist-cjs/lib/primitives/utils.js +4 -0
  48. package/dist-cjs/lib/primitives/utils.js.map +2 -2
  49. package/dist-cjs/version.js +3 -3
  50. package/dist-cjs/version.js.map +1 -1
  51. package/dist-esm/index.d.mts +103 -7
  52. package/dist-esm/index.mjs +3 -1
  53. package/dist-esm/index.mjs.map +2 -2
  54. package/dist-esm/lib/components/SVGContainer.mjs +1 -1
  55. package/dist-esm/lib/components/SVGContainer.mjs.map +2 -2
  56. package/dist-esm/lib/components/default-components/DefaultBrush.mjs +1 -1
  57. package/dist-esm/lib/components/default-components/DefaultBrush.mjs.map +2 -2
  58. package/dist-esm/lib/components/default-components/DefaultCanvas.mjs +1 -1
  59. package/dist-esm/lib/components/default-components/DefaultCanvas.mjs.map +2 -2
  60. package/dist-esm/lib/components/default-components/DefaultCollaboratorHint.mjs +1 -1
  61. package/dist-esm/lib/components/default-components/DefaultCollaboratorHint.mjs.map +2 -2
  62. package/dist-esm/lib/components/default-components/DefaultCursor.mjs +1 -1
  63. package/dist-esm/lib/components/default-components/DefaultCursor.mjs.map +2 -2
  64. package/dist-esm/lib/components/default-components/DefaultGrid.mjs +1 -1
  65. package/dist-esm/lib/components/default-components/DefaultGrid.mjs.map +2 -2
  66. package/dist-esm/lib/components/default-components/DefaultHandles.mjs +1 -1
  67. package/dist-esm/lib/components/default-components/DefaultHandles.mjs.map +2 -2
  68. package/dist-esm/lib/components/default-components/DefaultShapeIndicator.mjs +1 -1
  69. package/dist-esm/lib/components/default-components/DefaultShapeIndicator.mjs.map +2 -2
  70. package/dist-esm/lib/components/default-components/DefaultSnapIndictor.mjs +1 -1
  71. package/dist-esm/lib/components/default-components/DefaultSnapIndictor.mjs.map +2 -2
  72. package/dist-esm/lib/components/default-components/DefaultSpinner.mjs +17 -15
  73. package/dist-esm/lib/components/default-components/DefaultSpinner.mjs.map +2 -2
  74. package/dist-esm/lib/editor/Editor.mjs +88 -43
  75. package/dist-esm/lib/editor/Editor.mjs.map +2 -2
  76. package/dist-esm/lib/editor/managers/TextManager/TextManager.mjs +96 -101
  77. package/dist-esm/lib/editor/managers/TextManager/TextManager.mjs.map +2 -2
  78. package/dist-esm/lib/editor/shapes/ShapeUtil.mjs.map +2 -2
  79. package/dist-esm/lib/editor/tools/StateNode.mjs +20 -1
  80. package/dist-esm/lib/editor/tools/StateNode.mjs.map +2 -2
  81. package/dist-esm/lib/hooks/useEditorComponents.mjs.map +1 -1
  82. package/dist-esm/lib/license/Watermark.mjs +2 -2
  83. package/dist-esm/lib/license/Watermark.mjs.map +2 -2
  84. package/dist-esm/lib/primitives/geometry/Arc2d.mjs +2 -2
  85. package/dist-esm/lib/primitives/geometry/Arc2d.mjs.map +2 -2
  86. package/dist-esm/lib/primitives/geometry/Circle2d.mjs +2 -2
  87. package/dist-esm/lib/primitives/geometry/Circle2d.mjs.map +2 -2
  88. package/dist-esm/lib/primitives/geometry/CubicBezier2d.mjs +3 -1
  89. package/dist-esm/lib/primitives/geometry/CubicBezier2d.mjs.map +2 -2
  90. package/dist-esm/lib/primitives/geometry/Ellipse2d.mjs +2 -2
  91. package/dist-esm/lib/primitives/geometry/Ellipse2d.mjs.map +2 -2
  92. package/dist-esm/lib/primitives/geometry/geometry-constants.mjs +2 -2
  93. package/dist-esm/lib/primitives/geometry/geometry-constants.mjs.map +2 -2
  94. package/dist-esm/lib/primitives/intersect.mjs +5 -5
  95. package/dist-esm/lib/primitives/intersect.mjs.map +2 -2
  96. package/dist-esm/lib/primitives/utils.mjs +4 -0
  97. package/dist-esm/lib/primitives/utils.mjs.map +2 -2
  98. package/dist-esm/version.mjs +3 -3
  99. package/dist-esm/version.mjs.map +1 -1
  100. package/editor.css +21 -27
  101. package/package.json +9 -8
  102. package/src/index.ts +2 -0
  103. package/src/lib/components/SVGContainer.tsx +1 -1
  104. package/src/lib/components/default-components/DefaultBrush.tsx +1 -1
  105. package/src/lib/components/default-components/DefaultCanvas.tsx +1 -1
  106. package/src/lib/components/default-components/DefaultCollaboratorHint.tsx +1 -1
  107. package/src/lib/components/default-components/DefaultCursor.tsx +1 -1
  108. package/src/lib/components/default-components/DefaultGrid.tsx +1 -1
  109. package/src/lib/components/default-components/DefaultHandles.tsx +5 -1
  110. package/src/lib/components/default-components/DefaultShapeIndicator.tsx +1 -1
  111. package/src/lib/components/default-components/DefaultSnapIndictor.tsx +1 -1
  112. package/src/lib/components/default-components/DefaultSpinner.tsx +12 -12
  113. package/src/lib/editor/Editor.test.ts +407 -0
  114. package/src/lib/editor/Editor.ts +106 -44
  115. package/src/lib/editor/managers/TextManager/TextManager.ts +108 -128
  116. package/src/lib/editor/shapes/ShapeUtil.ts +57 -0
  117. package/src/lib/editor/tools/StateNode.test.ts +285 -0
  118. package/src/lib/editor/tools/StateNode.ts +27 -1
  119. package/src/lib/editor/types/misc-types.ts +19 -0
  120. package/src/lib/hooks/useEditorComponents.tsx +1 -1
  121. package/src/lib/license/Watermark.tsx +2 -2
  122. package/src/lib/primitives/geometry/Arc2d.ts +2 -2
  123. package/src/lib/primitives/geometry/Circle2d.ts +2 -2
  124. package/src/lib/primitives/geometry/CubicBezier2d.ts +4 -1
  125. package/src/lib/primitives/geometry/Ellipse2d.ts +2 -2
  126. package/src/lib/primitives/geometry/geometry-constants.ts +2 -1
  127. package/src/lib/primitives/intersect.test.ts +57 -11
  128. package/src/lib/primitives/intersect.ts +12 -5
  129. package/src/lib/primitives/utils.ts +11 -0
  130. package/src/version.ts +3 -3
  131. package/src/lib/test/currentToolIdMask.test.ts +0 -49
package/editor.css CHANGED
@@ -167,7 +167,7 @@
167
167
  --color-text: hsl(0, 0%, 0%);
168
168
  --color-text-0: hsl(0, 0%, 11%);
169
169
  --color-text-1: hsl(0, 0%, 18%);
170
- --color-text-3: hsl(220, 2%, 65%);
170
+ --color-text-3: hsl(204, 4%, 45%);
171
171
  --color-text-shadow: hsl(0, 0%, 100%);
172
172
  --color-text-highlight: hsl(52, 100%, 50%);
173
173
  --color-text-highlight-p3: color(display-p3 0.972 0.8205 0.05);
@@ -222,7 +222,7 @@
222
222
  --color-text: hsl(210, 17%, 98%);
223
223
  --color-text-0: hsl(0, 9%, 94%);
224
224
  --color-text-1: hsl(0, 0%, 85%);
225
- --color-text-3: hsl(210, 6%, 45%);
225
+ --color-text-3: hsl(204, 4%, 75%);
226
226
  --color-text-shadow: hsl(210, 13%, 18%);
227
227
  --color-text-highlight: hsl(52, 100%, 41%);
228
228
  --color-text-highlight-p3: color(display-p3 0.8078 0.6225 0.0312);
@@ -774,8 +774,7 @@ input,
774
774
  position: static;
775
775
  }
776
776
 
777
- .tl-text-wrapper[data-isediting='false'] .tl-text-input,
778
- .tl-arrow-label[data-isediting='false'] .tl-text-input {
777
+ .tl-text-wrapper[data-isediting='false'] .tl-text-input {
779
778
  opacity: 0;
780
779
  cursor: var(--tl-cursor-default);
781
780
  }
@@ -968,14 +967,14 @@ input,
968
967
  font-size: 14px;
969
968
  font-weight: 500;
970
969
  opacity: 0;
971
- animation: fade-in 0.2s ease-in-out forwards;
970
+ animation: tl-fade-in 0.2s ease-in-out forwards;
972
971
  animation-delay: 0.2s;
973
972
  position: absolute;
974
973
  inset: 0px;
975
974
  z-index: var(--layer-canvas-blocker);
976
975
  }
977
976
 
978
- @keyframes fade-in {
977
+ @keyframes tl-fade-in {
979
978
  0% {
980
979
  opacity: 0;
981
980
  }
@@ -984,6 +983,19 @@ input,
984
983
  }
985
984
  }
986
985
 
986
+ .tl-spinner {
987
+ animation: tl-spin 1s linear infinite;
988
+ }
989
+
990
+ @keyframes tl-spin {
991
+ 0% {
992
+ transform: rotate(0deg);
993
+ }
994
+ 100% {
995
+ transform: rotate(360deg);
996
+ }
997
+ }
998
+
987
999
  /* ---------------------- Brush --------------------- */
988
1000
 
989
1001
  .tl-brush {
@@ -1175,7 +1187,7 @@ input,
1175
1187
 
1176
1188
  /* --------------------- Arrow shape -------------------- */
1177
1189
 
1178
- .tl-arrow-label {
1190
+ .tl-shape[data-shape-type='arrow'] .tl-text-label {
1179
1191
  position: absolute;
1180
1192
  top: -1px;
1181
1193
  left: -1px;
@@ -1190,33 +1202,15 @@ input,
1190
1202
  text-shadow: var(--tl-text-outline);
1191
1203
  }
1192
1204
 
1193
- .tl-arrow-label[data-isediting='true'] p {
1194
- opacity: 0;
1195
- }
1196
-
1197
- .tl-arrow-label__inner {
1205
+ .tl-shape[data-shape-type='arrow'] .tl-text-label__inner {
1198
1206
  border-radius: var(--radius-1);
1199
1207
  box-sizing: content-box;
1200
- position: relative;
1201
1208
  height: max-content;
1202
1209
  width: max-content;
1203
- pointer-events: none;
1204
- display: flex;
1205
- justify-content: center;
1206
- align-items: center;
1207
1210
  }
1208
1211
 
1209
- .tl-arrow-label .tl-arrow {
1210
- position: relative;
1212
+ .tl-shape[data-shape-type='arrow'] .tl-text {
1211
1213
  height: max-content;
1212
- padding: inherit;
1213
- overflow: visible;
1214
- }
1215
-
1216
- .tl-arrow-label textarea {
1217
- padding: inherit;
1218
- /* Don't allow textarea to be zero width */
1219
- min-width: 4px;
1220
1214
  }
1221
1215
 
1222
1216
  .tl-arrow-hint {
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@tldraw/editor",
3
- "description": "A tiny little drawing app (editor).",
4
- "version": "3.15.0-canary.22a03ce9c171",
3
+ "description": "tldraw infinite canvas SDK (editor).",
4
+ "version": "3.15.0-canary.24182c470c85",
5
5
  "author": {
6
6
  "name": "tldraw Inc.",
7
7
  "email": "hello@tldraw.com"
@@ -17,6 +17,7 @@
17
17
  },
18
18
  "keywords": [
19
19
  "tldraw",
20
+ "sdk",
20
21
  "drawing",
21
22
  "app",
22
23
  "development",
@@ -48,12 +49,12 @@
48
49
  "@tiptap/core": "^2.9.1",
49
50
  "@tiptap/pm": "^2.9.1",
50
51
  "@tiptap/react": "^2.9.1",
51
- "@tldraw/state": "3.15.0-canary.22a03ce9c171",
52
- "@tldraw/state-react": "3.15.0-canary.22a03ce9c171",
53
- "@tldraw/store": "3.15.0-canary.22a03ce9c171",
54
- "@tldraw/tlschema": "3.15.0-canary.22a03ce9c171",
55
- "@tldraw/utils": "3.15.0-canary.22a03ce9c171",
56
- "@tldraw/validate": "3.15.0-canary.22a03ce9c171",
52
+ "@tldraw/state": "3.15.0-canary.24182c470c85",
53
+ "@tldraw/state-react": "3.15.0-canary.24182c470c85",
54
+ "@tldraw/store": "3.15.0-canary.24182c470c85",
55
+ "@tldraw/tlschema": "3.15.0-canary.24182c470c85",
56
+ "@tldraw/utils": "3.15.0-canary.24182c470c85",
57
+ "@tldraw/validate": "3.15.0-canary.24182c470c85",
57
58
  "@types/core-js": "^2.5.8",
58
59
  "@use-gesture/react": "^10.3.1",
59
60
  "classnames": "^2.5.1",
package/src/index.ts CHANGED
@@ -264,6 +264,7 @@ export {
264
264
  type TLImageExportOptions,
265
265
  type TLSvgExportOptions,
266
266
  type TLSvgOptions,
267
+ type TLUpdatePointerOptions,
267
268
  } from './lib/editor/types/misc-types'
268
269
  export {
269
270
  type TLAdjacentDirection,
@@ -346,6 +347,7 @@ export { CubicBezier2d } from './lib/primitives/geometry/CubicBezier2d'
346
347
  export { CubicSpline2d } from './lib/primitives/geometry/CubicSpline2d'
347
348
  export { Edge2d } from './lib/primitives/geometry/Edge2d'
348
349
  export { Ellipse2d } from './lib/primitives/geometry/Ellipse2d'
350
+ export { getVerticesCountForArcLength } from './lib/primitives/geometry/geometry-constants'
349
351
  export {
350
352
  Geometry2d,
351
353
  Geometry2dFilters,
@@ -7,7 +7,7 @@ export type SVGContainerProps = React.ComponentProps<'svg'>
7
7
  /** @public @react */
8
8
  export function SVGContainer({ children, className = '', ...rest }: SVGContainerProps) {
9
9
  return (
10
- <svg {...rest} className={classNames('tl-svg-container', className)}>
10
+ <svg {...rest} className={classNames('tl-svg-container', className)} aria-hidden="true">
11
11
  {children}
12
12
  </svg>
13
13
  )
@@ -21,7 +21,7 @@ export const DefaultBrush = ({ brush, color, opacity, className }: TLBrushProps)
21
21
  const h = toDomPrecision(Math.max(1, brush.h))
22
22
 
23
23
  return (
24
- <svg className="tl-overlays__item" ref={rSvg}>
24
+ <svg className="tl-overlays__item" ref={rSvg} aria-hidden="true">
25
25
  {color ? (
26
26
  <g className="tl-brush" opacity={opacity}>
27
27
  <rect width={w} height={h} fill={color} opacity={0.75} />
@@ -139,7 +139,7 @@ export function DefaultCanvas({ className }: TLCanvasComponentProps) {
139
139
  data-testid="canvas"
140
140
  {...events}
141
141
  >
142
- <svg className="tl-svg-context">
142
+ <svg className="tl-svg-context" aria-hidden="true">
143
143
  <defs>
144
144
  {shapeSvgDefs}
145
145
  <CursorDef />
@@ -39,7 +39,7 @@ export function DefaultCollaboratorHint({
39
39
  const cursorHintId = useSharedSafeId('cursor_hint')
40
40
 
41
41
  return (
42
- <svg ref={rSvg} className={classNames('tl-overlays__item', className)}>
42
+ <svg ref={rSvg} className={classNames('tl-overlays__item', className)} aria-hidden="true">
43
43
  <use
44
44
  href={`#${cursorHintId}`}
45
45
  color={color}
@@ -33,7 +33,7 @@ export const DefaultCursor = memo(function DefaultCursor({
33
33
 
34
34
  return (
35
35
  <div ref={rCursor} className={classNames('tl-overlays__item', className)}>
36
- <svg className="tl-cursor">
36
+ <svg className="tl-cursor" aria-hidden="true">
37
37
  <use href={`#${cursorId}`} color={color} />
38
38
  </svg>
39
39
  {chatMessage ? (
@@ -16,7 +16,7 @@ export function DefaultGrid({ x, y, z, size }: TLGridProps) {
16
16
  const editor = useEditor()
17
17
  const { gridSteps } = editor.options
18
18
  return (
19
- <svg className="tl-grid" version="1.1" xmlns="http://www.w3.org/2000/svg">
19
+ <svg className="tl-grid" version="1.1" xmlns="http://www.w3.org/2000/svg" aria-hidden="true">
20
20
  <defs>
21
21
  {gridSteps.map(({ min, mid, step }, i) => {
22
22
  const s = step * size * z
@@ -7,5 +7,9 @@ export interface TLHandlesProps {
7
7
 
8
8
  /** @public @react */
9
9
  export const DefaultHandles = ({ children }: TLHandlesProps) => {
10
- return <svg className="tl-user-handles tl-overlays__item">{children}</svg>
10
+ return (
11
+ <svg className="tl-user-handles tl-overlays__item" aria-hidden="true">
12
+ {children}
13
+ </svg>
14
+ )
11
15
  }
@@ -86,7 +86,7 @@ export const DefaultShapeIndicator = memo(function DefaultShapeIndicator({
86
86
  }, [hidden])
87
87
 
88
88
  return (
89
- <svg ref={rIndicator} className={classNames('tl-overlays__item', className)}>
89
+ <svg ref={rIndicator} className={classNames('tl-overlays__item', className)} aria-hidden="true">
90
90
  <g className="tl-shape-indicator" stroke={color ?? 'var(--color-selected)'} opacity={opacity}>
91
91
  <InnerIndicator editor={editor} id={shapeId} />
92
92
  </g>
@@ -163,7 +163,7 @@ export interface TLSnapIndicatorProps {
163
163
  /** @public @react */
164
164
  export function DefaultSnapIndicator({ className, line, zoom }: TLSnapIndicatorProps) {
165
165
  return (
166
- <svg className={classNames('tl-overlays__item', className)}>
166
+ <svg className={classNames('tl-overlays__item', className)} aria-hidden="true">
167
167
  {line.type === 'points' ? (
168
168
  <PointsSnapIndicator {...line} zoom={zoom} />
169
169
  ) : line.type === 'gaps' ? (
@@ -1,19 +1,19 @@
1
+ import classNames from 'classnames'
2
+
1
3
  /** @public @react */
2
- export function DefaultSpinner() {
4
+ export function DefaultSpinner(props: React.SVGProps<SVGSVGElement>) {
3
5
  return (
4
- <svg width={16} height={16} viewBox="0 0 16 16" aria-hidden="false">
6
+ <svg
7
+ width={16}
8
+ height={16}
9
+ viewBox="0 0 16 16"
10
+ aria-hidden="false"
11
+ {...props}
12
+ className={classNames('tl-spinner', props.className)}
13
+ >
5
14
  <g strokeWidth={2} fill="none" fillRule="evenodd">
6
15
  <circle strokeOpacity={0.25} cx={8} cy={8} r={7} stroke="currentColor" />
7
- <path strokeLinecap="round" d="M15 8c0-4.5-4.5-7-7-7" stroke="currentColor">
8
- <animateTransform
9
- attributeName="transform"
10
- type="rotate"
11
- from="0 8 8"
12
- to="360 8 8"
13
- dur="1s"
14
- repeatCount="indefinite"
15
- />
16
- </path>
16
+ <path strokeLinecap="round" d="M15 8c0-4.5-4.5-7-7-7" stroke="currentColor" />
17
17
  </g>
18
18
  </svg>
19
19
  )