Koha/admin/aqbudget_owner_search.pl
Srdjan Jankovic 18b8991cf1 bug_6253: Unified member Search()
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>
2011-10-19 16:23:02 +13:00

114 lines
3.7 KiB
Perl
Executable file

#!/usr/bin/perl
# script to find a guarantor
# Copyright 2008-2009 BibLibre SARL
#
# 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 $dbh = C4::Context->dbh;
my ( $template, $loggedinuser, $cookie, $staff_flags ) = get_template_and_user(
{ template_name => "admin/aqbudget_owner_search.tmpl",
query => $input,
type => "intranet",
authnotrequired => 0,
flagsrequired => { acquisition => 'budget_modify' },
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 $op = $input->param('op');
$template->param( $op || else => 1, );
$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 ( $count, $count2, $results );
my @resultsdata;
my $toggle = 0;
if ( $member ) {
my $results= Search($member,"surname");
foreach my $res (@$results) {
my $perms = haspermission( $res->{'userid'} );
my $subperms = get_user_subpermissions ($res->{'userid'} );
# if the member has 'acqui' permission set, then display to table.
if ( $perms->{superlibrarian} == 1 ||
$perms->{acquisition} == 1 ||
$subperms->{acquisition}->{'budget_manage'} ||
$subperms->{acquisition}->{'budget_modify'} ||
$subperms->{acquisition}->{'budget_add_del'} ) {
$count2++;
#find out stats
# my ( $od, $issue, $fines ) = GetMemberIssuesAndFines( $res->{'borrowerid'} );
#This looks unused and very unuseful
my $guarantorinfo = uc( $res->{'surname'} ) . " , " . ucfirst( $res->{'firstname'} );
my $budget_owner_name = $res->{'firstname'} . ' ' . $res->{'surname'}, my $budget_owner_id = $res->{'borrowernumber'};
my %row = (
borrowernumber => $res->{'borrowernumber'},
cardnumber => $res->{'cardnumber'},
surname => $res->{'surname'},
firstname => $res->{'firstname'},
categorycode => $res->{'categorycode'},
branchcode => $res->{'branchcode'},
guarantorinfo => $guarantorinfo,
budget_owner_id => $budget_owner_id,
budget_owner_name => $budget_owner_name,
# odissue => "$od/$issue",
# fines => $fines,
# borrowernotes => $res->{'borrowernotes'}
);
push( @resultsdata, \%row );
}
}
}
$template->param(
member => $member,
numres => $count2,
resultsloop => \@resultsdata
);
output_html_with_http_headers $input, $cookie, $template->output;