tldraw-mcp
Provides tools to read, write, and validate tldraw files, enabling interaction with tldraw scenes.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@tldraw-mcpread the drawing from drawing.tldr"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
tldraw-mcp — headless tldraw MCP server
Node-only MCP server exposing read_tldr, write_tldr, and validate_tldr tools.
No browser, no DOM, no React — runs in plain Node v24.
Pinned version
@tldraw/editor 5.1.1
@tldraw/store 5.1.1
@tldraw/tlschema 5.1.1Related MCP server: tldraw-mcp
Verified import surface (tldraw 5.1.1)
Symbol | Package | Notes |
|
| Use directly — |
|
| NOT in |
|
| |
|
| |
|
| For reading |
|
| Convert plain text → ProseMirror richText doc |
NEVER import the
tldrawumbrella package at runtime. NEVER callnew Editor()orcreateTLStorefrom@tldraw/editorin read/write/validate paths.@tldraw/tlschemais CJS — load viacreateRequirein.mjsfiles (named ESM imports fail).
Tools exposed
read_tldr— parse a.tldrfile, return records + schema versionwrite_tldr— accept a scene spec, build a.tldrfile envelopevalidate_tldr— validate a.tldrJSON blob against the live schema
Provisioning
Requires Node v24.
npm ci
npm run buildBuilt output: dist/index.js (ESM, produced by tsc).
MCP registration (LOCAL dev form)
Add to your repo's .mcp.json (already committed at repo root):
{
"mcpServers": {
"tldraw": {
"type": "stdio",
"command": "node",
"args": ["tools/tldraw-mcp/dist/index.js"]
}
}
}The universal
npx -y github:jinsoo/tldraw-mcpform (see below) can also be used here once the standalone repo is published.
Upstream tracking
To upgrade to a newer tldraw release:
./track-upstream.shThis bumps @tldraw/* in package.json, re-extracts src/defaults.json
via npm run probe-defaults, vendors a fresh llms-docs.txt, rebuilds,
and runs the full test suite. Do NOT run during active development.
llms-docs.txt
llms-docs.txt is the tldraw LLM reference doc vendored at the pinned version.
It is fetched by track-upstream.sh from https://tldraw.dev/llms-docs.txt.
.tldr file envelope
The correct write shape (do NOT use serializeTldrawJson — needs Editor):
{
tldrawFileFormatVersion: 1,
schema: store.schema.serialize(),
records: store.allRecords() // flat ARRAY, not a map
}schemaVersion is 2 for tldraw 5.1.1.
Universal install (any agent)
Runs straight from GitHub — no npm account, no local checkout:
npx -y github:jinsoo/tldraw-mcpClaude Code (.mcp.json):
{ "mcpServers": { "tldraw": { "type": "stdio", "command": "npx", "args": ["-y", "github:jinsoo/tldraw-mcp"] } } }Any MCP host that registers stdio servers (config.yaml mcp_servers example):
tldraw: { type: stdio, command: npx, args: ["-y", "github:jinsoo/tldraw-mcp"], enabled: true }Tools: read_tldr, write_tldr, validate_tldr.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/jinsoo/tldraw-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server