X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FPlack%2FApp%2FGruntmaster%2FHTML.pm;h=d37d1a703557d15cf4c245b43e5ea99c06f2904f;hb=b7aa9f38347edb4509ccd9dea924238f79afea71;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..d37d1a7 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'); } @@ -225,6 +227,7 @@ sub process_log { $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('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 +241,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 +254,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 +267,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); +}