Bug 8612: Use CSV profile for exporting basket
[koha.git] / serials / claims.pl
index 9dbfee6..fbf7743 100755 (executable)
 #!/usr/bin/perl
 
-use strict;
-use CGI;
+# Parts Copyright 2010 Biblibre
+
+# This file is part of Koha.
+#
+# Koha is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# Koha is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Koha; if not, see <http://www.gnu.org/licenses>.
+
+use Modern::Perl;
+use CGI qw ( -utf8 );
 use C4::Auth;
 use C4::Serials;
 use C4::Acquisition;
-
-use C4::Interface::CGI::Output;
+use C4::Output;
 use C4::Context;
+use C4::Letters;
+use C4::Koha qw( GetAuthorisedValues );
+
+use Koha::AdditionalField;
+use Koha::CsvProfiles;
 
+my $input = CGI->new;
 
-my $query = new CGI;
+my $serialid = $input->param('serialid');
+my $op = $input->param('op');
+my $claimletter = $input->param('claimletter');
+my $supplierid = $input->param('supplierid');
+my $suppliername = $input->param('suppliername');
 
-my $serialid = $query->param('serialid');
-my $op = $query->param('op');
-# my $claimletter = $query->param('claimletter');
-my $supplierid = $query->param('supplierid');
-my %supplierlist = GetSuppliersWithLateIssues;
-my @select_supplier;
+# open template first (security & userenv set here)
+my ($template, $loggedinuser, $cookie)
+= get_template_and_user({template_name => 'serials/claims.tt',
+            query => $input,
+            type => 'intranet',
+            authnotrequired => 0,
+            flagsrequired => {serials => 'claim_serials'},
+            debug => 1,
+            });
 
-foreach my $supplierid (keys %supplierlist){
-        my ($count, @dummy) = GetMissingIssues($supplierid);
-        my $counting = $count;
-        $supplierlist{$supplierid} = $supplierlist{$supplierid}." ($counting)";
-       push @select_supplier, $supplierid
+# supplierlist is returned in name order
+my $supplierlist = GetSuppliersWithLateIssues();
+for my $s (@{$supplierlist} ) {
+    $s->{count} = scalar  GetLateOrMissingIssues($s->{id});
+    if ($supplierid && $s->{id} == $supplierid) {
+        $s->{selected} = 1;
+    }
 }
 
-# my @select_letter = (1,2,3,4);
-# my %letters = (1=>'Claim Form 1',2=>'Claim Form 2',3=>'Claim Form 3',4=>'Claim Form 4');
-my ($count2, @missingissues) = GetMissingIssues($supplierid,$serialid);
+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 $CGIsupplier=CGI::scrolling_list( -name     => 'supplierid',
-                       -values   => \@select_supplier,
-                       -default  => $supplierid,
-                       -labels   => \%supplierlist,
-                       -size     => 1,
-                       -multiple => 0 );
 
-# my $CGIletter=CGI::scrolling_list( -name     => 'claimletter',
-#                      -values   => \@select_letter,
-#                      -default  => $claimletter,
-#                      -labels   => \%letters,
-#                      -size     => 1,
-#                      -multiple => 0 );
-my ($singlesupplier,@supplierinfo);
-if($supplierid){
-   ($singlesupplier,@supplierinfo)=bookseller($supplierid);
-} else { # set up supplierid for the claim links out of main table if all suppliers is chosen
-   for(my $i=0; $i<@missingissues;$i++){
-       $missingissues[$i]->{'supplierid'} = getsupplierbyserialid($missingissues[$i]->{'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} ) {
+            C4::Serials::updateClaim( \@serialnums );
+        }
+    };
+    if ( $@ ) {
+        $template->param(error_claim => $@);
+    } elsif ( ref $err and exists $err->{error} ) {
+        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 => 'bad_or_missing_sender' );
+        }
+    } else {
+        $template->param( info_claim => 1 );
+    }
 }
 
+my $letters = GetLetters({ module => 'claimissues' });
 
-my $preview=0;
-if($op eq 'preview'){
-    $preview = 1;
+my @missingissues;
+if ($supplierid) {
+    @missingissues = GetLateOrMissingIssues($supplierid);
+    foreach my $issue (@missingissues) {
+        $issue->{cannot_claim} = 1
+          unless C4::Serials::can_claim_subscription($issue);
+    }
 }
 
-my ($template, $loggedinuser, $cookie)
-= get_template_and_user({template_name => "serials/claims.tmpl",
-                               query => $query,
-                               type => "intranet",
-                               authnotrequired => 0,
-                               flagsrequired => {catalogue => 1},
-                               debug => 1,
-                               });
-
 $template->param(
-       CGIsupplier => $CGIsupplier,
-#      CGIletter => $CGIletter,
-        preview => $preview,
+        suploop => $supplierlist,
         missingissues => \@missingissues,
         supplierid => $supplierid,
-#       claimletter => $claimletter,
-        singlesupplier => $singlesupplier,
-        supplierloop => \@supplierinfo,
-       intranetcolorstylesheet => C4::Context->preference("intranetcolorstylesheet"),
-               intranetstylesheet => C4::Context->preference("intranetstylesheet"),
-               IntranetNav => C4::Context->preference("IntranetNav"),
-       );
-output_html_with_http_headers $query, $cookie, $template->output;
+        claimletter => $claimletter,
+        additional_fields_for_subscription => $additional_fields,
+        csv_profiles => [ Koha::CsvProfiles->search({ type => 'late_issues' }) ],
+        letters => $letters,
+        (uc(C4::Context->preference("marcflavour"))) => 1
+        );
+output_html_with_http_headers $input, $cookie, $template->output;