use C4::Auth;
use C4::Output;
use C4::Members;
-use C4::Branch;
+use C4::Branch qw(GetBranches);
+use List::MoreUtils qw/any uniq/;
+use Koha::DateUtils;
+
use C4::Dates qw/format_date/;
+use C4::Members::Attributes qw(GetBorrowerAttributes);
my $input = CGI->new;
my $borrowernumber = undef;
my $cardnumber = undef;
+my ($template, $loggedinuser, $cookie)= get_template_and_user({template_name => "members/readingrec.tmpl",
+ query => $input,
+ type => "intranet",
+ authnotrequired => 0,
+ flagsrequired => {borrowers => 1},
+ debug => 1,
+ });
+
+my $op = $input->param('op') || '';
if ($input->param('cardnumber')) {
$cardnumber = $input->param('cardnumber');
$data = GetMember(cardnumber => $cardnumber);
$data = GetMember(borrowernumber => $borrowernumber);
}
-my $order=$input->param('order') || '';
-my $order2=$order;
-if ($order2 eq ''){
- $order2="date_due desc";
+my $order = 'date_due desc';
+my $limit = 0;
+my $issues = ();
+# Do not request the old issues of anonymous patron
+if ( $borrowernumber eq C4::Context->preference('AnonymousPatron') ){
+ # use of 'eq' in the above comparison is intentional -- the
+ # system preference value could be blank
+ $template->param( is_anonymous => 1 );
+} else {
+ $issues = GetAllIssues($borrowernumber,$order,$limit);
}
-my $limit=$input->param('limit');
-if ($limit){
- if ($limit eq 'full'){
- $limit=0;
- }
-}
-else {
- $limit=50;
+my $branches = GetBranches();
+foreach my $issue ( @{$issues} ) {
+ $issue->{issuingbranch} = $branches->{ $issue->{branchcode} }->{branchname};
}
-my ($count,$issues)=GetAllIssues($borrowernumber,$order2,$limit);
-my ($template, $loggedinuser, $cookie)
-= get_template_and_user({template_name => "members/readingrec.tmpl",
- query => $input,
- type => "intranet",
- authnotrequired => 0,
- flagsrequired => {borrowers => 1},
- debug => 1,
- });
-
-my @loop_reading;
-
-for (my $i=0;$i<$count;$i++){
- my %line;
- $line{biblionumber}=$issues->[$i]->{'biblionumber'};
- $line{title}=$issues->[$i]->{'title'};
- $line{author}=$issues->[$i]->{'author'};
- $line{classification} = $issues->[$i]->{'classification'} || $issues->[$i]->{'itemcallnumber'};
- $line{date_due}=format_date($issues->[$i]->{'date_due'});
- $line{returndate}=format_date($issues->[$i]->{'returndate'});
- $line{renewals}=$issues->[$i]->{'renewals'};
- $line{barcode}=$issues->[$i]->{'barcode'};
- $line{volumeddesc}=$issues->[$i]->{'volumeddesc'};
- push(@loop_reading,\%line);
+# barcode export
+if ( $op eq 'export_barcodes' ) {
+ my $today = C4::Dates->new();
+ $today = $today->output('iso');
+ my @barcodes =
+ map { $_->{barcode} } grep { $_->{returndate} =~ m/^$today/o } @{$issues};
+ my $borrowercardnumber =
+ GetMember( borrowernumber => $borrowernumber )->{'cardnumber'};
+ my $delimiter = "\n";
+ binmode( STDOUT, ":encoding(UTF-8)" );
+ print $input->header(
+ -type => 'application/octet-stream',
+ -charset => 'utf-8',
+ -attachment => "$today-$borrowercardnumber-checkinexport.txt"
+ );
+ my $content = join $delimiter, uniq(@barcodes);
+ print $content;
+ exit;
}
if ( $data->{'category_type'} eq 'C') {
$limit = 'full';
}
-my ($picture, $dberror) = GetPatronImage($data->{'cardnumber'});
+
+my ($picture, $dberror) = GetPatronImage($data->{'borrowernumber'});
$template->param( picture => 1 ) if $picture;
+if (C4::Context->preference('ExtendedPatronAttributes')) {
+ my $attributes = GetBorrowerAttributes($borrowernumber);
+ $template->param(
+ ExtendedPatronAttributes => 1,
+ extendedattributes => $attributes
+ );
+}
+
$template->param(
- readingrecordview => 1,
- biblionumber => $data->{'biblionumber'},
- title => $data->{'title'},
- initials => $data->{'initials'},
- surname => $data->{'surname'},
- borrowernumber => $borrowernumber,
- limit => $limit,
- firstname => $data->{'firstname'},
- cardnumber => $data->{'cardnumber'},
- categorycode => $data->{'categorycode'},
- category_type => $data->{'category_type'},
- # category_description => $data->{'description'},
- categoryname => $data->{'description'},
- address => $data->{'address'},
- address2 => $data->{'address2'},
- city => $data->{'city'},
- zipcode => $data->{'zipcode'},
- country => $data->{'country'},
- phone => $data->{'phone'},
- email => $data->{'email'},
- branchcode => $data->{'branchcode'},
- is_child => ($data->{'category_type'} eq 'C'),
- branchname => GetBranchName($data->{'branchcode'}),
- showfulllink => ($count > 50),
- loop_reading => \@loop_reading);
+ readingrecordview => 1,
+ title => $data->{title},
+ initials => $data->{initials},
+ surname => $data->{surname},
+ othernames => $data->{othernames},
+ borrowernumber => $borrowernumber,
+ firstname => $data->{firstname},
+ cardnumber => $data->{cardnumber},
+ categorycode => $data->{categorycode},
+ category_type => $data->{category_type},
+ categoryname => $data->{description},
+ address => $data->{address},
+ address2 => $data->{address2},
+ city => $data->{city},
+ state => $data->{state},
+ zipcode => $data->{zipcode},
+ country => $data->{country},
+ phone => $data->{phone},
+ email => $data->{email},
+ branchcode => $data->{branchcode},
+ is_child => ( $data->{category_type} eq 'C' ),
+ branchname => $branches->{ $data->{branchcode} }->{branchname},
+ loop_reading => $issues,
+ activeBorrowerRelationship =>
+ ( C4::Context->preference('borrowerRelationship') ne '' ),
+ RoutingSerials => C4::Context->preference('RoutingSerials'),
+);
output_html_with_http_headers $input, $cookie, $template->output;
-
-