TldrawBaseProps
Table of contents
- acceptedImageMimeTypes
- acceptedVideoMimeTypes
- assetUrls
- assetUtils
- autoFocus
- bindingUtils
- cameraOptions
- children
- className
- colorScheme
- components
- deepLinks
- embeds
- forceMobile
- hideUi
- initialState
- initialTheme
- licenseKey
- maxAssetSize
- maxImageDimension
- mediaMimeTypes
- onMount
- onUiEvent
- options
- overrides
- shapeUtils
- textOptions
- themes
- tools
- user
- Properties
- Methods
Extends TldrawUiProps, TldrawEditorBaseProps, TLExternalContentProps.
interface TldrawBaseProps
extends TldrawUiProps, TldrawEditorBaseProps, TLExternalContentProps {}Properties
acceptedImageMimeTypes
The mime types of images that are allowed to be handled. When using the Tldraw component, defaults to DEFAULT_SUPPORTED_IMAGE_TYPES. If neither this nor acceptedVideoMimeTypes is provided, the registered asset utils determine which MIME types are allowed.
acceptedImageMimeTypes?: readonly string[];acceptedVideoMimeTypes
The mime types of videos that are allowed to be handled. When using the Tldraw component, defaults to DEFAULT_SUPPORT_VIDEO_TYPES. If neither this nor acceptedImageMimeTypes is provided, the registered asset utils determine which MIME types are allowed.
acceptedVideoMimeTypes?: readonly string[];assetUrls
Urls for custom assets.
⚠︎ Important! This must be memoized (with useMemo) or defined outside of any React component.
assetUrls?: TLUiAssetUrlOverrides;assetUtils
An array of asset utils to use in the editor.
assetUtils?: readonly TLAnyAssetUtilConstructor[];autoFocus
Whether to automatically focus the editor when it mounts.
autoFocus?: boolean;bindingUtils
An array of binding utils to use in the editor.
bindingUtils?: readonly TLAnyBindingUtilConstructor[];cameraOptions
Deprecated:
Use options.cameraOptions instead. This will be removed in a future release.
Camera options for the editor.
cameraOptions?: Partial<TLCameraOptions>;children
The component's children.
children?: ReactNode;className
A classname to pass to the editor's container.
className?: string;colorScheme
The editor's color scheme. Defaults to 'light'.
'light'- Always use light mode. -'dark'- Always use dark mode. -'system'- Follow the OS color scheme preference.
colorScheme?: "dark" | "light" | "system";components
Overrides for tldraw's components.
⚠︎ Important! This must be memoized (with useMemo) or defined outside of any React component.
components?: TLComponents;deepLinks
Deprecated:
Use options.deepLinks instead. This prop will be removed in a future release.
Options for syncing the editor's camera state with the URL.
deepLinks?: TLDeepLinkOptions | true;embeds
Deprecated:
Use EmbedShapeUtil.configure({ embedDefinitions: embeds }) instead.
Custom definitions for tldraw's embeds.
⚠︎ Important! This must be memoized (with useMemo) or defined outside of any React component.
embeds?: TLEmbedDefinition[];forceMobile
Whether to always should the mobile breakpoints.
forceMobile?: boolean;hideUi
Whether to hide the user interface and only display the canvas.
hideUi?: boolean;initialState
The editor's initial state (usually the id of the first active tool).
initialState?: string;initialTheme
The id of the initially active theme. Defaults to 'default'.
initialTheme?: TLThemeId;licenseKey
The license key.
licenseKey?: string;maxAssetSize
The maximum size (in bytes) of an asset. Assets larger than this will be rejected. Defaults to 10mb (10 * 1024 * 1024).
maxAssetSize?: number;maxImageDimension
The maximum dimension (width or height) of an image. Images larger than this will be rescaled to fit. Defaults to infinity.
maxImageDimension?: number;mediaMimeTypes
Supported mime types for media files.
mediaMimeTypes?: string[];onMount
Called when the editor has mounted.
onMount?: TLOnMountHandler;onUiEvent
Callback for when an event occurs in the UI.
onUiEvent?: TLUiEventHandler;options
Options for the editor.
options?: Partial<TldrawOptions>;overrides
Overrides for the UI.
overrides?: TLUiOverrides | TLUiOverrides[];shapeUtils
An array of shape utils to use in the editor.
shapeUtils?: readonly TLAnyShapeUtilConstructor[];textOptions
Deprecated:
Use options.text instead. This prop will be removed in a future release.
Text options for the editor.
textOptions?: TLTextOptions;themes
Named themes for the editor.
themes?: Partial<TLThemes>;tools
An array of tools to add to the editor's state chart.
tools?: readonly TLStateNodeConstructor[];user
The user interacting with the editor.
user?: TLCurrentUser;Methods
getShapeVisibility
Provides a way to hide shapes.
Hidden shapes will not render in the editor, and they will not be eligible for hit test via Editor.getShapeAtPoint and Editor.getShapesAtPoint. But otherwise they will remain in the store and participate in all other operations.
Example
getShapeVisibility={(shape, editor) => shape.meta.hidden ? 'hidden' : 'inherit'}'inherit' | undefined- (default) The shape will be visible unless its parent is hidden. -'hidden'- The shape will be hidden. -'visible'- The shape will be visible.
Parameters
Returns
"hidden" | "inherit" | "visible" | null | undefined;renderDebugMenuItems
Additional items to add to the debug menu (will be deprecated)