X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=opac%2Fopac-userupdate.pl;h=3b90498ef537d7212666dd39758962147ee40289;hb=369c5382a48ab2faab1f49e710681681e718ab40;hp=18cafdbe226e500df324eccdbaffaf49916553a2;hpb=9e9d8dbe2ce8544c111cff7ba7b687fd658ac6fa;p=koha.git diff --git a/opac/opac-userupdate.pl b/opac/opac-userupdate.pl index 18cafdbe22..3b90498ef5 100755 --- a/opac/opac-userupdate.pl +++ b/opac/opac-userupdate.pl @@ -22,6 +22,7 @@ use warnings; use CGI; use Mail::Sendmail; +use Encode; use C4::Auth; # checkauth, getborrowernumber. use C4::Context; @@ -48,12 +49,13 @@ my ( $template, $borrowernumber, $cookie ) = get_template_and_user( # get borrower information .... my ( $borr ) = GetMemberDetails( $borrowernumber ); +my ( $patronemail ) = GetFirstValidEmailAddress($borrowernumber); my $lib = GetBranchDetail($borr->{'branchcode'}); # handle the new information.... # collect the form values and send an email. my @fields = ( - 'surname','firstname','othernames','streetnumber','address','address2','city','zipcode','country','phone','mobile','fax','phonepro', 'email','emailpro','B_streetnumber','B_address','B_address2','B_city','B_zipcode','B_country','B_phone','B_email','dateofbirth','sex' + 'surname','firstname','othernames','streetnumber','address','address2','city','state','zipcode','country','phone','mobile','fax','phonepro', 'emailaddress','emailpro','B_streetnumber','B_address','B_address2','B_city','B_state','B_zipcode','B_country','B_phone','B_email','dateofbirth','sex' ); my $update; my $updateemailaddress = $lib->{'branchemail'}; @@ -80,14 +82,17 @@ if ( !$updateemailaddress || $updateemailaddress eq '' ) { exit; } +if ( !$patronemail || $patronemail eq '' ) { + $patronemail = $updateemailaddress; +}; + if ( $query->param('modify') ) { # get all the fields: my $message = <<"EOF"; -Patron $borr->{'cardnumber'} +Patron $borr->{'cardnumber'} has requested to change her/his personal details. +Please check these new details and make the changes to these fields: -has requested to change her/his personal details. -Please check these new details and make the changes: EOF my $streetnumber = $borr->{'streetnumber'} || ''; @@ -98,7 +103,7 @@ EOF my $B_address2 = $borr->{'B_address2'} || ''; foreach my $field (@fields) { - my $newfield = $query->param($field) || ''; + my $newfield = decode('utf-8',$query->param($field)) || ''; my $borrowerfield = ''; if($borr->{$field}) { $borrowerfield = $borr->{$field}; @@ -108,19 +113,20 @@ EOF $borrowerfield = format_date( $borr->{'dateofbirth'} ) || ''; } - if($borrowerfield eq $newfield) { - $message .= "$field : $borrowerfield --> $newfield\n"; - } else { - $message .= uc($field) . " : $borrowerfield --> $newfield\n"; + if($borrowerfield ne $newfield) { + $message .= $field . " : $borrowerfield --> $newfield\n"; } } + + $message .= "\nEdit this patron's record: http://".C4::Context->preference('staffClientBaseURL ')."/cgi-bin/koha/members/memberentry.pl?op=modify&borrowernumber=".$borr->{'borrowernumber'}."&categorycode=".$borr->{'categorycode'} if C4::Context->preference('staffClientBaseURL '); + $message .= "\n\nThanks,\nKoha\n\n"; my %mail = ( To => $updateemailaddress, - From => $updateemailaddress, + From => $patronemail, Subject => "User Request for update of Record.", - Message => $message, - 'Content-Type' => 'text/plain; charset="utf8"', + Message => encode('utf-8', $message), # Mail::Sendmail doesn't like wide characters + 'Content-Type' => 'text/plain; charset="utf-8"', ); if ( sendmail %mail ) { @@ -136,9 +142,6 @@ EOF } } -$borr->{'dateenrolled'} = format_date( $borr->{'dateenrolled'} ); -$borr->{'dateexpiry'} = format_date( $borr->{'dateexpiry'} ); -$borr->{'dateofbirth'} = format_date( $borr->{'dateofbirth'} ); $borr->{'ethnicity'} = fixEthnicity( $borr->{'ethnicity'} ); $borr->{'branchname'} = GetBranchName($borr->{'branchcode'}); @@ -154,17 +157,26 @@ my $checkin_prefs = C4::Members::Messaging::GetMessagingPreferences({ borrowernumber => $borrowernumber, message_name => 'Item Checkout' }); -for (@{ $checkin_prefs->{transports} }) { +for ( keys %{ $checkin_prefs->{transports} }) { $borr->{"items_returned_$_"} = 1; } my $checkout_prefs = C4::Members::Messaging::GetMessagingPreferences({ borrowernumber => $borrowernumber, message_name => 'Item Check-in' }); -for (@{ $checkout_prefs->{transports} }) { +for ( keys %{ $checkout_prefs->{transports} }) { $borr->{"items_borrowed_$_"} = 1; } +if (C4::Context->preference('OPACpatronimages')) { + my ($image, $dberror) = GetPatronImage($borr->{'cardnumber'}); + if ($image) { + $template->param( + display_patron_image => 1 + ); + } +} + my @bordat; $bordat[0] = $borr;