An example extension for Xcratch
This extension add extra-block “do it”, that executes string in its input field as a sentence in Javascript and return the result.
Play Example Project to look at what you can do with “Xcratch Example” extension.
This extension can be used with other extension in Xcratch.
https://xcratch.github.io/xcx-example/dist/xcratchExample.mjs
npm install
Change vmSrcOrg to your local scratch-vm directory in ./scripts/setup-dev.js then run setup-dev script to setup development environment.
npm run setup-dev
Run build script to bundle this extension into a module file which could be loaded on Xcratch.
npm run build
Run watch script to watch the changes of source files and bundle automatically.
npm run watch
Run test script to test this extension.
npm run test
This project uses npm version commands and GitHub Actions for versioning and deployment.
Use npm version command to update the version number. This will automatically:
package.jsondist/{version}/dist/versions.json with the new version info# Patch version (1.3.0 → 1.3.1)
npm version patch
# Minor version (1.3.1 → 1.4.0)
npm version minor
# Major version (1.4.0 → 2.0.0)
npm version major
After creating a new version, push the tag to trigger automatic deployment:
# Push the version tag
git push origin v1.4.0
# Or push all tags
git push --tags
The GitHub Actions workflow will:
dist/, projects/, and README.md to GitHub PagesYou can also manually trigger deployment from the Actions tab in GitHub.
All build versions are recorded in dist/versions.json:
{
"extensionId": "xcratchExample",
"latest": "1.4.0",
"versions": [
{
"version": "1.4.0",
"buildDate": "2025-10-19T12:34:56.789Z",
"module": "1.4.0/xcratchExample.mjs"
}
]
}
Open this page from https://xcratch.github.io/xcx-example/
Contributions, issues and feature requests are welcome!
Feel free to check issues page.