Bug 19813: Make MarcItemFieldsToOrder handle non-existing tags
[koha.git] / acqui / invoice.pl
1 #!/usr/bin/perl
2
3 # Copyright 2011 BibLibre SARL
4 # This file is part of Koha.
5 #
6 # Koha is free software; you can redistribute it and/or modify it
7 # under the terms of the GNU General Public License as published by
8 # the Free Software Foundation; either version 3 of the License, or
9 # (at your option) any later version.
10 #
11 # Koha is distributed in the hope that it will be useful, but
12 # WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 # GNU General Public License for more details.
15 #
16 # You should have received a copy of the GNU General Public License
17 # along with Koha; if not, see <http://www.gnu.org/licenses>.
18
19 =head1 NAME
20
21 invoice.pl
22
23 =head1 DESCRIPTION
24
25 Invoice details
26
27 =cut
28
29 use strict;
30 use warnings;
31
32 use CGI qw ( -utf8 );
33 use C4::Auth;
34 use C4::Output;
35 use C4::Acquisition;
36 use C4::Budgets;
37
38 use Koha::Acquisition::Booksellers;
39 use Koha::Acquisition::Currencies;
40 use Koha::DateUtils;
41 use Koha::Misc::Files;
42
43 my $input = new CGI;
44 my ( $template, $loggedinuser, $cookie, $flags ) = get_template_and_user(
45     {
46         template_name   => 'acqui/invoice.tt',
47         query           => $input,
48         type            => 'intranet',
49         authnotrequired => 0,
50         flagsrequired   => { 'acquisition' => '*' },
51         debug           => 1,
52     }
53 );
54
55 my $invoiceid = $input->param('invoiceid');
56 my $op        = $input->param('op');
57
58 my $invoice_files;
59 if ( C4::Context->preference('AcqEnableFiles') ) {
60     $invoice_files = Koha::Misc::Files->new(
61         tabletag => 'aqinvoices', recordid => $invoiceid );
62 }
63
64 if ( $op && $op eq 'close' ) {
65     CloseInvoice($invoiceid);
66     my $referer = $input->param('referer');
67     if ($referer) {
68         print $input->redirect($referer);
69         exit 0;
70     }
71 }
72 elsif ( $op && $op eq 'reopen' ) {
73     ReopenInvoice($invoiceid);
74     my $referer = $input->param('referer');
75     if ($referer) {
76         print $input->redirect($referer);
77         exit 0;
78     }
79 }
80 elsif ( $op && $op eq 'mod' ) {
81     my $shipmentcost       = $input->param('shipmentcost');
82     my $shipment_budget_id = $input->param('shipment_budget_id');
83     my $invoicenumber      = $input->param('invoicenumber');
84     ModInvoice(
85         invoiceid             => $invoiceid,
86         invoicenumber         => $invoicenumber,
87         shipmentdate          => scalar output_pref( { str => scalar $input->param('shipmentdate'), dateformat => 'iso', dateonly => 1 } ),
88         billingdate           => scalar output_pref( { str => scalar $input->param('billingdate'),  dateformat => 'iso', dateonly => 1 } ),
89         shipmentcost          => $shipmentcost,
90         shipmentcost_budgetid => $shipment_budget_id
91     );
92     if ($input->param('reopen')) {
93         ReopenInvoice($invoiceid);
94     } elsif ($input->param('close')) {
95         CloseInvoice($invoiceid);
96     } elsif ($input->param('merge')) {
97         my @sources = $input->multi_param('merge');
98         MergeInvoices($invoiceid, \@sources);
99         defined($invoice_files) && $invoice_files->MergeFileRecIds(@sources);
100     }
101     $template->param( modified => 1 );
102 }
103 elsif ( $op && $op eq 'delete' ) {
104     DelInvoice($invoiceid);
105     defined($invoice_files) && $invoice_files->DelAllFiles();
106     my $referer = $input->param('referer') || 'invoices.pl';
107     if ($referer) {
108         print $input->redirect($referer);
109         exit 0;
110     }
111 }
112
113
114 my $details = GetInvoiceDetails($invoiceid);
115 my $bookseller = Koha::Acquisition::Booksellers->find( $details->{booksellerid} );
116 my @orders_loop = ();
117 my $orders = $details->{'orders'};
118 my @foot_loop;
119 my %foot;
120 my $total_quantity = 0;
121 my $total_tax_excluded = 0;
122 my $total_tax_included = 0;
123 my $total_tax_value = 0;
124 foreach my $order (@$orders) {
125     my $line = get_infos( $order, $bookseller);
126
127     $line->{total_tax_excluded} = $line->{unitprice_tax_excluded} * $line->{quantity};
128     $line->{total_tax_included} = $line->{unitprice_tax_included} * $line->{quantity};
129
130     $line->{tax_value} = $line->{tax_value_on_receiving};
131     $line->{tax_rate} = $line->{tax_rate_on_receiving};
132
133     $foot{$$line{tax_rate}}{tax_rate} = $$line{tax_rate};
134     $foot{$$line{tax_rate}}{tax_value} += $$line{tax_value};
135     $total_tax_value += $$line{tax_value};
136     $foot{$$line{tax_rate}}{quantity}  += $$line{quantity};
137     $total_quantity += $$line{quantity};
138     $foot{$$line{tax_rate}}{total_tax_excluded} += $$line{total_tax_excluded};
139     $total_tax_excluded += $$line{total_tax_excluded};
140     $foot{$$line{tax_rate}}{total_tax_included} += $$line{total_tax_included};
141     $total_tax_included += $$line{total_tax_included};
142
143     $line->{orderline} = $line->{parent_ordernumber};
144     push @orders_loop, $line;
145 }
146
147 push @foot_loop, map {$_} values %foot;
148
149 my $budgets = GetBudgets();
150 my @budgets_loop;
151 my $shipmentcost_budgetid = $details->{shipmentcost_budgetid};
152 foreach my $budget (@$budgets) {
153     next unless CanUserUseBudget( $loggedinuser, $budget, $flags );
154     my %line = %{$budget};
155     if (    $shipmentcost_budgetid
156         and $budget->{budget_id} == $shipmentcost_budgetid )
157     {
158         $line{selected} = 1;
159     }
160     push @budgets_loop, \%line;
161 }
162
163 $template->param(
164     invoiceid        => $details->{'invoiceid'},
165     invoicenumber    => $details->{'invoicenumber'},
166     suppliername     => $details->{'suppliername'},
167     booksellerid     => $details->{'booksellerid'},
168     shipmentdate     => $details->{'shipmentdate'},
169     billingdate      => $details->{'billingdate'},
170     invoiceclosedate => $details->{'closedate'},
171     shipmentcost     => $details->{'shipmentcost'},
172     orders_loop      => \@orders_loop,
173     foot_loop        => \@foot_loop,
174     total_quantity   => $total_quantity,
175     total_tax_excluded => $total_tax_excluded,
176     total_tax_included => $total_tax_included,
177     total_tax_value  => $total_tax_value,
178     total_tax_excluded_shipment => $total_tax_excluded + $details->{shipmentcost},
179     total_tax_included_shipment => $total_tax_included + $details->{shipmentcost},
180     invoiceincgst    => $bookseller->invoiceincgst,
181     currency         => Koha::Acquisition::Currencies->get_active,
182     budgets_loop     => \@budgets_loop,
183 );
184
185 defined( $invoice_files ) && $template->param( files => $invoice_files->GetFilesInfo() );
186
187 # FIXME
188 # Fonction dupplicated from basket.pl
189 # Code must to be exported. Where ??
190 sub get_infos {
191     my $order = shift;
192     my $bookseller = shift;
193     my $qty = $order->{'quantity'} || 0;
194     if ( !defined $order->{quantityreceived} ) {
195         $order->{quantityreceived} = 0;
196     }
197     my $budget = GetBudget( $order->{'budget_id'} );
198
199     my %line = %{ $order };
200     $line{order_received} = ( $qty == $order->{'quantityreceived'} );
201     $line{budget_name}    = $budget->{budget_name};
202
203     if ( $line{uncertainprice} ) {
204         $template->param( uncertainprices => 1 );
205         $line{rrp} .= ' (Uncertain)';
206     }
207     if ( $line{'title'} ) {
208         my $volume      = $order->{'volume'};
209         my $seriestitle = $order->{'seriestitle'};
210         $line{'title'} .= " / $seriestitle" if $seriestitle;
211         $line{'title'} .= " / $volume"      if $volume;
212     }
213
214     return \%line;
215 }
216
217 output_html_with_http_headers $input, $cookie, $template->output;