18b8991cf1
Removed SearchMembers() and replaced with more generic Search() Amended Search() to try cardnumber first Replaced SearchMembers() calls with Search() Replaced SELECT with Search() where appropriate C4::SQLHelper: - added support for '' key for search filter. - when passing an array to filter, join with OR (rather than AND) - added support for key => [val1, val2] in filter - did not document - there was no input documentation to start with, and SQLHelper should be replaced with something better anyway Signed-off-by: Liz Rea <lrea@nekls.org> (again - testing merge issue) The functionality of the patch seems to be maintained with Biblibre's changes. I tested the following: Extended attribute searching: works 3 part name searching: works 2 part name searching: works 1 part name searching: works From: mainpage.pl members-home.pl Patron search limited by branch: Works Patron search limited by patron category: works Ordering by cardnumber instead of surname: works The "Check Out" field in the masthead. Circ Autocomplete is not reliably functional at this time, but the problem appears to predate this patch. Signed-off-by: Ian Walls <ian.walls@bywatersolutions.com> Signed-off-by: Chris Cormack <chrisc@catalyst.net.nz>
110 lines
3.3 KiB
Perl
Executable file
110 lines
3.3 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
|
|
# script to find a guarantor
|
|
|
|
# Copyright 2006 OUEST PROVENCE
|
|
#
|
|
# 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 2 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.
|
|
|
|
use strict;
|
|
#use warnings; FIXME - Bug 2505
|
|
use C4::Auth;
|
|
use C4::Output;
|
|
use CGI;
|
|
use C4::Dates qw/format_date/;
|
|
use C4::Members;
|
|
|
|
my $input = new CGI;
|
|
my ($template, $loggedinuser, $cookie);
|
|
|
|
($template, $loggedinuser, $cookie)
|
|
= get_template_and_user({template_name => "members/guarantor_search.tmpl",
|
|
query => $input,
|
|
type => "intranet",
|
|
authnotrequired => 0,
|
|
flagsrequired => {borrowers => 1},
|
|
debug => 1,
|
|
});
|
|
# }
|
|
my $theme = $input->param('theme') || "default";
|
|
# only used if allowthemeoverride is set
|
|
|
|
|
|
my $member=$input->param('member');
|
|
my $orderby=$input->param('orderby');
|
|
my $category_type=$input->param('category_type');
|
|
$orderby = "surname,firstname" unless $orderby;
|
|
$member =~ s/,//g; #remove any commas from search string
|
|
$member =~ s/\*/%/g;
|
|
if ($member eq ''){
|
|
$template->param(results=>0);
|
|
}else{
|
|
$template->param(results=>1);
|
|
}
|
|
|
|
my $search_category = 'A';
|
|
if ($category_type eq 'P'){
|
|
$search_category = 'I';
|
|
}
|
|
|
|
my ($count,$results);
|
|
my @resultsdata;
|
|
my $background = 0;
|
|
|
|
if ($member ne ''){
|
|
$results = Search({''=>$member, category_type=>$search_category},$orderby);
|
|
$count = $results ? @$results : 0;
|
|
|
|
for (my $i=0; $i < $count; $i++){
|
|
#find out stats
|
|
my ($od,$issue,$fines)=GetMemberIssuesAndFines($results->[$i]{'borrowerid'});
|
|
my $guarantorinfo=uc($results->[$i]{'surname'})." , ".ucfirst($results->[$i]{'firstname'});
|
|
my %row = (
|
|
background => $background,
|
|
count => $i+1,
|
|
borrowernumber => $results->[$i]{'borrowernumber'},
|
|
cardnumber => $results->[$i]{'cardnumber'},
|
|
surname => $results->[$i]{'surname'},
|
|
firstname => $results->[$i]{'firstname'},
|
|
categorycode => $results->[$i]{'categorycode'},
|
|
streetnumber => $results->[$i]{'streetnumber'},
|
|
address => $results->[$i]{'address'},
|
|
address2 => $results->[$i]{'address2'},
|
|
city => $results->[$i]{'city'},
|
|
state => $results->[$i]{'state'},
|
|
zipcode => $results->[$i]{'zipcode'},
|
|
country => $results->[$i]{'country'},
|
|
branchcode => $results->[$i]{'branchcode'},
|
|
guarantorinfo =>$guarantorinfo,
|
|
#op
|
|
dateofbirth =>format_date($results->[$i]{'dateofbirth'}),
|
|
#fi op
|
|
|
|
odissue => "$od/$issue",
|
|
fines => $fines,
|
|
borrowernotes => $results->[$i]{'borrowernotes'});
|
|
if ( $background ) { $background = 0; } else {$background = 1; }
|
|
push(@resultsdata, \%row);
|
|
}
|
|
}
|
|
$template->param(
|
|
member => $member,
|
|
numresults => $count,
|
|
category_type => $category_type,
|
|
resultsloop => \@resultsdata );
|
|
|
|
output_html_with_http_headers $input, $cookie, $template->output;
|