X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FPlack%2FApp%2FGruntmaster%2FHTML.pm;h=52afd1129128f719d235a7bf4017ac2115e31418;hb=a33e01dd99675a6b875dc923a30329978a3b164e;hp=3fe23e3fbd12fb432c2d71499202c02e7aa571cf;hpb=5b5b261c23f93d3b4835035a0ac369bf89c1e26b;p=plack-app-gruntmaster.git diff --git a/lib/Plack/App/Gruntmaster/HTML.pm b/lib/Plack/App/Gruntmaster/HTML.pm index 3fe23e3..52afd11 100644 --- a/lib/Plack/App/Gruntmaster/HTML.pm +++ b/lib/Plack/App/Gruntmaster/HTML.pm @@ -183,12 +183,13 @@ sub process_pb { $tr->fclass('name')->namedlink($data->{id}, $data->{name}); $tr->fclass('name')->find('a')->edit_href(sub {$_ .= "?contest=$args{contest}"}) if $args{contest}; $tr->fclass('owner')->namedlink($data->{owner}, $data->{owner_name}); + $tr->find('td')->attr(class => $tr->find('td')->attr('class').' warning') if $data->{private}; }; my $iter = sub { my ($data, $div) = @_; $div->attr(id => $data); $div->find('h2')->replace_content(ucfirst $data); - $div->find('tbody')->iter3($args{$data}, $titer); + $div->find('tbody')->find('tr')->iter3($args{$data}, $titer); }; $tree->fid('beginner')->iter3([grep {$args{$_}} qw/beginner easy medium hard/], $iter); } @@ -213,6 +214,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,6 +227,8 @@ 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); @@ -231,6 +236,7 @@ sub process_log { $tr->fclass('owner')->namedlink($data->{owner}, $data->{owner_name}); $tr->fclass('result_text')->replace_content($data->{result_text}); $tr->fclass('result_text')->attr(class => "r$data->{result}"); + $tr->find('td')->attr(class => $tr->find('td')->attr('class').' warning') if $data->{private}; }; $tree->find('table')->find('tbody')->find('tr')->iter3($args{log}, $iter); $args{next_page} ? $tree->fclass('next')->namedlink($args{next_page}, 'Next') : $tree->fclass('next')->detach; @@ -252,6 +258,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 { @@ -264,3 +271,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); +}