query => $input,
type => 'intranet',
authnotrequired => 0,
- flagsrequired => { borrowers => 1 },
+ flagsrequired => { borrowers => 'edit_borrowers' },
}
);
my $visit_id = $input->param('visit_id') // q{};
# Get patron
-my $patron = eval {
- my $borrowernumber = $input->param('borrowernumber') // q{};
- return Koha::Patrons->find($borrowernumber);
-};
-push @messages, { type => 'error', code => 'error_on_patron_load' }
- if ( $@ or !$patron );
+my $borrowernumber = $input->param('borrowernumber');
+my $logged_in_user = Koha::Patrons->find( $loggedinuser ) or die "Not logged in";
+my $patron = Koha::Patrons->find($borrowernumber);
+output_and_exit_if_error( $input, $cookie, $template, { module => 'members', logged_in_user => $logged_in_user, current_patron => $patron } );
# Get supporting cast
-my ( $branch, $category, $houseboundprofile, $visit, $patron_image );
-if ( $patron ) {
- $patron_image = Koha::Patron::Images->find($patron->borrowernumber);
- $branch = Koha::Libraries->new->find($patron->branchcode);
- $category = Koha::Patron::Categories->new->find($patron->categorycode);
+my ( $houseboundprofile, $visit );
+if ( $patron ) { # FIXME This test is not needed - output_and_exit_if_error handles it
$houseboundprofile = $patron->housebound_profile;
}
if ( $visit_id ) {
# We have received the input from the profile edit form. We must save the
# changes, and return to simple display.
$houseboundprofile->set({
- day => $input->param('day') // q{},
- frequency => $input->param('frequency') // q{},
- fav_itemtypes => $input->param('fav_itemtypes') // q{},
- fav_subjects => $input->param('fav_subjects') // q{},
- fav_authors => $input->param('fav_authors') // q{},
- referral => $input->param('referral') // q{},
- notes => $input->param('notes') // q{},
+ day => scalar $input->param('day') // q{},
+ frequency => scalar $input->param('frequency') // q{},
+ fav_itemtypes => scalar $input->param('fav_itemtypes') // q{},
+ fav_subjects => scalar $input->param('fav_subjects') // q{},
+ fav_authors => scalar $input->param('fav_authors') // q{},
+ referral => scalar $input->param('referral') // q{},
+ notes => scalar $input->param('notes') // q{},
});
my $success = eval { return $houseboundprofile->store };
push @messages, { type => 'error', code => 'error_on_profile_store' }
# save it, and return to simple display.
$houseboundprofile = Koha::Patron::HouseboundProfile->new({
borrowernumber => $patron->borrowernumber,
- day => $input->param('day') // q{},
- frequency => $input->param('frequency') // q{},
- fav_itemtypes => $input->param('fav_itemtypes') // q{},
- fav_subjects => $input->param('fav_subjects') // q{},
- fav_authors => $input->param('fav_authors') // q{},
- referral => $input->param('referral') // q{},
- notes => $input->param('notes') // q{},
+ day => scalar $input->param('day') // q{},
+ frequency => scalar $input->param('frequency') // q{},
+ fav_itemtypes => scalar $input->param('fav_itemtypes') // q{},
+ fav_subjects => scalar $input->param('fav_subjects') // q{},
+ fav_authors => scalar $input->param('fav_authors') // q{},
+ referral => scalar $input->param('referral') // q{},
+ notes => scalar $input->param('notes') // q{},
});
my $success = eval { return $houseboundprofile->store };
push @messages, { type => 'error', code => 'error_on_profile_create' }
# We have received input for editing a visit. We must store and return to
# simple display.
$visit->set({
- borrowernumber => $input->param('borrowernumber') // q{},
+ borrowernumber => scalar $input->param('borrowernumber') // q{},
appointment_date => dt_from_string($input->param('date') // q{}),
- day_segment => $input->param('segment') // q{},
- chooser_brwnumber => $input->param('chooser') // q{},
- deliverer_brwnumber => $input->param('deliverer') // q{},
+ day_segment => scalar $input->param('segment') // q{},
+ chooser_brwnumber => scalar $input->param('chooser') // q{},
+ deliverer_brwnumber => scalar $input->param('deliverer') // q{},
});
my $success = eval { return $visit->store };
push @messages, { type => 'error', code => 'error_on_visit_store' }
# We have received input for creating a visit. We must store and return
# to simple display.
my $visit = Koha::Patron::HouseboundVisit->new({
- borrowernumber => $input->param('borrowernumber') // q{},
+ borrowernumber => scalar $input->param('borrowernumber') // q{},
appointment_date => dt_from_string($input->param('date') // q{}),
- day_segment => $input->param('segment') // q{},
- chooser_brwnumber => $input->param('chooser') // q{},
- deliverer_brwnumber => $input->param('deliverer') // q{},
+ day_segment => scalar $input->param('segment') // q{},
+ chooser_brwnumber => scalar $input->param('chooser') // q{},
+ deliverer_brwnumber => scalar $input->param('deliverer') // q{},
});
my $success = eval { return $visit->store };
push @messages, { type => 'error', code => 'error_on_visit_create' }
$method = 'update_or_create' if ( !$houseboundprofile );
# Ensure template has all patron details.
-$template->param(%{$patron->unblessed}) if ( $patron );
+$template->param( patron => $patron );
# Load extended patron attributes if necessary (taken from members/files.pl).
if ( C4::Context->preference('ExtendedPatronAttributes') and $patron ) {
);
}
-$template->param( adultborrower => 1 ) if ( $category->category_type eq 'A' );
$template->param(
- picture => $patron_image,
housebound_profile => $houseboundprofile,
visit => $houseboundvisit,
- branch => $branch,
- category => $category,
messages => \@messages,
method => $method,
choosers => $choosers,