From 028f4f24fb7cf4b5186e6a32d7e701cc56947193 Mon Sep 17 00:00:00 2001 From: Chris Nighswonger Date: Wed, 26 Mar 2008 06:01:34 -0400 Subject: [PATCH] Adding member search to patron card generation feature Signed-off-by: Joshua Ferraro --- .../modules/labels/pcard-members-search.tmpl | 128 ++++++++++++++ labels/label-manager.pl | 7 +- labels/pcard-member-search.pl | 161 ++++++++++++++++++ 3 files changed, 291 insertions(+), 5 deletions(-) create mode 100644 koha-tmpl/intranet-tmpl/prog/en/modules/labels/pcard-members-search.tmpl create mode 100755 labels/pcard-member-search.pl diff --git a/koha-tmpl/intranet-tmpl/prog/en/modules/labels/pcard-members-search.tmpl b/koha-tmpl/intranet-tmpl/prog/en/modules/labels/pcard-members-search.tmpl new file mode 100644 index 0000000000..628fb2978b --- /dev/null +++ b/koha-tmpl/intranet-tmpl/prog/en/modules/labels/pcard-members-search.tmpl @@ -0,0 +1,128 @@ + +Koha › Patrons <!-- TMPL_IF NAME="searching" -->› Search Results<!-- /TMPL_IF --> + + + + + + + + +
+ + + + + + + + + + +

Results to of found for ''

+
,''); return false" />
+
Select AllClear All
+
+ + + + + + + + + + + + + + + + + + + + + + + + +
&orderby=cardnumber">Card&orderby=surname">Name&orderby=borrowers.categorycode">Cat&orderby=branchcode">BranchExpires onNotes
" value="" /> ">,


