Bug 15164 - Allow editing of the invoice number after initial saving
[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::Bookseller;
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          => output_pref( { str => scalar $input->param('shipmentdate'), dateformat => 'iso', dateonly => 1 } ),
88         billingdate           => 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::Bookseller->fetch({ id => $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_gste = 0;
122 my $total_gsti = 0;
123 my $total_gstvalue = 0;
124 foreach my $order (@$orders) {
125     $order = C4::Acquisition::populate_order_with_prices(
126         {
127             order        => $order,
128             booksellerid => $bookseller->{id},
129             receiving    => 1,
130         }
131     );
132     my $line = get_infos( $order, $bookseller);
133
134     $foot{$$line{gstrate}}{gstrate} = $$line{gstrate};
135     $foot{$$line{gstrate}}{gstvalue} += $$line{gstvalue};
136     $total_gstvalue += $$line{gstvalue};
137     $foot{$$line{gstrate}}{quantity}  += $$line{quantity};
138     $total_quantity += $$line{quantity};
139     $foot{$$line{gstrate}}{totalgste} += $$line{totalgste};
140     $total_gste += $$line{totalgste};
141     $foot{$$line{gstrate}}{totalgsti} += $$line{totalgsti};
142     $total_gsti += $$line{totalgsti};
143
144     $line->{orderline} = $line->{parent_ordernumber};
145     push @orders_loop, $line;
146 }
147
148 push @foot_loop, map {$_} values %foot;
149
150 my $format = "%.2f";
151 my $budgets = GetBudgets();
152 my @budgets_loop;
153 my $shipmentcost_budgetid = $details->{shipmentcost_budgetid};
154 foreach my $budget (@$budgets) {
155     next unless CanUserUseBudget( $loggedinuser, $budget, $flags );
156     my %line = %{$budget};
157     if (    $shipmentcost_budgetid
158         and $budget->{budget_id} == $shipmentcost_budgetid )
159     {
160         $line{selected} = 1;
161     }
162     push @budgets_loop, \%line;
163 }
164
165 $template->param(
166     invoiceid        => $details->{'invoiceid'},
167     invoicenumber    => $details->{'invoicenumber'},
168     suppliername     => $details->{'suppliername'},
169     booksellerid     => $details->{'booksellerid'},
170     shipmentdate     => $details->{'shipmentdate'},
171     billingdate      => $details->{'billingdate'},
172     invoiceclosedate => $details->{'closedate'},
173     shipmentcost     => $details->{'shipmentcost'},
174     orders_loop      => \@orders_loop,
175     foot_loop        => \@foot_loop,
176     total_quantity   => $total_quantity,
177     total_gste       => sprintf( $format, $total_gste ),
178     total_gsti       => sprintf( $format, $total_gsti ),
179     total_gstvalue   => sprintf( $format, $total_gstvalue ),
180     total_gste_shipment => sprintf( $format, $total_gste + $details->{shipmentcost}),
181     total_gsti_shipment => sprintf( $format, $total_gsti + $details->{shipmentcost}),
182     invoiceincgst    => $bookseller->{invoiceincgst},
183     currency         => Koha::Acquisition::Currencies->get_active,
184     budgets_loop     => \@budgets_loop,
185 );
186
187 defined( $invoice_files ) && $template->param( files => $invoice_files->GetFilesInfo() );
188
189 # FIXME
190 # Fonction dupplicated from basket.pl
191 # Code must to be exported. Where ??
192 sub get_infos {
193     my $order = shift;
194     my $bookseller = shift;
195     my $qty = $order->{'quantity'} || 0;
196     if ( !defined $order->{quantityreceived} ) {
197         $order->{quantityreceived} = 0;
198     }
199     my $budget = GetBudget( $order->{'budget_id'} );
200
201     my %line = %{ $order };
202     $line{order_received} = ( $qty == $order->{'quantityreceived'} );
203     $line{budget_name}    = $budget->{budget_name};
204
205     if ( $line{uncertainprice} ) {
206         $template->param( uncertainprices => 1 );
207         $line{rrp} .= ' (Uncertain)';
208     }
209     if ( $line{'title'} ) {
210         my $volume      = $order->{'volume'};
211         my $seriestitle = $order->{'seriestitle'};
212         $line{'title'} .= " / $seriestitle" if $seriestitle;
213         $line{'title'} .= " / $volume"      if $volume;
214     }
215
216     return \%line;
217 }
218
219 output_html_with_http_headers $input, $cookie, $template->output;