X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FPlack%2FApp%2FGruntmaster%2FHTML.pm;h=8f47616eaf4e9446ee550c774b62e60972e49e2b;hb=52a7850b7a5c640391ab280394a9b1a79096db70;hp=3306be2100508109375494120dfba633ef897bdd;hpb=4a3952b20e4aea2e548cbd806953e4d7c61f495f;p=plack-app-gruntmaster.git diff --git a/lib/Plack/App/Gruntmaster/HTML.pm b/lib/Plack/App/Gruntmaster/HTML.pm index 3306be2..8f47616 100644 --- a/lib/Plack/App/Gruntmaster/HTML.pm +++ b/lib/Plack/App/Gruntmaster/HTML.pm @@ -213,6 +213,8 @@ sub process_log_entry { $tr->defmap(class => $data); $tr->fclass('result_text')->attr(class => "r$data->{result}") }; + $tree->fclass('result_text')->replace_content($args{result_text}); + $tree->fclass('result_text')->attr(class => "r$args{result}"); $args{results} ? $tree->fid('results')->find('tbody')->find('tr')->iter3($args{results}, $iter) : $tree->fid('results')->detach; $tree->fid('no_results')->detach if $tree->fid('results') || $tree->fid('errors'); } @@ -224,7 +226,10 @@ sub process_log { $tr->fclass('id')->namedlink($data->{id}); $tr->fclass('problem')->namedlink($data->{problem}, $data->{problem_name}); $tr->fclass('problem')->find('a')->edit_href(sub{$_ .= "?contest=$args{contest}"}) if $args{contest}; + $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('format')->replace_content($data->{format}); $tr->fclass('size')->namedlink("$data->{id}.$data->{extension}", sprintf "%.2fKB", $data->{size}/1024); $tr->fclass('size')->attr('data-private', '') if $data->{private}; $tr->fclass('owner')->namedlink($data->{owner}, $data->{owner_name}); @@ -238,7 +243,7 @@ sub process_log { my $elem = $tree->fclass($cls); next unless $elem; delete $args{args}{page}; - my $str = join '&', map { $_ . '=' . $args{args}{$_} } keys $args{args}; + my $str = join '&', map { $_ . '=' . $args{args}{$_} } keys %{$args{args}}; $elem->find('a')->edit_href(sub{s/$/&$str/}); } $tree->fclass('current')->replace_content("Page $args{current_page} of $args{last_page}"); @@ -251,6 +256,7 @@ sub process_st { my ($data, $th) = @_; $th->attr(class => undef); $th->namedlink(@$data); + $th->find('a')->edit_href(sub{s/$/?contest=$args{args}{contest}/}); }; $tree->fclass('problem')->iter3($args{problems}, $pbiter); my $iter = sub { @@ -263,3 +269,15 @@ sub process_st { }; $tree->find('tbody')->find('tr')->iter3($args{st}, $iter); } + +sub process_ed { + my ($tree, %args) = @_; + my $iter = sub { + my ($data, $div) = @_; + $div->set_child_content(class => 'value', $data->{value}); + $div->set_child_content(class => 'solution', literal $data->{solution}); + $div->fclass('problem')->namedlink($data->{id}, $data->{name}); + }; + my @pb = map { @{$args{$_}} } qw/beginner easy medium hard/; + $tree->fclass('well')->iter3(\@pb, $iter); +}