tldraw 3.16.0-canary.acb40a76700b → 3.16.0-canary.b4611e27bade
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.
- package/dist-cjs/index.d.ts +71 -0
- package/dist-cjs/index.js +5 -1
- package/dist-cjs/index.js.map +2 -2
- package/dist-cjs/lib/shapes/shared/freehand/svg.js.map +2 -2
- package/dist-cjs/lib/ui/assetUrls.js +13 -10
- package/dist-cjs/lib/ui/assetUrls.js.map +2 -2
- package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js +1 -1
- package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js.map +1 -1
- package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js +1 -1
- package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js.map +2 -2
- package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js +2 -1
- package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js.map +2 -2
- package/dist-cjs/lib/ui/context/actions.js +16 -2
- package/dist-cjs/lib/ui/context/actions.js.map +2 -2
- package/dist-cjs/lib/ui/version.js +3 -3
- package/dist-cjs/lib/ui/version.js.map +1 -1
- package/dist-esm/index.d.mts +71 -0
- package/dist-esm/index.mjs +5 -1
- package/dist-esm/index.mjs.map +2 -2
- package/dist-esm/lib/shapes/shared/freehand/svg.mjs.map +2 -2
- package/dist-esm/lib/ui/assetUrls.mjs +13 -10
- package/dist-esm/lib/ui/assetUrls.mjs.map +2 -2
- package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs +1 -1
- package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs.map +1 -1
- package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs +1 -1
- package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs.map +2 -2
- package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs +2 -1
- package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs.map +2 -2
- package/dist-esm/lib/ui/context/actions.mjs +16 -2
- package/dist-esm/lib/ui/context/actions.mjs.map +2 -2
- package/dist-esm/lib/ui/version.mjs +3 -3
- package/dist-esm/lib/ui/version.mjs.map +1 -1
- package/package.json +11 -34
- package/src/index.ts +3 -0
- package/src/lib/shapes/arrow/ArrowShapeOptions.test.ts +2 -1
- package/src/lib/shapes/arrow/ArrowShapeTool.test.ts +4 -3
- package/src/lib/shapes/arrow/ArrowShapeUtil.test.ts +7 -6
- package/src/lib/shapes/draw/DrawShapeTool.test.ts +0 -5
- package/src/lib/shapes/line/LineShapeUtil.test.tsx +4 -3
- package/src/lib/shapes/line/__snapshots__/LineShapeUtil.test.tsx.snap +2 -2
- package/src/lib/shapes/shared/freehand/svg.ts +2 -0
- package/src/lib/shapes/text/TextShapeTool.test.ts +6 -5
- package/src/lib/ui/assetUrls.ts +13 -10
- package/src/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.tsx +1 -1
- package/src/lib/ui/components/StylePanel/DropdownPicker.tsx +1 -1
- package/src/lib/ui/components/primitives/menus/TldrawUiMenuItem.tsx +3 -2
- package/src/lib/ui/context/actions.tsx +16 -2
- package/src/lib/ui/version.ts +3 -3
- package/src/lib/ui.css +3 -0
- package/src/lib/utils/excalidraw/__snapshots__/putExcalidrawContent.test.tsx.snap +5 -5
- package/src/lib/utils/tldr/__snapshots__/buildFromV1Document.test.ts.snap +4 -4
- package/src/test/A11y.test.tsx +3 -2
- package/src/test/ClickManager.test.ts +7 -6
- package/src/test/Editor.test.tsx +20 -19
- package/src/test/EraserTool.test.ts +12 -11
- package/src/test/HandTool.test.ts +10 -9
- package/src/test/HighlightShape.test.ts +2 -1
- package/src/test/SelectTool.test.ts +3 -2
- package/src/test/TLUserPreferences.test.ts +4 -3
- package/src/test/TestEditor.ts +13 -15
- package/src/test/TldrawEditor.test.tsx +11 -10
- package/src/test/ZoomTool.test.ts +7 -6
- package/src/test/__snapshots__/drawing.test.ts.snap +2 -2
- package/src/test/__snapshots__/groups.test.tsx.snap +6 -6
- package/src/test/__snapshots__/resizing.test.ts.snap +2 -2
- package/src/test/arrows-megabus.test.tsx +5 -4
- package/src/test/bindings.test.tsx +24 -37
- package/src/test/bookmark-shapes.test.ts +1 -8
- package/src/test/commands/__snapshots__/getSvgString.test.ts.snap +23 -7
- package/src/test/commands/__snapshots__/packShapes.test.ts.snap +8 -8
- package/src/test/commands/__snapshots__/zoomToFit.test.ts.snap +2 -2
- package/src/test/commands/alignShapes.test.tsx +25 -24
- package/src/test/commands/animationSpeed.test.ts +2 -1
- package/src/test/commands/centerOnPoint.test.ts +3 -2
- package/src/test/commands/clipboard.test.ts +3 -2
- package/src/test/commands/createShapes.test.ts +2 -1
- package/src/test/commands/deleteShapes.test.ts +2 -1
- package/src/test/commands/distributeShapes.test.tsx +11 -10
- package/src/test/commands/getSvgString.test.ts +2 -1
- package/src/test/commands/packShapes.test.ts +5 -4
- package/src/test/commands/resizeShape.test.ts +2 -1
- package/src/test/commands/rotateShapes.test.ts +7 -6
- package/src/test/commands/setCamera.test.ts +4 -3
- package/src/test/commands/setCurrentPage.test.ts +3 -2
- package/src/test/commands/stackShapes.test.ts +11 -10
- package/src/test/commands/stretch.test.tsx +13 -12
- package/src/test/createDeepLink.test.tsx +2 -1
- package/src/test/cropping.test.ts +3 -2
- package/src/test/drawing.test.ts +2 -1
- package/src/test/flipShapes.test.ts +4 -3
- package/src/test/frames.test.ts +25 -24
- package/src/test/getCulledShapes.test.tsx +3 -2
- package/src/test/groups.test.tsx +1 -1
- package/src/test/handleDeepLink.test.tsx +2 -1
- package/src/test/maxShapes.test.ts +3 -2
- package/src/test/modifiers.test.ts +5 -4
- package/src/test/navigation.test.ts +12 -11
- package/src/test/panning.test.ts +2 -1
- package/src/test/perf/perf.test.ts +2 -1
- package/src/test/registerDeepLinkListener.test.tsx +10 -9
- package/src/test/resizing.test.ts +39 -38
- package/src/test/select.test.tsx +4 -3
- package/src/test/selection-omnibus.test.ts +11 -10
- package/src/test/shapeutils.test.ts +4 -3
- package/src/test/translating.test.ts +9 -8
- package/tldraw.css +3 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
//
|
|
1
|
+
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
|
|
2
2
|
|
|
3
|
-
exports[`Matches a snapshot
|
|
3
|
+
exports[`Matches a snapshot > Basic SVG 1`] = `
|
|
4
4
|
<wrapper>
|
|
5
5
|
<svg
|
|
6
6
|
class="tl-container tl-theme__force-sRGB tl-theme__light"
|
|
@@ -64,6 +64,13 @@ exports[`Matches a snapshot: Basic SVG 1`] = `
|
|
|
64
64
|
y="0"
|
|
65
65
|
/>
|
|
66
66
|
</pattern>
|
|
67
|
+
<style>
|
|
68
|
+
@font-face {
|
|
69
|
+
font-family: "tldraw_draw";
|
|
70
|
+
font-weight: normal;
|
|
71
|
+
src: url("data:font/woff2;base64,") format(woff2);
|
|
72
|
+
}
|
|
73
|
+
</style>
|
|
67
74
|
</defs>
|
|
68
75
|
<g
|
|
69
76
|
opacity="1"
|
|
@@ -83,14 +90,15 @@ exports[`Matches a snapshot: Basic SVG 1`] = `
|
|
|
83
90
|
y="0"
|
|
84
91
|
>
|
|
85
92
|
<div
|
|
86
|
-
style="display:
|
|
93
|
+
style="display: block; font-family: serif; height: 0px; justify-content: center; align-items: center; padding: 0px; position: static; width: 0px; margin: 0px; border: 0px; font-size: 16px; line-height: normal; color: rgb(0, 0, 0); background-color: rgba(0, 0, 0, 0);"
|
|
87
94
|
xmlns="http://www.w3.org/1999/xhtml"
|
|
88
95
|
>
|
|
89
96
|
<div
|
|
90
|
-
style="font-size: 22px; color: rgb(
|
|
97
|
+
style="font-size: 22px; color: rgb(0, 0, 0); line-height: 1.35; text-align: center; width: 0px; word-wrap: break-word; overflow-wrap: break-word; white-space: pre-wrap; text-shadow: var(--tl-text-outline); position: static; height: 0px; margin: 0px; padding: 0px; border: 0px;"
|
|
91
98
|
>
|
|
92
99
|
<p
|
|
93
100
|
dir="auto"
|
|
101
|
+
style="position: static; width: 0px; height: 0px; margin: 0px; padding: 0px; border: 0px; color: rgb(0, 0, 0);"
|
|
94
102
|
>
|
|
95
103
|
Hello world
|
|
96
104
|
</p>
|
|
@@ -132,7 +140,7 @@ exports[`Matches a snapshot: Basic SVG 1`] = `
|
|
|
132
140
|
</wrapper>
|
|
133
141
|
`;
|
|
134
142
|
|
|
135
|
-
exports[`Returns all shapes when no ids are provided
|
|
143
|
+
exports[`Returns all shapes when no ids are provided > All shapes 1`] = `
|
|
136
144
|
<wrapper>
|
|
137
145
|
<svg
|
|
138
146
|
class="tl-container tl-theme__force-sRGB tl-theme__light"
|
|
@@ -196,6 +204,13 @@ exports[`Returns all shapes when no ids are provided: All shapes 1`] = `
|
|
|
196
204
|
y="0"
|
|
197
205
|
/>
|
|
198
206
|
</pattern>
|
|
207
|
+
<style>
|
|
208
|
+
@font-face {
|
|
209
|
+
font-family: "tldraw_draw";
|
|
210
|
+
font-weight: normal;
|
|
211
|
+
src: url("data:font/woff2;base64,") format(woff2);
|
|
212
|
+
}
|
|
213
|
+
</style>
|
|
199
214
|
</defs>
|
|
200
215
|
<g
|
|
201
216
|
opacity="1"
|
|
@@ -215,14 +230,15 @@ exports[`Returns all shapes when no ids are provided: All shapes 1`] = `
|
|
|
215
230
|
y="0"
|
|
216
231
|
>
|
|
217
232
|
<div
|
|
218
|
-
style="display:
|
|
233
|
+
style="display: block; font-family: serif; height: 0px; justify-content: center; align-items: center; padding: 0px; position: static; width: 0px; margin: 0px; border: 0px; font-size: 16px; line-height: normal; color: rgb(0, 0, 0); background-color: rgba(0, 0, 0, 0);"
|
|
219
234
|
xmlns="http://www.w3.org/1999/xhtml"
|
|
220
235
|
>
|
|
221
236
|
<div
|
|
222
|
-
style="font-size: 22px; color: rgb(
|
|
237
|
+
style="font-size: 22px; color: rgb(0, 0, 0); line-height: 1.35; text-align: center; width: 0px; word-wrap: break-word; overflow-wrap: break-word; white-space: pre-wrap; text-shadow: var(--tl-text-outline); position: static; height: 0px; margin: 0px; padding: 0px; border: 0px;"
|
|
223
238
|
>
|
|
224
239
|
<p
|
|
225
240
|
dir="auto"
|
|
241
|
+
style="position: static; width: 0px; height: 0px; margin: 0px; padding: 0px; border: 0px; color: rgb(0, 0, 0);"
|
|
226
242
|
>
|
|
227
243
|
Hello world
|
|
228
244
|
</p>
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
//
|
|
1
|
+
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
|
|
2
2
|
|
|
3
|
-
exports[`editor.packShapes packs rotated shapes
|
|
3
|
+
exports[`editor.packShapes > packs rotated shapes > packed shapes 1`] = `
|
|
4
4
|
[
|
|
5
5
|
{
|
|
6
6
|
"id": "shape:boxA",
|
|
@@ -116,7 +116,7 @@ exports[`editor.packShapes packs rotated shapes: packed shapes 1`] = `
|
|
|
116
116
|
]
|
|
117
117
|
`;
|
|
118
118
|
|
|
119
|
-
exports[`editor.packShapes packs shapes
|
|
119
|
+
exports[`editor.packShapes > packs shapes > packed shapes 1`] = `
|
|
120
120
|
[
|
|
121
121
|
{
|
|
122
122
|
"id": "shape:boxA",
|
|
@@ -152,7 +152,7 @@ exports[`editor.packShapes packs shapes using the adjacent shape margin option:
|
|
|
152
152
|
"rotation": 0,
|
|
153
153
|
"type": "geo",
|
|
154
154
|
"typeName": "shape",
|
|
155
|
-
"x":
|
|
155
|
+
"x": 84,
|
|
156
156
|
"y": 200,
|
|
157
157
|
},
|
|
158
158
|
{
|
|
@@ -226,13 +226,13 @@ exports[`editor.packShapes packs shapes using the adjacent shape margin option:
|
|
|
226
226
|
"rotation": 0,
|
|
227
227
|
"type": "geo",
|
|
228
228
|
"typeName": "shape",
|
|
229
|
-
"x":
|
|
229
|
+
"x": 316,
|
|
230
230
|
"y": 200,
|
|
231
231
|
},
|
|
232
232
|
]
|
|
233
233
|
`;
|
|
234
234
|
|
|
235
|
-
exports[`editor.packShapes packs shapes
|
|
235
|
+
exports[`editor.packShapes > packs shapes using the adjacent shape margin option > packed shapes 1`] = `
|
|
236
236
|
[
|
|
237
237
|
{
|
|
238
238
|
"id": "shape:boxA",
|
|
@@ -268,7 +268,7 @@ exports[`editor.packShapes packs shapes: packed shapes 1`] = `
|
|
|
268
268
|
"rotation": 0,
|
|
269
269
|
"type": "geo",
|
|
270
270
|
"typeName": "shape",
|
|
271
|
-
"x":
|
|
271
|
+
"x": 99,
|
|
272
272
|
"y": 200,
|
|
273
273
|
},
|
|
274
274
|
{
|
|
@@ -342,7 +342,7 @@ exports[`editor.packShapes packs shapes: packed shapes 1`] = `
|
|
|
342
342
|
"rotation": 0,
|
|
343
343
|
"type": "geo",
|
|
344
344
|
"typeName": "shape",
|
|
345
|
-
"x":
|
|
345
|
+
"x": 301,
|
|
346
346
|
"y": 200,
|
|
347
347
|
},
|
|
348
348
|
]
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import { Box, PI, TLShapeId } from '@tldraw/editor'
|
|
2
|
+
import { vi } from 'vitest'
|
|
2
3
|
import { TestEditor } from '../TestEditor'
|
|
3
4
|
import { TL } from '../test-jsx'
|
|
4
5
|
|
|
5
6
|
let editor: TestEditor
|
|
6
7
|
let ids: Record<string, TLShapeId>
|
|
7
8
|
|
|
8
|
-
|
|
9
|
+
vi.useFakeTimers()
|
|
9
10
|
|
|
10
11
|
beforeEach(() => {
|
|
11
12
|
editor = new TestEditor()
|
|
@@ -22,10 +23,10 @@ describe('when less than two shapes are selected', () => {
|
|
|
22
23
|
it('does nothing', () => {
|
|
23
24
|
editor.setSelectedShapes([ids.boxB])
|
|
24
25
|
|
|
25
|
-
const fn =
|
|
26
|
+
const fn = vi.fn()
|
|
26
27
|
editor.store.listen(fn)
|
|
27
28
|
editor.alignShapes(editor.getSelectedShapeIds(), 'top')
|
|
28
|
-
|
|
29
|
+
vi.advanceTimersByTime(1000)
|
|
29
30
|
expect(fn).not.toHaveBeenCalled()
|
|
30
31
|
})
|
|
31
32
|
})
|
|
@@ -34,7 +35,7 @@ describe('when multiple shapes are selected', () => {
|
|
|
34
35
|
it('does, undoes and redoes command', () => {
|
|
35
36
|
editor.markHistoryStoppingPoint('align')
|
|
36
37
|
editor.alignShapes(editor.getSelectedShapeIds(), 'top')
|
|
37
|
-
|
|
38
|
+
vi.advanceTimersByTime(1000)
|
|
38
39
|
|
|
39
40
|
editor.expectShapeToMatch({ id: ids.boxB, y: 0 })
|
|
40
41
|
editor.undo()
|
|
@@ -45,7 +46,7 @@ describe('when multiple shapes are selected', () => {
|
|
|
45
46
|
|
|
46
47
|
it('aligns top', () => {
|
|
47
48
|
editor.alignShapes(editor.getSelectedShapeIds(), 'top')
|
|
48
|
-
|
|
49
|
+
vi.advanceTimersByTime(1000)
|
|
49
50
|
|
|
50
51
|
editor.expectShapeToMatch(
|
|
51
52
|
{ id: ids.boxA, y: 0 },
|
|
@@ -56,7 +57,7 @@ describe('when multiple shapes are selected', () => {
|
|
|
56
57
|
|
|
57
58
|
it('aligns right', () => {
|
|
58
59
|
editor.alignShapes(editor.getSelectedShapeIds(), 'right')
|
|
59
|
-
|
|
60
|
+
vi.advanceTimersByTime(1000)
|
|
60
61
|
|
|
61
62
|
editor.expectShapeToMatch(
|
|
62
63
|
{ id: ids.boxA, x: 400 },
|
|
@@ -67,7 +68,7 @@ describe('when multiple shapes are selected', () => {
|
|
|
67
68
|
|
|
68
69
|
it('aligns bottom', () => {
|
|
69
70
|
editor.alignShapes(editor.getSelectedShapeIds(), 'bottom')
|
|
70
|
-
|
|
71
|
+
vi.advanceTimersByTime(1000)
|
|
71
72
|
|
|
72
73
|
editor.expectShapeToMatch(
|
|
73
74
|
{ id: ids.boxA, y: 400 },
|
|
@@ -78,7 +79,7 @@ describe('when multiple shapes are selected', () => {
|
|
|
78
79
|
|
|
79
80
|
it('aligns left', () => {
|
|
80
81
|
editor.alignShapes(editor.getSelectedShapeIds(), 'left')
|
|
81
|
-
|
|
82
|
+
vi.advanceTimersByTime(1000)
|
|
82
83
|
|
|
83
84
|
editor.expectShapeToMatch(
|
|
84
85
|
{ id: ids.boxA, x: 0 },
|
|
@@ -89,7 +90,7 @@ describe('when multiple shapes are selected', () => {
|
|
|
89
90
|
|
|
90
91
|
it('aligns center horizontal', () => {
|
|
91
92
|
editor.alignShapes(editor.getSelectedShapeIds(), 'center-horizontal')
|
|
92
|
-
|
|
93
|
+
vi.advanceTimersByTime(1000)
|
|
93
94
|
|
|
94
95
|
editor.expectShapeToMatch(
|
|
95
96
|
{ id: ids.boxA, x: 200 },
|
|
@@ -100,7 +101,7 @@ describe('when multiple shapes are selected', () => {
|
|
|
100
101
|
|
|
101
102
|
it('aligns center vertical', () => {
|
|
102
103
|
editor.alignShapes(editor.getSelectedShapeIds(), 'center-vertical')
|
|
103
|
-
|
|
104
|
+
vi.advanceTimersByTime(1000)
|
|
104
105
|
|
|
105
106
|
editor.expectShapeToMatch(
|
|
106
107
|
{ id: ids.boxA, y: 200 },
|
|
@@ -129,9 +130,9 @@ describe('when multiple shapes are selected', () => {
|
|
|
129
130
|
])
|
|
130
131
|
|
|
131
132
|
editor.alignShapes(editor.getSelectedShapeIds(), 'center-vertical')
|
|
132
|
-
|
|
133
|
+
vi.advanceTimersByTime(1000)
|
|
133
134
|
editor.alignShapes(editor.getSelectedShapeIds(), 'center-horizontal')
|
|
134
|
-
|
|
135
|
+
vi.advanceTimersByTime(1000)
|
|
135
136
|
|
|
136
137
|
const commonBounds = Box.Common([
|
|
137
138
|
editor.getShapePageBounds(ids.boxA)!,
|
|
@@ -168,9 +169,9 @@ describe('when multiple shapes are selected', () => {
|
|
|
168
169
|
])
|
|
169
170
|
|
|
170
171
|
editor.alignShapes(editor.getSelectedShapeIds(), 'top')
|
|
171
|
-
|
|
172
|
+
vi.advanceTimersByTime(1000)
|
|
172
173
|
editor.alignShapes(editor.getSelectedShapeIds(), 'left')
|
|
173
|
-
|
|
174
|
+
vi.advanceTimersByTime(1000)
|
|
174
175
|
|
|
175
176
|
const commonBounds = Box.Common([
|
|
176
177
|
editor.getShapePageBounds(ids.boxA)!,
|
|
@@ -208,9 +209,9 @@ describe('when multiple shapes are selected', () => {
|
|
|
208
209
|
|
|
209
210
|
editor.setSelectedShapes([ids.boxA, ids.boxB, ids.boxC])
|
|
210
211
|
editor.alignShapes(editor.getSelectedShapeIds(), 'bottom')
|
|
211
|
-
|
|
212
|
+
vi.advanceTimersByTime(1000)
|
|
212
213
|
editor.alignShapes(editor.getSelectedShapeIds(), 'right')
|
|
213
|
-
|
|
214
|
+
vi.advanceTimersByTime(1000)
|
|
214
215
|
|
|
215
216
|
const commonBounds = Box.Common([
|
|
216
217
|
editor.getShapePageBounds(ids.boxA)!,
|
|
@@ -251,9 +252,9 @@ describe('When shapes are parented to other shapes...', () => {
|
|
|
251
252
|
])
|
|
252
253
|
|
|
253
254
|
editor.alignShapes(editor.getSelectedShapeIds(), 'top')
|
|
254
|
-
|
|
255
|
+
vi.advanceTimersByTime(1000)
|
|
255
256
|
editor.alignShapes(editor.getSelectedShapeIds(), 'left')
|
|
256
|
-
|
|
257
|
+
vi.advanceTimersByTime(1000)
|
|
257
258
|
|
|
258
259
|
const commonBoundsAfter = Box.Common([
|
|
259
260
|
editor.getShapePageBounds(ids.boxC)!,
|
|
@@ -273,9 +274,9 @@ describe('When shapes are parented to other shapes...', () => {
|
|
|
273
274
|
])
|
|
274
275
|
|
|
275
276
|
editor.alignShapes(editor.getSelectedShapeIds(), 'bottom')
|
|
276
|
-
|
|
277
|
+
vi.advanceTimersByTime(1000)
|
|
277
278
|
editor.alignShapes(editor.getSelectedShapeIds(), 'right')
|
|
278
|
-
|
|
279
|
+
vi.advanceTimersByTime(1000)
|
|
279
280
|
|
|
280
281
|
const commonBoundsAfter = Box.Common([
|
|
281
282
|
editor.getShapePageBounds(ids.boxC)!,
|
|
@@ -339,9 +340,9 @@ describe('When shapes are parented to a rotated shape...', () => {
|
|
|
339
340
|
])
|
|
340
341
|
|
|
341
342
|
editor.alignShapes(editor.getSelectedShapeIds(), 'top')
|
|
342
|
-
|
|
343
|
+
vi.advanceTimersByTime(1000)
|
|
343
344
|
editor.alignShapes(editor.getSelectedShapeIds(), 'left')
|
|
344
|
-
|
|
345
|
+
vi.advanceTimersByTime(1000)
|
|
345
346
|
|
|
346
347
|
const commonBoundsAfter = Box.Common([
|
|
347
348
|
editor.getShapePageBounds(ids.boxC)!,
|
|
@@ -367,9 +368,9 @@ describe('When shapes are parented to a rotated shape...', () => {
|
|
|
367
368
|
])
|
|
368
369
|
|
|
369
370
|
editor.alignShapes(editor.getSelectedShapeIds(), 'bottom')
|
|
370
|
-
|
|
371
|
+
vi.advanceTimersByTime(1000)
|
|
371
372
|
editor.alignShapes(editor.getSelectedShapeIds(), 'right')
|
|
372
|
-
|
|
373
|
+
vi.advanceTimersByTime(1000)
|
|
373
374
|
|
|
374
375
|
const commonBoundsAfter = Box.Common([
|
|
375
376
|
editor.getShapePageBounds(ids.boxC)!,
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { vi } from 'vitest'
|
|
1
2
|
import { TestEditor } from '../TestEditor'
|
|
2
3
|
|
|
3
4
|
let editor: TestEditor
|
|
@@ -6,7 +7,7 @@ beforeEach(() => {
|
|
|
6
7
|
editor = new TestEditor()
|
|
7
8
|
})
|
|
8
9
|
|
|
9
|
-
|
|
10
|
+
vi.useFakeTimers()
|
|
10
11
|
|
|
11
12
|
it('zooms in gradually when duration is present and animtion speed is default', () => {
|
|
12
13
|
expect(editor.getZoomLevel()).toBe(1)
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { vi } from 'vitest'
|
|
1
2
|
import { TestEditor } from '../TestEditor'
|
|
2
3
|
|
|
3
4
|
let editor: TestEditor
|
|
@@ -14,9 +15,9 @@ it('centers on the point', () => {
|
|
|
14
15
|
it('centers on the point with animation', () => {
|
|
15
16
|
editor.centerOnPoint({ x: 400, y: 400 }, { animation: { duration: 200 } })
|
|
16
17
|
expect(editor.getViewportPageCenter()).not.toMatchObject({ x: 400, y: 400 })
|
|
17
|
-
|
|
18
|
+
vi.advanceTimersByTime(100)
|
|
18
19
|
expect(editor.getViewportPageCenter()).not.toMatchObject({ x: 400, y: 400 })
|
|
19
|
-
|
|
20
|
+
vi.advanceTimersByTime(200)
|
|
20
21
|
expect(editor.getViewportPageCenter()).toMatchObject({ x: 400, y: 400 })
|
|
21
22
|
})
|
|
22
23
|
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { createShapeId, TLArrowShape } from '@tldraw/editor'
|
|
2
|
+
import { vi } from 'vitest'
|
|
2
3
|
import { getArrowBindings } from '../../lib/shapes/arrow/shared'
|
|
3
4
|
import { TestEditor } from '../TestEditor'
|
|
4
5
|
|
|
@@ -27,13 +28,13 @@ const doMockClipboard = () => {
|
|
|
27
28
|
|
|
28
29
|
Object.assign(window.navigator, {
|
|
29
30
|
clipboard: {
|
|
30
|
-
write:
|
|
31
|
+
write: vi.fn((content: any) => {
|
|
31
32
|
context.current = content
|
|
32
33
|
}),
|
|
33
34
|
},
|
|
34
35
|
})
|
|
35
36
|
|
|
36
|
-
globalThis.ClipboardItem =
|
|
37
|
+
globalThis.ClipboardItem = vi.fn((payload: any) => payload) as any
|
|
37
38
|
|
|
38
39
|
return context
|
|
39
40
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { DefaultColorStyle, TLArrowShape, TLGeoShape, createShapeId } from '@tldraw/editor'
|
|
2
|
+
import { vi } from 'vitest'
|
|
2
3
|
import { TestEditor } from '../TestEditor'
|
|
3
4
|
|
|
4
5
|
let editor: TestEditor
|
|
@@ -126,7 +127,7 @@ it('Throws out all shapes if any shape is invalid', () => {
|
|
|
126
127
|
|
|
127
128
|
expect(editor.getCurrentPageShapeIds().size).toBe(n + 1)
|
|
128
129
|
|
|
129
|
-
console.error =
|
|
130
|
+
console.error = vi.fn()
|
|
130
131
|
|
|
131
132
|
// But these will need to be thrown out
|
|
132
133
|
expect(() => {
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { createBindingId, createShapeId } from '@tldraw/editor'
|
|
2
|
+
import { vi } from 'vitest'
|
|
2
3
|
import { getArrowBindings } from '../../lib/shapes/arrow/shared'
|
|
3
4
|
import { TestEditor } from '../TestEditor'
|
|
4
5
|
|
|
@@ -12,7 +13,7 @@ const ids = {
|
|
|
12
13
|
arrow1: createShapeId('arrow1'),
|
|
13
14
|
}
|
|
14
15
|
|
|
15
|
-
|
|
16
|
+
vi.useFakeTimers()
|
|
16
17
|
|
|
17
18
|
beforeEach(() => {
|
|
18
19
|
editor = new TestEditor()
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { PI, TLShapeId, createShapeId } from '@tldraw/editor'
|
|
2
|
+
import { vi } from 'vitest'
|
|
2
3
|
import { TestEditor } from '../TestEditor'
|
|
3
4
|
import { TL } from '../test-jsx'
|
|
4
5
|
|
|
5
|
-
|
|
6
|
+
vi.useFakeTimers()
|
|
6
7
|
|
|
7
8
|
let editor: TestEditor
|
|
8
9
|
|
|
@@ -46,10 +47,10 @@ describe('distributeShapes command', () => {
|
|
|
46
47
|
describe('when less than three shapes are selected', () => {
|
|
47
48
|
it('does nothing', () => {
|
|
48
49
|
editor.setSelectedShapes([ids.boxA, ids.boxB])
|
|
49
|
-
const fn =
|
|
50
|
+
const fn = vi.fn()
|
|
50
51
|
editor.store.listen(fn)
|
|
51
52
|
editor.distributeShapes(editor.getSelectedShapeIds(), 'horizontal')
|
|
52
|
-
|
|
53
|
+
vi.advanceTimersByTime(1000)
|
|
53
54
|
expect(fn).not.toHaveBeenCalled()
|
|
54
55
|
})
|
|
55
56
|
})
|
|
@@ -58,7 +59,7 @@ describe('distributeShapes command', () => {
|
|
|
58
59
|
it('distributeShapes horizontally', () => {
|
|
59
60
|
editor.selectAll()
|
|
60
61
|
editor.distributeShapes(editor.getSelectedShapeIds(), 'horizontal')
|
|
61
|
-
|
|
62
|
+
vi.advanceTimersByTime(1000)
|
|
62
63
|
editor.expectShapeToMatch(
|
|
63
64
|
{ id: ids.boxA, x: 0 },
|
|
64
65
|
{ id: ids.boxB, x: 200 },
|
|
@@ -70,7 +71,7 @@ describe('distributeShapes command', () => {
|
|
|
70
71
|
editor.updateShapes([{ id: ids.boxC, type: 'geo', x: 25 }])
|
|
71
72
|
editor.selectAll()
|
|
72
73
|
editor.distributeShapes(editor.getSelectedShapeIds(), 'horizontal')
|
|
73
|
-
|
|
74
|
+
vi.advanceTimersByTime(1000)
|
|
74
75
|
editor.expectShapeToMatch(
|
|
75
76
|
{ id: ids.boxA, x: 0 },
|
|
76
77
|
{ id: ids.boxB, x: 100 },
|
|
@@ -81,7 +82,7 @@ describe('distributeShapes command', () => {
|
|
|
81
82
|
it('distributeShapes vertically', () => {
|
|
82
83
|
editor.selectAll()
|
|
83
84
|
editor.distributeShapes(editor.getSelectedShapeIds(), 'vertical')
|
|
84
|
-
|
|
85
|
+
vi.advanceTimersByTime(1000)
|
|
85
86
|
editor.expectShapeToMatch(
|
|
86
87
|
{ id: ids.boxA, y: 0 },
|
|
87
88
|
{ id: ids.boxB, y: 200 },
|
|
@@ -93,7 +94,7 @@ describe('distributeShapes command', () => {
|
|
|
93
94
|
editor.updateShapes([{ id: ids.boxC, type: 'geo', y: 25 }])
|
|
94
95
|
editor.selectAll()
|
|
95
96
|
editor.distributeShapes(editor.getSelectedShapeIds(), 'vertical')
|
|
96
|
-
|
|
97
|
+
vi.advanceTimersByTime(1000)
|
|
97
98
|
editor.expectShapeToMatch(
|
|
98
99
|
{ id: ids.boxA, y: 0 },
|
|
99
100
|
{ id: ids.boxB, y: 100 },
|
|
@@ -135,7 +136,7 @@ describe('distributeShapes command', () => {
|
|
|
135
136
|
editor.setSelectedShapes([ids.boxB, ids.boxC, ids.boxD])
|
|
136
137
|
|
|
137
138
|
editor.distributeShapes(editor.getSelectedShapeIds(), 'horizontal')
|
|
138
|
-
|
|
139
|
+
vi.advanceTimersByTime(1000)
|
|
139
140
|
|
|
140
141
|
editor.expectShapeToMatch(
|
|
141
142
|
{ id: ids.boxB, x: 100 },
|
|
@@ -177,7 +178,7 @@ describe('distributeShapes command', () => {
|
|
|
177
178
|
editor.setSelectedShapes([ids.boxB, ids.boxC, ids.boxD])
|
|
178
179
|
|
|
179
180
|
editor.distributeShapes(editor.getSelectedShapeIds(), 'horizontal')
|
|
180
|
-
|
|
181
|
+
vi.advanceTimersByTime(1000)
|
|
181
182
|
|
|
182
183
|
editor.expectShapeToMatch(
|
|
183
184
|
{ id: ids.boxB, x: 100 },
|
|
@@ -222,7 +223,7 @@ describe('distributeShapes command', () => {
|
|
|
222
223
|
editor.setSelectedShapes([ids.boxB, ids.boxC, ids.boxD])
|
|
223
224
|
|
|
224
225
|
editor.distributeShapes(editor.getSelectedShapeIds(), 'horizontal')
|
|
225
|
-
|
|
226
|
+
vi.advanceTimersByTime(1000)
|
|
226
227
|
|
|
227
228
|
editor.expectShapeToMatch(
|
|
228
229
|
{ id: ids.boxB, x: 100 },
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { DefaultDashStyle, TLGeoShape, createShapeId, toRichText } from '@tldraw/editor'
|
|
2
|
+
import { vi } from 'vitest'
|
|
2
3
|
import { TestEditor } from '../TestEditor'
|
|
3
4
|
|
|
4
5
|
let editor: TestEditor
|
|
@@ -14,7 +15,7 @@ function parseSvg({ svg }: { svg: string } = { svg: '' }) {
|
|
|
14
15
|
return parser.parseFromString(svg, 'image/svg+xml').firstElementChild as SVGSVGElement
|
|
15
16
|
}
|
|
16
17
|
|
|
17
|
-
|
|
18
|
+
vi.useRealTimers()
|
|
18
19
|
|
|
19
20
|
beforeEach(() => {
|
|
20
21
|
editor = new TestEditor()
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { createShapeId } from '@tldraw/editor'
|
|
2
|
+
import { vi } from 'vitest'
|
|
2
3
|
import { TestEditor } from '../TestEditor'
|
|
3
4
|
|
|
4
5
|
let editor: TestEditor
|
|
@@ -10,7 +11,7 @@ const ids = {
|
|
|
10
11
|
boxD: createShapeId('boxD'),
|
|
11
12
|
}
|
|
12
13
|
|
|
13
|
-
|
|
14
|
+
vi.useFakeTimers()
|
|
14
15
|
|
|
15
16
|
beforeEach(() => {
|
|
16
17
|
editor = new TestEditor()
|
|
@@ -45,7 +46,7 @@ describe('editor.packShapes', () => {
|
|
|
45
46
|
editor.selectAll()
|
|
46
47
|
const centerBefore = editor.getSelectionRotatedPageBounds()!.center.clone()
|
|
47
48
|
editor.packShapes(editor.getSelectedShapeIds())
|
|
48
|
-
|
|
49
|
+
vi.advanceTimersByTime(1000)
|
|
49
50
|
expect(
|
|
50
51
|
editor.getCurrentPageShapes().map((s) => ({ ...s, parentId: 'wahtever' }))
|
|
51
52
|
).toMatchSnapshot('packed shapes')
|
|
@@ -57,7 +58,7 @@ describe('editor.packShapes', () => {
|
|
|
57
58
|
editor.selectAll()
|
|
58
59
|
const centerBefore = editor.getSelectionRotatedPageBounds()!.center.clone()
|
|
59
60
|
editor.packShapes(editor.getSelectedShapeIds(), 16)
|
|
60
|
-
|
|
61
|
+
vi.advanceTimersByTime(1000)
|
|
61
62
|
expect(
|
|
62
63
|
editor.getCurrentPageShapes().map((s) => ({ ...s, parentId: 'wahtever' }))
|
|
63
64
|
).toMatchSnapshot('packed shapes')
|
|
@@ -68,7 +69,7 @@ describe('editor.packShapes', () => {
|
|
|
68
69
|
it('packs rotated shapes', () => {
|
|
69
70
|
editor.updateShapes([{ id: ids.boxA, type: 'geo', rotation: Math.PI }])
|
|
70
71
|
editor.selectAll().packShapes(editor.getSelectedShapeIds(), 16)
|
|
71
|
-
|
|
72
|
+
vi.advanceTimersByTime(1000)
|
|
72
73
|
expect(
|
|
73
74
|
editor.getCurrentPageShapes().map((s) => ({ ...s, parentId: 'wahtever' }))
|
|
74
75
|
).toMatchSnapshot('packed shapes')
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { createShapeId } from '@tldraw/editor'
|
|
2
|
+
import { vi } from 'vitest'
|
|
2
3
|
import { TestEditor } from '../TestEditor'
|
|
3
4
|
|
|
4
5
|
let editor: TestEditor
|
|
@@ -40,20 +41,20 @@ beforeEach(() => {
|
|
|
40
41
|
})
|
|
41
42
|
|
|
42
43
|
describe('editor.rotateShapesBy', () => {
|
|
43
|
-
let fnStart =
|
|
44
|
-
let fnChange =
|
|
45
|
-
let fnEnd =
|
|
44
|
+
let fnStart = vi.fn()
|
|
45
|
+
let fnChange = vi.fn()
|
|
46
|
+
let fnEnd = vi.fn()
|
|
46
47
|
|
|
47
48
|
beforeEach(() => {
|
|
48
49
|
// Set start / change / end events on only the geo shape
|
|
49
50
|
const util = editor.getShapeUtil('geo')
|
|
50
51
|
|
|
51
52
|
// Bad! who did this (did I do this)
|
|
52
|
-
util.onRotateStart = fnStart =
|
|
53
|
+
util.onRotateStart = fnStart = vi.fn()
|
|
53
54
|
|
|
54
|
-
util.onRotate = fnChange =
|
|
55
|
+
util.onRotate = fnChange = vi.fn()
|
|
55
56
|
|
|
56
|
-
util.onRotateEnd = fnEnd =
|
|
57
|
+
util.onRotateEnd = fnEnd = vi.fn()
|
|
57
58
|
})
|
|
58
59
|
it('Rotates shapes and fires events', () => {
|
|
59
60
|
// Select the shape...
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { Box, DEFAULT_CAMERA_OPTIONS, Vec, createShapeId } from '@tldraw/editor'
|
|
2
|
+
import { vi } from 'vitest'
|
|
2
3
|
import { TestEditor } from '../TestEditor'
|
|
3
4
|
|
|
4
5
|
let editor: TestEditor
|
|
@@ -366,14 +367,14 @@ describe('CameraOptions.zoomSpeed', () => {
|
|
|
366
367
|
editor.setCameraOptions({ ...DEFAULT_CAMERA_OPTIONS, zoomSpeed: 2 })
|
|
367
368
|
expect(editor.getCamera()).toMatchObject({ x: 0, y: 0, z: 1 })
|
|
368
369
|
editor.setCurrentTool('zoom').click()
|
|
369
|
-
|
|
370
|
+
vi.advanceTimersByTime(300)
|
|
370
371
|
expect(editor.getCamera()).toMatchObject({ x: 0, y: 0, z: 2 })
|
|
371
372
|
})
|
|
372
373
|
it('Does not affect zoom tool zooming (0.5x)', () => {
|
|
373
374
|
editor.setCameraOptions({ ...DEFAULT_CAMERA_OPTIONS, zoomSpeed: 0.5 })
|
|
374
375
|
expect(editor.getCamera()).toMatchObject({ x: 0, y: 0, z: 1 })
|
|
375
376
|
editor.setCurrentTool('zoom').click()
|
|
376
|
-
|
|
377
|
+
vi.advanceTimersByTime(300)
|
|
377
378
|
expect(editor.getCamera()).toMatchObject({ x: 0, y: 0, z: 2 })
|
|
378
379
|
})
|
|
379
380
|
it('Does not affect editor zoom method (2x)', () => {
|
|
@@ -1028,7 +1029,7 @@ describe('Allows mixed values for x and y', () => {
|
|
|
1028
1029
|
|
|
1029
1030
|
test('it animated towards the constrained viewport rather than the given viewport', () => {
|
|
1030
1031
|
// @ts-expect-error
|
|
1031
|
-
const mockAnimateToViewport = (editor._animateToViewport =
|
|
1032
|
+
const mockAnimateToViewport = (editor._animateToViewport = vi.fn())
|
|
1032
1033
|
editor.setCameraOptions({
|
|
1033
1034
|
...DEFAULT_CAMERA_OPTIONS,
|
|
1034
1035
|
constraints: {
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { IndexKey, PageRecordType, TLPageId, createShapeId } from '@tldraw/editor'
|
|
2
|
+
import { vi } from 'vitest'
|
|
2
3
|
import { TestEditor } from '../TestEditor'
|
|
3
4
|
|
|
4
5
|
let editor: TestEditor
|
|
@@ -76,7 +77,7 @@ describe('setCurrentPage', () => {
|
|
|
76
77
|
it('logs an error when trying to navigate to a page that does not exist', () => {
|
|
77
78
|
const initialPageId = editor.getCurrentPageId()
|
|
78
79
|
expect(editor.getCurrentPageId()).toBe(initialPageId)
|
|
79
|
-
console.error =
|
|
80
|
+
console.error = vi.fn()
|
|
80
81
|
|
|
81
82
|
expect(() => {
|
|
82
83
|
editor.setCurrentPage('page:does-not-exist' as TLPageId)
|
|
@@ -105,7 +106,7 @@ describe('setCurrentPage', () => {
|
|
|
105
106
|
})
|
|
106
107
|
|
|
107
108
|
it('applies camera constraints', () => {
|
|
108
|
-
const spy =
|
|
109
|
+
const spy = vi.spyOn(editor, 'setCamera')
|
|
109
110
|
|
|
110
111
|
let currentPageId = editor.getCurrentPageId()
|
|
111
112
|
expect(currentPageId).toMatchInlineSnapshot(`"page:page"`)
|