X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FPage%2FPb%2FEntry.pm;h=771808b7b022a47d7a6a53af924294a20a191325;hb=1fb046b0868290f70fdc596644984f67874b3b99;hp=dbfbe18ca42b86c6c2f0b7fd3a6b21de6518b503;hpb=2b0036ac8e077cc20cf9db6ff8dad4091ab50cb3;p=plack-app-gruntmaster.git diff --git a/lib/Gruntmaster/Page/Pb/Entry.pm b/lib/Gruntmaster/Page/Pb/Entry.pm index dbfbe18..771808b 100644 --- a/lib/Gruntmaster/Page/Pb/Entry.pm +++ b/lib/Gruntmaster/Page/Pb/Entry.pm @@ -3,58 +3,63 @@ package Gruntmaster::Page::Pb::Entry; use 5.014000; use strict; use warnings; -use parent qw/Exporter/; -our @EXPORT_OK = qw/generate/; +use Gruntmaster::Page::Base pb_entry => ''; +our @ISA = qw/Gruntmaster::Page::Base/; our $VERSION = '0.001'; -use HTML::Template::Compiled; -use POSIX qw/strftime/; -use Gruntmaster::Page::Common qw/cook_templates reload_templates/; -use Gruntmaster::Data qw/contest_start contest_end problem_name problem_statement/; +use constant TEMPLATES => { + en => <<'HTML', +
+
+ +
-use constant FORMATS => [qw/CPP/]; +
+ -my %orig_templates = ( - en => <<'HTML', - +

Problem information

+
+
Author
+
Owner
+

Submit solution

-
+ - -
+
+
+
- + +
HTML -); - -my %templates = cook_templates %orig_templates, pb_entry => ''; +}; -sub generate{ - %templates = cook_templates %orig_templates, pb_entry => '' if reload_templates; - $_[0] =~ m,(?:ct/([^/])+/)?pb/(\w+)\.html$,; +use constant FORMATS => [qw/C CPP MONO JAVA PASCAL PERL PYTHON/]; - my ($contest, $id) = ($1, $2); - my $htc = HTML::Template::Compiled->new(scalarref => \$templates{$_[1]}); +sub _generate{ + my ($self, $htc, $lang, $env, $contest, $id) = @_; + debug $env => "language is '$lang', contest is '$contest', id is '$id'"; $htc->param(cansubmit => 1); - if (defined $contest) { - $htc->param(cansubmit => time >= contest_start $contest && time <= contest_end $contest); + if ($contest) { + $htc->param(cansubmit => time <= contest_end $contest); $htc->param(contest => $contest); } $htc->param(formats => FORMATS); $htc->param(id => $id); local $Gruntmaster::Data::contest = $contest if $contest; $htc->param(name => problem_name $id); + $htc->param(author => problem_author $id); + $htc->param(owner => problem_owner $id); $htc->param(statement => problem_statement $id); - $htc->output } 1