4 #script to show display basket of orders
5 #written by chris@katipo.co.nz 24/2/2000
8 # Copyright 2000-2002 Katipo Communications
10 # This file is part of Koha.
12 # Koha is free software; you can redistribute it and/or modify it under the
13 # terms of the GNU General Public License as published by the Free Software
14 # Foundation; either version 2 of the License, or (at your option) any later
17 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
18 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
19 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
21 # You should have received a copy of the GNU General Public License along with
22 # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
23 # Suite 330, Boston, MA 02111-1307 USA
30 This script shows all orders/parcels receipt or pending for a given supplier.
31 It allows to write an order/parcels as 'received' when he arrives.
38 To know the supplier this script has to show orders.
41 sort list of order by 'orderby'.
42 Orderby can be equals to
43 * datereceived desc (default value)
44 * aqorders.booksellerinvoicenumber
46 * aqorders.booksellerinvoicenumber desc
57 To know how many results have to be display / page.
68 use C4::Dates qw/format_date/;
73 my $supplierid=$input->param('supplierid');
74 my $order=$input->param('orderby') || "datereceived desc";
75 my $startfrom=$input->param('startfrom');
76 my $code=$input->param('filter');
77 my $datefrom=$input->param('datefrom');
78 my $dateto=$input->param('dateto');
79 my $resultsperpage = $input->param('resultsperpage');
82 my ($template, $loggedinuser, $cookie)
83 = get_template_and_user({template_name => "acqui/parcels.tmpl",
87 flagsrequired => {acquisition => 1},
92 my $bookseller=GetBookSellerFromId($supplierid);
93 $resultsperpage = 20 unless ($resultsperpage);
94 my @results =GetParcels($supplierid, $order, $code,$datefrom,$dateto);
95 my $count = scalar @results;
97 # multi page display gestion
98 $startfrom=0 unless ($startfrom);
99 if ($count>$resultsperpage){
101 my $displayprev=$startfrom;
102 if(($count - ($startfrom+$resultsperpage)) > 0 ) {
107 if ($count>$resultsperpage) {
108 for (my $i=1; $i<$count/$resultsperpage+1; $i++) {
111 ($startfrom/$resultsperpage==($i-1)) && ($highlight=1);
112 push @numbers, { number => $i,
113 highlight => $highlight ,
114 # searchdata=> "test",
115 startfrom => ($i-1)*$resultsperpage};
120 my $from = $startfrom*$resultsperpage+1;
122 if($count < (($startfrom+1)*$resultsperpage)){
125 $to = (($startfrom+1)*$resultsperpage);
127 $template->param(numbers=>\@numbers,
128 displaynext=>$displaynext,
129 displayprev=>$displayprev,
130 nextstartfrom=>(($startfrom+$resultsperpage<$count)?$startfrom+$resultsperpage:$count),
131 prevstartfrom=>(($startfrom-$resultsperpage>0)?$startfrom-$resultsperpage:0)
137 for (my $i=$startfrom;$i<=($startfrom+$resultsperpage-1<$count-1?$startfrom+$resultsperpage-1:$count-1);$i++){
141 $cell{code}=$results[$i]->{booksellerinvoicenumber};
142 $cell{nullcode}=$results[$i]->{booksellerinvoicenumber} eq "NULL";
143 $cell{emptycode}=$results[$i]->{booksellerinvoicenumber} eq '';
144 $cell{raw_datereceived}=$results[$i]->{datereceived};
145 $cell{datereceived}=format_date($results[$i]->{datereceived});
146 $cell{bibcount}=$results[$i]->{biblio};
147 $cell{reccount}=$results[$i]->{itemsreceived};
148 $cell{itemcount}=$results[$i]->{itemsexpected};
149 $cell{hilighted} = $hilighted%2;
151 push @loopres, \%cell;
153 $template->param(searchresults=>\@loopres, count=>$count) if ($count);
154 $template->param(orderby=>$order, filter=>$code, datefrom=>$datefrom,dateto=>$dateto, resultsperpage=>$resultsperpage);
156 name => $bookseller->{'name'},
157 DHTMLcalendar_dateformat => C4::Dates->DHTMLcalendar(),
158 datereceived_today => C4::Dates->new()->output(),
159 supplierid => $supplierid,
160 GST => C4::Context->preference("gist"),
163 output_html_with_http_headers $input, $cookie, $template->output;