Bug Fixing : Browse shelves not displaying results
[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
14 my $input = new CGI;
15
16 my $serialid = $input->param('serialid');
17 my $op = $input->param('op');
18 my $claimletter = $input->param('claimletter');
19 my $supplierid = $input->param('supplierid');
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 => 'claim_serials'},
31             debug => 1,
32             });
33
34 foreach my $supplierid (sort {$supplierlist{$a} cmp $supplierlist{$b} } keys %supplierlist){
35         my ($count, @dummy) = GetLateOrMissingIssues($supplierid,"",$order);
36         my $counting = $count;
37         $supplierlist{$supplierid} = $supplierlist{$supplierid}." ($counting)";
38         push @select_supplier, $supplierid
39 }
40
41 my $letters = GetLetters("claimissues");
42 my @letters;
43 foreach (keys %$letters){
44     push @letters ,{code=>$_,name=> $letters->{$_}};
45 }
46
47 my $letter=((scalar(@letters)>1) || ($letters[0]->{name}||$letters[0]->{code}));
48 my ($count2, @missingissues);
49 if ($supplierid) {
50     ($count2, @missingissues) = GetLateOrMissingIssues($supplierid,$serialid,$order);
51 }
52
53 my $CGIsupplier=CGI::scrolling_list( -name     => 'supplierid',
54                         -id        => 'supplierid',
55                         -values   => \@select_supplier,
56                         -default  => $supplierid,
57                         -labels   => \%supplierlist,
58                         -size     => 1,
59                         -multiple => 0 );
60
61 my ($singlesupplier,@supplierinfo);
62 if($supplierid){
63    (@supplierinfo)=GetBookSeller($supplierid);
64 } else { # set up supplierid for the claim links out of main table if all suppliers is chosen
65    for my $mi (@missingissues){
66        $mi->{supplierid} = getsupplierbyserialid($mi->{serialid});
67    }
68 }
69
70 my $preview=0;
71 if($op && $op eq 'preview'){
72     $preview = 1;
73 }
74
75 if ($op eq "send_alert"){
76   my @serialnums=$input->param("serialid");
77   SendAlerts('claimissues',\@serialnums,$input->param("letter_code"));
78   my $cntupdate=UpdateClaimdateIssues(\@serialnums);
79   ### $cntupdate SHOULD be equal to scalar(@$serialnums)
80 }
81
82 $template->param('letters'=>\@letters,'letter'=>$letter);
83 $template->param(
84         order =>$order,
85         CGIsupplier => $CGIsupplier,
86         phone => $supplierinfo[0]->{phone},
87         booksellerfax => $supplierinfo[0]->{booksellerfax},
88         bookselleremail => $supplierinfo[0]->{bookselleremail},
89         preview => $preview,
90         missingissues => \@missingissues,
91         supplierid => $supplierid,
92         claimletter => $claimletter,
93         singlesupplier => $singlesupplier,
94         supplierloop => \@supplierinfo,
95         dateformat    => C4::Context->preference("dateformat"),
96         );
97 output_html_with_http_headers $input, $cookie, $template->output;