This generator app is driven by grunt.js, which means that it is highly customizable to suit your developer needs. Be sure to take a look at Gruntfile.js.
- Run
git clone
to download the app. - Run
npm install
- Run
bower install
- To get the basic site, copy
example
folder to root folder.
$ cp example/ ./
- Run
grunt
to generate preview, build and deploy your website.
- By default, running
grunt
will rungrunt dev
. - Other grunt options include
grunt build
andgrunt deploy
High level, site-wide configurations can be specified in config.json
.
This section explains the inner working of the import_contents
Grunt task.
By default, the site contents will be in the contents
folder. This option could be changed in Gruntfile.js
, under import_contents
task.
Content can be written in json
and markdown
with yaml
frontmatter.
All contents are written to data.json
in the build
directory.
The structure of the contents
directory will be reflected in the final static directory.
In any directory, a file's sibling files and directories are available in the template to access. This is a convenient and structural way to store and organize data, instead of dumping everything into a JSON file.
For example, for this file structure
contents
├── index.json
└── cars
├── 1.tesla.json
├── 2.ford.json
├── 3.volve.json
├── 4.honda.json
├── 5.toyota.json
└── accessories
└── spoiler.json
If you're writing the template for index.json
, its own content is available through the content
variable.
<h1>{{content.title}}</h1>
And cars
are also available as
<ul>
{{#each cars}}
<li><h2>{{title}}</h2></li>
{{/each}}
</ul>
<div class="spoiler">
{{cars.accessories["spoiler.json"]}}
</div>
By default, the path of the page is its directory structure.
For example, the page contents/articles/06/a-new-day.json
will have the URL http://localhost/articles/06/a-new-day.json
.
However, each page's path can be overwritten by a filepath
property.
Example:
{
filepath: "articles/archives/some-post.md"
}
This could be useful as a way to order files in a directory structure. In the cars example above:
contents
├── index.json
└── cars
├── 1.tesla.json
├── 2.ford.json
├── 3.volve.json
├── 4.honda.json
├── 5.toyota.json
└── accessories
└── spoiler.json
In order to avoid the number 1, 2, 3 etc. appear in these car's URL, they could have a custom filepath
property, such as contents/cars/tesla.json
.
Post or page date is supported by declaring property date
in JSON or YAML. Any ISO-8601 string formats for date is supported.
By default, a file without a date
specified will have the date
value of when the file was created. (To be more exact, it will have the ctime
value when grunt
is first run).
See momentjs for more information about the date format.
A directory with a big number of posts could be configured to paginate. The paginated pages are called archives.
The option for enabling pagination can be added in Gruntfile.js
under import_contents
task. For example:
import_contents: {
options : {
paginate: [
{dir: 'articles', orderBy: 'date', postPerPage: 4, template: 'archive.hbs', title: 'Articles'}
]
}
}
Each object in the paginate
option represents a directory to be paginated. The options for each directory are:
dir
: (string) directory nameorderby
: (number/ date) how to order the posts in the archives. Default to datepostPerPage
: (number) number of posts to be displayed per archive pagetemplate
: (string) the template used to display these archive pagestitle
: (string) title of these archive pages (this will be made available to use in template ascontent.title
)
This section explains the inner working of the handlebars_html
Grunt task.
By default tobiko uses Handlebars as its templating engine. However, if you want to use a different templating engine, you can easily do so by plugging in a different grunt
task that would compile your templating engine of choice.
Note: true to a static site generator, all compiled templates need to be in .html
formats
Helpers and Partials are supported. They can be stored under helpers
and partials
directories under templates
. These directory names of course can be changed in Gruntfile.js
.
Each page specifies a template that it uses, either as a JSON property or YAML frontmmatter.
Example:
// JSON declaration
{
template: "index.hbs"
}
<!-- YAML Frontmatter -->
---
template: "archive.hbs"
---
If a file doesn't specify a template, its data is available to be used in the ContentTree but will not be rendered.
A file's content is available in the template under the content
variable. Other sub-directories included in the same directory is accessible in the template with nesting.
The posts in each archive page is accessible in the template file under content
property, similar to a regular file. See example.
Any issues, questions or feature requests could be created under Github Issues.