update-release-notes
Update the release notes file at `apps/docs/content/releases/next.mdx` based on PRs merged to main since the previous release, or archive `next.mdx` to a versioned file when a new version is published.
Install
mkdir -p .claude/skills/update-release-notes && curl -L -o skill.zip "https://mcp.directory/api/skills/download/4150" && unzip -o skill.zip -d .claude/skills/update-release-notes && rm skill.zipInstalls to .claude/skills/update-release-notes
About this skill
Update release notes
This skill handles the operational tasks of maintaining release notes in the tldraw/tldraw repo: adding new PR entries to next.mdx and archiving releases when a new version is published.
This skill runs from the tldraw-internal repo but operates on a local clone of tldraw/tldraw.
Setup
Before starting, clone the tldraw repo:
git clone https://github.com/tldraw/tldraw.git /tmp/tldraw
All scripts take the repo path as their first argument. All file edits happen in this clone. At the end, commit and push from the clone.
Release cycle
The SDK releases every four weeks. One week before launch, the SDK is frozen and a production branch is cut from main. During release week, only hotfixes are cherry-picked to production.
The release notes in next.mdx must ultimately reflect what ships on the production branch. However, during the ~3 development weeks before the freeze, we build up release notes from main so they're not empty. The status script detects which phase we're in based on the date of the last minor release:
- Development weeks (
source: "main", <3 weeks since last minor release): PRs are gathered frommainsince the last release tag. These are preliminary — some may not ship if they're reverted or if production cherry-picks differ. - Freeze week (
source: "production", 3+ weeks since last minor release): PRs are gathered from theproductionbranch usinggit cherryagainst the previous release branch. Only PRs that landed before the freeze or were hotfixed onto production are included. Entries accumulated frommainthat aren't on production will be pruned.
Process
1. Check status
Run the status script to determine versions and diff branch:
.claude/skills/update-release-notes/scripts/get-changelog-status.sh /tmp/tldraw
This returns:
source- either"main"(development weeks) or"production"(release week)diff_branch(e.g.,v4.3.x) - the branch to diff against (used whensourceis"production")last_tag(e.g.,v4.4.0) - the last release tag (used whensourceis"main")latest_release- the most recent published release- Whether archival is needed
2. Handle archival (if needed)
If a new release was published since last_version in next.mdx:
- Copy
next.mdxcontent tovX.Y.0.mdx(e.g.,v4.3.0.mdx) - Update the frontmatter in the new file:
- Set
titleto the version - Update dates
- Add the GitHub release link after frontmatter
- Set
- Add the new version to the releases index at
apps/docs/content/getting-started/releases.mdx:- Add a line at the top of the appropriate
## v{major}.xsection - Format:
- [vX.Y](/releases/vX.Y.0) - Brief description - The description should be a short summary of the release highlights from the intro paragraph (3-5 key features, comma-separated)
- If a new major version section is needed, create it above the previous one
- Add a line at the top of the appropriate
- Reset
next.mdx:- Update
last_versionfield to the new release - Clear the content sections
- Keep the file structure for accumulating new changes
- Update
3. Find new PRs
The approach depends on the source field from step 1.
If source is "production" (release week):
Get PR numbers on the production branch since the previous release:
.claude/skills/update-release-notes/scripts/get-new-prs.sh /tmp/tldraw <diff_branch>
This uses git cherry (same approach as extract-draft-changelog.tsx) to compare patches between origin/production and origin/<diff_branch>. Unlike git log, git cherry correctly handles cherry-picked hotfix commits by comparing patch content rather than commit hashes.
If source is "main" (development weeks):
Get PR numbers on main since the last release tag:
.claude/skills/update-release-notes/scripts/get-new-prs-from-main.sh /tmp/tldraw <last_tag>
This uses git cherry to compare patches between origin/main and the release tag, excluding commits that were cherry-picked to production and already shipped in the release.
Both scripts output:
- stdout: PR numbers (one per line) extracted from commit messages
- stderr: Commits without PR numbers (typically hotfixes or direct commits)
4. Resolve hotfix commits
Check stderr from step 3 for any [HOTFIX] commits without PR numbers. For each SDK-relevant one (skip dotcom-only), find the corresponding PR:
gh pr list -R tldraw/tldraw --state merged --search "<hotfix title keywords>" --json number,title --jq '.[]'
Also check sdk-hotfix-please labeled PRs, but verify they actually landed on production — this label is also used for patch releases on the previous release branch (e.g., v4.3.x):
gh pr list -R tldraw/tldraw --label "sdk-hotfix-please" --state merged --limit 20 --json number,title,mergedAt
Add any matched PR numbers to the production PR list from step 3.
5. Fetch PR details
Batch fetch all PR information:
.claude/skills/update-release-notes/scripts/fetch-pr-batch.sh <pr1> <pr2> ...
6. Remove stale entries
Compare the full PR list (from steps 3 + 4) against the PR numbers already referenced in next.mdx. Remove any entries from next.mdx whose PRs are not in the current set.
- When
sourceis"production": This prunes entries that were accumulated frommainduring development but didn't make it to production. These are PRs that landed onmainafter the production branch was cut and will not ship in this release. - When
sourceis"main": This removes entries for PRs that were reverted or otherwise no longer on main. Pruning is less aggressive since the full set isn't finalized until production is cut.
When removing an entry, also check whether it was referenced in a featured "What's new" section and remove that section too. Update the intro paragraph if it mentions a removed feature.
7. Add new entries
For each PR not already in next.mdx:
- Check PR labels and body against the style guide's categorization rules
- Skip PRs that should be omitted (see style guide)
- Skip PRs that fix bugs introduced in the same release cycle (i.e., bugs caused by other PRs already in
next.mdxthat were not in the previous release) - If a PR is a revert, also remove the original reverted PR's entry from
next.mdxif present - Add entries to the appropriate section
- Promote significant changes to featured sections when warranted
8. Verify
Check that:
- Every PR referenced in
next.mdxis in the current PR set (frommainorproductiondepending onsource) - PR links are correct
- Community contributors are credited
- Sections are in the correct order
- Breaking changes are marked with 💥
- Deprecations are marked with 🔜
Note: When source is "main", the entries are preliminary. Some may be pruned later when the production branch is cut and the source switches to "production".
9. Push changes
After editing next.mdx (and any archive files), commit and push from the tldraw clone:
cd /tmp/tldraw
BRANCH="update-release-notes-$(date -u +%Y%m%d-%H%M)"
git checkout -b "$BRANCH"
git add apps/docs/content/releases/
git commit -m "docs: update release notes"
git push -u origin "$BRANCH"
Then create the PR following the standards in @.claude/skills/write-pr/SKILL.md:
- Title:
docs(releases): update release notes - Change type:
other - Test plan: Remove the numbered list (no manual testing steps). Untick both unit tests and end to end tests.
- Release notes: Omit this section (internal docs work with no user-facing impact)
- Description paragraph: Start with "In order to..." and mention the source (
mainorproduction) and what was updated (new entries added, stale entries pruned, archival performed, etc.) - Include a Code changes table with a
Documentationrow
The last_version field
The next.mdx frontmatter includes a last_version field that tracks the most recent published release. This determines which PRs are "new" and need to be added.
SDK release workflow
During an SDK release, this skill is run twice to get the docs site into its post-release state:
- First run — update
next.mdxwith all PRs that will ship in the release (source is"production"during freeze week). This ensures the release notes are complete before publishing. - Publish the release to NPM — this happens outside of this skill.
- Second run — now that the release is published, the status script will detect
needs_archive: true. This run:- Archives
next.mdxto a versioned file (e.g.,v4.5.0.mdx) - Adds the new version to the releases index (
releases.mdx) - Resets
next.mdxwith the newlast_version - Finds PRs that landed on
mainduring the freeze (since the release tag) and adds them to the freshnext.mdx
- Archives
After the second run, the docs site reflects the published release and next.mdx already has a head start on the next cycle's changes.
References
- Style guide: See
shared/release-notes-guide.mdfor guidance on what a release notes article should contain and how to format it. - Writing guide: See
shared/writing-guide.mdfor voice and style conventions. - Scripts: See
scripts/for automation helpers
More by tldraw
View all →You might also like
flutter-development
aj-geddes
Build beautiful cross-platform mobile apps with Flutter and Dart. Covers widgets, state management with Provider/BLoC, navigation, API integration, and material design.
drawio-diagrams-enhanced
jgtolentino
Create professional draw.io (diagrams.net) diagrams in XML format (.drawio files) with integrated PMP/PMBOK methodologies, extensive visual asset libraries, and industry-standard professional templates. Use this skill when users ask to create flowcharts, swimlane diagrams, cross-functional flowcharts, org charts, network diagrams, UML diagrams, BPMN, project management diagrams (WBS, Gantt, PERT, RACI), risk matrices, stakeholder maps, or any other visual diagram in draw.io format. This skill includes access to custom shape libraries for icons, clipart, and professional symbols.
godot
bfollington
This skill should be used when working on Godot Engine projects. It provides specialized knowledge of Godot's file formats (.gd, .tscn, .tres), architecture patterns (component-based, signal-driven, resource-based), common pitfalls, validation tools, code templates, and CLI workflows. The `godot` command is available for running the game, validating scripts, importing resources, and exporting builds. Use this skill for tasks involving Godot game development, debugging scene/resource files, implementing game systems, or creating new Godot components.
nano-banana-pro
garg-aayush
Generate and edit images using Google's Nano Banana Pro (Gemini 3 Pro Image) API. Use when the user asks to generate, create, edit, modify, change, alter, or update images. Also use when user references an existing image file and asks to modify it in any way (e.g., "modify this image", "change the background", "replace X with Y"). Supports both text-to-image generation and image-to-image editing with configurable resolution (1K default, 2K, or 4K for high resolution). DO NOT read the image file first - use this skill directly with the --input-image parameter.
ui-ux-pro-max
nextlevelbuilder
"UI/UX design intelligence. 50 styles, 21 palettes, 50 font pairings, 20 charts, 8 stacks (React, Next.js, Vue, Svelte, SwiftUI, React Native, Flutter, Tailwind). Actions: plan, build, create, design, implement, review, fix, improve, optimize, enhance, refactor, check UI/UX code. Projects: website, landing page, dashboard, admin panel, e-commerce, SaaS, portfolio, blog, mobile app, .html, .tsx, .vue, .svelte. Elements: button, modal, navbar, sidebar, card, table, form, chart. Styles: glassmorphism, claymorphism, minimalism, brutalism, neumorphism, bento grid, dark mode, responsive, skeuomorphism, flat design. Topics: color palette, accessibility, animation, layout, typography, font pairing, spacing, hover, shadow, gradient."
rust-coding-skill
UtakataKyosui
Guides Claude in writing idiomatic, efficient, well-structured Rust code using proper data modeling, traits, impl organization, macros, and build-speed best practices.
Stay ahead of the MCP ecosystem
Get weekly updates on new skills and servers.