metalsmith-morph

0.0.4 • Public • Published

metalsmith-morph

build status

A jstransformer template engine for metalsmith

This metalsmith plugin allows you to render templates with jstransformer. The plugin exposes two properties: templatePath and destinationPath to help with linking between pages.

The templatePath refers to the main template being transformed (e.g. index.html.njk). The destinationPath refers to the name of the output file after all transformations have been rendered (e.g.: index.html). The variable names are borrowed from yeoman.

Files will be transformed based on their extension, last extension first. Transformations are applied until there are no more applicable jstransformers remaining.

Templating engines

You can use any jstransformer-compatible engine to render output including:

Example

The following example shows you how to use jstransformer-nunjucks with metalsmith-morph.

npm install metalsmith metalsmith-morph jstransformer-nunjucks --save
var metalsmith = require('metalsmith')
var morph = require('metalsmith-morph')

metalsmith(__dirname)
  .use(morph())
  .build(function(err){
    if (err) throw err;
  });

Source file src/index.html.njk:

---
title: Page title
---
<p>{{ title }} ({{ destinationPath }})</p>

Results in build/index.html:

<p>Page title (index.html)</p>

Options

You can pass additional options to a jstransformer engine by using the options parameter. The first key in the object is the name of the transformer (in this example, nunjucks).

The following example exposes node's require function in nunjucks so that it may be used inside a template:

var metalsmith = require('metalsmith')
var morph = require('metalsmith-morph')

metalsmith(__dirname)
  .use(morph({
    nunjucks: {
      globals: {
        require: function () { return require.apply(this, arguments) }
      }
    }
  }))
  .build(function(err){
    if (err) throw err;
  });

Implementation example:

{% set path = require('path') -%}
{{ path.parse('http://www.example.com') | dump | safe }}

Acknowledgements

This project draws significant inspiration from metalsmith-in-place and metalsmith-engine-jstransformer.

The main difference is that metalsmith-morph is a single plugin which exposes destinationPath and templatePath.

Readme

Keywords

none

Package Sidebar

Install

npm i metalsmith-morph

Weekly Downloads

0

Version

0.0.4

License

MIT

Unpacked Size

6.95 kB

Total Files

4

Last publish

Collaborators

  • bashaus