]> iEval git - gruntmaster-page.git/blobdiff - lib/Gruntmaster/Page/Generic.pm
Add title to job entries
[gruntmaster-page.git] / lib / Gruntmaster / Page / Generic.pm
index 2cb82d91d86720a5e79e3ff3573a72e83f34e9d0..fe9525dc44a1feb392f30f290adcdd9450d0896f 100644 (file)
@@ -29,14 +29,15 @@ sub makepkg {
 }
 
 sub list {
-       my ($thing, $lang, $env, $ct) = @_;
+       my ($thing, $lang, $env) = @_;
        my %thing = %$thing;
-       my $req = Plack::Request->new($env);
-       debug $env => "Contest is $ct";
-       $thing{makers} //= sub { shift->resultset($thing{rsname}) };
-       my $rs = $thing{makers}->(db $env)->search(undef, {order_by => 'me.id'});
-       if (my $page = $req->param('page')) {
+       #debug $env => "Contest is $ct";
+       $thing{makers} //= sub { db(shift)->resultset($thing{rsname}) };
+       my $rs = $thing{makers}->($env);
+       $rs = $rs->search(undef, {order_by => 'me.id'}) unless $rs->is_ordered;
+       if (my $page = $env->{'gruntmaster.page'}) {
                my $pages = $rs->count / PAGE_SIZE;
+               $page = $pages if $page == -1;
                $rs = $rs->search(undef, {offset => ($page - 1) * PAGE_SIZE, ($page == $pages ? () : (rows => PAGE_SIZE))});
        }
        $rs = $rs->search(undef, {prefetch => $thing{prefetch}}) if exists $thing{prefetch};
@@ -55,13 +56,11 @@ sub list {
 }
 
 sub entry {
-       my ($thing, $lang, $env, $id, $ct) = @_;
+       my ($thing, $lang, $env, $id) = @_;
        my %thing = %$thing;
-       ($id, $ct) = ($ct, $id) if $ct;
        debug $env => "Rsname is $thing{rsname} and id is $id";
-       $thing{makers} //= sub { shift->resultset($thing{rsname}) };
-       my %params = map {+ rs => $_, $_->get_columns } $thing{makers}->(db $env)->find($id);
-       $params{contest} = $ct if  $ct;
+       $thing{makers} //= sub { db(shift)->resultset($thing{rsname}) };
+       my %params = map {+ rs => $_, $_->get_columns } $thing{makers}->($env)->find($id);
        $thing{mangle}->(local $_ = \%params) if exists $thing{mangle};
        wantarray ? %params : \%params
 }
@@ -74,7 +73,7 @@ sub create_thing {
        my $pkg = "Gruntmaster::Page::$ucid";
 
        putsym "${pkg}::_generate", sub { $_[1]->param(list \%thing, @_[2..$#_]) } if makepkg $pkg, @thing{qw/id title/};
-       putsym "${pkg}::Entry::_generate",  sub { $_[1]->param(entry \%thing, @_[2..$#_]) } if makepkg "${pkg}::Entry", "$thing{id}_entry", '<tmpl_var name>';
+       putsym "${pkg}::Entry::_generate",  sub { $_[1]->param(entry \%thing, @_[2..$#_]) } if makepkg "${pkg}::Entry", "$thing{id}_entry", $thing{entry_title} // '<tmpl_var name>';
        putsym "${pkg}::Read::generate", sub { [200, headers shift, [encode_json list \%thing, @_]] } if makepkg "${pkg}::Read";
        putsym "${pkg}::Entry::Read::generate", sub { [200, headers shift, [encode_json entry \%thing, @_]] } if makepkg "${pkg}::Entry::Read";
 }
@@ -90,7 +89,7 @@ sub prefetch;
 sub thing (&){
        my %thing;
        no strict 'refs';
-       local *{"params"} = sub { @thing{qw/id rsname title/} = @_ };
+       local *{"params"} = sub { @thing{qw/id rsname title entry_title/} = @_ };
        local *{"choose"} = sub { $thing{choose} = shift };
        local *{"sortby"} = sub { $thing{sortby} = shift };
        local *{"mangle"} = sub { $thing{mangle} = shift };
@@ -114,7 +113,13 @@ thing {
 thing {
        params qw/pb Problem Problems/;
        prefetch 'owner';
-       makers { my ($db, $ct) = @_; $ct ? $db->contest($ct)->problems : $db->problems->search({private => 0}) };
+       makers {
+               my $env = $_[0];
+               my $db = db $env;
+               return $db->contest($env->{'gruntmaster.contest'})->problems->search(undef, {order_by => 'problem.id'}) if exists $env->{'gruntmaster.contest'};
+               return $db->problems->search({owner => $env->{'gruntmaster.user'}}) if exists $env->{'gruntmaster.user'};
+               $db->problems->search({private => 0});
+       };
        sortby { $a->{name} cmp $b->{name}};
        group { $_->{level} };
        mangle {
@@ -140,9 +145,15 @@ thing {
 };
 
 thing {
-       params qw/log Job/, 'Job log';
+       params qw/log Job/, 'Job log', 'Job <tmpl_var id>';
        prefetch 'owner', 'problem';
-       makers { shift->jobs->search({contest => shift}) };
+       makers {
+               my $env = $_[0];
+               my $db = db $env;
+               return $db->jobs->search({'me.owner' => $env->{'gruntmaster.user'}}) if exists $env->{'gruntmaster.user'};
+               return $db->jobs->search({problem => $env->{'gruntmaster.problem'}}) if exists $env->{'gruntmaster.problem'};
+               $db->jobs->search({contest => $env->{'gruntmaster.contest'}})
+       };
        sortby { $b->{id} <=> $a->{id}};
        mangle {
                $_->{results} &&= decode_json $_->{results};
This page took 0.023445 seconds and 4 git commands to generate.