static-site-boilerplate

static-site-boilerplate

Static site boilerplate with preconfigured Jekyll, esbuild, Tailwind CSS, I18n, and build pipeline. Supports Github Pages.

Static website boilerplate

This repo is a template of a static website that supports internationalization. It uses Jekyll, esbuild, and Tailwind CSS. Ready to use with Github Pages.

Check out the gh-pages branch on this repo or visit the Github Pages endpoint to see what the output of the template looks like.

Contents

  • Jekyll and Jekyll Multiple Languages for static HTML generation
  • esbuild for Javascript bundling
  • Tailwind CSS for auto-generating CSS utility classes
  • A base layout and a sitemap that supports i18n by generating alternate language links
  • A Github action that runs the build pipeline in production, enabling Jekyll plugins that Github does not support by default
  • Utility scripts to run the build pipeline in development

Serving your site in production

When forking, remember to:

  • update the baseurl entry in docs/_config.yml so that your links point to the right location
  • if you're using Github Pages to serve the website from a custom domain, add a docs/CNAME file with your domain (e.g. www.example.com). Refer to Github's documentation on custom domains.

To serve ths site using Github pages, go to the Repo's Settings > Pages, and update the Source option to the root directory of the gh-pages branch. This branch is updated automatically by the build pipeline every time you push an update to the main branch.

CSS

To apply standard styles on your HTML tags without repeating utility classes for each instance, update docs/assets/stylesheets/tailwind.css per Tailwind's documentation.

To DRY components that rely on many Tailwind CSS classes, you could:

  • render them in HTML by creating the docs/_includes folder and following Jekyll's documentation on includes
  • render them in Javascript using a library like React

Javascript

Thanks to esbuild, you can use ES6 and CommonJS modules, Typescript, and React out of the box. Add javascript files to the docs/assets/javascripts folder, and import them into app.js as usual. They will all be bundled into a single docs/_site/assets/javascripts/main.js file that the base layout includes.

To add a javascript library, run yarn add ... and import it in your javascript files.

Jekyll plugin

To add a Jekyll plugin, run bundle add ... per the plugin's instructions and load it by updating the plugins entry in docs/_config.yml.

Sitemap

The sitemap.xml file generates I18n alternate links. It is quite basic. If you need more control over the last modified or change frequency fields, refer to this article or use one of the sitemap plugins for Jekyll.

The build pipeline

When pushing changes to the main branch on Github, the .github/workflows/build.yml Github Action runs the bin/build script, and commits the resulting files in docs/_site into the gh-pages branch at its root.

bin/build performs the following:

Local development

Run bin/dev to have Jekyll, esbuild, and Tailwind watch for files and recreate docs/_site using Foreman. Your site is served from http://localhost:4000 using Webrick as usual.