5 #script to set up screen for modification of borrower details
6 #written 20/12/99 by chris@katipo.co.nz
9 # Copyright 2000-2002 Katipo Communications
11 # This file is part of Koha.
13 # Koha is free software; you can redistribute it and/or modify it under the
14 # terms of the GNU General Public License as published by the Free Software
15 # Foundation; either version 2 of the License, or (at your option) any later
18 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
19 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
20 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
22 # You should have received a copy of the GNU General Public License along with
23 # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
24 # Suite 330, Boston, MA 02111-1307 USA
37 my ($template, $loggedinuser, $cookie)
38 = get_template_and_user({template_name => "members/memberentry.tmpl",
42 flagsrequired => {borrowers => 1},
46 my $member=$input->param('bornum');
48 $member=NewBorrowerNumber();
50 my $type=$input->param('type') || '';
51 my $modify=$input->param('modify.x');
52 my $delete=$input->param('delete.x');
54 print $input->redirect("/cgi-bin/koha/deletemem.pl?member=$member");
56 } else { # this else goes down the whole script
58 $template->param( header => 'Update Member Details'); # bad templating style
60 $template->param( header => 'Add New Member');
63 my $data=borrdata('',$member);
66 $template->param( updtype => 'I');
68 $template->param( updtype => 'M');
71 my $cardnumber=$data->{'cardnumber'};
72 my $autonumber_members = C4::Context->preference("autoMemberNum") || 0;
73 # Find out whether member numbers should be generated
74 # automatically. Should be either "1" or something else.
75 # Defaults to "0", which is interpreted as "no".
77 # This logic should probably be moved out of the presentation code.
80 if ($cardnumber eq '' && $autonumber_members eq '1') {
81 my $dbh = C4::Context->dbh;
82 my $query="select max(substring(borrowers.cardnumber,2,7)) from borrowers";
83 my $sth=$dbh->prepare($query);
85 my $data=$sth->fetchrow_hashref;
86 $cardnumber=$data->{'max(substring(borrowers.cardnumber,2,7))'};
88 # purpose: generate checksum'd member numbers.
89 # We'll assume we just got the max value of digits 2-8 of member #'s from the database and our job is to
90 # increment that by one, determine the 1st and 9th digits and return the full string.
91 my @weightings = (8,4,6,3,5,2,1);
94 if (! $cardnumber) { # If DB has no values, start at 1000000
95 $cardnumber = 1000000;
97 $cardnumber = $cardnumber + 1; # FIXME - $cardnumber++;
100 while ($i <8) { # step from char 1 to 7.
101 my $temp1 = $weightings[$i]; # read weightings, left to right, 1 char at a time
102 my $temp2 = substr($cardnumber,$i,1); # sequence left to right, 1 char at a time
104 $sum += $temp1*$temp2; # mult each char 1-7 by its corresponding weighting
105 $i++; # increment counter
107 my $rem = ($sum%11); # remainder of sum/11 (eg. 9999999/11, remainder=2)
108 if ($rem == 10) { # if remainder is 10, use X instead
111 $cardnumber="V$cardnumber$rem";
113 $cardnumber=$data->{'cardnumber'};
116 if ($data->{'sex'} eq 'F'){
117 $template->param(female => 1);
120 my @titles = ('Miss', 'Mrs', 'Ms', 'Mr', 'Dr', 'Sir');
121 # FIXME - Assumes English. This ought to be made part of i18n.
125 my $title = shift @titles;
126 $row{'title'} = $title;
127 if ($data->{'title'} eq $title) {
128 $row{'selected'}=' selected';
132 push(@titledata, \%row);
135 my ($categories,$labels)=ethnicitycategories();
136 my $ethnicitycategoriescount=$#{$categories};
138 if ($ethnicitycategoriescount>=0) {
139 $ethcatpopup = CGI::popup_menu(-name=>'ethnicity',
140 -values=>$categories,
141 -default=>$data->{'ethnicity'},
143 $template->param(ethcatpopup => $ethcatpopup); # bad style, has to be fixed
146 ($categories,$labels)=borrowercategories();
147 my $catcodepopup = CGI::popup_menu(-name=>'categorycode',
148 -values=>$categories,
149 -default=>$data->{'categorycode'},
152 my @areas = ('L','F','S','H','K','O','X','Z','V');
153 my %arealabels = ('L' => 'Levin',
158 'O' => 'Out of District',
159 'X' => 'Temporary Visitor',
160 'Z' => 'Interloan Libraries',
166 my $shortcut = shift @areas;
167 $row{'shortcut'} = $shortcut;
168 if ($data->{'area'} eq $shortcut) {
169 $row{'selected'}=' selected';
173 $row{'area'}=$arealabels{$shortcut};
174 push(@areadata, \%row);
178 my @relationships = ('workplace', 'relative','friend', 'neighbour');
180 while (@relationships) {
181 my $relship = shift @relationships;
182 my %row = ('relationship' => $relship);
183 if ($data->{'altrelationship'} eq $relship) {
184 $row{'selected'}=' selected';
188 push(@relshipdata, \%row);
191 # %flags: keys=$data-keys, datas=[formname, HTML-explanation]
192 my %flags = ('gonenoaddress' => ['gna', 'Gone no address'],
193 'lost' => ['lost', 'Lost'],
194 'debarred' => ['debarred', 'Debarred']);
197 foreach (keys(%flags)) {
199 my %row = ('key' => $key,
200 'name' => $flags{$key}[0],
201 'html' => $flags{$key}[1]);
203 $row{'yes'}=' checked';
207 $row{'no'}=' checked';
209 push(@flagdata, \%row);
213 $template->param( modify => 1 );
216 $template->param( startmenumember => join ('', startmenu('member')),
217 endmenumember => join ('', endmenu('member')),
219 firstname => $data->{'firstname'},
220 surname => $data->{'surname'},
221 othernames => $data->{'othernames'},
222 initials => $data->{'initials'},
223 ethcatpopup => $ethcatpopup,
224 catcodepopup => $catcodepopup,
225 streetaddress => $data->{'physstreet'},
226 streetcity => $data->{'streetcity'},
227 city => $data->{'city'},
228 phone => $data->{'phone'},
229 phoneday => $data->{'phoneday'},
230 faxnumber => $data->{'faxnumber'},
231 emailaddress => $data->{'emailaddress'},
232 contactname => $data->{'contactname'},
233 altphone => $data->{'altphone'},
234 altnotes => $data->{'altnotes'},
235 borrowernotes => $data->{'borrowernotes'},
236 flagloop => \@flagdata,
237 relshiploop => \@relshipdata,
238 titleloop => \@titledata,
239 arealoop => \@areadata,
240 dateenrolled => $data->{'dateenrolled'},
241 expiry => $data->{'expiry'},
242 cardnumber => $cardnumber,
243 dateofbirth => $data->{'dateofbirth'});
245 print $input->header(-cookie => $cookie),$template->output;