A general purpose website generator which can render pages from static markdown files, nunjucks templates, CraftCMS instances, or from custom content sources. The generator makes the ONS Design System components and macros available to templates as pages are being processed and rendered.
This package treats the @ons/design-system package as a peer dependency leaving the website project to include the desired version.
Install the static website generator:
yarn add https://github.com/ONSdigital/static-website-generator#v1.9.0
Install the required version of the ONS Design System; for example, to install the latest version:
yarn add @ons/design-system
At minimum a project directory must contain the file ./config/sites.js
to configure sites.
Website projects can be structured however desired; however the following pattern works well:
-
./content/{site-name}/
- Contains static source content for a site (at the very least should contain an empty placeholder file like.gitkeep
). -
./static/
- Static files to copy into output website. -
./static-dev/
- Static files to copy into output website for local development only (have these excluded in.gitignore
).
The following is recommended for CraftCMS sources:
./graphql/content.gql
- GraphQL query to fetch content from CMS.
- Navigate to your website project directory (contains "config" directory).
- Run
generate-website
to generate the website into an output directory "dist". - Preview website output using a tool like
npx serve dist
.
Ideally the website project should contain scripts like the following:
"scripts": { "build": "generate-website", "serve": "npx serve dist", "preview": "yarn build && yarn serve" }
- Project sites configuration
- Static content
- CraftCMS GraphQL queries
- Templating
- Creating a custom content source
GitHub's
gh
command is needed in order to use thecreate-release
command (see Take GitHub to the command line).
- Ensure that your local working directory is clear.
- Run the command
yarn create-release {x.y.z}
with the new release number in place of{x.y.z}
.This bumps the package release number and creates a PR for the release.
- Review and merge the release PR.
- Create a release version. Specify a version number tag (eg. v1.0.0), use the version number (eg. 1.0.0) for the release title, and summarise the release.