]> iEval git - gruntmaster-page.git/blobdiff - lib/Gruntmaster/Page/Pb/Entry.pm
Show submit box in pb_entry before contest_start
[gruntmaster-page.git] / lib / Gruntmaster / Page / Pb / Entry.pm
index dbfbe18ca42b86c6c2f0b7fd3a6b21de6518b503..2dd0a7b5674afa577350a7da7551a7eaa61605ca 100644 (file)
@@ -3,20 +3,13 @@ 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 => '<tmpl_var name>';
+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 FORMATS => [qw/CPP/];
-
-my %orig_templates = (
+use constant TEMPLATES => {
        en => <<'HTML',
-<tmpl_var statement>
+<tmpl_var ESCAPE=0 statement>
 
 <tmpl_if cansubmit>
 <h1>Submit solution</h1>
@@ -33,28 +26,27 @@ my %orig_templates = (
 </form>
 </tmpl_if>
 HTML
-);
+};
 
-my %templates = cook_templates %orig_templates, pb_entry => '<tmpl_var name>';
+sub _generate{
+       my ($self, $htc, $path, $lang) = @_;
 
-sub generate{
-       %templates = cook_templates %orig_templates, pb_entry => '<tmpl_var name>' if reload_templates;
-       $_[0] =~ m,(?:ct/([^/])+/)?pb/(\w+)\.html$,;
+       $path =~ m,(?:ct/([^/]+)/)?pb/(\w+)\.html$,;
 
        my ($contest, $id) = ($1, $2);
-       my $htc = HTML::Template::Compiled->new(scalarref => \$templates{$_[1]});
 
        $htc->param(cansubmit => 1);
        if (defined $contest) {
-               $htc->param(cansubmit => time >= contest_start $contest && time <= contest_end $contest);
+               $htc->param(cansubmit => time <= contest_end $contest);
                $htc->param(contest => $contest);
        }
-       $htc->param(formats => FORMATS);
+       $htc->param(formats => Gruntmaster::Page::Submit::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
This page took 0.020828 seconds and 4 git commands to generate.