Releases
How tldraw is versioned
Unlike many JavaScript packages distributed on NPM, the tldraw SDK does not follow semantic versioning in its release versions. Here's what we do instead:
- Major version bumps are very rare and we reserve them for special changes that signify a paradigm shift of some kind.
- Minor version bumps are released on a regular cadence - approximately monthly. They may contain breaking changes. We aim to make breaking changes as minimally disruptive as possible, but tldraw is actively evolving as we add new features. We recommend updating tldraw at a similar pace to our release cadence, and be sure to check the release notes.
- Patch version bumps are for bugfixes and hotfixes that can't wait for the next cadence release.
Current release: v3.0.0
Welcome to the 3.0.0 release of the tldraw SDK. This release includes a number of new features, improved features, and bug fixes.
The biggest change, and the reason for a new major version, is our new watermark and licenses. See the New licenses section below.
Thank you also to all of our first-time contributors: Alex (@qwertyu-alex), @dimitriadamou, Ravi theja (@raviteja83), & Zachary Wood (@zacwood9).
What's new
New license
This release includes new licenses for the tldraw SDK. These are meant to make the SDK more accessible to small teams and independent developers with commercial products.
Previously, the tldraw SDK was provided under a non-commercial license, with commercial licenses available for purchase separately. In this version, the tldraw SDK's new license permits use in both commercial non-commercial projects so long as our "Made with tldraw" watermark is visible.
If you wish to use the tldraw SDK without the watermark, you can purchase a Business License. You'll receive a License Key that hides the watermark while the license is active. For more information, or to request a business license, visit tldraw.dev.
The watermark is a link to tldraw.dev. It becomes active after a short delay, ensuring that users don't accidentally click on it while trying to perform other actions on the canvas.
If you don't have a business license, then you must preserve the watermark as it is and not obscure it, disable it, or otherwise make it inaccessible to your users.
If you have questions or comments, let us know at hello@tldraw.com.
Deep Links
'Deep Links' are URLs that point to a specific part of a document, like a particular shape or a particular part of a page. We added some APIs to help creating and using deep links, and for updating the current page's URL as the user navigates around the document.
See the Deep Links documentation for more information and example code.
(#4333)
Export custom shapes as images
Tldraw lets you convert the contents of your canvas to a PNG or SVG image. Previously, this relied on each shape implementing a method that would render it as an SVG. If your shape is complex with lots of HTML/CSS UI, this isn't an easy thing to do.
Now, custom shapes are supported in image exports by default. This relies on embedding HTML/CSS into an SVG which does have some issues, so it's worth reading about image exports in tldraw and testing the feature for yourself.
(#4403)
Custom embeds API
Tldraw supports including content from other websites (e.g. YouTube, Google Maps, CodeSandbox) via the embed
shape. Previously the list of supported websites was hard-coded. This release includes support to fully customize the list of supported websites. This means you can now add your own custom embeds, or remove existing ones.
(#4326)
Enabling text search with the getText
API
Previously there was no reliable way to get the human-readable text from a shape. This is now possible with the new getText
API.
The main intended usage of this API is to implement text search in your application. We provide a basic example of how to go about that here
Move the camera while spacebar panning
While holding the space bar, use the arrow keys to move the viewport.
Breaking changes
-
Removes the
TLRotationSnapshot
type. This was exported by mistake and should not have been useful to SDK users. -
The
onEditorMount
option tocreateTLStore
is now calledonMount
. (#4320) -
Editor.mark()
was deprecated in favour ofEditor.markHistoryStoppingPoint()
. (#4250)In most cases you can treat this as a renamed method. However if you previously passed an ID to
Editor.mark()
, you should now use the return value ofEditor.markHistoryStoppingPoint()
as the mark ID instead. -
Rename
TLSvgOptions
toTLImageExportOptions
(#4442) -
Setting
editor.updateInstanceState({isFocused: true})
no longer triggers afocus
event on the canvas container. Useeditor.focus()
andeditor.blur()
instead.
Improvements
- Enable interpolation method for all builtin shapes, including draw and highlighter. (#4241)
- Custom shapes (and our own bookmark shapes) now render in image exports by default. (#4403)
- We detect when there are multiple versions of tldraw installed and let you know, as this can cause bugs in your application. (#4398)
- Improved
loadSnapshot
to preserve page state like camera position and current page if no session snapshot is provided. (#4392) - Make arrow labels reflow text dynamically. (#4384)
- Prevent accidental creation of tiny fixed-width text shapes. (#4293) (#4331)
- Upgrade fractional indexing to use jittered indexes, to help avoid conflicts (#4312)
- Show ghost preview image whilst uploading images (#3988)
- Update the 'x-box' icon to more closely resemble the shape itself. (#4287)
API changes
- Allow the
<TldrawImage />
component to accept custom asset URLs. (#4465) - Allow the users to programmatically disable the context menu. (#4415)
- Make
rotateShapesBy
work with any shapes, not just the currently selected shapes. (#4385) - When deleting actions or tools using overrides, menu items are automatically removed. (#4345)
- Make the page management UI disappear when maxPages is 1 (#4348)
- Export some missing components that are used in the
DefaultToolbar
(#4321) - Export
registerDefaultSideEffects
andregisterDefaultExternalContentHandler
(#4323) - Added an option for for the maximum number of files that a user can paste/drop at once (#4294)
- Added support for laser delay customization (#4300)
- Allow scribble points to have non default z values. (#4260)
- Export certain helpers for pasting external content. (#4258)
Bug fixes
- Fix an issue with not being able to cancel out changing of page names and user names. (#4408)
- Fix an issue with migrating legacy assets in Firefox. (#4432)
- Allow the 'insert media' file picker to use the custom mime types configuration to control which files can be selected. (#4453)
- Fixed a perf issue that caused shapes to rerender too often. (#4433)
- Fixed issue where pinch gestures on Safari would snap camera at low zoom levels. (#4427)
- Fix exports for dark mode frames and flipped images. (#4424)
- Prevented a harmless Unhandled Promise Rejection error message during dev time with React strict mode. (#4406)
- Fix a bug with embed dialog throwing an error when entering an invalid url. (#4397)
- Fix a couple of minor cloud rendering issues. (#4382) (#4380)
- Fix cropping of images that have been flipped. (#4337) (#4350)
- Fix fullscreen video rendering. (#4338)
- Fix bookmark shape rendering. (#4330)
- Fix an issue with duplicating groups. (#4316)
- Fix dotted line draw shape rendering when zoomed out. (#4261)
- Fix the threshold for arrow label snapping. (#4265)
- Fix the checkbox value for the theme menu item. (#4289)
- Fix a minor rendering issue in the sharing menu. (#4271)
- Prevent accidental drawing / tool usage when closing menus. (#4247)
Authors
-
Alex (@SomeHats)
-
Alex (@qwertyu-alex)
-
David Sheldrick (@ds300)
-
Lu Wilson (@TodePond)
-
Lukas Wiesehan (@lukaswiesehan)
-
Mime Čuvalo (@mimecuvalo)
-
Mitja Bezenšek (@MitjaBezensek)
-
Ravi theja (@raviteja83)
-
Steve Ruiz (@steveruizok)
-
Taha (@Taha-Hassan-Git)
-
Zachary Wood (@zacwood9)