X-Git-Url: http://koha-dev.rot13.org:8081/gitweb/?a=blobdiff_plain;f=opac%2Fopac-userupdate.pl;h=297d5be26a8b5d6c568c106b00f8ea7ae9302766;hb=28646dd55007003300b8c76262c25ab96e04871e;hp=55bbefc3837f4d2da835f996dd9dfeafc38588f2;hpb=fc1342f73df868410e0ab670981f25ba2e1acd74;p=koha_gimpoz diff --git a/opac/opac-userupdate.pl b/opac/opac-userupdate.pl index 55bbefc383..297d5be26a 100755 --- a/opac/opac-userupdate.pl +++ b/opac/opac-userupdate.pl @@ -13,22 +13,25 @@ # 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., 59 Temple Place, -# Suite 330, Boston, MA 02111-1307 USA +# 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. use strict; -require Exporter; +use warnings; + use CGI; use Mail::Sendmail; use C4::Auth; # checkauth, getborrowernumber. use C4::Context; use C4::Koha; -use C4::Circulation::Circ2; -use C4::Interface::CGI::Output; -use C4::Date; +use C4::Circulation; +use C4::Output; +use C4::Dates qw/format_date/; use C4::Members; +use C4::Members::Attributes; +use C4::Branch; my $query = new CGI; @@ -44,17 +47,19 @@ my ( $template, $borrowernumber, $cookie ) = get_template_and_user( ); # get borrower information .... -my ( $borr, $flags ) = getpatroninformation( undef, $borrowernumber ); +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 = ( - 'title', 'surname', 'firstname', 'phone', - 'fax', 'streetaddress', 'emailaddress', 'city','phonepro', + '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 = C4::Context->preference('KohaAdminEmailAddress'); -if ( $updateemailaddress eq '' ) { +my $updateemailaddress = $lib->{'branchemail'}; +$updateemailaddress = C4::Context->preference('KohaAdminEmailAddress') unless( $updateemailaddress =~ /\w+@\w+/); +if ( !$updateemailaddress || $updateemailaddress eq '' ) { warn "KohaAdminEmailAddress system preference not set. Couldn't send patron update information for $borr->{'firstname'} $borr->{'surname'} (#$borrowernumber)\n"; my ($template) = get_template_and_user( @@ -69,40 +74,64 @@ if ( $updateemailaddress eq '' ) { ); $template->param( - errormessage => 'KohaAdminEmailAddress system preference - is not set. Please visit the library to update your user record' + noadminemail => 1, ); output_html_with_http_headers $query, $cookie, $template->output; exit; } -if ( $query->{'title'} ) { +if ( !$patronemail || $patronemail eq '' ) { + $patronemail = $updateemailaddress; +}; + +if ( $query->param('modify') ) { # get all the fields: my $message = <<"EOF"; -Borrower $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'} || ''; + my $address = $borr->{'address'} || ''; + my $address2 = $borr->{'address2'} || ''; + my $B_streetnumber = $borr->{'B_streetnumber'} || ''; + my $B_address = $borr->{'B_address'} || ''; + my $B_address2 = $borr->{'B_address2'} || ''; + foreach my $field (@fields) { - my $newfield = $query->param($field); - $message .= "$field : $borr->{$field} --> $newfield\n"; + my $newfield = $query->param($field) || ''; + my $borrowerfield = ''; + if($borr->{$field}) { + $borrowerfield = $borr->{$field}; + } + + if($field eq "dateofbirth") { + $borrowerfield = format_date( $borr->{'dateofbirth'} ) || ''; + } + + 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 + Message => $message, + 'Content-Type' => 'text/plain; charset="utf8"', ); if ( sendmail %mail ) { # do something if it works.... - warn "Mail sent ok\n"; - print $query->redirect('/cgi-bin/koha/opac-user.pl'); + print $query->redirect('/cgi-bin/koha/opac-user.pl?patronupdate=sent'); exit; } else { @@ -113,15 +142,40 @@ EOF } $borr->{'dateenrolled'} = format_date( $borr->{'dateenrolled'} ); -$borr->{'expiry'} = format_date( $borr->{'expiry'} ); +$borr->{'dateexpiry'} = format_date( $borr->{'dateexpiry'} ); $borr->{'dateofbirth'} = format_date( $borr->{'dateofbirth'} ); $borr->{'ethnicity'} = fixEthnicity( $borr->{'ethnicity'} ); +$borr->{'branchname'} = GetBranchName($borr->{'branchcode'}); + +if (C4::Context->preference('ExtendedPatronAttributes')) { + my $attributes = C4::Members::Attributes::GetBorrowerAttributes($borrowernumber, 'opac'); + if (scalar(@$attributes) > 0) { + $borr->{ExtendedPatronAttributes} = 1; + $borr->{patron_attributes} = $attributes; + } +} + +my $checkin_prefs = C4::Members::Messaging::GetMessagingPreferences({ + borrowernumber => $borrowernumber, + message_name => 'Item Checkout' +}); +for (@{ $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} }) { + $borr->{"items_borrowed_$_"} = 1; +} my @bordat; $bordat[0] = $borr; $template->param( - BORROWER_INFO => \@bordat + BORROWER_INFO => \@bordat, + userupdateview => 1, ); output_html_with_http_headers $query, $cookie, $template->output;