The goal of this is to help test the web components and to serve as a training module for new users.
This is a replacement of the old toolkit builder.
This deploys to:
- https://builder3.toolkit.illinois.edu: the individual environment for a version 3 build. This is for both development (dev.toolkit.illinois.edu) and production (cdn.toolkit.illinois.edu).
The bad news is GitHub actions don't support looping except with the matrix option and external jobs have a limit of 20. I am using judicious copy-paste. To add a new component to the toolkit builder, update the /.github/workflows/deploy_release.yml file and add another Checkout section name of the repository. You will need to update the name of the repository in two places -- once in the title, once in the with repository name. This will check out the repository and copy the json files from the /builder/ and /builder/versions/ folders.
Copy component JSON files. If you have the toolkit-management
repository, you can use something like:
rm toolkit-builder-3/site/imported_json/components/*.json
rm toolkit-builder-3/site/imported_json/component_versions/*.json
cp toolkit-management/node_modules/@illinois-toolkit/*/builder/*.json toolkit-builder-3/site/imported_json/components/.
cp toolkit-management/node_modules/@illinois-toolkit/*/builder/versions/*.json toolkit-builder-3/site/imported_json/component_versions/.
cp toolkit-management/global-css/builder/*.json toolkit-builder-3/site/imported_json/components/.
cp toolkit-management/global-css/builder/versions/*.json toolkit-builder-3/site/imported_json/component_versions/.
You can run the following commands to build the test site:
npm install
npm rebuild
npm run build
This will generate a static site under _site. You can use a live server tool to run this from your local machine. If you are using Visual Studio Code, you can choose File --> Add Folder to Workspace to add _site and make this the root.
Note: this is assuming that the root directory is _site. If you are using Visual Studio Code, you can choose Add Folder to Workspace to add _site to the workspace so you can run Live Server with _site as the root folder.
You can use the builder to test your components without publishing.
Before you run this on your local machine, make sure you include the json files in /site/imported_json/component_versions and /site/imported_json/components. By default, this will be blank, so you will need to manually copy the files from your component repository to these folders.
Note that if you are testing the component using the path /component/name/version/index.html, it's not going to use the NPM package. It will use the file path listed in your /site/imported_json/component_versions/ file.
To point to a local copy of your files, copy your js and css files to /_localfiles/ and change your component_versions file to
"css": "/_localfiles/ilw-hero.css",
"js": "/_localfiles/ilw-hero.js",
Any files in the directories /site/imported_json/component_versions, /site/imported_json/components, and /site/_localfiles will not be pushed to GitHub.
You may want to run a local version of code so you can test interactions with other components. The toolkit builder and toolkit management Github repositories support this workflow.
In Github, make a local copy of the toolkit-management repository. Manually run an NPM install of the packages you want to run, and then run the build step for the toolkit management. Then, copy those build files to the _localfiles folder in the builder application. These _localfiles will not be deployed to Github. Below is a sample Windows script to run that installs the local version of ilw-page, assuming you are on the toolkit-management repository.
cd source/repos/toolkit-management
npm install ../ilw-page/
npm run build
copy dist-toolkit\* ..\toolkit-builder-3\site\_localfiles /Y
To run the demo pages, change the localFiles
of the demo pages to true in the .md file and run the npm build script for the toolkit builder 3 project. Make sure you change the localFiles
variable back to false before checking the files back in.
If you are changing the toolkit-management repository, make sure you rebuild the package.json and package-lock.json files. Updating the package.json can be done manually, but to update the package-lock.json, run npm update --save
.