X-Git-Url: http://git.ieval.ro/?p=gruntmaster-page.git;a=blobdiff_plain;f=lib%2FPlack%2FApp%2FGruntmaster%2FHTML.pm;h=04127828de03ee7704f2deb2887d0eba9142a2ee;hp=16ae617ecf9c3635f5a9d2bbba0701a62c039659;hb=9a4806b3c49eef940ac5d2d2b38f9d47b346d544;hpb=84ca7535f20b19636518768b8f578b4394bf6391 diff --git a/lib/Plack/App/Gruntmaster/HTML.pm b/lib/Plack/App/Gruntmaster/HTML.pm index 16ae617..0412782 100644 --- a/lib/Plack/App/Gruntmaster/HTML.pm +++ b/lib/Plack/App/Gruntmaster/HTML.pm @@ -122,6 +122,18 @@ sub process_pb_entry { statement => literal $args{statement}, author => $args{author}, owner => $args{owner_name} || $args{owner}); + if ($args{contest_stop}) { + my $countdown = $tree->fid('countdown'); + $countdown->attr('data-start' => $args{contest_start}); + $countdown->attr('data-stop' => $args{contest_stop}); + $countdown->attr('data-time' => $args{time}); + my $left = $args{contest_stop} - $args{time}; + $countdown->replace_content(sprintf '%02d:%02d:%02d', $left/60/60, $left/60%60, $left%60); + $tree->fid('score')->attr('data-value' => $args{value}); + $tree->fid('score')->replace_content(Gruntmaster::Data::calc_score($args{value}, $args{time} - $args{contest_start}, 0, $args{contest_stop} - $args{contest_start})); + } else { + $_->detach for $tree->fclass('rc'); # requires contest + } if ($args{cansubmit}) { $tree->look_down(name => 'problem')->attr(value => $args{id}); my $contest = $tree->look_down(name => 'contest');