NAME
Jifty::Plugin::Chart::Renderer - Base class for chart rendering classes
SYNOPSIS
In your config.yml:
Plugins:
- Chart:
renderer: MyApp::Renderer;
In lib/MyApp/Renderer.pm:
package MyApp::Renderer;
use base qw/ Jifty::Plugin::Chart::Renderer /;
sub init {
my $self = shift;
# Handle any required initialization, like required CSS, JS, etc.
}
sub render {
my $self = shift;
my %args = @_;
# Output your chart
Jifty->web->out( #{ Output your chart here... } );
# You could also return it as a string...
return;
}
METHODS
Your renderer implementation must subclass this package and implement the following methods:
new
This is the constructor. Don't override this directly. Instead implement "init".
init
$renderer->init();
This is called by new
immediately after constructing the object. It is passed a param hash from the config file. Subclasses should implement this method to do any required initialization such as letting Jifty know about required CSS files, JS files, etc.
render
Jifty->web->out($renderer->render(%args));
See Jifty::Plugin::Chart::Web for the arguments. It must (at least) accept the arguments given to the "chart" in Jifty::Plugin::Chart::Web method.
The render
method may either return it's output or print it out using Jifty::Web::out.
SEE ALSO
Jifty::Plugin::Chart::Web, Jifty::Plugin::Chart::Renderer::Chart
AUTHOR
Andrew Sterling Hanenkamp <andrew.hanenkamp@boomer.com>
COPYRIGHT AND LICENSE
Copyright 2007 Boomer Consulting, Inc.
This is free software and may be modified and distributed under the same terms as Perl itself.