| name | release |
| description | Automates the mthds-ui release workflow: bumps the version in package.json, finalizes the CHANGELOG.md Unreleased section, runs quality checks and tests, creates a release/vX.Y.Z branch, commits, pushes, and opens a PR to main. Use when user says "release", "cut a release", "bump version", "prepare a release", "make a release", "ship it", "create release branch", or any variation of shipping a new version of mthds-ui. The user can optionally provide changelog content inline when invoking the skill (e.g. "/release Added StuffViewer component"), which will be used as the changelog entry for this version.
|
mthds-ui Release Workflow
This skill handles the full release cycle for the @pipelex/mthds-ui npm package.
Files touched
package.json — the version field (line 3)
CHANGELOG.md — add [vX.Y.Z] - YYYY-MM-DD entry (remove [Unreleased] if present)
package-lock.json — regenerated via npm install
Workflow
1. Pre-flight checks
- Read the current version from
package.json.
- Read
CHANGELOG.md to understand the current state (create it if it doesn't exist).
- Run
git status and git log origin/main..HEAD to assess the working tree:
- If there are uncommitted changes (staged or unstaged), warn the user and
ask whether to commit them as part of the release, stash them, or abort.
- If there are unpushed commits on the current branch, list them so the
user is aware — these will be included in the release branch.
2. Determine the bump type
Ask the user which kind of version bump they want — patch, minor, or
major — unless they already specified it. Show the current version and what
the new version would be for each option so the choice is concrete.
3. Run quality checks
Run make check && make test. This is the gate — if it fails, stop and report
the errors so they can be fixed before retrying. Do not proceed past this step
on failure.
4. Ensure we're on the right branch
The release branch must be named release/vX.Y.Z where X.Y.Z is the new
version. All file modifications (changelog, version bump, lock) must happen on
this branch.
- If already on
release/vX.Y.Z matching the new version, stay on it.
- If on
dev, main, or any other branch, create and switch to
release/vX.Y.Z from the current HEAD.
- If on a
release/ branch for a different version, warn the user and ask
how to proceed.
5. Finalize the changelog
Add a new version entry at the top of the changelog for the release.
- If there is an
## [Unreleased] section, remove it (including any blank
lines that follow it) and replace it with the new version heading. Any
content that was under [Unreleased] becomes the content of the new version.
- If there is no
[Unreleased] section, insert the new version heading
directly after the # Changelog title.
- Never add an
[Unreleased] heading. The changelog should only contain
concrete version entries.
- If the user provided changelog content when invoking the skill (e.g.
/release Added StuffViewer component), merge that content with any
existing [Unreleased] content (do not discard either source). Format the
combined content properly under the appropriate headings (e.g. ### Added,
### Changed, ### Fixed), inferring headings from the content when
possible.
- If the release has no changelog content yet (neither from an
[Unreleased]
section nor from inline user input), ask the user what to include before
proceeding.
- If
CHANGELOG.md doesn't exist yet, create it with the standard structure.
- The result should look like:
# Changelog
## [vX.Y.Z] - YYYY-MM-DD
### Changed
- ...
## [vPREVIOUS] - PREVIOUS-DATE
...
6. Bump the version in package.json
Edit package.json line 3 to the new version string. Only change the version
field — don't touch anything else.
7. Regenerate the lockfile
Run npm install to regenerate package-lock.json. This ensures the lockfile
reflects the new version in package.json. If this step fails, stop and report
the error.
8. Commit and push
Stage all release-related changes. This includes at minimum package.json,
CHANGELOG.md, and package-lock.json, plus any other files the user chose to
include in step 1 (e.g. previously uncommitted work that belongs in this
release).
Commit with the message:
bump version to X.Y.Z
Push the branch to origin with -u to set up tracking.
9. Open a PR
Create a pull request targeting main with:
- Title:
Release vX.Y.Z
- Body: Include:
- The changelog entries for this version (copied from CHANGELOG.md)
- A note about the version bump from old to new
Use this format for the PR body:
## Release vX.Y.Z
Bumps version from `A.B.C` to `X.Y.Z`.
### Changelog
<paste the changelog entries for this version here>
Report the PR URL back to the user.
Important details
- The version follows semver:
MAJOR.MINOR.PATCH.
- Always confirm the bump type with the user before making changes.
- If
make check or make test fails, the release is blocked — help the user
fix the issues rather than skipping the checks.
- Today's date for the changelog entry: use the current date in
YYYY-MM-DD
format.