Writing content Nunjucks

Nunjucks

Templates of your pages fully support markdown but also nunjucks, a powerful templating language that allows you to create more dynamic templates.

This means that you can use any of the functions provided by nunjucks inside your templates! We'll give some examples of nunjucks usage below, and to learn more, go to its documentation.

We use a relative loader, which means that all paths you specify for nunjucks functions must be relative to your template

Including template

To follow the DRY principle even in your templates, you can include one template in another, for example, to add the dry-template.md template to your current page template, you can write the following

index.md
{% include "../shared/dry-template.md" %}

This will force nunjucks to include the dry-template.md template in your current page, and NgDoc will start watching for changes to this template so that if it changes, NgDoc will re-render all templates that depend on it

Macros

Another powerful feature of nunjucks is macros, macros it's a function that you can call with parameters to render a specific part of the page.

For example, let's say you have macros in your shared folder, that looks like this:

span-macro.md
{% macro spanText(text) %}
    <span>{{text}}</span>
{% endmacro %}

This is a macro that just wraps the text in a span tag, but now you can use it in other templates, for this you need to import it, and after that it will become available on your page.

index.md
{% import "../shared/span-macro.md" as myMacro %}

{{ myMacro.spanText("Text in the span!") }}

Variables

Some variables are also available in your template, such as NgDocPageand NgDocActions.

The NgDocPage variable contains information about the current page, which you can use to, for example, render its title. You may have noticed that NgDoc creates similar dynamic titles when you generate pages via schematics.

So, for example to render title, you can do this

index.md
{{ NgDocPage.title }}

The NgDocActions provides some functions that you can call to render demo on the page, for example, to render demo you can call demo method with the name of you demo component. You can read more about the demo in the Demo and Demo Pane.

index.md
{{ NgDocActions.demo("MyDemoComponent") }}