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.
<iframe src="https://xcratch.github.io/editor/player#https://xcratch.github.io/xcx-example/projects/example.sb3" width="540px" height="460px"></iframe>This extension can be used with other extension in Xcratch.
- Open Xcratch Editor
- Click 'Add Extension' button
- Select 'Extension Loader' extension
- Type the module URL in the input field
https://xcratch.github.io/xcx-example/dist/xcratchExample.mjs
- Click 'OK' button
- Now you can use the blocks of this extension
npm installChange vmSrcOrg to your local scratch-vm directory in ./scripts/setup-dev.js then run setup-dev script to setup development environment.
npm run setup-devRun build script to bundle this extension into a module file which could be loaded on Xcratch.
npm run buildRun watch script to watch the changes of source files and bundle automatically.
npm run watchRun test script to test this extension.
npm run testThis project uses npm version commands and GitHub Actions for versioning and deployment.
Use npm version command to update the version number. This will automatically:
- Update version in
package.json - Run the build script
- Create version-specific build files in
dist/{version}/ - Update
dist/versions.jsonwith the new version info - Create a git commit and tag
# 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 majorAfter 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 --tagsThe GitHub Actions workflow will:
- Build the extension
- Deploy
dist/,projects/, andREADME.mdto GitHub Pages
You 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.