use warnings;
use Template;
-use Locale::gettext;
+use URI ();
+use HTML::Entities ();
+use URI::Escape ();
use Benchmark ':hireswallclock';
use Packages::CGI;
+use Packages::Config qw( @LANGUAGES );
use Packages::I18N::Locale;
use Packages::I18N::Languages;
use Packages::I18N::LanguageNames;
sub new {
my ($classname, $include, $format, $vars, $options) = @_;
+ $vars ||= {};
$options ||= {};
my $self = {};
year => $timestamp[5]+1900,
string => scalar gmtime() .' UTC',
};
+ $vars->{make_search_url} = sub { return &Packages::CGI::make_search_url(@_) };
+ $vars->{make_url} = sub { return &Packages::CGI::make_url(@_) };
+ if ($vars->{cat}) {
+ $vars->{g} = sub { return Packages::I18N::Locale::g($vars->{cat}, @_) };
+ }
+ $vars->{extract_host} = sub { my $uri = URI->new($_[0]);
+ my $host = $uri->host;
+ $host .= ':'.$uri->port if $uri->port != $uri->default_port;
+ return $host;
+ };
+ # needed to work around the limitations of the the FILTER syntax
+ $vars->{html_encode} = sub { return HTML::Entities::encode_entities(@_,'<>&"') };
+ $vars->{uri_escape} = sub { return URI::Escape::uri_escape(@_) };
+ $vars->{quotemeta} = sub { return quotemeta($_[0]) };
+ $vars->{string2id} = sub { return &Packages::CGI::string2id(@_) };
$self->{template} = Template->new( {
PRE_PROCESS => [ 'config.tmpl' ],
VARIABLES => $vars,
COMPILE_EXT => '.ttc',
%$options,
- } ) or fatal_error( sprintf( _g( "Initialization of Template Engine failed: %s" ), $Template::ERROR ) );
+ } ) or die sprintf( "Initialization of Template Engine failed: %s", $Template::ERROR );
$self->{format} = $format;
+ $self->{vars} = $vars;
return $self;
}
}
sub page {
- my ($self, $action, $page_content) = @_;
+ my ($self, $action, $page_content, $target) = @_;
#use Data::Dumper;
#die Dumper($self, $action, $page_content);
+ if ($page_content->{cat}) {
+ $page_content->{g} =
+ sub { return Packages::I18N::Locale::g($page_content->{cat}, @_) };
+ }
+ $page_content->{used_langs} ||= \@LANGUAGES;
+ $page_content->{langs} = languages( $page_content->{lang}
+ || $self->{vars}{lang} || 'en',
+ @{$page_content->{used_langs}} );
my $txt;
- $self->process("$self->{format}/$action.tmpl", $page_content, \$txt)
- or die sprintf( "template error: %s", $self->error ); # too late for reporting on-line
-
+ if ($target) {
+ $self->process("$self->{format}/$action.tmpl", $page_content, $target)
+ or die sprintf( "template error: %s", $self->error ); # too late for reporting on-line
+ } else {
+ $self->process("$self->{format}/$action.tmpl", $page_content, \$txt)
+ or die sprintf( "template error: %s", $self->error );
+ }
return $txt;
}
return $txt;
}
-sub trailer {
- my ($self, $NAME, $LANG, $USED_LANGS, $timediff) = @_;
-
- my $langs = languages( $LANG, @$USED_LANGS );
-
- my $txt;
- $self->process("$self->{format}/foot.tmpl", { langs => $langs, name => $NAME, benchmark => $timediff ? timestr($timediff) : '' }, \$txt)
- or die sprintf( "template error: %s", $self->error ); # too late for reporting on-line
-
- return $txt;
-}
-
sub languages {
my ( $lang, @used_langs ) = @_;
-
+ my $cat = Packages::I18N::Locale->get_handle($lang)
+ || Packages::I18N::Locale->get_handle('en');
+
my @langs;
if (@used_langs) {
-
+
my @printed_langs = ();
foreach (@used_langs) {
next if $_ eq $lang; # Never print the current language
foreach my $cur_lang (sort langcmp @printed_langs) {
my %lang;
$lang{lang} = $cur_lang;
- $lang{tooltip} = dgettext( "langs", get_language_name($cur_lang) );
- $lang{selfname} = get_selfname($cur_lang);
- $lang{transliteration} = get_transliteration($cur_lang) if defined get_transliteration($cur_lang);
+ $lang{tooltip} = $cat->g(get_language_name($cur_lang));
+ $lang{selfname} = get_selfname($cur_lang);
+ $lang{transliteration} = get_transliteration($cur_lang)
+ if defined get_transliteration($cur_lang);
push @langs, \%lang;
}
}
-
+
return \@langs;
}