diff --git a/cgi/CRMS.pm b/cgi/CRMS.pm index c029e2ad..3f11ba8b 100755 --- a/cgi/CRMS.pm +++ b/cgi/CRMS.pm @@ -1436,11 +1436,15 @@ sub LoadQueueForProject { my $project_name = $self->GetProjectRef($project)->name; my $sql = 'SELECT COUNT(*) FROM queue WHERE project=?'; my $queueSize = $self->SimpleSqlGet($sql, $project); - my $targetQueueSize = $self->GetProjectRef($project)->queue_size(); + my $project_ref = $self->GetProjectRef($project); + my $targetQueueSize = $project_ref->queue_size(); my $needed = $targetQueueSize - $queueSize; $self->ReportMsg("Project $project_name: $queueSize volumes -- need $needed"); return if $needed <= 0; my $count = 0; + my @orders = ('c.time DESC'); + my $project_order = $project_ref->queue_order; + unshift @orders, $project_order if defined $project_order; $sql = 'SELECT DISTINCT b.sysid FROM bibdata b'. ' INNER JOIN candidates c ON b.id = c.id'. ' WHERE b.id NOT IN (SELECT DISTINCT id FROM inherit)'. @@ -1448,7 +1452,7 @@ sub LoadQueueForProject { ' AND b.id NOT IN (SELECT DISTINCT id FROM reviews)'. ' AND b.id NOT IN (SELECT DISTINCT id FROM historicalreviews)'. ' AND c.time<=DATE_SUB(NOW(), INTERVAL 1 WEEK) AND c.project=?'. - ' ORDER BY c.time DESC'; + ' ORDER BY ' . join(',', @orders); my $ref = $self->SelectAll($sql, $project); my $potential = scalar @$ref; $self->ReportMsg("$potential qualifying catalog records for project $project queue"); @@ -1458,7 +1462,7 @@ sub LoadQueueForProject { $sql = 'SELECT c.id FROM candidates c'. ' INNER JOIN bibdata b ON c.id=b.id'. ' WHERE c.project=? AND b.sysid=?'. - ' ORDER BY c.time ASC'; + ' ORDER BY ' . join(',', @orders); my $ref2 = $self->SelectAll($sql, $project, $sysid); foreach my $row2 (@$ref2) { my $id = $row2->[0]; diff --git a/cgi/Project.pm b/cgi/Project.pm index 0bb0a9ca..9278145d 100644 --- a/cgi/Project.pm +++ b/cgi/Project.pm @@ -10,9 +10,11 @@ sub new $self->{$_} = $args{$_} for keys %args; my $id = $args{'id'}; die "No CRMS object passed to project" unless $args{'crms'}; - my $sql = 'SELECT * FROM projects WHERE id=?'; - my $ref = $self->{'crms'}->get('dbh')->selectall_hashref($sql, 'id', undef, $id); - $self->{$_} = $ref->{$id}->{$_} for keys %{$ref->{$id}}; + if (defined $id) { + my $sql = 'SELECT * FROM projects WHERE id=?'; + my $ref = $self->{'crms'}->get('dbh')->selectall_hashref($sql, 'id', undef, $id); + $self->{$_} = $ref->{$id}->{$_} for keys %{$ref->{$id}}; + } return $self; } @@ -93,6 +95,16 @@ sub EvaluateCandidacy } # ========== REVIEW INTERFACE ========== # +# Called by CRMS::LoadQueueForProject to prioritize candidates for the queue. +# Return undef for no additional order (the default), or +# a column name in bibdata (b.*) or candidates (c.*). +# Example: 'b.author DESC' +sub queue_order { + my $self = shift; + + return; +} + # Called by CRMS::GetNextItemForReview to order volumes. # Return undef for no additional order (the default), or # a column name in bibdata (b.*) or the queue (q.*). diff --git a/cgi/Project/Core.pm b/cgi/Project/Core.pm index 6c4da74a..dc706421 100644 --- a/cgi/Project/Core.pm +++ b/cgi/Project/Core.pm @@ -120,6 +120,16 @@ sub HasCCLicense } # ========== REVIEW ========== # +sub queue_order { + # Add mdp namespace to queue ahead of everything else. + return 'IF("mdp"=LEFT(c.id,LOCATE(".",c.id)-1),1,0) DESC'; +} + +sub PresentationOrder { + # Present mdp namespace ahead of everything else. + return 'IF("mdp"=LEFT(q.id,LOCATE(".",q.id)-1),1,0) DESC'; +} + sub ReviewPartials { return ['top', 'bibdata', 'authorities', diff --git a/t/Project.t b/t/Project.t index bbc40ad2..a3f3416a 100755 --- a/t/Project.t +++ b/t/Project.t @@ -6,6 +6,8 @@ BEGIN { unshift(@INC, $ENV{'SDRROOT'}. '/crms/cgi'); } use Test::More; +use CRMS; + my $dir = $ENV{'SDRROOT'}. '/crms/cgi/Project'; opendir(DIR, $dir) or die "Can't open $dir\n"; my @files = readdir(DIR); @@ -17,5 +19,12 @@ foreach my $file (sort @files) require_ok($path); } +my $crms = CRMS->new; + +my $project = Project->new(crms => $crms); +subtest '#queue_order' => sub { + is($project->queue_order, undef, 'default project has no queue_order'); +}; + done_testing(); diff --git a/t/Project/Core.t b/t/Project/Core.t new file mode 100644 index 00000000..d01feba7 --- /dev/null +++ b/t/Project/Core.t @@ -0,0 +1,35 @@ +#!/usr/bin/perl + +use strict; +use warnings; +use utf8; + +use CGI; +use Data::Dumper; +use Test::More; + +use lib $ENV{'SDRROOT'} . '/crms/cgi'; +use lib $ENV{'SDRROOT'} . '/crms/t/support'; +use CRMS; +use FakeMetadata; + +require_ok($ENV{'SDRROOT'}. '/crms/cgi/Project/Core.pm'); + +my $crms = CRMS->new(); +# TODO: Project::for_name would be a much nicer way to do this. +my $sql = 'SELECT id FROM projects WHERE name="Core"'; +my $project_id = $crms->SimpleSqlGet($sql); +my $project = Core->new(crms => $crms, id => $project_id); +ok(defined $project); + +subtest '#queue_order' => sub { + ok(defined $project->queue_order, 'Core project defines a queue_order'); +}; + +subtest '#PresentationOrder' => sub { + ok(defined $project->PresentationOrder, 'Core project defines a PresentationOrder'); +}; + +done_testing(); + +