This is a starter repo for The New Dynamic's web projects. Do with as you wish, but keep in mind that everything here is designed for our internal workflow.
We use a Changelog on all of our projects. Please see that file for updates.
- Hugo, to generate HTML
- Webpack 4+
- Prettier (code formatting, wip)
- PostCSS | TailwindsCSS (library of JS-based CSS classes ) | PurgeCSS (removes unused CSS)
- JS: Turbolinks sometimes (HTML5 History API for faster navigation)
- JS: Lazysizes (lazy asset loading)
- KyleAMathews/typefaces (load OS fonts locally with one little
require
)
git clone https://github.com/theNewDynamic/hugo-starter.git yourprojectname
cd yourprojectname
rm -rf .git
git init
git add .
git commit -m "initial commit"
git remote add origin https://github.com/theNewDynamic/YOURPROJECTNAME.git
git push -u origin master
git submodule add https://github.com/theNewDynamic/hugo-layout_module-base.git layout_modules/hugo-layout_module-base
repeat for additional modules
Add theme component to config.toml:
theme = ["hugo-layout_module-base", "hugo-layout_module-nameofmodule"]
Note. Hugo uses the "themes" directory by default. We've renamed that to layout_modules
.
To build JS files, we use webpack. The entry point is ./assets/index.js
for adding new scripts.
- Add the script via Yarn (
yarn add scriptname -D
). - Place a file in the JS folder and add the script, or, preferably, require/import it from its node module.
- Import the file (
import "./js/scriptname.js"
) in the index.js file.
yarn install
yarn build-dev
oryarn build
if you want to generate the file once.
When possible, we use Kyle Mathews' Typefaces so that we can server our font files locally. Just add the typeface to assets/index.js
and run the webpack build, as above (yarn build
). This will generate the font files into the static/fonts
directory (which Hugo will automatically copy into the public directory) and generate a fonts CSS file, which then Hugo will minify and fingerprint into your head.
We use TailwindCSS and several PostCSS plugins to generate CSS. Most of your CSS will be utility classes in your templates. Hugo will not rebuild your CSS file unless the file itself is changed. In a TailwindCSS context, most of your work occurs in templates, not in the CSS file. To make development easier, we've created a separate PostCSS config file without PurgeCSS. However, this means you must run yarn deploy
(as outline below) for you push your changes.
- Before deploying, run
yarn deploy
(orhugo --gc
if you're not generating fonts or JS) to generate a minified, purged CSS file. - Check the
resources
folder into your repository.
- PurgeCSS will fail if any of your templates are empty.
- If you add themes, you may need to add the file location in the PurgeCSS
content
configuration item. This is done for you, with a glob pattern, but it is something to be aware of.