()',,''); return false" href="/cgi-bin/koha/barcodes/label-manager.pl?borrowernumber=&batch_id=&type=&op=add">Add
+ + + + +No results found + + + + + + +
+ diff --git a/labels/label-manager.pl b/labels/label-manager.pl index 50d81359e5..55e12576b9 100755 --- a/labels/label-manager.pl +++ b/labels/label-manager.pl @@ -7,7 +7,7 @@ use C4::Labels; use C4::Output; use HTML::Template::Pro; #use POSIX qw(ceil); -use Data::Dumper; +#use Data::Dumper; #use Smart::Comments; use vars qw($debug); @@ -110,14 +110,11 @@ elsif ( $op eq 'add_layout' ) { # FIXME: The trinary conditionals here really need to be replaced with a more robust form of db abstraction -fbcit elsif ( $op eq 'add' ) { # add item - warn "op \'add\': batch id = $batch_id, type = $batch_type"; my $query2 = "INSERT INTO $batch_type ( " . (($batch_type eq 'labels') ? 'itemnumber' : 'borrowernumber') . ", batch_id ) values ( ?,? )"; - warn "op \'add\' \$query2=$query2"; my $sth2 = $dbh->prepare($query2); - warn Dumper($itemnumber); for my $inum (@itemnumber) { warn "INSERTing " . (($batch_type eq 'labels') ? 'itemnumber' : 'borrowernumber') . ":$inum for batch $batch_id"; - $sth2->execute($inum, $batch_id); + $sth2->execute($inum, $batch_id); } $sth2->finish; } diff --git a/labels/pcard-member-search.pl b/labels/pcard-member-search.pl new file mode 100755 index 0000000000..d40da1b659 --- /dev/null +++ b/labels/pcard-member-search.pl @@ -0,0 +1,161 @@ +#!/usr/bin/perl + + +#script to do a borrower enquiry/bring up borrower details etc +#written 20/12/99 by chris@katipo.co.nz + + +# Copyright 2000-2002 Katipo Communications +# +# 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., 59 Temple Place, +# Suite 330, Boston, MA 02111-1307 USA + +use strict; +use C4::Auth; +use C4::Output; +use CGI; +use C4::Members; + + +my $input = new CGI; +my $batch_id = $input->param('batch_id'); +my $batch_type = $input->param('type'); + +warn "Passed Batch Id: $batch_id and Type: $batch_type"; + +my $quicksearch = $input->param('quicksearch'); +my $startfrom = $input->param('startfrom')||1; +my $resultsperpage = $input->param('resultsperpage')||C4::Context->preference("PatronsPerPage")||20; + +my ($template, $loggedinuser, $cookie); +if($quicksearch){ + ($template, $loggedinuser, $cookie) + = get_template_and_user({template_name => "members/member-quicksearch-results.tmpl", + query => $input, + type => "intranet", + authnotrequired => 0, + flagsrequired => {borrowers => 1}, + debug => 1, + }); +} else { + ($template, $loggedinuser, $cookie) + = get_template_and_user({template_name => "labels/pcard-members-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 %tmpldata = pathtotemplate ( template => 'member.tmpl', theme => $theme, language => 'fi' ); + # FIXME - Error-checking +#my $template = HTML::Template->new( filename => $tmpldata{'path'}, +# die_on_bad_params => 0, +# loop_context_vars => 1 ); + + +my $member=$input->param('member'); +my $orderby=$input->param('orderby'); +$orderby = "surname,firstname" unless $orderby; +$member =~ s/,//g; #remove any commas from search string +$member =~ s/\*/%/g; + +unless ($member) { + $template->param( batch_id => $batch_id, type => $batch_type,); + output_html_with_http_headers $input, $cookie, $template->output; + exit; +} + +my ($count,$results); + +if(length($member) == 1) +{ + ($count,$results)=SearchMember($member,$orderby,"simple"); +} +else +{ + ($count,$results)=SearchMember($member,$orderby,"advanced"); +} + + +my @resultsdata; +my $toggle = 0; +my $to=($count>($startfrom*$resultsperpage)?$startfrom*$resultsperpage:$count); +for (my $i=($startfrom-1)*$resultsperpage; $i < $to; $i++){ + #find out stats + my ($od,$issue,$fines)=GetMemberIssuesAndFines($results->[$i]{'borrowernumber'}); + + my %row = ( + toggle => $toggle, + count => $i+1, + borrowernumber => $results->[$i]{'borrowernumber'}, + cardnumber => $results->[$i]{'cardnumber'}, + surname => $results->[$i]{'surname'}, + firstname => $results->[$i]{'firstname'}, + categorycode => $results->[$i]{'categorycode'}, + category_type => $results->[$i]{'category_type'}, + category_description => $results->[$i]{'description'}, + address => $results->[$i]{'address'}, + address2 => $results->[$i]{'address2'}, + city => $results->[$i]{'city'}, + zipcode => $results->[$i]{'zipcode'}, + branchcode => $results->[$i]{'branchcode'}, + overdues => $od, + issues => $issue, + odissue => "$od/$issue", + fines => sprintf("%.2f",$fines), + borrowernotes => $results->[$i]{'borrowernotes'}, + sort1 => $results->[$i]{'sort1'}, + sort2 => $results->[$i]{'sort2'}, + dateexpiry => C4::Dates->new($results->[$i]{'dateexpiry'},'iso')->output('syspref'), + ); + if ( $toggle ) { $toggle = 0; } else {$toggle = 1; } + push(@resultsdata, \%row); +} +my $base_url = + 'member.pl?&' + . join( + '&', + map { $_->{term} . '=' . $_->{val} } ( + { term => 'member', val => $member}, + { term => 'orderby', val => $orderby }, + { term => 'resultsperpage', val => $resultsperpage }, + { term => 'type', val => 'intranet' }, + ) + ); + +$template->param( + paginationbar => pagination_bar( + $base_url, int( $count / $resultsperpage ) + 1, + $startfrom, 'startfrom' + ), + startfrom => $startfrom, + from => ($startfrom-1)*$resultsperpage+1, + to => $to, + multipage => ($count != $to || $startfrom!=1), +); + +$template->param( + searching => "1", + member => $member, + numresults => $count, + resultsloop => \@resultsdata, + batch_id => $batch_id, + type => $batch_type, + ); + +output_html_with_http_headers $input, $cookie, $template->output; -- 2.39.5