3 # This file is part of Koha.
5 # Copyright (c) 2015 Mark Tompsett
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
21 use Test::More tests => 6;
26 use_ok('C4::Context');
32 can_ok('C4::Items','GetItemsForInventory');
34 my $dbh = C4::Context->dbh;
35 $dbh->{AutoCommit} = 0;
36 $dbh->{RaiseError} = 1;
38 diag("This could take a while for large datasets...");
40 my ($oldResults, $oldCount) = OldWay($dbh);
41 my ($newResults, $newCount) = GetItemsForInventory( { interface => 'staff' } );
43 is_deeply($newResults,$oldResults,"Inventory results unchanged.");
54 my $ignoreissued = '';
55 my $datelastseen = '';
63 my ( @bind_params, @where_strings );
65 my $select_columns = q{
66 SELECT items.itemnumber, barcode, itemcallnumber, title, author, biblio.biblionumber, biblio.frameworkcode, datelastseen, homebranch, location, notforloan, damaged, itemlost, withdrawn, stocknumber
68 my $select_count = q{SELECT COUNT(*)};
71 LEFT JOIN biblio ON items.biblionumber = biblio.biblionumber
72 LEFT JOIN biblioitems on items.biblionumber = biblioitems.biblionumber
75 for my $authvfield (keys %$statushash){
76 if ( scalar @{$statushash->{$authvfield}} > 0 ){
77 my $joinedvals = join ',', @{$statushash->{$authvfield}};
78 push @where_strings, "$authvfield in (" . $joinedvals . ")";
84 push @where_strings, 'itemcallnumber >= ?';
85 push @bind_params, $minlocation;
89 push @where_strings, 'itemcallnumber <= ?';
90 push @bind_params, $maxlocation;
94 $datelastseen = format_date_in_iso($datelastseen);
95 push @where_strings, '(datelastseen < ? OR datelastseen IS NULL)';
96 push @bind_params, $datelastseen;
100 push @where_strings, 'items.location = ?';
101 push @bind_params, $location;
105 if($branch eq "homebranch"){
106 push @where_strings, 'items.homebranch = ?';
108 push @where_strings, 'items.holdingbranch = ?';
110 push @bind_params, $branchcode;
114 push @where_strings, 'biblioitems.itemtype = ?';
115 push @bind_params, $itemtype;
118 if ( $ignoreissued) {
119 $query .= "LEFT JOIN issues ON items.itemnumber = issues.itemnumber ";
120 push @where_strings, 'issues.date_due IS NULL';
123 if ( @where_strings ) {
125 $query .= join ' AND ', @where_strings;
127 $query .= ' ORDER BY items.cn_sort, itemcallnumber, title';
128 my $count_query = $select_count . $query;
129 $query .= " LIMIT $offset, $size" if ($offset and $size);
130 $query = $select_columns . $query;
131 my $sth = $ldbh->prepare($query);
132 $sth->execute( @bind_params );
135 my $tmpresults = $sth->fetchall_arrayref({});
136 $sth = $ldbh->prepare( $count_query );
137 $sth->execute( @bind_params );
138 my ($iTotalRecords) = $sth->fetchrow_array();
140 foreach my $row (@$tmpresults) {
143 foreach my $field (sort keys %$row) {
144 # If the koha field is mapped to a marc field
145 my ($f, $sf) = C4::Biblio::GetMarcFromKohaField("items.$field", $row->{'frameworkcode'});
146 if (defined($f) and defined($sf)) {
147 # We replace the code with it's description
148 my $authvals = C4::Koha::GetKohaAuthorisedValuesFromField($f, $sf, $row->{'frameworkcode'});
149 $row->{$field} = $authvals->{$row->{$field}} if defined $authvals && defined $row->{$field} && defined $authvals->{$row->{$field}};
155 return (\@results, $iTotalRecords);