NAME
Catalyst::View::Jemplate - Jemplate files server
SYNOPSIS
package MyApp::View::Jemplate;
use base qw( Catalyst::View::Jemplate );
package MyApp;
MyApp->config(
'View::Jemplate' => {
jemplate_dir => MyApp->path_to('root', 'jemplate'),
jemplate_ext => '.tt',
},
);
sub jemplate : Global {
my($self, $c) = @_;
$c->forward('View::Jemplate');
}
# To specify which files you want to include
sub select : Global {
my($self, $c) = @_;
$c->stash->{jemplate} = {
files => [ 'foo.tt', 'bar.tt' ]
}
}
# To serve Jemplate rutime
sub runtime : Path('Jemplate.js') {
my($self, $c) = @_;
$c->stash->{jemplate} = {
runtime => 1,
files => [], # runtime only
}
}
# To use caching
use Catalyst qw(
...
Cache
);
MyApp->config(
cache => {
backends => {
jemplate => {
# Your cache backend of choice
store => "FastMmap",
}
}
}
);
DESCRIPTION
Catalyst::View::Jemplate is a Catalyst View plugin to automatically compile TT files into JavaScript, using ingy's Jemplate.
Instead of creating the compiled javascript files by-hand, you can include the file via Catalyst app like:
<script src="js/Jemplate.js" type="text/javascript"></script>
<script src="/jemplate/all.js" type="text/javascript"></script>
TODO
Yeah, we definitely need a cache. For now it compiles templates in every request, which is not very efficient.
Right now all the template files under
jemplate_dir
is compiled into a single JavaScript file and served. Probably we need a path option to limit the directory.
AUTHOR
Tatsuhiko Miyagawa <miyagawa@bulknews.net>
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
SEE ALSO
L<>
2 POD Errors
The following errors were encountered while parsing the POD:
- Around line 186:
You forgot a '=back' before '=head1'
- Around line 195:
An empty L<>