Skip to content

A simple example of the `metalsmith-json-to-files` plugin in use.

Notifications You must be signed in to change notification settings

toddmorey/metalsmith-json-to-files-example

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Metalsmith json to files example

A simple example of the metalsmith-json-to-files plugin in use.

The metalsmith-json-to-files plugin for Metalsmith lets you generate files from JSON.

This repository is an example project showing the plugin in use.

Run the example

$ git clone https://github.com/toddmorey/metalsmith-json-to-files-example
$ cd metalsmith-json-to-files-example
$ npm install
$ metalsmith

A build folder will be created with sample output.

The metalsmith plugins used

Even though metalsmith-json-to-files will work on it's own, the best results come from pairing it with a few other metalsmith plugins. This example uses four total plugins:

"plugins": {
  "metalsmith-json-to-files": {
    "source_path": "./json/"
  },
  "metalsmith-collections": {
     "albums": {}
  },
  "metalsmith-permalinks": {
    "pattern": ":title",
    "relative": false
  },
  "metalsmith-layouts": {
    "engine": "handlebars"
  }
  1. metalsmith-json-to-files is called first. As the plugin runs, it will parse the json source (json/ablums.json) to create virtual files (pages) which are then passed on to the other plugins.
  2. metalsmith-collections is used to group the pages created by step 1 into a collection which will be available globally. This allows us to refer to the collection on any page of the site (handy for building index pages). If you look at the layouts/list.html layout template, you'll see an index page being built by looping over the collection: {{#each collections.albums}}.
  3. metalsmith-permalinks is used in part to create pretty URLS, but most importantly because this plugin adds a path variable to each file that can be used as it's URL in templates.
  4. metalsmith-layouts is used for rendering each page. Two layout examples are provided: one for a list display and one for each item.

Providing a json source file

You can see the sample json file ablums.json in the json folder. The metalsmith-json-to-files plugin expects a top-level array of objects. Each member of the array will be used to create a new virtual file with the properties you provide attached to the page as data.property-name.

Creating a collection

Only one source file is needed, src/ablums. It provides parameters for how the new pages should be created: the specific json source file to use, the name of the collection, and the layout templates for the index page and each entry.

---
title: albums
layout: list.html # this layout will be used for the index page
json_files:
    source_file: albums # defines the json file that will be used for the data
    filename_pattern: albums/:data.title # defines the url scheme for the generated files
    as_permalink: true
    layout: single.html # the layout that will be used to render each entry
    collection: albums # the name of the collection (used on the template for the index page)
---

About

A simple example of the `metalsmith-json-to-files` plugin in use.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages