Bug 19669: (QA follow-up) Remove itemstypes.plugin
[koha.git] / reports / cash_register_stats.pl
1 #!/usr/bin/perl
2 #
3 # This file is part of Koha.
4 #
5 # Koha is free software; you can redistribute it and/or modify it under the
6 # terms of the GNU General Public License as published by the Free Software
7 # Foundation;
8 #
9 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
10 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
11 # A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
12 #
13 # You should have received a copy of the GNU General Public License along
14 # with Koha; if not, write to the Free Software Foundation, Inc.,
15 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
16
17 use Modern::Perl;
18 use C4::Auth;
19 use CGI;
20 use C4::Context;
21 use C4::Reports;
22 use C4::Output;
23 use C4::Koha;
24 use C4::Circulation;
25 use DateTime;
26 use Koha::DateUtils;
27 use Text::CSV::Encoded;
28
29 my $input            = new CGI;
30 my $dbh              = C4::Context->dbh;
31
32 my ($template, $borrowernumber, $cookie) = get_template_and_user({
33     template_name => "reports/cash_register_stats.tt",
34     query => $input,
35     type => "intranet",
36     authnotrequired => 0,
37     flagsrequired => {reports => '*'},
38     debug => 1,
39 });
40
41 my $do_it            = $input->param('do_it');
42 my $output           = $input->param("output");
43 my $basename         = $input->param("basename");
44 my $transaction_type = $input->param("transaction_type") || 'ACT';
45 my $manager_branchcode       = $input->param("branch") || C4::Context->userenv->{'branch'};
46
47 $template->param(
48     do_it => $do_it,
49     CGIsepChoice => GetDelimiterChoices,
50 );
51
52 #Initialize date pickers to today
53 my $fromDate = dt_from_string;
54 my $toDate   = dt_from_string;
55
56 my $query_manualinv = "SELECT id, authorised_value FROM authorised_values WHERE category = 'MANUAL_INV'";
57 my $sth_manualinv = $dbh->prepare($query_manualinv) or die "Unable to prepare query" . $dbh->errstr;
58 $sth_manualinv->execute() or die "Unable to execute query " . $sth_manualinv->errstr;
59 my $manualinv_types = $sth_manualinv->fetchall_arrayref({});
60
61
62 if ($do_it) {
63
64     $fromDate = output_pref({ dt => eval { dt_from_string($input->param("from")) } || dt_from_string,
65             dateformat => 'sql', dateonly => 1 }); #for sql query
66     $toDate   = output_pref({ dt => eval { dt_from_string($input->param("to")) } || dt_from_string,
67             dateformat => 'sql', dateonly => 1 }); #for sql query
68
69     my $whereTType = q{};
70     my @extra_params; # if we add conditions to the select we need extra params
71
72     if ($transaction_type eq 'ALL') { #All Transactons
73         $whereTType = q{};
74     } elsif ($transaction_type eq 'ACT') { #Active
75         $whereTType = q{ AND accounttype IN ('Pay','C') };
76     } else { #Single transac type
77         if ($transaction_type eq 'FORW') {
78             $whereTType = q{ AND accounttype IN ('FOR','W') };
79         } else {
80             $whereTType = q{ AND accounttype = ? };
81             push @extra_params, $transaction_type;
82         }
83     }
84
85     my $whereBranchCode = q{};
86     if ($manager_branchcode ne 'ALL') {
87         $whereBranchCode = q{ AND m.branchcode = ?};
88         push @extra_params, $manager_branchcode;
89     }
90
91
92     my $query = "
93     SELECT round(amount,2) AS amount, description,
94         bo.surname AS bsurname, bo.firstname AS bfirstname, m.surname AS msurname, m.firstname AS mfirstname,
95         bo.cardnumber, br.branchname, bo.borrowernumber,
96         al.borrowernumber, DATE(al.date) as date, al.accounttype, al.amountoutstanding, al.note,
97         bi.title, bi.biblionumber, i.barcode, i.itype
98         FROM accountlines al
99         LEFT JOIN borrowers bo ON (al.borrowernumber = bo.borrowernumber)
100         LEFT JOIN borrowers m ON (al.manager_id = m.borrowernumber)
101         LEFT JOIN branches br ON (br.branchcode = m.branchcode )
102         LEFT JOIN items i ON (i.itemnumber = al.itemnumber)
103         LEFT JOIN biblio bi ON (bi.biblionumber = i.biblionumber)
104         WHERE CAST(al.date AS DATE) BETWEEN ? AND ?
105         $whereTType
106         $whereBranchCode
107         ORDER BY al.date
108     ";
109     my $sth_stats = $dbh->prepare($query) or die "Unable to prepare query " . $dbh->errstr;
110     $sth_stats->execute($fromDate, $toDate, @extra_params) or die "Unable to execute query " . $sth_stats->errstr;
111
112     my @loopresult;
113     my $grantotal = 0;
114     while ( my $row = $sth_stats->fetchrow_hashref()) {
115         $row->{amountoutstanding} = 0 if (!$row->{amountoutstanding});
116         #if ((abs($row->{amount}) - $row->{amountoutstanding}) > 0) {
117             $row->{amount} = sprintf("%.2f", abs ($row->{amount}));
118             $row->{date} = dt_from_string($row->{date}, 'sql');
119
120             push (@loopresult, $row);
121             if($transaction_type eq 'ACT' && ($row->{accounttype} !~ /^C$|^CR$|^LR$|^Pay$/)){
122                 pop @loopresult;
123                 next;
124             }
125             if($row->{accounttype} =~ /^C$|^CR$|^LR$/){
126                 $grantotal -= abs($row->{amount});
127                 $row->{amount} = '-' . $row->{amount};
128             }elsif($row->{accounttype} eq 'FORW' || $row->{accounttype} eq 'W'){
129             }else{
130                 $grantotal += abs($row->{amount});
131             }
132         #}
133     }
134
135     $grantotal = sprintf("%.2f", $grantotal);
136
137     if($output eq 'screen'){
138         $template->param(
139             loopresult => \@loopresult,
140             total => $grantotal,
141         );
142     } else{
143         my $format = 'csv';
144         my $reportname = $input->param('basename');
145         my $reportfilename = $reportname ? "$reportname.$format" : "reportresults.$format" ;
146         #my $reportfilename = "$reportname.html" ;
147         my $delimiter = C4::Context->preference('delimiter') || ',';
148             my @rows;
149             foreach my $row (@loopresult) {
150                 my @rowValues;
151                 push @rowValues, $row->{mfirstname},
152                         $row->{cardnumber},
153                         $row->{bfirstname},
154                         $row->{branchname},
155                         $row->{date},
156                         $row->{accounttype},
157                         $row->{amount},
158                         $row->{title},
159                         $row->{barcode},
160                         $row->{itype};
161                     push (@rows, \@rowValues) ;
162                 }
163                 my @total;
164                 for (1..6){push(@total,"")};
165                 push(@total, $grantotal);
166         print $input->header(
167             -type       => 'text/csv',
168             -encoding    => 'utf-8',
169             -attachment => $reportfilename,
170             -name       => $reportfilename
171          );
172         my $csvTemplate = C4::Templates::gettemplate('reports/csv/cash_register_stats.tt', 'intranet', $input);
173             $csvTemplate->param(sep => $delimiter, rows => \@rows, total => \@total );
174         print $csvTemplate->output;
175         exit;
176     }
177
178 }
179
180 $template->param(
181     beginDate        => $fromDate,
182     endDate          => $toDate,
183     transaction_type => $transaction_type,
184     branchloop       => Koha::Libraries->search({}, { order_by => ['branchname'] })->unblessed,
185     manualinv_types  => $manualinv_types,
186     CGIsepChoice => GetDelimiterChoices,
187 );
188
189 output_html_with_http_headers $input, $cookie, $template->output;
190
191 1;