X-Git-Url: http://koha-dev.rot13.org:8081/gitweb/?a=blobdiff_plain;f=members%2Fmoremember.pl;h=593b0d1156d0cdc4e565d5598b7c052f0a3afde3;hb=109334102fbb29c60fa9a7a762c5e68f4b2ce0be;hp=50a72f552eb6ba8b400c70e70f06006456ef55ee;hpb=453e8e723508463f57577bbbc21a4ea7cc4befb7;p=srvgit diff --git a/members/moremember.pl b/members/moremember.pl index 50a72f552e..593b0d1156 100755 --- a/members/moremember.pl +++ b/members/moremember.pl @@ -22,83 +22,46 @@ =head1 moremember.pl - script to do a borrower enquiry/bring up borrower details etc - Displays all the details about a borrower - written 20/12/99 by chris@katipo.co.nz - last modified 21/1/2000 by chris@katipo.co.nz - modified 31/1/2001 by chris@katipo.co.nz - to not allow items on request to be renewed - - needs html removed and to use the C4::Output more, but its tricky + script to do a borrower enquiry/bring up patron details etc + Displays all the details about a patron =cut -use strict; -#use warnings; FIXME - Bug 2505 +use Modern::Perl; use CGI qw ( -utf8 ); use C4::Context; use C4::Auth; use C4::Output; -use C4::Members; -use C4::Members::Attributes; use C4::Members::AttributeTypes; -use C4::Reserves; -use C4::Circulation; -use C4::Koha; -use C4::Letters; -use C4::Biblio; use C4::Form::MessagingPreferences; use List::MoreUtils qw/uniq/; use C4::Members::Attributes qw(GetBorrowerAttributes); use Koha::Patron::Debarments qw(GetDebarments); -use Koha::Patron::Images; -use Module::Load; -if ( C4::Context->preference('NorwegianPatronDBEnable') && C4::Context->preference('NorwegianPatronDBEnable') == 1 ) { - load Koha::NorwegianPatronDB, qw( NLGetSyncDataFromBorrowernumber ); -} -#use Smart::Comments; -#use Data::Dumper; -use DateTime; +use Koha::Patron::Messages; use Koha::DateUtils; -use Koha::Database; -use Koha::Patron::Categories; +use Koha::CsvProfiles; +use Koha::Patrons; +use Koha::Token; +use Koha::Checkouts; use vars qw($debug); BEGIN { - $debug = $ENV{DEBUG} || 0; + $debug = $ENV{DEBUG} || 0; } -my $dbh = C4::Context->dbh; - my $input = CGI->new; $debug or $debug = $input->param('debug') || 0; + + my $print = $input->param('print'); my $template_name; -my $quickslip = 0; - -my $flagsrequired; -if (defined $print and $print eq "page") { - $template_name = "members/moremember-print.tt"; - # circ staff who process checkouts but can't edit - # patrons still need to be able to access print view - $flagsrequired = { circulate => "circulate_remaining_permissions" }; -} elsif (defined $print and $print eq "slip") { - $template_name = "members/moremember-receipt.tt"; - # circ staff who process checkouts but can't edit - # patrons still need to be able to print receipts - $flagsrequired = { circulate => "circulate_remaining_permissions" }; -} elsif (defined $print and $print eq "qslip") { - $template_name = "members/moremember-receipt.tt"; - $quickslip = 1; - $flagsrequired = { circulate => "circulate_remaining_permissions" }; -} elsif (defined $print and $print eq "brief") { - $template_name = "members/moremember-brief.tt"; - $flagsrequired = { borrowers => 1 }; + +if (defined $print and $print eq "brief") { + $template_name = "members/moremember-brief.tt"; } else { - $template_name = "members/moremember.tt"; - $flagsrequired = { borrowers => 1 }; + $template_name = "members/moremember.tt"; } my ( $template, $loggedinuser, $cookie ) = get_template_and_user( @@ -107,7 +70,7 @@ my ( $template, $loggedinuser, $cookie ) = get_template_and_user( query => $input, type => "intranet", authnotrequired => 0, - flagsrequired => $flagsrequired, + flagsrequired => { borrowers => 'edit_borrowers' }, debug => 1, } ); @@ -115,163 +78,57 @@ my $borrowernumber = $input->param('borrowernumber'); my $error = $input->param('error'); $template->param( error => $error ) if ( $error ); -my ( $od, $issue, $fines ) = GetMemberIssuesAndFines($borrowernumber); -$template->param( issuecount => $issue, fines => $fines ); +my $patron = Koha::Patrons->find( $borrowernumber ); +my $logged_in_user = Koha::Patrons->find( $loggedinuser ) or die "Not logged in"; +output_and_exit_if_error( $input, $cookie, $template, { module => 'members', logged_in_user => $logged_in_user, current_patron => $patron } ); -my $data = GetMember( 'borrowernumber' => $borrowernumber ); +my $category_type = $patron->category->category_type; -if ( not defined $data ) { - $template->param (unknowuser => 1); - output_html_with_http_headers $input, $cookie, $template->output; - exit; +for (qw(gonenoaddress lost borrowernotes is_debarred)) { + $patron->$_ and $template->param(flagged => 1) and last; } -my $category_type = $data->{'category_type'}; - -$debug and printf STDERR "dates (enrolled,expiry,birthdate) raw: (%s, %s, %s)\n", map {$data->{$_}} qw(dateenrolled dateexpiry dateofbirth); -foreach (qw(dateenrolled dateexpiry dateofbirth)) { - my $userdate = $data->{$_}; - unless ($userdate) { - $debug and warn sprintf "Empty \$data{%12s}", $_; - $data->{$_} = ''; - next; - } - $template->param( $_ => dt_from_string( $userdate ) ); -} -$data->{'IS_ADULT'} = ( $data->{'categorycode'} ne 'I' ); - -for (qw(gonenoaddress lost borrowernotes)) { - $data->{$_} and $template->param(flagged => 1) and last; -} - -if ( Koha::Patrons->find( $borrowernumber )->is_debarred ) { - $template->param( 'userdebarred' => 1, 'flagged' => 1 ); - my $debar = $data->{'debarred'}; - if ( $debar ne "9999-12-31" ) { - $template->param( 'userdebarreddate' => output_pref( { dt => dt_from_string( $debar ), dateonly => 1 } ) ); - $template->param( 'debarredcomment' => $data->{debarredcomment} ); - } -} - -$data->{ "sex_".$data->{'sex'}."_p" } = 1 if defined $data->{sex}; - -if ( $category_type eq 'C') { - my $patron_categories = Koha::Patron::Categories->search_limited({ category_type => 'A' }, {order_by => ['categorycode']}); - $template->param( 'CATCODE_MULTI' => 1) if $patron_categories->count > 1; - $template->param( 'catcode' => $patron_categories->next ) if $patron_categories->count == 1; -} - -my $patron = Koha::Patrons->find($data->{borrowernumber}); -my @relatives; -if ( my $guarantor = $patron->guarantor ) { - $template->param( guarantor => $guarantor ); - push @relatives, $guarantor->borrowernumber; - push @relatives, $_->borrowernumber for $patron->siblings; -} elsif ( $patron->contactname || $patron->contactfirstname ) { +if ( $patron->is_debarred ) { $template->param( - guarantor => { - firstname => $patron->contactfirstname, - surname => $patron->contactname, - } + debarments => scalar GetDebarments({ borrowernumber => $borrowernumber }), ); -} else { - my @guarantees = $patron->guarantees; - $template->param( guarantees => \@guarantees ); - push @relatives, $_->borrowernumber for @guarantees; -} - -my $relatives_issues_count = - Koha::Database->new()->schema()->resultset('Issue') - ->count( { borrowernumber => \@relatives } ); - -$template->param( adultborrower => 1 ) if ( $category_type eq 'A' || $category_type eq 'I' ); - -my %bor; -$bor{'borrowernumber'} = $borrowernumber; - -# Converts the branchcode to the branch name -my $samebranch; -if ( C4::Context->preference("IndependentBranches") ) { - my $userenv = C4::Context->userenv; - if ( C4::Context->IsSuperLibrarian() ) { - $samebranch = 1; + if ( $patron->debarred ne "9999-12-31" ) { + $template->param( 'userdebarreddate' => $patron->debarred ); } - else { - $samebranch = ( $data->{'branchcode'} eq $userenv->{branch} ); - } -} -else { - $samebranch = 1; } -my $library = Koha::Libraries->find( $data->{branchcode})->unblessed; -@{$data}{keys %$library} = values %$library; # merge in all branch columns - -my ( $total, $accts, $numaccts) = GetMemberAccountRecords( $borrowernumber ); +$template->param( flagged => 1 ) if $patron->account_locked; -# If printing a page, send the account informations to the template -if ($print eq "page") { - foreach my $accountline (@$accts) { - $accountline->{amount} = sprintf '%.2f', $accountline->{amount}; - $accountline->{amountoutstanding} = sprintf '%.2f', $accountline->{amountoutstanding}; - - if ($accountline->{accounttype} ne 'F' && $accountline->{accounttype} ne 'FU'){ - $accountline->{printtitle} = 1; - } - } - $template->param( accounts => $accts ); +my @relatives; +my $guarantor_relationships = $patron->guarantor_relationships; +my @guarantees = $patron->guarantee_relationships->guarantees; +my @guarantors = $guarantor_relationships->guarantors; +if (@guarantors) { + push( @relatives, $_->id ) for @guarantors; + push( @relatives, $_->id ) for $patron->siblings(); } - -# Show OPAC privacy preference is system preference is set -if ( C4::Context->preference('OPACPrivacy') ) { - $template->param( OPACPrivacy => 1); - $template->param( "privacy".$data->{'privacy'} => 1); +else { + push( @relatives, $_->id ) for @guarantees; } +$template->param( + guarantor_relationships => $guarantor_relationships, + guarantees => \@guarantees, +); -my $today = DateTime->now( time_zone => C4::Context->tz); -$today->truncate(to => 'day'); -my $overdues_exist = 0; -my $totalprice = 0; +my $relatives_issues_count = + Koha::Checkouts->count({ borrowernumber => \@relatives }); # Calculate and display patron's age -my $dateofbirth = $data->{ 'dateofbirth' }; -my $age = GetAge($dateofbirth); -$template->param( age => $age ); - -### ############################################################################### -# BUILD HTML -# show all reserves of this borrower, and the position of the reservation .... -if ($borrowernumber) { - $template->param( - holds_count => Koha::Database->new()->schema()->resultset('Reserve') - ->count( { borrowernumber => $borrowernumber } ) ); +if ( !$patron->is_valid_age ) { + $template->param( age_limitations => 1 ); + $template->param( age_low => $patron->category->dateofbirthrequired ); + $template->param( age_high => $patron->category->upperagelimit ); } +$template->param( age => $patron->get_age ); -# current alert subscriptions -my $alerts = getalert($borrowernumber); -foreach (@$alerts) { - $_->{ $_->{type} } = 1; - $_->{relatedto} = findrelatedto( $_->{type}, $_->{externalid} ); -} - -# Add sync data to the user data -if ( C4::Context->preference('NorwegianPatronDBEnable') && C4::Context->preference('NorwegianPatronDBEnable') == 1 ) { - my $sync = NLGetSyncDataFromBorrowernumber( $borrowernumber ); - if ( $sync ) { - $data->{'sync'} = $sync->sync; - $data->{'syncstatus'} = $sync->syncstatus; - $data->{'lastsync'} = $sync->lastsync; - } -} - -# check to see if patron's image exists in the database -# basically this gives us a template var to condition the display of -# patronimage related interface on -my $patron_image = Koha::Patron::Images->find($data->{borrowernumber}); -$template->param( picture => 1 ) if $patron_image; - -my $branch=C4::Context->userenv->{'branch'}; - -$template->param(%$data); +# Generate CSRF token for upload and delete image buttons +$template->param( + csrf_token => Koha::Token->new->generate_csrf({ session_id => $input->cookie('CGISESSID'),}), +); if (C4::Context->preference('ExtendedPatronAttributes')) { my $attributes = C4::Members::Attributes::GetBorrowerAttributes($borrowernumber); @@ -284,7 +141,9 @@ if (C4::Context->preference('ExtendedPatronAttributes')) { for my $attr (@$attributes) { push @items, $attr if $attr->{class} eq $class } - my $lib = GetAuthorisedValueByCode( 'PA_CLASS', $class ) || $class; + my $av = Koha::AuthorisedValues->search({ category => 'PA_CLASS', authorised_value => $class }); + my $lib = $av->count ? $av->next->lib : $class; + push @attributes_loop, { class => $class, items => \@items, @@ -293,7 +152,6 @@ if (C4::Context->preference('ExtendedPatronAttributes')) { } $template->param( - ExtendedPatronAttributes => 1, attributes_loop => \@attributes_loop ); @@ -306,37 +164,49 @@ if (C4::Context->preference('ExtendedPatronAttributes')) { if (C4::Context->preference('EnhancedMessagingPreferences')) { C4::Form::MessagingPreferences::set_form_values({ borrowernumber => $borrowernumber }, $template); $template->param(messaging_form_inactive => 1); - $template->param(SMSSendDriver => C4::Context->preference("SMSSendDriver")); - $template->param(SMSnumber => defined $data->{'smsalertnumber'} ? $data->{'smsalertnumber'} : $data->{'mobile'}); - $template->param(TalkingTechItivaPhone => C4::Context->preference("TalkingTechItivaPhoneNotification")); } -# in template => instutitional (A for Adult, C for children) -$template->param( $data->{'categorycode'} => 1 ); +if ( C4::Context->preference("ExportCircHistory") ) { + $template->param(csv_profiles => [ Koha::CsvProfiles->search({ type => 'marc' }) ]); +} + +my $patron_messages = Koha::Patron::Messages->search( + { + 'me.borrowernumber' => $patron->borrowernumber, + }, + { + join => 'manager', + '+select' => ['manager.surname', 'manager.firstname' ], + '+as' => ['manager_surname', 'manager_firstname'], + } +); + +if( $patron_messages->count > 0 ){ + $template->param( patron_messages => $patron_messages ); +} + +# Display the language description instead of the code +# Note that this is certainly wrong +my ( $subtag, $region ) = split '-', $patron->lang; +my $translated_language = C4::Languages::language_get_description( $subtag, $subtag, 'language' ); + +# if the expiry date is before today ie they have expired +if ( $patron->is_expired || $patron->is_going_to_expire ) { + $template->param( + flagged => 1 + ); +} + $template->param( - detailview => 1, - borrowernumber => $borrowernumber, - othernames => $data->{'othernames'}, - categoryname => $data->{'description'}, + patron => $patron, + issuecount => $patron->checkouts->count, + holds_count => $patron->holds->count, + fines => $patron->account->balance, + translated_language => $translated_language, + detailview => 1, was_renewed => scalar $input->param('was_renewed') ? 1 : 0, - branch => $branch, - branchcode => $branch, - todaysdate => output_pref({ dt => dt_from_string, dateformat => 'iso', dateonly => 1 }), - totalprice => sprintf("%.2f", $totalprice), - totaldue => sprintf("%.2f", $total), - totaldue_raw => $total, - overdues_exist => $overdues_exist, - StaffMember => ($category_type eq 'S'), - is_child => ($category_type eq 'C'), - samebranch => $samebranch, - quickslip => $quickslip, - privacy_guarantor_checkouts => $data->{'privacy_guarantor_checkouts'}, - activeBorrowerRelationship => (C4::Context->preference('borrowerRelationship') ne ''), - AutoResumeSuspendedHolds => C4::Context->preference('AutoResumeSuspendedHolds'), - SuspendHoldsIntranet => C4::Context->preference('SuspendHoldsIntranet'), - RoutingSerials => C4::Context->preference('RoutingSerials'), - debarments => GetDebarments({ borrowernumber => $borrowernumber }), - PatronsPerPage => C4::Context->preference("PatronsPerPage") || 20, + $category_type => 1, # [% IF ( I ) %] = institutional/organisation + housebound_role => scalar $patron->housebound_role, relatives_issues_count => $relatives_issues_count, relatives_borrowernumbers => \@relatives, );