@tldraw/editor 3.13.0-canary.1793786aff8a → 3.13.0-canary.2449ca610c41

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 (50) hide show
  1. package/dist-cjs/index.d.ts +5 -0
  2. package/dist-cjs/index.js +1 -1
  3. package/dist-cjs/lib/TldrawEditor.js +2 -1
  4. package/dist-cjs/lib/TldrawEditor.js.map +2 -2
  5. package/dist-cjs/lib/components/default-components/DefaultErrorFallback.js +14 -12
  6. package/dist-cjs/lib/components/default-components/DefaultErrorFallback.js.map +2 -2
  7. package/dist-cjs/lib/components/default-components/DefaultSpinner.js +1 -1
  8. package/dist-cjs/lib/components/default-components/DefaultSpinner.js.map +2 -2
  9. package/dist-cjs/lib/editor/Editor.js +25 -20
  10. package/dist-cjs/lib/editor/Editor.js.map +3 -3
  11. package/dist-cjs/lib/hooks/useDocumentEvents.js +3 -2
  12. package/dist-cjs/lib/hooks/useDocumentEvents.js.map +2 -2
  13. package/dist-cjs/lib/license/LicenseManager.js +8 -1
  14. package/dist-cjs/lib/license/LicenseManager.js.map +2 -2
  15. package/dist-cjs/lib/options.js.map +2 -2
  16. package/dist-cjs/lib/utils/dom.js +3 -3
  17. package/dist-cjs/lib/utils/dom.js.map +2 -2
  18. package/dist-cjs/version.js +3 -3
  19. package/dist-cjs/version.js.map +1 -1
  20. package/dist-esm/index.d.mts +5 -0
  21. package/dist-esm/index.mjs +1 -1
  22. package/dist-esm/lib/TldrawEditor.mjs +2 -1
  23. package/dist-esm/lib/TldrawEditor.mjs.map +2 -2
  24. package/dist-esm/lib/components/default-components/DefaultErrorFallback.mjs +14 -12
  25. package/dist-esm/lib/components/default-components/DefaultErrorFallback.mjs.map +2 -2
  26. package/dist-esm/lib/components/default-components/DefaultSpinner.mjs +1 -1
  27. package/dist-esm/lib/components/default-components/DefaultSpinner.mjs.map +2 -2
  28. package/dist-esm/lib/editor/Editor.mjs +25 -20
  29. package/dist-esm/lib/editor/Editor.mjs.map +3 -3
  30. package/dist-esm/lib/hooks/useDocumentEvents.mjs +3 -2
  31. package/dist-esm/lib/hooks/useDocumentEvents.mjs.map +2 -2
  32. package/dist-esm/lib/license/LicenseManager.mjs +8 -1
  33. package/dist-esm/lib/license/LicenseManager.mjs.map +2 -2
  34. package/dist-esm/lib/options.mjs.map +2 -2
  35. package/dist-esm/lib/utils/dom.mjs +3 -3
  36. package/dist-esm/lib/utils/dom.mjs.map +2 -2
  37. package/dist-esm/version.mjs +3 -3
  38. package/dist-esm/version.mjs.map +1 -1
  39. package/editor.css +6 -0
  40. package/package.json +7 -7
  41. package/src/lib/TldrawEditor.tsx +6 -1
  42. package/src/lib/components/default-components/DefaultErrorFallback.tsx +25 -14
  43. package/src/lib/components/default-components/DefaultSpinner.tsx +1 -1
  44. package/src/lib/editor/Editor.ts +22 -19
  45. package/src/lib/hooks/useDocumentEvents.ts +7 -2
  46. package/src/lib/license/LicenseManager.test.ts +40 -0
  47. package/src/lib/license/LicenseManager.ts +13 -1
  48. package/src/lib/options.ts +4 -0
  49. package/src/lib/utils/dom.ts +4 -4
  50. package/src/version.ts +3 -3
@@ -317,6 +317,46 @@ describe('LicenseManager', () => {
317
317
  expect(result.isDomainValid).toBe(false)
318
318
  })
319
319
 
