Preload templates
[plack-app-gruntmaster.git] / lib / Plack / App / Gruntmaster / HTML.pm
index 4a22292702ed0d1446dfa619aba4ae4cfba57697..f2b4ec9cead19e8e98af996ff35a3e0f4f8bc83f 100644 (file)
@@ -42,6 +42,14 @@ sub HTML::Element::namedlink {
        $self->replace_content($name);
 }
 
+my %page_cache;
+for (<tmpl/*>) {
+       my ($tmpl, $lang) = m,tmpl/(\w+)\.(\w+),;
+       my $builder = HTML::Seamstress->new;
+       $builder->ignore_unknown(0);
+       $page_cache{$tmpl, $lang} = $builder->parse_file($_);
+}
+
 sub render {
        my ($tmpl, $lang, %args) = @_;
        $lang //= 'en';
@@ -59,9 +67,7 @@ sub render_article {
 
 sub _render {
        my ($tmpl, $lang, %args) = @_;
-       my $builder = HTML::Seamstress->new;
-       $builder->ignore_unknown(0);
-       my $tree = $builder->parse_file("tmpl/$tmpl.$lang");
+       my $tree = $page_cache{$tmpl, $lang}->clone or die "No such template/language combination: $tmpl/$lang\n";
        $tree = $tree->guts unless $tmpl eq 'skel';
        $tree->defmap(smap => \%args);
        my $process = __PACKAGE__->can("process_$tmpl");
@@ -146,7 +152,6 @@ sub process_pb_entry {
        $tree->fid('owner')->edit_href(sub{s/owner_id/$args{owner}/});
        $tree->fid('job_log')->edit_href(sub{s/problem_id/$args{id}/});
        $tree->fid('solution')->edit_href(sub{s/problem_id/$args{id}/});
-       $tree->fid('job_log')->edit_href(sub{$_ .= "&private=$args{private}"}) if $args{private};
        $tree->content_handler(
                statement => literal $args{statement},
                level     => ucfirst $args{level},
@@ -166,6 +171,7 @@ sub process_pb_entry {
                $score->attr('data-value'  => $args{value});
                $tree->fid('countdown')->attr('data-stop' => $args{contest_stop});
        } else {
+               $tree->fid('job_log')->edit_href(sub{$_ .= "&private=$args{private}"}) if $args{private};
                $tree->fid('solution')->detach unless $args{solution};
                $_->detach for $tree->fclass('rc'); # requires contest
                $tree->fid('solution_modal')->fclass('modal-body')->replace_content(literal $args{solution});
@@ -243,7 +249,7 @@ sub process_log {
                $tr->fclass('contest')->namedlink($data->{contest}, $data->{contest_name}) if $data->{contest};
                $tr->fclass('contest')->replace_content('None') unless $data->{contest};
                $tr->fclass('date')->replace_content(ftime $data->{date});
-               $tr->fclass('source')->namedlink("$data->{id}.$data->{extension}", sprintf "%.2fKB %s", $data->{size}/1024, $data->{format});
+               $tr->fclass('source')->namedlink("$data->{id}.$data->{extension}", sprintf "%.2fKB %s", $data->{size}/1024, Plack::App::Gruntmaster::FORMAT_EXTENSION()->{$data->{format}});
                $tr->fclass('owner')->namedlink($data->{owner}, $data->{owner_name});
                $tr->fclass('result_text')->replace_content($data->{result_text});
                $tr->fclass('result_text')->attr(class => "r$data->{result}");
@@ -295,3 +301,6 @@ sub process_ed {
        my @pb = map { @{$args{$_} // []} } qw/beginner easy medium hard/;
        $tree->fclass('well')->iter3(\@pb, $iter);
 }
+
+1;
+__END__
This page took 0.010371 seconds and 4 git commands to generate.