# NAME

Dancer::Template::Caribou - Template::Caribou wrapper for Dancer

# VERSION

version 1.0.1

# SYNOPSIS

```perl
# in 'config.yml'
template: Caribou

engines:
  Caribou:
    namespace:               MyApp::View
    layout_namespace:        MyApp::View::Layout
    default_template:        inner_page
    default_layout_template: page

# and then in the application
get '/' => sub { 
    ...;

    template 'main' => \%options;
};
```

# DESCRIPTION

`Dancer::Template::Caribou` is an interface for the [Template::Caribou](https://metacpan.org/pod/Template::Caribou)
template system. Be forewarned, both this module and `Template::Caribou`
itself are alpha-quality software and are still subject to any changes. 
**Caveat Maxima Emptor**.

## Basic Usage

At the base, if you do

```perl
get '/' => sub {
    ...

    return template 'MyView', \%options;
};
```

the template name (here _MyView_) will be concatenated with the 
configured view namespace (which defaults to _Dancer::View_)
to generate the Caribou class name. A Caribou object is created
using `%options` as its arguments, and its default template (defaulting to `page`) 
is then
rendered. In other words, the last line of the code above becomes 
equivalent to 

```
return Dancer::View::MyView->new( %options )->page;
```

### Layouts as roles

Layouts, just like templates, are package names. They are expected to be
roles that will be composed with the template class.

# CONFIGURATION

- default\_template

    The name of the entry template to use. In other words, with the configuration
    given in the SYNOPSIS, the dancer code

    ```
    return template 'MyThing';
    ```

    is equivalent to

    ```
    return MyApp::View::MyThing->page;
    ```

    Defaults to `page`.

- default\_layout\_template

    Entry template to use when a layout is provided. Defaults to `page`.

- namespace 

    The namespace under which the Caribou template classes are.
    defaults to `Dancer::View`.

    Template names can be prefixed with a plus sign if you want it to be used as an absolute namespace.

    ```
    template 'Relative::View';       # -> Dancer::View::Relative::View
    template '+My::Absolute::View';  # -> My::Absolute::View
    ```

- layout\_namespace 

    The namespace under which the Caribou layout roles are.
    defaults to the `::Layout` sub-namespace under the template
    namespace.

    Like template names, layout names can be prefixed with a plus sign for
    absolute namespaces;

    ```perl
    set layout => 'My::Relative';  # -> Dancer::View::Layour::My::Relative
    set layout => '+My::Absolute'; # -> My::Absolute
    ```

# AUTHOR

Yanick Champoux <yanick@babyl.dyndns.org> [![endorse](http://api.coderwall.com/yanick/endorsecount.png)](http://coderwall.com/yanick)

# COPYRIGHT AND LICENSE

This software is copyright (c) 2013 by Yanick Champoux.

This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.