320
+ it('Succeeds if it is a vscode extension', async () => {
321
+ // @ts-ignore
322
+ delete window.location
323
+ // @ts-ignore
324
+ window.location = new URL(
325
+ 'vscode-webview:vscode-webview://1ipd8pun8ud7nd7hv9d112g7evi7m10vak9vviuvia66ou6aibp3/index.html?id=6ec2dc7a-afe9-45d9-bd71-1749f9568d28&origin=955b256f-37e1-4a72-a2f4-ad633e88239c&swVersion=4&extensionId=tldraw-org.tldraw-vscode&platform=electron&vscode-resource-base-authority=vscode-resource.vscode-cdn.net&parentOrigin=vscode-file%3A%2F%2Fvscode-app'
326
+ )
327
+
328
+ const permissiveHostsInfo = JSON.parse(STANDARD_LICENSE_INFO)
329
+ permissiveHostsInfo[PROPERTIES.HOSTS] = ['tldraw-org.tldraw-vscode']
330
+ const permissiveLicenseKey = await generateLicenseKey(
331
+ JSON.stringify(permissiveHostsInfo),
332
+ keyPair
333
+ )
334
+ const result = (await licenseManager.getLicenseFromKey(
335
+ permissiveLicenseKey
336
+ )) as ValidLicenseKeyResult
337
+ expect(result.isDomainValid).toBe(true)
338
+ })
339
+
340
+ it('Fails if it is a vscode extension with the wrong id', async () => {
341
+ // @ts-ignore
342
+ delete window.location
343
+ // @ts-ignore
344
+ window.location = new URL(
345
+ 'vscode-webview:vscode-webview://1ipd8pun8ud7nd7hv9d112g7evi7m10vak9vviuvia66ou6aibp3/index.html?id=6ec2dc7a-afe9-45d9-bd71-1749f9568d28&origin=955b256f-37e1-4a72-a2f4-ad633e88239c&swVersion=4&extensionId=tldraw-org.tldraw-vscode&platform=electron&vscode-resource-base-authority=vscode-resource.vscode-cdn.net&parentOrigin=vscode-file%3A%2F%2Fvscode-app'
346
+ )
347
+
348
+ const permissiveHostsInfo = JSON.parse(STANDARD_LICENSE_INFO)
349
+ permissiveHostsInfo[PROPERTIES.HOSTS] = ['blah-org.blah-vscode']
350
+ const permissiveLicenseKey = await generateLicenseKey(
351
+ JSON.stringify(permissiveHostsInfo),
352
+ keyPair
353
+ )
354
+ const result = (await licenseManager.getLicenseFromKey(
355
+ permissiveLicenseKey
356
+ )) as ValidLicenseKeyResult
357
+ expect(result.isDomainValid).toBe(false)
358
+ })
359
+
320
360
  it('Checks for internal license', async () => {
321
361
  const internalLicenseInfo = JSON.parse(STANDARD_LICENSE_INFO)
322
362
  internalLicenseInfo[PROPERTIES.FLAGS] = FLAGS.INTERNAL_LICENSE
@@ -111,7 +111,10 @@ export class LicenseManager {
111
111
  if (testEnvironment === 'production') return false
112
112
 
113
113
  // If we are using https on a non-localhost domain we assume it's a production env and a development one otherwise
114
- return window.location.protocol !== 'https:' || window.location.hostname === 'localhost'
114
+ return (
115
+ !['https:', 'vscode-webview:'].includes(window.location.protocol) ||
116
+ window.location.hostname === 'localhost'
117
+ )
115
118
  }
116
119
 
117
120
  private async extractLicenseKey(licenseKey: string): Promise<LicenseInfo> {
@@ -250,6 +253,15 @@ export class LicenseManager {
250
253
  return globToRegex.test(currentHostname) || globToRegex.test(`www.${currentHostname}`)
251
254
  }
252
255
 
256
+ // VSCode support
257
+ if (window.location.protocol === 'vscode-webview:') {
258
+ const currentUrl = new URL(window.location.href)
259
+ const extensionId = currentUrl.searchParams.get('extensionId')
260
+ if (normalizedHost === extensionId) {
261
+ return true
262
+ }
263
+ }
264
+
253
265
  return false
254
266
  })
255
267
  }
@@ -80,6 +80,10 @@ export interface TldrawOptions {
80
80
  * nonce to use in the editor's styles.
81
81
  */
82
82
  readonly nonce: string | undefined
83
+ /**
84
+ * Branding name of the app, currently only used for adding aria-label for the application.
85
+ */
86
+ readonly branding?: string
83
87
  }
84
88
 
85
89
  /** @public */
@@ -91,14 +91,14 @@ export const setStyleProperty = (
91
91
  elm.style.setProperty(property, value as string)
92
92
  }
93
93
 
94
- const INPUTS = ['input', 'select', 'button', 'textarea']
95
-
96
94
  /** @internal */
97
- export function activeElementShouldCaptureKeys() {
95
+ export function activeElementShouldCaptureKeys(allowButtons = false) {
98
96
  const { activeElement } = document
97
+ const elements = allowButtons ? ['input', 'textarea'] : ['input', 'select', 'button', 'textarea']
99
98
  return !!(
100
99
  activeElement &&
101
100
  ((activeElement as HTMLElement).isContentEditable ||
102
- INPUTS.indexOf(activeElement.tagName.toLowerCase()) > -1)
101
+ elements.indexOf(activeElement.tagName.toLowerCase()) > -1 ||
102
+ activeElement.classList.contains('tlui-slider__thumb'))
103
103
  )
104
104
  }
package/src/version.ts CHANGED
@@ -1,9 +1,9 @@
1
1
  // This file is automatically generated by internal/scripts/refresh-assets.ts.
2
2
  // Do not edit manually. Or do, I'm a comment, not a cop.
3
3
 
4
- export const version = '3.13.0-canary.1793786aff8a'
4
+ export const version = '3.13.0-canary.2449ca610c41'
5
5
  export const publishDates = {
6
6
  major: '2024-09-13T14:36:29.063Z',
7
- minor: '2025-04-15T13:56:27.884Z',
8
- patch: '2025-04-15T13:56:27.884Z',
7
+ minor: '2025-04-29T10:47:44.728Z',
8
+ patch: '2025-04-29T10:47:44.728Z',
9
9
  }