Editor
Public Class
Table of Contents
- Properties
- allShapesCommonBounds
- animationSpeed
- assets
- brush
- camera
- canMoveCamera
- canRedo
- canUndo
- croppingId
- cullingBounds
- cullingBoundsExpanded
- currentPage
- currentPageId
- currentToolId
- cursor
- devicePixelRatio
- disposables
- documentSettings
- editingId
- editingShape
- erasingIds
- erasingIdsSet
- externalContentManager
- focusLayerId
- focusLayerShape
- getContainer
- gridSize
- hintingIds
- history
- hoveredId
- hoveredShape
- inputs
- instanceState
- isChangingStyle
- isChromeForIos
- isCoarsePointer
- isDarkMode
- isFocused
- isFocusMode
- isGridMode
- isIos
- isMenuOpen
- isPenMode
- isReadOnly
- isSafari
- isSnapMode
- isToolLocked
- locale
- onlySelectedShape
- opacity
- openMenus
- pages
- pageState
- renderingShapes
- root
- scribble
- selectedIds
- selectedIdsSet
- selectedPageBounds
- selectedShapes
- selectionBounds
- selectionPageCenter
- selectionRotation
- shapeIds
- shapesArray
- shapeUtils
- snaps
- sortedShapesArray
- store
- styles
- textMeasure
- user
- viewportPageBounds
- viewportPageCenter
- viewportScreenBounds
- viewportScreenCenter
- zoomBrush
- zoomLevel
- Methods
- addOpenMenu
- alignShapes
- animateCamera
- animateShapes
- animateToShape
- bail
- bailToMark
- batch
- blur
- bringForward
- bringToFront
- cancel
- cancelDoubleClick
- centerOnPoint
- complete
- createAssets
- createPage
- createShapes
- deleteAssets
- deleteOpenMenu
- deletePage
- deleteShapes
- deselect
- dispatch
- dispose
- distributeShapes
- duplicatePage
- duplicateShapes
- findAncestor
- findCommonAncestor
- flipShapes
- focus
- getAncestors
- getAncestorsById
- getArrowsBoundTo
- getAssetById
- getAssetBySrc
- getBounds
- getBoundsById
- getClipPathById
- getContent
- getCssColor
- getDeltaInParentSpace
- getDeltaInShapeSpace
- getDroppingShape
- getHighestIndexForParent
- getMaskedPageBounds
- getMaskedPageBoundsById
- getOutermostSelectableShape
- getOutline
- getOutlineById
- getPageBounds
- getPageBoundsById
- getPageById
- getPageCenter
- getPageCenterById
- getPageCorners
- getPageInfoById
- getPageMaskById
- getPagePointById
- getPageRotation
- getPageRotationById
- getPageStateByPageId
- getPageTransform
- getPageTransformById
- getParentIdForNewShapeAtPoint
- getParentPageId
- getParentShape
- getParentsMappedToChildren
- getParentTransform
- getPointInParentSpace
- getPointInShapeSpace
- getShapeAndDescendantIds
- getShapeById
- getShapeIdsInPage
- getShapesAtPoint
- getShapeUtil
- getShapeUtil
- getSortedChildIds
- getStateDescendant
- getStrokeWidth
- getSvg
- getTransform
- groupShapes
- hasAncestor
- interrupt
- isIn
- isInAny
- isPointInShape
- isSelected
- isShapeInPage
- isShapeInViewport
- isShapeOfType
- isShapeOrAncestorLocked
- isWithinSelection
- mark
- moveShapesToPage
- nudgeShapes
- packShapes
- pageToScreen
- pan
- panZoomIntoView
- popFocusLayer
- putContent
- putExternalContent
- redo
- renamePage
- reorderShapes
- reparentShapesById
- replaceStoreContentsWithRecordsForOtherDocument
- resetZoom
- resizeShape
- rotateShapesBy
- screenToPage
- select
- selectAll
- selectNone
- sendBackward
- sendToBack
- setAnimationSpeed
- setBrush
- setCamera
- setCroppingId
- setCurrentPageId
- setCursor
- setDarkMode
- setEditingId
- setErasingIds
- setFocusLayer
- setFocusMode
- setGridMode
- setHintingIds
- setHoveredId
- setInstancePageState
- setLocale
- setOpacity
- setPenMode
- setProp
- setReadOnly
- setScribble
- setSelectedIds
- setSelectedTool
- setSnapMode
- setToolLocked
- setZoomBrush
- slideCamera
- stackShapes
- startFollowingUser
- stopCameraAnimation
- stopFollowingUser
- stretchShapes
- toggleLock
- undo
- ungroupShapes
- updateAssets
- updateDocumentSettings
- updateInstanceState
- updatePage
- updateShapes
- updateViewportScreenBounds
- visitDescendants
- zoomIn
- zoomOut
- zoomToBounds
- zoomToContent
- zoomToFit
- zoomToSelection
Signature
class Editor extends EventEmitter<TLEventMap> {}
References
Constructor
Public Constructor
Constructs a new instance of the Editor
class
Parameters
Name | Description |
---|---|
|
|
References
Properties
allShapesCommonBounds
Public Readonly Property
The common bounds of all of the shapes on the page.
Signature
get allShapesCommonBounds(): Box2d | null
References
animationSpeed
Public Readonly Property
The user's chosen animation speed.
Signature
get animationSpeed(): number
assets
Public Readonly Property
Get all assets in the editor.
Signature
get assets(): (
| import('@tldraw/tlschema').TLBookmarkAsset
| TLImageAsset
| TLVideoAsset
)[]
References
TLBookmarkAsset, TLImageAsset, TLVideoAsset
brush
Public Readonly Property
The instance's brush state.
Signature
get brush(): Box2dModel | null
References
camera
Public Readonly Property
The current camera.
Signature
get camera(): import('@tldraw/tlschema').TLCamera
References
canMoveCamera
Public Property
Whether the editor's camera can move.
Example
editor.canMoveCamera = false
Parameters
Name | Description |
---|---|
| Whether the camera can move. |
Signature
get canMoveCamera(): boolean
set canMoveCamera(canMove: boolean)
canRedo
Public Readonly Property
Whether the app can redo.
Signature
get canRedo(): boolean
canUndo
Public Readonly Property
Whether the app can undo.
Signature
get canUndo(): boolean
croppingId
Public Readonly Property
The current cropping shape's id.
Signature
get croppingId(): null | TLShapeId
References
cullingBounds
Public Readonly Property
The current culling bounds in page space, used for checking which shapes are "on screen".
Signature
get cullingBounds(): Box2d
References
cullingBoundsExpanded
Public Readonly Property
The current culling bounds in page space, expanded slightly. Used for determining which shapes to render and which to "cull".
Signature
get cullingBoundsExpanded(): Box2d
References
currentPage
Public Readonly Property
The current page.
Signature
get currentPage(): TLPage
References
currentPageId
Public Readonly Property
The current page id.
Signature
get currentPageId(): TLPageId
References
currentToolId
Public Readonly Property
The id of the current selected tool.
Signature
get currentToolId(): string
cursor
Public Readonly Property
The instance's cursor state.
Signature
get cursor(): TLCursor
References
devicePixelRatio
Public Readonly Property
The window's device pixel ratio.
Signature
get devicePixelRatio(): number
disposables
Public Readonly Property
A set of functions to call when the app is disposed.
Signature
readonly disposables: Set<() => void>
References
documentSettings
Public Readonly Property
The global document settings that apply to all users.
Signature
get documentSettings(): TLDocument
References
editingId
Public Readonly Property
The current editing shape's id.
Signature
get editingId(): null | TLShapeId
References
editingShape
Public Readonly Property
Signature
get editingShape(): null | TLUnknownShape
References
erasingIds
Public Readonly Property
The editor's current erasing ids.
Signature
get erasingIds(): TLShapeId[]
References
erasingIdsSet
Public Readonly Property
A derived set containing the current erasing ids.
Signature
get erasingIdsSet(): Set<TLShapeId>
References
externalContentManager
Public Property
Signature
externalContentManager: ExternalContentManager
References
focusLayerId
Public Readonly Property
The shape id of the current focus layer.
Signature
get focusLayerId(): TLPageId | TLShapeId
References
focusLayerShape
Public Readonly Property
The shape of the current focus layer.
Signature
get focusLayerShape(): TLShape | undefined
References
getContainer
Public Property
The current HTML element containing the editor.
Example
const container = editor.getContainer()
Signature
getContainer: () => HTMLElement
References
gridSize
Public Readonly Property
The document's grid size.
Signature
get gridSize(): number
hintingIds
Public Readonly Property
The editor's current hinting ids.
Signature
get hintingIds(): TLShapeId[]
References
history
Public Readonly Property
A manager for the app's history.
Signature
readonly history: HistoryManager<this>
References
hoveredId
Public Readonly Property
The current hovered shape id.
Signature
get hoveredId(): null | TLShapeId
References
hoveredShape
Public Readonly Property
The current hovered shape.
Signature
get hoveredShape(): null | TLUnknownShape
References
inputs
Public Property
The app's current input state.
Signature
inputs: {
originPagePoint: Vec2d
originScreenPoint: Vec2d
previousPagePoint: Vec2d
previousScreenPoint: Vec2d
currentPagePoint: Vec2d
currentScreenPoint: Vec2d
keys: Set<string>
buttons: Set<number>
isPen: boolean
shiftKey: boolean
ctrlKey: boolean
altKey: boolean
isDragging: boolean
isPointing: boolean
isPinching: boolean
isEditing: boolean
isPanning: boolean
pointerVelocity: Vec2d
}
References
instanceState
Public Readonly Property
The current instance's state.
Signature
get instanceState(): TLInstance
References
isChangingStyle
Public Property
Whether the user is currently changing the style of a shape. This may cause the UI to change.
Example
editor.isChangingStyle = true
Signature
get isChangingStyle(): boolean
set isChangingStyle(v: boolean)
isChromeForIos
Public Readonly Property
Whether the editor is running on iOS.
Signature
readonly isChromeForIos: boolean
isCoarsePointer
Public Property
Whether the user is using a "coarse" pointer, such as on a touch screen. This is automatically set by the canvas.
Signature
get isCoarsePointer(): boolean
set isCoarsePointer(v: boolean)
isDarkMode
Public Readonly Property
Whether the user has dark mode enabled.
Signature
get isDarkMode(): boolean
isFocused
Public Readonly Property
Whether or not the editor is focused.
Signature
get isFocused(): boolean
isFocusMode
Public Readonly Property
Whether the instance is in focus mode or not.
Signature
get isFocusMode(): boolean
isGridMode
Public Readonly Property
Whether the instance's grid is enabled.
Signature
get isGridMode(): boolean
isIos
Public Readonly Property
Whether the editor is running on iOS.
Signature
readonly isIos: boolean
isMenuOpen
Public Readonly Property
Get whether any menus are open.
Signature
get isMenuOpen(): boolean
isPenMode
Public Readonly Property
Whether the editor is in pen mode or not.
Signature
get isPenMode(): boolean
isReadOnly
Public Readonly Property
Whether the editor is in read-only mode or not.
Signature
get isReadOnly(): boolean
isSafari
Public Readonly Property
Whether the editor is running in Safari.
Signature
readonly isSafari: boolean
isSnapMode
Public Readonly Property
Whether the user has "always snap" mode enabled.
Signature
get isSnapMode(): boolean
isToolLocked
Public Readonly Property
Whether the instance has "tool lock" mode enabled.
Signature
get isToolLocked(): boolean
locale
Public Readonly Property
Get the user's locale.
Signature
get locale(): string
onlySelectedShape
Public Readonly Property
The app's only selected shape.
Example
editor.onlySelectedShape
Signature
get onlySelectedShape(): null | TLShape
References
opacity
Public Readonly Property
Get the currently selected opacity. If any shapes are selected, this returns the opacity of the selected shapes. Otherwise, this returns the chosen opacity for the next shape.
Signature
get opacity(): null | number
openMenus
Public Readonly Property
A set of strings representing any open menus. When menus are open, certain interactions will behave differently; for example, when a draw tool is selected and a menu is open, a pointer-down will not create a dot (because the user is probably trying to close the menu) however a pointer-down event followed by a drag will begin drawing a line (because the user is BOTH trying to close the menu AND start drawing a line).
Signature
get openMenus(): string[]
pages
Public Readonly Property
Info about the project's current pages.
Signature
get pages(): TLPage[]
References
pageState
Public Readonly Property
The current page state.
Signature
get pageState(): TLInstancePageState
References
renderingShapes
Public Readonly Property
Get the shapes that should be displayed in the current viewport.
Signature
get renderingShapes(): {
id: TLShapeId
index: number
backgroundIndex: number
opacity: number
isCulled: boolean
isInViewport: boolean
maskedPageBounds: Box2d | undefined
}[]
References
root
Public Readonly Property
The root state of the statechart.
Signature
readonly root: RootState
References
scribble
Public Readonly Property
The instance's scribble state.
Signature
get scribble(): null | TLScribble
References
selectedIds
Public Readonly Property
The current selected ids.
Signature
get selectedIds(): TLShapeId[]
References
selectedIdsSet
Public Readonly Property
The current selected ids as a set
Signature
get selectedIdsSet(): ReadonlySet<TLShapeId>
References
selectedPageBounds
Public Readonly Property
The current page bounds of all the selected shapes (Not the same thing as the page bounds of the selection bounding box when the selection has been rotated)
Signature
get selectedPageBounds(): Box2d | null
References
selectedShapes
Public Readonly Property
An array containing all of the currently selected shapes.
Example
editor.selectedShapes
Signature
get selectedShapes(): TLShape[]
References
selectionBounds
Public Readonly Property
The bounds of the selection bounding box.
Signature
get selectionBounds(): Box2d | undefined
References
selectionPageCenter
Public Readonly Property
The center of the selection bounding box.
Signature
get selectionPageCenter(): null | Vec2d
References
selectionRotation
Public Readonly Property
The rotation of the selection bounding box.
Signature
get selectionRotation(): number
shapeIds
Public Readonly Property
An array of all of the shapes on the current page.
Signature
get shapeIds(): Set<TLShapeId>
References
shapesArray
Public Readonly Property
An array containing all of the shapes in the current page.
Example
editor.shapesArray
Signature
get shapesArray(): TLShape[]
References
shapeUtils
Public Property
A map of shape utility classes (TLShapeUtils) by shape type.
Signature
shapeUtils: {
readonly [K in string]?: ShapeUtil<TLUnknownShape>
}
References
snaps
Public Readonly Property
A manager for the app's snapping feature.
Signature
readonly snaps: SnapManager
References
sortedShapesArray
Public Readonly Property
An array containing all of the shapes in the current page, sorted in z-index order (accounting for nested shapes): e.g. A, B, BA, BB, C.
Example
editor.sortedShapesArray
Signature
get sortedShapesArray(): TLShape[]
References
store
Public Readonly Property
The editor's store
Signature
readonly store: TLStore
References
styles
Public Static Property
The app's set of styles.
Signature
static styles: import('@tldraw/tlschema').TLStyleCollections
References
textMeasure
Public Property
A helper for measuring text.
Signature
textMeasure: TextManager
References
user
Public Readonly Property
A manager for the user and their preferences.
Signature
readonly user: UserPreferencesManager
References
viewportPageBounds
Public Readonly Property
The current viewport in page space.
Signature
get viewportPageBounds(): Box2d
References
viewportPageCenter
Public Readonly Property
The center of the viewport in page space.
Signature
get viewportPageCenter(): Vec2d
References
viewportScreenBounds
Public Readonly Property
The bounds of the editor's viewport in screen space.
Signature
get viewportScreenBounds(): Box2d
References
viewportScreenCenter
Public Readonly Property
The center of the editor's viewport in screen space.
Signature
get viewportScreenCenter(): Vec2d
References
zoomBrush
Public Readonly Property
The instance's zoom brush state.
Signature
get zoomBrush(): Box2dModel | null
References
zoomLevel
Public Readonly Property
The current camera zoom level.
Signature
get zoomLevel(): number
Methods
addOpenMenu()
Public Method
Add an open menu.
Example
editor.addOpenMenu('menu-id')
Parameters
Name | Description |
---|---|
|
|
Returns
this
alignShapes()
Public Method
Align shape positions.
Example
editor.alignShapes('left')
editor.alignShapes('left', ['box1', 'box2'])
Parameters
Name | Description |
---|---|
|
The align operation to apply. |
(optional) |
The ids of the shapes to align. Defaults to selected shapes. |
Returns
this
References
animateCamera()
Public Method
Animate the camera.
Example
editor.animateCamera(0, 0)
editor.animateCamera(0, 0, 1)
editor.animateCamera(0, 0, 1, { duration: 1000, easing: (t) => t * t })
Parameters
Name | Description |
---|---|
|
The camera's x position. |
|
The camera's y position. |
(optional) |
The camera's z position. Defaults to the current zoom. |
(optional) |
Options for the animation. |
Returns
this
References
animateShapes()
Public Method
Animate shapes.
Example
editor.animateShapes([{ id: 'box1', type: 'box', x: 100, y: 100 }])
Parameters
Name | Description |
---|---|
|
The shape partials to update. |
(optional) |
|
Returns
this
References
animateToShape()
Public Method
Animate the camera to a shape.
Parameters
Name | Description |
---|---|
|
|
(optional) |
|
Returns
this
References
bail()
Public Method
Clear all marks in the undo stack back to the next mark.
Example
editor.bail()
Parameters
None
Returns
this
bailToMark()
Public Method
Clear all marks in the undo stack back to the mark with the provided mark id.
Example
editor.bailToMark('creating')
Parameters
Name | Description |
---|---|
|
|
Returns
this
batch()
Public Method
Run a function in a batch, which will be undone/redone as a single action.
Example
editor.batch(() => {
editor.selectAll()
editor.deleteShapes()
editor.createShapes(myShapes)
editor.selectNone()
})
editor.undo() // will undo all of the above
Parameters
Name | Description |
---|---|
|
|
Returns
this
blur()
Public Method
Blur the app, cancelling any interaction state.
Example
editor.blur()
Parameters
None
Returns
this
bringForward()
Public Method
Bring shapes forward in the page's object list.
Example
editor.bringForward()
editor.bringForward(['id1', 'id2'])
Parameters
Name | Description |
---|---|
(optional) |
The ids of the shapes to move. Defaults to the ids of the selected shapes. |
Returns
this
References
bringToFront()
Public Method
Bring shapes to the front of the page's object list.
Example
editor.bringToFront()
editor.bringToFront(['id1', 'id2'])
Parameters
Name | Description |
---|---|
(optional) |
The ids of the shapes to move. Defaults to the ids of the selected shapes. |
Returns
this
References
cancel()
Public Method
Dispatch a cancel event.
Example
editor.cancel()
Parameters
None
Returns
this
cancelDoubleClick()
Public Method
Prevent a double click event from firing the next time the user clicks
Parameters
None
Returns
void
centerOnPoint()
Public Method
Center the camera on a point (in page space).
Example
editor.centerOnPoint(100, 100)
Parameters
Name | Description |
---|---|
|
The x position of the point. |
|
The y position of the point. |
(optional) |
The options for an animation. |
Returns
this
References
complete()
Public Method
Dispatch a complete event.
Example
editor.complete()
Parameters
None
Returns
this
createAssets()
Public Method
Create one or more assets.
Example
editor.createAssets([...myAssets])
Parameters
Name | Description |
---|---|
|
The assets to create. |
Returns
this
References
createPage()
Public Method
Create a page.
Example
editor.createPage('New Page')
editor.createPage('New Page', 'page1')
Parameters
Name | Description |
---|---|
|
The new page's title. |
(optional) |
The new page's id. |
(optional) |
|
Returns
this
References
createShapes()
Public Method
Create shapes.
Example
editor.createShapes([{ id: 'box1', type: 'text', props: { text: 'ok' } }])
Parameters
Name | Description |
---|---|
|
The shape partials to create. |
(optional) |
Whether to select the created shapes. Defaults to false. |
Returns
this
References
TLUnknownShape, TLShapePartial
deleteAssets()
Public Method
Delete one or more assets.
Example
editor.deleteAssets(['asset1', 'asset2'])
Parameters
Name | Description |
---|---|
|
The assets to delete. |
Returns
this
References
deleteOpenMenu()
Public Method
Delete an open menu.
Example
editor.deleteOpenMenu('menu-id')
Parameters
Name | Description |
---|---|
|
|
Returns
this
deletePage()
Public Method
Delete a page.
Example
editor.deletePage('page1')
Parameters
Name | Description |
---|---|
|
The id of the page to delete. |
Returns
void
References
deleteShapes()
Public Method
Delete shapes.
Example
editor.deleteShapes()
editor.deleteShapes(['box1', 'box2'])
Parameters
Name | Description |
---|---|
(optional) |
The ids of the shapes to delete. Defaults to the selected shapes. |
Returns
this
References
deselect()
Public Method
Remove a shape from the existing set of selected shapes.
Example
editor.deselect(shape.id)
Parameters
Name | Description |
---|---|
|
|
Returns
this
References
dispatch()
Public Method
Dispatch an event to the editor.
Example
editor.dispatch(myPointerEvent)
Parameters
Name | Description |
---|---|
|
The event info. |
Returns
this
References
dispose()
Public Method
Dispose the editor.
Parameters
None
Returns
void
distributeShapes()
Public Method
Distribute shape positions.
Example
editor.distributeShapes('left')
editor.distributeShapes('left', ['box1', 'box2'])
Parameters
Name | Description |
---|---|
|
Whether to distribute shapes horizontally or vertically. |
(optional) |
The ids of the shapes to distribute. Defaults to selected shapes. |
Returns
this
References
duplicatePage()
Public Method
Duplicate a page.
Parameters
Name | Description |
---|---|
(optional) |
The id of the page to duplicate. Defaults to the current page. |
(optional) |
The id of the new page. Defaults to a new id. |
Returns
this
References
duplicateShapes()
Public Method
Duplicate shapes.
Example
editor.duplicateShapes()
editor.duplicateShapes(['id1', 'id2'])
editor.duplicateShapes(['id1', 'id2'], { x: 8, y: 8 })
Parameters
Name | Description |
---|---|
(optional) |
The ids of the shapes to duplicate. Defaults to the ids of the selected shapes. |
(optional) |
The offset (in pixels) to apply to the duplicated shapes. |
Returns
this
References
findAncestor()
Public Method
Find the first ancestor matching the given predicate
Example
const ancestor = editor.findAncestor(myShape)
Parameters
Name | Description |
---|---|
|
The shape to check the ancestors for. |
|
|
Returns
TLShape | undefined
References
findCommonAncestor()
Public Method
Get the common ancestor of two or more shapes that matches a predicate.
Parameters
Name | Description |
---|---|
|
The shapes to check. |
(optional) |
The predicate to match. |
Returns
TLShapeId | undefined
References
flipShapes()
Public Method
Flip shape positions.
Example
editor.flipShapes('horizontal')
editor.flipShapes('horizontal', ['box1', 'box2'])
Parameters
Name | Description |
---|---|
|
Whether to flip horizontally or vertically. |
(optional) |
The ids of the shapes to flip. Defaults to selected shapes. |
Returns
this
References
focus()
Public Method
Focus the editor.
Example
editor.focus()
Parameters
None
Returns
this
getAncestors()
Public Method
Get the ancestors of a shape.
Example
const ancestors = editor.getAncestors(myShape)
Parameters
Name | Description |
---|---|
|
The shape to get the ancestors for. |
(optional) |
|
Returns
TLShape[]
References
getAncestorsById()
Public Method
Get the ancestors of a shape by its id.
Example
const ancestors = editor.getAncestorsById(myShape)
Parameters
Name | Description |
---|---|
|
The id of the shape to get the ancestors for. |
(optional) |
|
Returns
TLShape[]
References
getArrowsBoundTo()
Public Method
Get all arrows bound to a shape.
Parameters
Name | Description |
---|---|
|
The id of the shape. |
Returns
{
arrowId: TLShapeId
handleId: 'end' | 'start'
}[]
References
getAssetById()
Public Method
Get an asset by its id.
Example
editor.getAssetById('asset1')
Parameters
Name | Description |
---|---|
|
The id of the asset. |
Returns
TLAsset | undefined
References
getAssetBySrc()
Public Method
Get an asset by its src property.
Example
editor.getAssetBySource('https://example.com/image.png')
Parameters
Name | Description |
---|---|
|
The source value of the asset. |
Returns
| import('@tldraw/tlschema').TLBookmarkAsset
| TLImageAsset
| TLVideoAsset
| undefined
References
TLBookmarkAsset, TLImageAsset, TLVideoAsset
getBounds()
Public Method
Get the local bounds of a shape.
Example
editor.getBounds(myShape)
Parameters
Name | Description |
---|---|
|
The shape to get the bounds for. |
Returns
Box2d
References
getBoundsById()
Public Method
Get the local bounds of a shape by its id.
Example
editor.getBoundsById(myShape)
Parameters
Name | Description |
---|---|
|
The id of the shape to get the bounds for. |
Returns
Box2d | undefined
References
getClipPathById()
Public Method
Get the clip path for a shape.
Example
const clipPath = editor.getClipPathById(shape.id)
Parameters
Name | Description |
---|---|
|
The shape id. |
Returns
string | undefined
The clip path or undefined.
References
getContent()
Public Method
Get content that can be exported for the given shape ids.
Parameters
Name | Description |
---|---|
(optional) |
The ids of the shapes to get content for. Defaults to the selected shape ids. |
Returns
TLContent | undefined
The exported content.
References
getCssColor()
Public Method
Get the CSS color value for a given color id.
Example
editor.getCssColor('red')
Parameters
Name | Description |
---|---|
|
The id of the color to get. |
Returns
string
References
getDeltaInParentSpace()
Public Method
Convert a delta in page space to a delta in the parent space of a shape.
Example
editor.getDeltaInParentSpace(myShape, { x: 100, y: 100 })
Parameters
Name | Description |
---|---|
|
The shape to get the delta in the parent space of. |
|
The page delta to convert. |
Returns
Vec2d
References
getDeltaInShapeSpace()
Public Method
Convert a delta in page space to a delta in the local space of a shape.
Example
editor.getDeltaInShapeSpace(myShape, { x: 100, y: 100 })
Parameters
Name | Description |
---|---|
|
The shape to get the delta in the local space of. |
|
The page delta to convert. |
Returns
Vec2d
References
getDroppingShape()
Public Method
Get the shape that some shapes should be dropped on at a given point.
Parameters
Name | Description |
---|---|
|
The point to find the parent for. |
(optional) |
The shapes that are being dropped. |
Returns
TLUnknownShape | undefined
The shape to drop on.
References
VecLike, TLShape, TLUnknownShape
getHighestIndexForParent()
Public Method
Get the index above the highest child of a given parent.
Parameters
Name | Description |
---|---|
|
The id of the parent. |
Returns
string
The index.
References
getMaskedPageBounds()
Public Method
Get the page (or absolute) bounds of a shape, incorporating any masks. For example, if the shape were the child of a frame and was half way out of the frame, the bounds would be the half of the shape that was in the frame.
Example
editor.getMaskedPageBounds(myShape)
Parameters
Name | Description |
---|---|
|
The shape to get the masked bounds for. |
Returns
Box2d | undefined
References
getMaskedPageBoundsById()
Public Method
Get the page (or absolute) bounds of a shape by its id, incorporating any masks. For example, if the shape were the child of a frame and was half way out of the frame, the bounds would be the half of the shape that was in the frame.
Example
editor.getMaskedPageBoundsById(myShape)
Parameters
Name | Description |
---|---|
|
The id of the shape to get the masked page bounds for. |
Returns
Box2d | undefined
References
getOutermostSelectableShape()
Public Method
Get the shape that should be selected when you click on a given shape, assuming there is nothing already selected. It will not return anything higher than or including the current focus layer.
Parameters
Name | Description |
---|---|
|
The shape to get the outermost selectable shape for. |
(optional) |
A function to filter the selectable shapes. |
Returns
TLShape
The outermost selectable shape.
References
getOutline()
Public Method
Get the local outline of a shape.
Example
editor.getOutline(myShape)
Parameters
Name | Description |
---|---|
|
The shape to get the outline for. |
Returns
Vec2dModel[]
References
getOutlineById()
Public Method
Get the local outline of a shape.
Example
editor.getOutlineById(myShape)
Parameters
Name | Description |
---|---|
|
The shape id to get the outline for. |
Returns
Vec2dModel[]
References
getPageBounds()
Public Method
Get the page (or absolute) bounds of a shape.
Example
editor.getPageBounds(myShape)
Parameters
Name | Description |
---|---|
|
The shape to get the bounds for. |
Returns
Box2d | undefined
References
getPageBoundsById()
Public Method
Get the page (or absolute) bounds of a shape by its id.
Example
editor.getPageBoundsById(myShape)
Parameters
Name | Description |
---|---|
|
The id of the shape to get the page bounds for. |
Returns
Box2d | undefined
References
getPageById()
Public Method
Get a page by its ID.
Example
editor.getPageById(myPage.id)
Parameters
Name | Description |
---|---|
|
|
Returns
TLPage | undefined
References
getPageCenter()
Public Method
Get the page point (or absolute point) of a shape.
Example
editor.getPagePoint(myShape)
Parameters
Name | Description |
---|---|
|
The shape to get the page point for. |
Returns
null | Vec2d
References
getPageCenterById()
Public Method
Get the page point (or absolute point) of a shape by its id.
Example
editor.getPagePoint(myShape)
Parameters
Name | Description |
---|---|
|
The shape id to get the page point for. |
Returns
null | Vec2d
References
getPageCorners()
Public Method
Get the corners of a shape in page space.
Example
const corners = editor.getPageCorners(myShape)
Parameters
Name | Description |
---|---|
|
The shape to get the corners for. |
Returns
Vec2d[]
References
getPageInfoById()
Public Method
Get a page by its ID.
Example
editor.getPageById(myPage.id)
Parameters
Name | Description |
---|---|
|
|
Returns
TLPage | undefined
References
getPageMaskById()
Public Method
Get the page mask for a shape.
Example
const pageMask = editor.getPageMaskById(shape.id)
Parameters
Name | Description |
---|---|
|
The id of the shape to get the page mask for. |
Returns
undefined | VecLike[]
The page mask for the shape.
References
getPagePointById()
Public Method
Get the page point (or absolute point) of a shape.
Example
editor.getPagePoint(myShape)
Parameters
Name | Description |
---|---|
|
|
Returns
undefined | Vec2d
References
getPageRotation()
Public Method
Get the page rotation (or absolute rotation) of a shape.
Example
editor.getPageRotation(myShape)
Parameters
Name | Description |
---|---|
|
The shape to get the page rotation for. |
Returns
number
References
getPageRotationById()
Public Method
Get the page rotation (or absolute rotation) of a shape by its id.
Example
editor.getPageRotationById(myShapeId)
Parameters
Name | Description |
---|---|
|
The id of the shape to get the page rotation for. |
Returns
number
References
getPageStateByPageId()
Public Method
Get a page state by its id.
Example
editor.getPageStateByPageId('page1')
Parameters
Name | Description |
---|---|
|
|
Returns
TLInstancePageState | undefined
References
getPageTransform()
Public Method
Get the page transform (or absolute transform) of a shape.
Example
editor.getPageTransform(myShape)
Parameters
Name | Description |
---|---|
|
The shape to get the page transform for. |
Returns
Matrix2d | undefined
References
getPageTransformById()
Public Method
Get the page transform (or absolute transform) of a shape by its id.
Example
editor.getPageTransformById(myShape)
Parameters
Name | Description |
---|---|
|
The if of the shape to get the page transform for. |
Returns
Matrix2d | undefined
References
getParentIdForNewShapeAtPoint()
Public Method
Get the id of what should be the parent of a new shape at a given point. The parent can be a page or shape.
Parameters
Name | Description |
---|---|
|
The point to find the parent for. |
|
The type of shape that will be created. |
Returns
TLPageId | TLShapeId
The id of the parent.
References
VecLike, TLShape, TLPageId, TLShapeId
getParentPageId()
Public Method
Get the id of the containing page for a given shape.
Parameters
Name | Description |
---|---|
(optional) |
The shape to get the page id for. |
Returns
TLPageId | undefined
The id of the page that contains the shape, or undefined if the shape is undefined.
References
getParentShape()
Public Method
Get the parent shape for a given shape. Returns undefined if the shape is the direct child of the page.
Example
editor.getParentShape(myShape)
Parameters
Name | Description |
---|---|
(optional) |
|
Returns
TLShape | undefined
References
getParentsMappedToChildren()
Public Method
For a given set of ids, get a map containing the ids of their parents and the children of those parents.
Example
editor.getParentsMappedToChildren(['id1', 'id2', 'id3'])
Parameters
Name | Description |
---|---|
|
The ids to get the parents and children of. |
Returns
Map<TLParentId, Set<TLShape>>
References
TLShapeId, Map, TLParentId, Set, TLShape
getParentTransform()
Public Method
Get the local transform of a shape's parent as a matrix model.
Example
editor.getParentTransform(myShape)
Parameters
Name | Description |
---|---|
|
The shape to get the parent transform for. |
Returns
Matrix2d
References
getPointInParentSpace()
Public Method
Convert a delta in page space to a point in the local space of a shape. For example, if a shape's page point were { x: 100, y: 100 }
, a page point at { x: 110, y: 110 }
would be at { x: 10, y: 10 }
in the shape's local space.
Example
editor.getPointInShapeSpace(myShape.id, { x: 100, y: 100 })
Parameters
Name | Description |
---|---|
|
|
|
The page point to get in the local space of the shape. |
Returns
Vec2d
References
getPointInShapeSpace()
Public Method
Convert a point in page space to a point in the local space of a shape. For example, if a shape's page point were { x: 100, y: 100 }
, a page point at { x: 110, y: 110 }
would be at { x: 10, y: 10 }
in the shape's local space.
Example
editor.getPointInShapeSpace(myShape, { x: 100, y: 100 })
Parameters
Name | Description |
---|---|
|
The shape to get the point in the local space of. |
|
The page point to get in the local space of the shape. |
Returns
Vec2d
References
getShapeAndDescendantIds()
Public Method
Get the shape ids of all descendants of the given shapes (including the shapes themselves).
Parameters
Name | Description |
---|---|
|
The ids of the shapes to get descendants of. |
Returns
Set<TLShapeId>
The decscendant ids.
References
getShapeById()
Public Method
Get a shape by its id.
Example
editor.getShapeById('box1')
Parameters
Name | Description |
---|---|
|
The id of the shape to get. |
Returns
T | undefined
References
getShapeIdsInPage()
Public Method
Get the ids of shapes on a page.
Parameters
Name | Description |
---|---|
|
The id of the page. |
Returns
Set<TLShapeId>
References
getShapesAtPoint()
Public Method
Get the shapes, if any, at a given page point.
Example
editor.getShapesAtPoint({ x: 100, y: 100 })
Parameters
Name | Description |
---|---|
|
The page point to test. |
Returns
TLShape[]
References
getShapeUtil()
Public Method
Get a shape util by its definition.
Example
editor.getShapeUtil(ArrowShapeUtil)
Parameters
Name | Description |
---|---|
|
The shape util. |
Returns
InstanceType<C>
References
getShapeUtil()
Public Method
Get a shape util from a shape itself.
Example
const util = editor.getShapeUtil(myShape)
const util = editor.getShapeUtil<ArrowShapeUtil>(myShape)
const util = editor.getShapeUtil(ArrowShapeUtil)
Parameters
Name | Description |
---|---|
|
A shape or shape partial. |
Returns
ShapeUtil<S>
References
TLUnknownShape, TLShapePartial, ShapeUtil
getSortedChildIds()
Public Method
Get an array of all the children of a shape.
Example
editor.getSortedChildIds('frame1')
Parameters
Name | Description |
---|---|
|
The id of the parent shape. |
Returns
TLShapeId[]
References
getStateDescendant()
Public Method
Get a descendant by its path.
Example
state.getStateDescendant('select')
state.getStateDescendant('select.brushing')
Parameters
Name | Description |
---|---|
|
The descendant's path of state ids, separated by periods. |
Returns
StateNode | undefined
References
getStrokeWidth()
Public Method
Get the stroke width value for a given size id.
Example
editor.getStrokeWidth('m')
Parameters
Name | Description |
---|---|
|
The id of the size to get. |
Returns
number
References
getSvg()
Public Method
Get an exported SVG of the given shapes.
Parameters
Name | Description |
---|---|
(optional) |
The ids of the shapes to export. Defaults to selected shapes. |
(optional) |
Options for the export. |
Returns
Promise<SVGSVGElement | undefined>
The SVG element.
References
TLShapeId, Partial, React.SVGAttributes, SVGSVGElement, Promise
getTransform()
Public Method
Get the local transform for a shape as a matrix model. This transform reflects both its translation (x, y) from from either its parent's top left corner, if the shape's parent is another shape, or else from the 0,0 of the page, if the shape's parent is the page; and the shape's rotation.
Example
editor.getTransform(myShape)
Parameters
Name | Description |
---|---|
|
The shape to get the local transform for. |
Returns
Matrix2d
References
groupShapes()
Public Method
Group some shapes together.
Parameters
Name | Description |
---|---|
(optional) |
Ids of the shapes to group. Defaults to the selected shapes. |
(optional) |
Id of the group to create. Defaults to a new shape id. |
Returns
this
References
hasAncestor()
Public Method
Returns true if the the given shape has the given ancestor.
Parameters
Name | Description |
---|---|
|
The shape. |
|
The id of the ancestor. |
Returns
boolean
References
interrupt()
Public Method
Dispatch an interrupt event.
Example
editor.interrupt()
Parameters
None
Returns
this
isIn()
Public Method
Get whether a certain tool (or other state node) is currently active.
Example
editor.isIn('select')
editor.isIn('select.brushing')
Parameters
Name | Description |
---|---|
|
The path of active states, separated by periods. |
Returns
boolean
isInAny()
Public Method
Get whether the state node is in any of the given active paths.
Example
state.isInAny('select', 'erase')
state.isInAny('select.brushing', 'erase.idle')
Parameters
Name | Description |
---|---|
|
|
Returns
boolean
isPointInShape()
Public Method
Test whether a point (in page space) will will a shape. This method takes into account masks, such as when a shape is the child of a frame and is partially clipped by the frame.
Example
editor.isPointInShape({ x: 100, y: 100 }, myShape)
Parameters
Name | Description |
---|---|
|
The page point to test. |
|
The shape to test against. |
Returns
boolean
References
isSelected()
Public Method
Determine whether or not a shape is selected
Example
editor.isSelected('id1')
Parameters
Name | Description |
---|---|
|
The id of the shape to check. |
Returns
boolean
References
isShapeInPage()
Public Method
Get whether the given shape is the descendant of the given page.
Example
editor.isShapeInPage(myShape)
editor.isShapeInPage(myShape, 'page1')
Parameters
Name | Description |
---|---|
|
The shape to check. |
(optional) |
The id of the page to check against. Defaults to the current page. |
Returns
boolean
References
isShapeInViewport()
Public Method
Check whether a shape is within the bounds of the current viewport.
Parameters
Name | Description |
---|---|
|
The id of the shape to check. |
Returns
boolean
References
isShapeOfType()
Public Method
Get whether a shape matches the type of a TLShapeUtil.
Example
const isArrowShape = isShapeOfType(someShape, ArrowShapeUtil)
Parameters
Name | Description |
---|---|
|
the shape to test |
|
the TLShapeUtil constructor to test against |
Returns
shape is T
References
TLUnknownShape, ShapeUtil, shape
isShapeOrAncestorLocked()
Public Method
Check whether a shape or its parent is locked.
Parameters
Name | Description |
---|---|
(optional) |
|
Returns
boolean
References
isWithinSelection()
Public Method
Determine whether a not a shape is within the current selection. A shape is within the selection if it or any of its parents is selected.
Parameters
Name | Description |
---|---|
|
The id of the shape to check. |
Returns
boolean
References
mark()
Public Method
Create a new "mark", or stopping point, in the undo redo history. Creating a mark will clear any redos.
Example
editor.mark()
editor.mark('flip shapes')
Parameters
Name | Description |
---|---|
(optional) |
The reason for the mark. |
(optional) |
Whether to stop at the mark when undoing. |
(optional) |
Whether to stop at the mark when redoing. |
Returns
string
moveShapesToPage()
Public Method
Move shapes to page.
Example
editor.moveShapesToPage(['box1', 'box2'], 'page1')
Parameters
Name | Description |
---|---|
|
The ids of the shapes to move. |
|
The id of the page where the shapes will be moved. |
Returns
this
References
nudgeShapes()
Public Method
Move shapes by a delta.
Example
editor.nudgeShapes(['box1', 'box2'], { x: 0, y: 1 })
editor.nudgeShapes(['box1', 'box2'], { x: 0, y: 1 }, true)
Parameters
Name | Description |
---|---|
|
The ids of the shapes to move. |
|
The direction in which to move the shapes. |
(optional) |
Whether this is a major nudge, e.g. a shift + arrow nudge. |
(optional) |
|
Returns
this
References
packShapes()
Public Method
Pack shapes into a grid centered on their current position. Based on potpack (https://github.com/mapbox/potpack)
Parameters
Name | Description |
---|---|
(optional) |
The ids of the shapes to pack. Defaults to selected shapes. |
(optional) |
The padding to apply to the packed shapes. |
Returns
this
References
pageToScreen()
Public Method
Convert a point in page space to a point in screen space.
Example
editor.pageToScreen(100, 100)
Parameters
Name | Description |
---|---|
|
The x coordinate of the point in screen space. |
|
The y coordinate of the point in screen space. |
(optional) |
|
(optional) |
The camera to use. Defaults to the current camera. |
Returns
{
x: number
y: number
z: number
}
References
pan()
Public Method
Pan the camera.
Example
editor.pan(100, 100)
editor.pan(100, 100, { duration: 1000 })
Parameters
Name | Description |
---|---|
|
The amount to pan on the x axis. |
|
The amount to pan on the y axis. |
(optional) |
The animation options |
Returns
this
References
panZoomIntoView()
Public Method
Pan or pan/zoom the selected ids into view. This method tries to not change the zoom if possible.
Parameters
Name | Description |
---|---|
|
The ids of the shapes to pan and zoom into view. |
(optional) |
The options for an animation. |
Returns
this
References
popFocusLayer()
Public Method
Exit the current focus layer, moving up to the next group if there is one.
Parameters
None
Returns
this
putContent()
Public Method
Place content into the editor.
Parameters
Name | Description |
---|---|
|
The content. |
(optional) |
Options for placing the content. |
Returns
this
References
putExternalContent()
Public Method
Handle external content, such as files, urls, embeds, or plain text which has been put into the app, for example by pasting external text or dropping external images onto canvas.
Parameters
Name | Description |
---|---|
|
Info about the external content. |
Returns
Promise<void>
References
redo()
Public Method
Redo to the next mark.
Example
editor.redo()
Parameters
None
Returns
this
renamePage()
Public Method
Rename a page.
Example
editor.renamePage('page1', 'My Page')
Parameters
Name | Description |
---|---|
|
The id of the page to rename. |
|
The new name. |
(optional) |
|
Returns
this
References
reorderShapes()
Public Method
Reorder shapes.
Parameters
Name | Description |
---|---|
|
The operation to perform. |
|
The ids to reorder. |
Returns
this
References
reparentShapesById()
Public Method
Reparent shapes to a new parent. This operation preserves the shape's current page positions / rotations.
Example
editor.reparentShapesById(['box1', 'box2'], 'frame1')
Parameters
Name | Description |
---|---|
|
The ids of the shapes to reparent. |
|
The id of the new parent shape. |
(optional) |
The index to insert the children. |
Returns
this
References
replaceStoreContentsWithRecordsForOtherDocument()
Public Method
Replace the store's contents with the given records.
Parameters
Name | Description |
---|---|
|
The records to replace the store's contents with. |
Returns
void
References
resetZoom()
Public Method
Set the zoom back to 100%.
Example
editor.resetZoom()
Parameters
Name | Description |
---|---|
(optional) |
|
(optional) |
The options for an animation. |
Returns
this
References
resizeShape()
Public Method
Resize a shape.
Parameters
Name | Description |
---|---|
|
The id of the shape to resize. |
|
The scale factor to apply to the shape. |
(optional) |
Additional options. |
Returns
this
References
TLShapeId, VecLike, Box2d, TLShape, MatLike, TLResizeHandle, TLResizeMode
rotateShapesBy()
Public Method
Rotate shapes by a delta in radians.
Example
editor.rotateShapesBy(['box1', 'box2'], Math.PI)
editor.rotateShapesBy(['box1', 'box2'], Math.PI / 2)
Parameters
Name | Description |
---|---|
|
The ids of the shapes to move. |
|
The delta in radians to apply to the selection rotation. |
Returns
this
References
screenToPage()
Public Method
Convert a point in screen space to a point in page space.
Example
editor.screenToPage(100, 100)
Parameters
Name | Description |
---|---|
|
The x coordinate of the point in screen space. |
|
The y coordinate of the point in screen space. |
(optional) |
|
(optional) |
The camera to use. Defaults to the current camera. |
Returns
{
x: number
y: number
z: number
}
References
select()
Public Method
Select one or more shapes.
Example
editor.select('id1')
editor.select('id1', 'id2')
Parameters
Name | Description |
---|---|
|
The ids to select. |
Returns
this
References
selectAll()
Public Method
Select all direct children of the current page.
Example
editor.selectAll()
Parameters
None
Returns
this
selectNone()
Public Method
Clear the selection.
Example
editor.selectNone()
Parameters
None
Returns
this
sendBackward()
Public Method
Send shapes backward in the page's object list.
Example
editor.sendBackward()
editor.sendBackward(['id1', 'id2'])
Parameters
Name | Description |
---|---|
(optional) |
The ids of the shapes to move. Defaults to the ids of the selected shapes. |
Returns
this
References
sendToBack()
Public Method
Send shapes to the back of the page's object list.
Example
editor.sendToBack()
editor.sendToBack(['id1', 'id2'])
Parameters
Name | Description |
---|---|
(optional) |
The ids of the shapes to move. Defaults to the ids of the selected shapes. |
Returns
this
References
setAnimationSpeed()
Public Method
Set the user's chosen animation speed. Set to 0.0 to disable animations. Set to 1.0 for full speed.
Parameters
Name | Description |
---|---|
|
|
Returns
this
setBrush()
Public Method
Set the current brush.
Example
editor.setBrush({ x: 0, y: 0, w: 100, h: 100 })
editor.setBrush() // Clears the brush
Parameters
Name | Description |
---|---|
(optional) |
The brush box model to set, or null for no brush model. |
Returns
this
References
setCamera()
Public Method
Set the current camera.
Example
editor.setCamera(0, 0)
editor.setCamera(0, 0, 1)
Parameters
Name | Description |
---|---|
|
The camera's x position. |
|
The camera's y position. |
(optional) |
The camera's z position. Defaults to the current zoom. |
(optional) |
|
Returns
this
References
setCroppingId()
Public Method
Set the current cropping shape's id.
Parameters
Name | Description |
---|---|
|
The id of the shape to crop or null to clear the cropping id. |
Returns
this
References
setCurrentPageId()
Public Method
Set the current page.
Example
editor.setCurrentPageId('page1')
Parameters
Name | Description |
---|---|
|
The id of the page to set as the current page. |
(optional) |
|
Returns
this
References
setCursor()
Public Method
Set the current cursor.
Example
editor.setCursor({ type: 'default' })
editor.setCursor({ type: 'default', rotation: Math.PI / 2, color: 'red' })
Parameters
Name | Description |
---|---|
|
A partial of the cursor object. |
Returns
this
References
setDarkMode()
Public Method
Set whether the user has dark mode enabled.
Parameters
Name | Description |
---|---|
|
|
Returns
this
setEditingId()
Public Method
Set the current editing id.
Parameters
Name | Description |
---|---|
|
The id of the shape to edit or null to clear the editing id. |
Returns
this
References
setErasingIds()
Public Method
Set the current erasing shapes.
Example
editor.setErasingIds(['box1', 'box2'])
editor.setErasingIds() // Clears the erasing set
Parameters
Name | Description |
---|---|
(optional) |
The ids of shapes to set as erasing. |
Returns
this
References
setFocusLayer()
Public Method
Set the focus layer to the given shape id.
Parameters
Name | Description |
---|---|
|
The next focus layer id or null to reset the focus layer to the page |
Returns
this
References
setFocusMode()
Public Method
Set whether the instance is in focus mode or not.
Parameters
Name | Description |
---|---|
|
|
Returns
this
setGridMode()
Public Method
Set whether the instance's grid is enabled.
Parameters
Name | Description |
---|---|
|
|
Returns
this
setHintingIds()
Public Method
Set the hinted shape ids.
Parameters
Name | Description |
---|---|
|
The ids to set as hinted. |
Returns
this
References
setHoveredId()
Public Method
Set the current hovered shape.
Example
editor.setHoveredId('box1')
editor.setHoveredId() // Clears the hovered shape.
Parameters
Name | Description |
---|---|
(optional) |
The id of the page to set as the current page |
Returns
this
References
setInstancePageState()
Public Method
Update a page state.
Example
editor.setInstancePageState({ id: 'page1', editingId: 'shape:123' })
editor.setInstancePageState({ id: 'page1', editingId: 'shape:123' }, true)
Parameters
Name | Description |
---|---|
|
The partial of the page state object containing the changes. |
(optional) |
Whether the command is ephemeral. |
Returns
void
References
setLocale()
Public Method
Update the user's locale. This affects which translations are used when rendering UI elements.
Example
editor.setLocale('fr')
Parameters
Name | Description |
---|---|
|
|
Returns
void
setOpacity()
Public Method
Set the current opacity. This will effect any selected shapes, or the next-created shape.
Example
editor.setOpacity(0.5)
editor.setOpacity(0.5, true)
Parameters
Name | Description |
---|---|
|
The opacity to set. Must be a number between 0 and 1 inclusive. |
(optional) |
Whether the opacity change is ephemeral. Ephemeral changes don't get added to the undo/redo stack. Defaults to false. |
(optional) |
Whether the opacity change will be squashed into the existing history entry rather than creating a new one. Defaults to false. |
Returns
this
setPenMode()
Public Method
Set whether the editor is in pen mode or not.
Parameters
Name | Description |
---|---|
|
|
Returns
this
setProp()
Public Method
Set the current props (generally styles).
Example
editor.setProp('color', 'red')
editor.setProp('color', 'red', true)
Parameters
Name | Description |
---|---|
|
The key to set. |
|
The value to set. |
(optional) |
Whether the style change is ephemeral. Ephemeral changes don't get added to the undo/redo stack. Defaults to false. |
(optional) |
Whether the style change will be squashed into the existing history entry rather than creating a new one. Defaults to false. |
Returns
this
References
setReadOnly()
Public Method
Set whether the editor is in read-only mode or not.
Parameters
Name | Description |
---|---|
|
|
Returns
this
setScribble()
Public Method
Set the current scribble.
Example
editor.setScribble(nextScribble)
editor.setScribble() // clears the scribble
Parameters
Name | Description |
---|---|
(optional) |
The new scribble object. |
Returns
this
References
setSelectedIds()
Public Method
Select one or more shapes.
Example
editor.setSelectedIds(['id1'])
editor.setSelectedIds(['id1', 'id2'])
Parameters
Name | Description |
---|---|
|
The ids to select. |
(optional) |
Whether the change should create a new history entry or combine with the previous (if the previous is the same type). |
Returns
this
References
setSelectedTool()
Public Method
Set the selected tool.
Example
editor.setSelectedTool('hand')
editor.setSelectedTool('hand', { date: Date.now() })
Parameters
Name | Description |
---|---|
|
The id of the tool to select. |
(optional) |
Arbitrary data to pass along into the transition. |
Returns
this
setSnapMode()
Public Method
Set whether the user has "always snap" mode enabled.
Parameters
Name | Description |
---|---|
|
|
Returns
this
setToolLocked()
Public Method
Set whether the instance has "tool lock" mode enabled.
Parameters
Name | Description |
---|---|
|
|
Returns
this
setZoomBrush()
Public Method
Set the current zoom brush.
Example
editor.setZoomBrush({ x: 0, y: 0, w: 100, h: 100 })
editor.setZoomBrush() // Clears the zoom
Parameters
Name | Description |
---|---|
(optional) |
The zoom box model to set, or null for no zoom model. |
Returns
this
References
slideCamera()
Public Method
Slide the camera in a certain direction.
Parameters
Name | Description |
---|---|
(optional) |
Options for the slide |
Returns
this | undefined
References
stackShapes()
Public Method
Stack shape.
Example
editor.stackShapes('horizontal')
editor.stackShapes('horizontal', ['box1', 'box2'])
editor.stackShapes('horizontal', ['box1', 'box2'], 20)
Parameters
Name | Description |
---|---|
|
Whether to stack horizontally or vertically. |
(optional) |
The ids of the shapes to stack. Defaults to selected shapes. |
(optional) |
A specific gap to use when stacking. |
Returns
this
References
startFollowingUser()
Public Method
Start viewport-following a user.
Parameters
Name | Description |
---|---|
|
The id of the user to follow. |
Returns
this | undefined
stopCameraAnimation()
Public Method
Stop the current camera animation, if any.
Parameters
None
Returns
this
stopFollowingUser()
Public Method
Stop viewport-following a user.
Parameters
None
Returns
this
stretchShapes()
Public Method
Stretch shape sizes and positions to fill their common bounding box.
Example
editor.stretchShapes('horizontal')
editor.stretchShapes('horizontal', ['box1', 'box2'])
Parameters
Name | Description |
---|---|
|
Whether to stretch shapes horizontally or vertically. |
(optional) |
The ids of the shapes to stretch. Defaults to selected shapes. |
Returns
this
References
toggleLock()
Public Method
Toggle the lock state of one or more shapes. If there is a mix of locked and unlocked shapes, all shapes will be locked.
Parameters
Name | Description |
---|---|
(optional) |
The ids of the shapes to toggle. Defaults to selected shapes. |
Returns
this
References
undo()
Public Method
Undo to the last mark.
Example
editor.undo()
Parameters
None
Returns
HistoryManager<this>
References
ungroupShapes()
Public Method
Ungroup some shapes.
Parameters
Name | Description |
---|---|
(optional) |
Ids of the shapes to ungroup. Defaults to the selected shapes. |
Returns
this
References
updateAssets()
Public Method
Update one or more assets.
Example
editor.updateAssets([{ id: 'asset1', name: 'New name' }])
Parameters
Name | Description |
---|---|
|
The assets to update. |
Returns
this
References
updateDocumentSettings()
Public Method
Update the global document settings that apply to all users.
Parameters
Name | Description |
---|---|
|
|
Returns
void
References
updateInstanceState()
Public Method
Update the instance's state.
Parameters
Name | Description |
---|---|
|
A partial object to update the instance state with. |
(optional) |
Whether the change is ephemeral. Ephemeral changes don't get added to the undo/redo stack. Defaults to false. |
(optional) |
Whether the change will be squashed into the existing history entry rather than creating a new one. Defaults to false. |
Returns
this
References
updatePage()
Public Method
Update a page.
Example
editor.updatePage({ id: 'page2', name: 'Page 2' })
Parameters
Name | Description |
---|---|
|
The partial of the shape to update. |
(optional) |
|
Returns
this
References
updateShapes()
Public Method
Update shapes using partials of each shape.
Example
editor.updateShapes([{ id: 'box1', type: 'geo', props: { w: 100, h: 100 } }])
Parameters
Name | Description |
---|---|
|
The shape partials to update. |
(optional) |
Whether the change is ephemeral. |
Returns
this
References
TLUnknownShape, TLShapePartial
updateViewportScreenBounds()
Public Method
Update the viewport. The viewport will measure the size and screen position of its container element. This should be done whenever the container's position on the screen changes.
Example
editor.updateViewportScreenBounds()
editor.updateViewportScreenBounds(true)
Parameters
Name | Description |
---|---|
(optional) |
(optional) Whether to preserve the viewport page center as the viewport changes. |
Returns
this
visitDescendants()
Public Method
Run a visitor function for all descendants of a shape.
Example
editor.visitDescendants('frame1', myCallback)
Parameters
Name | Description |
---|---|
|
The id of the parent shape. |
|
The visitor function. |
Returns
void
References
zoomIn()
Public Method
Zoom the camera in.
Example
editor.zoomIn()
editor.zoomIn(editor.viewportScreenCenter, { duration: 120 })
editor.zoomIn(editor.inputs.currentScreenPoint, { duration: 120 })
Parameters
Name | Description |
---|---|
(optional) |
|
(optional) |
The options for an animation. |
Returns
this
References
zoomOut()
Public Method
Zoom the camera out.
Example
editor.zoomOut()
editor.zoomOut(editor.viewportScreenCenter, { duration: 120 })
editor.zoomOut(editor.inputs.currentScreenPoint, { duration: 120 })
Parameters
Name | Description |
---|---|
(optional) |
|
(optional) |
The options for an animation. |
Returns
this
References
zoomToBounds()
Public Method
Zoom the camera to fit a bounding box (in page space).
Example
editor.zoomToBounds(0, 0, 100, 100)
Parameters
Name | Description |
---|---|
|
The bounding box's x position. |
|
The bounding box's y position. |
|
The bounding box's width. |
|
The bounding box's height. |
(optional) |
The desired zoom level. Defaults to 0.1. |
(optional) |
|
Returns
this
References
zoomToContent()
Public Method
Move the camera to the nearest content.
Parameters
None
Returns
this
zoomToFit()
Public Method
Zoom the camera to fit the current page's content in the viewport.
Example
editor.zoomToFit()
Parameters
Name | Description |
---|---|
(optional) |
|
Returns
this
References
zoomToSelection()
Public Method
Zoom the camera to fit the current selection in the viewport.
Example
editor.zoomToSelection()
Parameters
Name | Description |
---|---|
(optional) |
The options for an animation. |
Returns
this