Skip to content

Generate and compile static HTML pages using Nunjucks with asset compilation and minification

License

Notifications You must be signed in to change notification settings

chidiwilliams/nunjucks-templating-starter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

nunjucks-templating-starter

About

Use this tool to generate static HTML pages from templates and compiles CSS and JS asset files.

Quickly write HTML for design screens for small projects without building a full frontend app.

Supported by Gulp tasks and Nunjucks templating engine.

Table of Contents

  1. Quick Start

  2. Usage

  3. Available commands

  4. Configuration

  5. Dependencies

Quick Start

To begin:

  1. Create new app directory

  2. Clone this repository

git clone https://www.github.com/chidiwilliams/nunjucks-templating-starter
  1. Install dependencies
npm install
  1. Build files and start development server
npm run watch

Features

  1. Generate HTML files quickly with only HTML, CSS and JS

  2. Bootstrap and jQuery included

  3. CSS and JavaScript minifier

  4. SASS compiler

  5. Server not required

  6. Works out of the box!

Usage

HTML

This tool uses the Nunjucks templating engine. To learn more about Nunjucks, visit the website.

The Nunjucks templates are kept in the resources/views directory. Both .njk and .html file extensions are supported for the templates.

Example:

|--views/
  |--layouts/
  | |--master.njk
  |--home.njk

views/layouts/master.njk

<html>
...
<body>
...
{% block content %}{% endblock %}
...
</body>
</html>

views/home.njk

{% extends 'layouts/master.njk' %}

{% block content %}
  Giraffes were invented when Chuck Norris laid an uppercut to a horse.
{% endblock %}

The rendered HTML files would be sent to the dist directory.

home.html

<html>
...
<body>
...
Giraffes were invented when Chuck Norris laid an uppercut to a horse.
...
</body>
</html>

CSS

Place precompiled SCSS files in the resources/assets/scss directory. To minify the output CSS, set:

config/config.js

config.sass.outputStyle = 'compressed'

After building, the compiled CSS files are sent to the dist/css directory.

To import the CSS into a Nunjucks template, link to dist/css/[FILE_NAME]. Example:

master.njk

<html>
<head>
  ...
  <link rel="stylesheet" href="css/main.css">
</head>
<body>
...
<script src="js/main.js"></script>
</body>
...
</html>

JS

Place precompiled JS files in the resources/assets/js directory. To minify the output JS, set:

config/config.js

config.sass.outputStyle = 'compressed'

After building, the compiled CSS files are sent to the dist/css directory.

Vendor

Put vendor CSS and JS assets in the resources/vendor/css and resources/vendor/js respectively. During compilation, these assets are directly copied into the dist directory without processing.

Available commands

npm run build

Compiles the HTML and assets files into the dist directory. This action can also be done by running node index.js.

npm run watch

Same as above but watches for file changes in the resources directory and recompiles the assets accordingly.

Also, it starts a server at http://localhost:3000/ and syncs your browser with your output files. Great for development.

Configuration

The configuration object is exported by the 'config/config.js' file.

config.njk

Configuration for the Nunjucks renderer

config.njk.templateVars: Pass in variables here to add them as global variables in your Nunjucks templates.

Example:

config.js

module.exports = {
  ...
  njk: {
    ...
    templateVars: {
      quote1: "Chuck Norris can light a fire by rubbing two ice-cubes together.",
      quote2: "When Chuck Norris does a push up, he isn't lifting himself up, he's pushing the Earth down.",
    }
    ...
  }
  ...
}

home.njk

<html>
  ...
  <body>
    {{ quote1 }}
    {{ quote2 }}
  </body>
</html>

config.sass

Configuration for the SASS renderer

config.sass.outputStyle: Style of the output CSS files ('nested' | 'expanded' | 'compact' | 'compressed'). Default is 'nested'.

config.js

Configuration for the JS renderer

config.js.doCompress: Determines if the final JS files would be compressed (true | false). Default is false.

config.js.doKeepSource: Determines if the .js source file would be included after compression (true | false). Default is false. config.js.doCompress must be set to true.

Dependencies

  1. Gulp GitHub, NPM, Website

  2. Nunjucks GitHub, Website

  3. Nodemon GitHub, NPM, Website

  4. Browser Sync NPM, Website

About

Generate and compile static HTML pages using Nunjucks with asset compilation and minification

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published