Bug 21552: Use raw filter for displaying RoutingListNote
[koha.git] / serials / claims.pl
index fb3bcd9..44cff74 100755 (executable)
@@ -17,8 +17,7 @@
 # You should have received a copy of the GNU General Public License
 # along with Koha; if not, see <http://www.gnu.org/licenses>.
 
-use strict;
-use warnings;
+use Modern::Perl;
 use CGI qw ( -utf8 );
 use C4::Auth;
 use C4::Serials;
@@ -26,8 +25,10 @@ use C4::Acquisition;
 use C4::Output;
 use C4::Context;
 use C4::Letters;
-use C4::Branch;    # GetBranches GetBranchesLoop
-use C4::Csv qw( GetCsvProfiles );
+use C4::Koha qw( GetAuthorisedValues );
+
+use Koha::AdditionalField;
+use Koha::CsvProfiles;
 
 my $input = CGI->new;
 
@@ -56,15 +57,21 @@ for my $s (@{$supplierlist} ) {
     }
 }
 
-my $branchloop = GetBranchesLoop();
+my $additional_fields = Koha::AdditionalField->all( { tablename => 'subscription', searchable => 1 } );
+for my $field ( @$additional_fields ) {
+    if ( $field->{authorised_value_category} ) {
+        $field->{authorised_value_choices} = GetAuthorisedValues( $field->{authorised_value_category} );
+    }
+}
 
-my @serialnums=$input->param('serialid');
+
+my @serialnums=$input->multi_param('serialid');
 if (@serialnums) { # i.e. they have been flagged to generate claims
     my $err;
     eval {
         $err = SendAlerts('claimissues',\@serialnums,$input->param("letter_code"));
         if ( not ref $err or not exists $err->{error} ) {
-           UpdateClaimdateIssues(\@serialnums);
+            C4::Serials::updateClaim( \@serialnums );
         }
     };
     if ( $@ ) {
@@ -73,7 +80,7 @@ if (@serialnums) { # i.e. they have been flagged to generate claims
         if ( $err->{error} eq "no_email" ) {
             $template->param( error_claim => 'no_vendor_email' );
         } elsif ( $err->{error} =~ m|Bad or missing From address| ) {
-            $template->param( error_claim => 'no_loggedin_user_email' );
+            $template->param( error_claim => 'bad_or_missing_sender' );
         }
     } else {
         $template->param( info_claim => 1 );
@@ -85,6 +92,10 @@ my $letters = GetLetters({ module => 'claimissues' });
 my @missingissues;
 if ($supplierid) {
     @missingissues = GetLateOrMissingIssues($supplierid);
+    foreach my $issue (@missingissues) {
+        $issue->{cannot_claim} = 1
+          unless C4::Serials::can_claim_subscription($issue);
+    }
 }
 
 $template->param(
@@ -92,8 +103,8 @@ $template->param(
         missingissues => \@missingissues,
         supplierid => $supplierid,
         claimletter => $claimletter,
-        branchloop   => $branchloop,
-        csv_profiles => C4::Csv::GetCsvProfiles( "sql" ),
+        additional_fields_for_subscription => $additional_fields,
+        csv_profiles => [ Koha::CsvProfiles->search({ type => 'sql', used_for => 'late_issues' }) ],
         letters => $letters,
         (uc(C4::Context->preference("marcflavour"))) => 1
         );