17. Templates
Templates and Layouts are template files which located in the template/ directory. Their file extension is .tpl.
You are supposed to write your document such as HTML, XML, JSON in there.
Web Template System
Touse templates are rendered by a template system called Liquid.
You may use Liquid’s features such as operators, variables, comment, control structures, filters, tags, more in your templates.
Directory For Templates And Layouts
Templates and layouts files are supposed located to the directories below.
- Template files
- template/
- Layout files
- template/layout/
- Partial template files
- template/partial/
Template files are rendered into the placement ‘{{content}}’ that’s supposed to be wrriten in layout files.
In layout files, the variable named content will be set template data.
So there will be ‘{{content}}’ in your layout files.
Creating Template Or Layout Files
Creating A Template File
Creating a template file is just typing nekonote new template <template_name> on your teminal.
nekonote new template example/top --root /path/to/app/root
    * Created a directory -> /path/to/app/root/template/example
    Success!
      Created a new template '/path/to/app/root/template/example/top.tpl'
    Note:
      To use the template file you created, you need to set 'template' directive in your route as:
      e.g.
      ExampleHandler
         path: /example
         execute: index
         template: example/top
The template file you created is just a empty file. You are supposed to write your document such as HTML, XML, JSON in them.
If you specified a relative path to <template_name> such as example/top, and if template/example directory doesn't exist,
it will be created automatically and top.tpl is created in that directory.
You may use an abbreviation tpl like nekonote new tpl <template_name>.
Creating A Layout Files
It’s possible to create a layout file as well by typing nekonote new layout <layout_name>.
nekonote new layout example/layout --root /path/to/app/root
    * Created a directory -> /path/to/app/root/template/layout/example
    Success!
      Created a new layout '/path/to/app/root/template/layout/example/layout.tpl'
    Note:
      To use the layout file you created, you need to set 'layout' directive in your route as:
      e.g.
      ExampleHandler
         path: /example
         execute: index
         layout: example/layout
Assign Variables
You may assign variables to your templates from Handler classes.
As previously mentioned at 10. Business Logic there is the method to assign variables to templates.
Example for Assigning Variables
Creating Necessary Parts
on terminal
cd /path/to/app/root
nekonote new tpl example
nekonote new layout common
nekonote new handler example
Defining A Route
preference/your_environment/route.yml
ExampleHandler:
    path: /example
    execute: index
    template: example
    layout: common
    title: example page
Editing Layout
It’s good for writing some structure such as <html>, <head>, <body> elements.
template/layout/common.tpl
<!DOCTYPE html>
<html>
<head>
  <title>{{title}}</title>
</head>
<body>
{{content}}
</body>
</html>
As previously mentioned, ‘{{content}}’ is replaced with the template file which you specified.
If you didn’t set template directive, the default one will be used instead.
Editing Template
The next point is editing the template you created.
template/example.tpl
This page is an example for assigning some variables into templates.<br />
string: {{string}}<br />
int: {{int}}<br />
float: {{float}}<br />
array: {{array}}<br />
hash: {{hash}}<br />
bool: {{bool}}<br />
nil: {{nil}}
As you might know, the above variables are not assigned yet.
There is a need to assign the variables manually as:
handler/example.rb
class ExampleHandler < BaseHandler
    def index
        list = {
            :string => 'STRING',
            :int    => 2002,
            :float  => 2.002,
            :array  => ['N', 'E', 'K', 'O', 'N', 'O', 'T', 'E'],
            :hash   => {:type => 'kitten', :id => 2002, :is_cat => true},
            :bool   => false,
            :nil    => nil
        }
        __assign list
    end
end
Now everything is prepared. It’s time to start the web server and access to URL http://example.com/example.
The Rendered HTML must be following.
The response body will be rendered as HTML below:
<!DOCTYPE html>
<html>
<head>
  <title>example page</title>
</head>
<body>
This page is for example of assigning variables into template.<br />
string: STRING<br />
int: 2002<br />
float: 2.002<br />
array: NEKONOTE<br />
hash: {:type=>"kitten", :id=>2002, :is_cat=>true}<br />
bool: false<br />
nil: 
</body>
</html>
Setting Templates In Handler
It’s possible to set template or layout files in your Handler classes.
This will overwrite configurations in route.yml
e.g.
class ExampleHandler < BaseHandler
    def index
        __set_template 'top/index' #=> template/top/index.tpl will be used
        __set_layout 'top/default' #=> template/layout/top/default.tpl will be used
    end
end
Custom Tags For Nekonote Framework
There are the special tags for Nekonote Framework. You may use them in your template files.
Any value for parameters below is not allowd surrounding by "".
| tag name | parameter | description | 
|---|---|---|
| setting_get | key name (multiple is ok by comma) | Returns values from user configuration files by some specific field names. This is the same as Nekonote::Setting.get. | 
| partial | relative path to file from template/partial (without .tpl) | Loads data from a specific template file. |