#
# This file is part of Koha.
#
-# Koha is free software; you can redistribute it and/or modify it under the
-# terms of the GNU General Public License as published by the Free Software
-# Foundation; either version 2 of the License, or (at your option) any later
-# version.
+# Koha is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
#
-# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
-# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
-# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
+# Koha is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
#
-# You should have received a copy of the GNU General Public License along
-# with Koha; if not, write to the Free Software Foundation, Inc.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+# You should have received a copy of the GNU General Public License
+# along with Koha; if not, see <http://www.gnu.org/licenses>.
=head1 itemslost
=cut
-use strict;
-use warnings;
+use Modern::Perl;
-use CGI;
-use C4::Auth;
-use C4::Output;
-use C4::Biblio;
-use C4::Items;
-use C4::Koha; # GetItemTypes
-use C4::Branch; # GetBranches
-use C4::Dates qw/format_date/;
+use CGI qw ( -utf8 );
+use Text::CSV_XS;
+use C4::Auth qw( get_template_and_user );
+use C4::Output qw( output_html_with_http_headers );
+use Text::CSV::Encoded;
+use Koha::AuthorisedValues;
+use Koha::CsvProfiles;
-my $query = new CGI;
+my $query = CGI->new;
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
{
- template_name => "reports/itemslost.tmpl",
+ template_name => "reports/itemslost.tt",
query => $query,
type => "intranet",
- authnotrequired => 0,
flagsrequired => { reports => '*' },
- debug => 1,
}
);
my $params = $query->Vars;
my $get_items = $params->{'get_items'};
-
-if ( $get_items ) {
- my $orderbyfilter = $params->{'orderbyfilter'} || undef;
- my $branchfilter = $params->{'branchfilter'} || undef;
- my $barcodefilter = $params->{'barcodefilter'} || undef;
- my $itemtypesfilter = $params->{'itemtypesfilter'} || undef;
+my $op = $query->param('op') || '';
+
+if ( $op eq 'export' ) {
+ my @itemnumbers = $query->multi_param('itemnumber');
+ my $csv_profile_id = $query->param('csv_profile_id');
+ my @rows;
+ if ($csv_profile_id) {
+ # FIXME This following code has the same logic as GetBasketAsCSV
+ # We should refactor all the CSV export code
+ # Note: For MARC it is already done in Koha::Exporter::Record but not for SQL CSV profiles type
+ my $csv_profile = Koha::CsvProfiles->find( $csv_profile_id );
+ die "There is no valid csv profile given" unless $csv_profile;
+
+ my $csv_profile_content = $csv_profile->content;
+ my ( @headers, @fields );
+ while ( $csv_profile_content =~ /
+ ([^=\|]+) # header
+ =?
+ ([^\|]*) # fieldname (table.row or row)
+ \|? /gxms
+ ) {
+ my $header = $1;
+ my $field = ($2 eq '') ? $1 : $2;
+
+ $header =~ s/^\s+|\s+$//g; # Trim whitespaces
+ push @headers, $header;
+
+ $field =~ s/[^\.]*\.{1}//; # Remove the table name if exists.
+ $field =~ s/^\s+|\s+$//g; # Trim whitespaces
+ push @fields, $field;
+ }
+ my $items = Koha::Items->search({ itemnumber => { -in => \@itemnumbers } });
+ while ( my $item = $items->next ) {
+ my @row;
+ my $all_fields = $item->unblessed;
+ $all_fields = { %$all_fields, %{$item->biblio->unblessed}, %{$item->biblioitem->unblessed} };
+ for my $field (@fields) {
+ push @row, $all_fields->{$field};
+ }
+ push @rows, \@row;
+ }
+ my $delimiter = $csv_profile->csv_separator;
+ $delimiter = "\t" if $delimiter eq "\\t";
+
+ my $csv = Text::CSV::Encoded->new({ encoding_out => 'UTF-8', sep_char => $delimiter});
+ $csv or die "Text::CSV::Encoded->new({binary => 1}) FAILED: " . Text::CSV::Encoded->error_diag();
+ $csv->combine(@headers);
+ my $content .= Encode::decode('UTF-8', $csv->string()) . "\n";
+ for my $row ( @rows ) {
+ $csv->combine(@$row);
+ $content .= $csv->string . "\n";
+ }
+ print $query->header(
+ -type => 'text/csv',
+ -attachment => 'lost_items.csv',
+ );
+ print $content;
+ exit;
+ }
+} elsif ( $get_items ) {
+ my $branchfilter = $params->{'branchfilter'} || undef;
+ my $barcodefilter = $params->{'barcodefilter'} || undef;
+ my $itemtypesfilter = $params->{'itemtypesfilter'} || undef;
my $loststatusfilter = $params->{'loststatusfilter'} || undef;
-
- my %where;
- $where{'homebranch'} = $branchfilter if defined $branchfilter;
- $where{'barcode'} = $barcodefilter if defined $barcodefilter;
- $where{'authorised_value'} = $loststatusfilter if defined $loststatusfilter;
-
- my $itype = C4::Context->preference('item-level_itypes') ? "itype" : "itemtype";
- $where{$itype} = $itemtypesfilter if defined $itemtypesfilter;
-
- my $items = GetLostItems( \%where, $orderbyfilter );
- foreach my $it (@$items) {
- $it->{'datelastseen'} = format_date($it->{'datelastseen'});
+ my $notforloanfilter = $params->{'notforloanfilter'} || undef;
+
+ my $params = {
+ ( $branchfilter ? ( homebranch => $branchfilter ) : () ),
+ (
+ $loststatusfilter
+ ? ( itemlost => $loststatusfilter )
+ : ( itemlost => { '!=' => 0 } )
+ ),
+ (
+ $notforloanfilter
+ ? ( notforloan => $notforloanfilter )
+ : ()
+ ),
+ ( $barcodefilter ? ( barcode => { like => "%$barcodefilter%" } ) : () ),
+ };
+
+ my $attributes;
+ if ($itemtypesfilter) {
+ if ( C4::Context->preference('item-level_itypes') ) {
+ $params->{itype} = $itemtypesfilter;
+ }
+ else {
+ # We want a join on biblioitems
+ $attributes = { join => 'biblioitem' };
+ $params->{'biblioitem.itemtype'} = $itemtypesfilter;
+ }
}
- $template->param(
- total => scalar @$items,
- itemsloop => $items,
- get_items => $get_items,
- itype_level => C4::Context->preference('item-level_itypes'),
- );
-}
-# getting all branches.
-#my $branches = GetBranches;
-#my $branch = C4::Context->userenv->{"branchname"};
+ my $items = Koha::Items->search( $params, $attributes );
-# getting all itemtypes
-my $itemtypes = &GetItemTypes();
-my @itemtypesloop;
-foreach my $thisitemtype ( sort {$itemtypes->{$a}->{description} cmp $itemtypes->{$b}->{description}} keys %$itemtypes ) {
- my %row = (
- value => $thisitemtype,
- description => $itemtypes->{$thisitemtype}->{'description'},
+ $template->param(
+ items => $items,
+ get_items => $get_items,
);
- push @itemtypesloop, \%row;
}
-# get lost statuses
-my $lost_status_loop = C4::Koha::GetAuthorisedValues( 'LOST' );
+# getting all itemtypes
+my $itemtypes = Koha::ItemTypes->search_with_localization;
+
+my $csv_profiles = Koha::CsvProfiles->search({ type => 'sql', used_for => 'export_lost_items' });
-$template->param( branchloop => GetBranchesLoop(C4::Context->userenv->{'branch'}),
- itemtypeloop => \@itemtypesloop,
- loststatusloop => $lost_status_loop,
+$template->param(
+ itemtypes => $itemtypes,
+ csv_profiles => $csv_profiles,
);
# writing the template