Jonathan Druart
47fb829694
Signed-off-by: Claire Gravely <claire_gravely@hotmail.com> Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com>
193 lines
7.4 KiB
Perl
Executable file
193 lines
7.4 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# Copyright 2016 PTFS-Europe Ltd
|
|
#
|
|
# This file is part of Koha.
|
|
#
|
|
# Koha is free software; you can redistribute it and/or modify it under the
|
|
# terms of the GNU General Public License as published by the Free Software
|
|
# Foundation; either version 3 of the License, or (at your option) any later
|
|
# version.
|
|
#
|
|
# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
# 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.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
=head1 housebound.pl
|
|
|
|
Script to handle housebound management for patrons. This single script
|
|
handles display, creation, deletion and management of profiles and visits.
|
|
|
|
=cut
|
|
|
|
use Modern::Perl;
|
|
use CGI;
|
|
use C4::Auth;
|
|
use C4::Context;
|
|
use C4::Members::Attributes qw(GetBorrowerAttributes);
|
|
use C4::Output;
|
|
use DateTime;
|
|
use Koha::DateUtils;
|
|
use Koha::Libraries;
|
|
use Koha::Patrons;
|
|
use Koha::Patron::Categories;
|
|
use Koha::Patron::HouseboundProfile;
|
|
use Koha::Patron::HouseboundVisit;
|
|
use Koha::Patron::HouseboundVisits;
|
|
|
|
my $input = CGI->new;
|
|
|
|
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
|
|
{
|
|
template_name => 'members/housebound.tt',
|
|
query => $input,
|
|
type => 'intranet',
|
|
authnotrequired => 0,
|
|
flagsrequired => { borrowers => 1 },
|
|
}
|
|
);
|
|
|
|
my @messages; # For error messages.
|
|
my $method = $input->param('method') // q{};
|
|
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 );
|
|
|
|
# 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);
|
|
$houseboundprofile = $patron->housebound_profile;
|
|
}
|
|
if ( $visit_id ) {
|
|
$visit = eval {
|
|
return Koha::Patron::HouseboundVisits->find($visit_id);
|
|
};
|
|
push @messages, { type => 'error', code => 'error_on_visit_load' }
|
|
if ( $@ or !$visit );
|
|
}
|
|
|
|
# Main processing
|
|
my ( $deliverers, $choosers, $houseboundvisit );
|
|
|
|
if ( $method eq 'updateconfirm' and $houseboundprofile ) {
|
|
# 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{},
|
|
});
|
|
my $success = eval { return $houseboundprofile->store };
|
|
push @messages, { type => 'error', code => 'error_on_profile_store' }
|
|
if ( $@ or !$success );
|
|
$method = undef;
|
|
} elsif ( $method eq 'createconfirm' ) {
|
|
# We have received the input necessary to create a new profile. We must
|
|
# 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{},
|
|
});
|
|
my $success = eval { return $houseboundprofile->store };
|
|
push @messages, { type => 'error', code => 'error_on_profile_create' }
|
|
if ( $@ or !$success );
|
|
$method = undef;
|
|
} elsif ( $method eq 'visit_update_or_create' ) {
|
|
# We want to edit, edit a visit, so we must pass its details.
|
|
$deliverers = Koha::Patrons->search_housebound_deliverers;
|
|
$choosers = Koha::Patrons->search_housebound_choosers;
|
|
$houseboundvisit = $visit;
|
|
} elsif ( $method eq 'visit_delete' and $visit ) {
|
|
# We want ot delete a specific visit.
|
|
my $success = eval { return $visit->delete };
|
|
push @messages, { type => 'error', code => 'error_on_visit_delete' }
|
|
if ( $@ or !$success );
|
|
$method = undef;
|
|
} elsif ( $method eq 'editvisitconfirm' and $visit ) {
|
|
# We have received input for editing a visit. We must store and return to
|
|
# simple display.
|
|
$visit->set({
|
|
borrowernumber => $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{},
|
|
});
|
|
my $success = eval { return $visit->store };
|
|
push @messages, { type => 'error', code => 'error_on_visit_store' }
|
|
if ( $@ or !$success );
|
|
$method = undef;
|
|
} elsif ( $method eq 'addvisitconfirm' and !$visit ) {
|
|
# 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{},
|
|
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{},
|
|
});
|
|
my $success = eval { return $visit->store };
|
|
push @messages, { type => 'error', code => 'error_on_visit_create' }
|
|
if ( $@ or !$success );
|
|
$method = undef;
|
|
}
|
|
|
|
# We don't have any profile information, so we must display a creation form.
|
|
$method = 'update_or_create' if ( !$houseboundprofile );
|
|
|
|
# Ensure template has all patron details.
|
|
$template->param(%{$patron->unblessed}) if ( $patron );
|
|
|
|
# Load extended patron attributes if necessary (taken from members/files.pl).
|
|
if ( C4::Context->preference('ExtendedPatronAttributes') and $patron ) {
|
|
my $attributes = GetBorrowerAttributes($patron->borrowernumber);
|
|
$template->param(
|
|
ExtendedPatronAttributes => 1,
|
|
extendedattributes => $attributes
|
|
);
|
|
}
|
|
|
|
$template->param(
|
|
picture => $patron_image,
|
|
housebound_profile => $houseboundprofile,
|
|
visit => $houseboundvisit,
|
|
branch => $branch,
|
|
category => $category,
|
|
messages => \@messages,
|
|
method => $method,
|
|
choosers => $choosers,
|
|
deliverers => $deliverers,
|
|
houseboundview => 'on',
|
|
);
|
|
|
|
output_html_with_http_headers $input, $cookie, $template->output;
|
|
|
|
=head1 AUTHOR
|
|
|
|
Alex Sassmannshausen <alex.sassmannshausen@ptfs-europe.com>
|
|
|
|
=cut
|