Skip to content

A general purpose static website generator that can render static content and optionally content pulled from a Craft CMS instance.

License

Notifications You must be signed in to change notification settings

ONSdigital/static-website-generator

Repository files navigation

static-website-generator

Run tests

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.

Getting started with a new project

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.

Using the CLI

  1. Navigate to your website project directory (contains "config" directory).
  2. Run generate-website to generate the website into an output directory "dist".
  3. 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"
}

Documentation

Releasing a new version of this generator

GitHub's gh command is needed in order to use the create-release command (see Take GitHub to the command line).

  1. Ensure that your local working directory is clear.
  2. 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.

  3. Review and merge the release PR.
  4. 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.

About

A general purpose static website generator that can render static content and optionally content pulled from a Craft CMS instance.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages