Merge commit 'pianohacker-koha/prefs-submit' into master
[koha.git] / serials / claims.pl
1 #!/usr/bin/perl
2
3 use strict;
4 use warnings;
5 use CGI;
6 use C4::Auth;
7 use C4::Serials;
8 use C4::Acquisition;
9 use C4::Output;
10 use C4::Bookseller;
11 use C4::Context;
12 use C4::Letters;
13 my $input = new CGI;
14
15 my $serialid = $input->param('serialid');
16 my $op = $input->param('op');
17 my $claimletter = $input->param('claimletter');
18 my $supplierid = $input->param('supplierid');
19 my $suppliername = $input->param('suppliername');
20 my $order = $input->param('order');
21 my %supplierlist = GetSuppliersWithLateIssues();
22 my @select_supplier;
23
24 # open template first (security & userenv set here)
25 my ($template, $loggedinuser, $cookie)
26 = get_template_and_user({template_name => "serials/claims.tmpl",
27             query => $input,
28             type => "intranet",
29             authnotrequired => 0,
30             flagsrequired => {serials => 1},
31             debug => 1,
32             });
33 my $supplier_loop = [];
34 foreach my $s_id (sort {$supplierlist{$a} cmp $supplierlist{$b} } keys %supplierlist){
35         my ($count) = GetLateOrMissingIssues($supplierid,q{},$order);
36         push @{$supplier_loop}, {
37             id   => $s_id,
38             name => $supplierlist{$s_id} . "($count)",
39             selected => ( $supplierid && $supplierid == $s_id ),
40         };
41 }
42
43 my $letters = GetLetters('claimissues');
44 my @letters;
45 foreach (keys %{$letters}){
46     push @letters ,{code=>$_,name=> $letters->{$_}};
47 }
48
49 my $letter=((scalar(@letters)>1) || ($letters[0]->{name}||$letters[0]->{code}));
50 my ($count2, @missingissues);
51 if ($supplierid) {
52     ($count2, @missingissues) = GetLateOrMissingIssues($supplierid,$serialid,$order);
53 }
54
55 my ($singlesupplier,@supplierinfo);
56 if($supplierid){
57    (@supplierinfo)=GetBookSeller($supplierid);
58 } else { # set up supplierid for the claim links out of main table if all suppliers is chosen
59    for my $mi (@missingissues){
60        $mi->{supplierid} = getsupplierbyserialid($mi->{serialid});
61    }
62 }
63
64 my $preview=0;
65 if($op && $op eq 'preview'){
66     $preview = 1;
67 }
68 if ($op eq "send_alert"){
69   my @serialnums=$input->param("serialid");
70   SendAlerts('claimissues',\@serialnums,$input->param("letter_code"));
71   my $cntupdate=UpdateClaimdateIssues(\@serialnums);
72   ### $cntupdate SHOULD be equal to scalar(@$serialnums)
73   $template->param('SHOWCONFIRMATION' => 1);
74   $template->param('suppliername' => $suppliername);
75 }
76
77 $template->param('letters'=>\@letters,'letter'=>$letter);
78 $template->param(
79         order =>$order,
80         supplier_loop => $supplier_loop,
81         phone => $supplierinfo[0]->{phone},
82         booksellerfax => $supplierinfo[0]->{booksellerfax},
83         bookselleremail => $supplierinfo[0]->{bookselleremail},
84         preview => $preview,
85         missingissues => \@missingissues,
86         supplierid => $supplierid,
87         claimletter => $claimletter,
88         singlesupplier => $singlesupplier,
89         supplierloop => \@supplierinfo,
90         dateformat    => C4::Context->preference("dateformat"),
91         DHTMLcalendar_dateformat => C4::Dates->DHTMLcalendar(),
92         );
93 output_html_with_http_headers $input, $cookie, $template->output;