NAME
Catalyst::View::HTML::Mason - HTML::Mason rendering for Catalyst
SYNOPSIS
package MyApp::View::Mason;
use Moose;
use namespace::autoclean;
extends 'Catalyst::View::HTML::Mason';
__PACKAGE__->config(
interp_args => {
comp_root => MyApp->path_to('root'),
},
);
1;
DESCRIPTION
This module provides rendering of HTML::Mason templates for Catalyst applications.
It's basically a rewrite of Catalyst::View::Mason, which became increasingly hard to maintain over time, while keeping backward compatibility.
ATTRIBUTES
interp
The mason interpreter instance responsible for rendering templates.
interp_class
The class the interp
instance is constructed from. Defaults to HTML::Mason::Interp
.
interp_args
Arguments to be passed to the construction of interp
. Defaults to an empty hash reference.
template_extension
File extension to be appended to every component file. By default it's only appended if no explicit component file has been provided in $ctx->stash->{template}
.
always_append_template_extension
If this is set to a true value, template_extension
will also be appended to component paths provided in $ctx->stash->{template}
.
encoding
Encode Mason output with the given encoding. Can be a string encoding name (which will be resolved using Encode::find_encoding()), or an Encode::Encoding object. See Encode::Supported for a list of encodings.
globals
Arrayref of string names to export into each rendered component. Off by default.
Example:
globals => [ '$foo', '%bar' ]
#or
globals => '$baz',
Would export $foo and %bar to every Mason component as globals using identically-named values in the stash, similar to:
our $foo = $c->stash->{foo};
our %bar = %{ $c->stash->{bar} };
To export just the context as $c, one would set globals => '$c' and make sure to set $c->stash->{c} = $c on each request, such as in an auto
in the root controller.
METHODS
render($ctx, $component, \%args)
Renders the given component and returns its output.
A hash of template variables may be provided in $args
. If $args
isn't given, template variables will be taken from $ctx->stash
.
A NOTE ABOUT DHANDLERS
Note that this view does not support automatic dispatching to Mason dhandlers. Dhandlers can still be used, but they must be referred to explicitly like any other component.
AUTHORS
Florian Ragwitz <rafl@debian.org>
Sebastian Willert <willert@cpan.org>
Robert Buels <rbuels@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2011 by Florian Ragwitz.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.