refining barcode plugin, two new options
authorJoshua Ferraro <jmf@liblime.com>
Sat, 6 Oct 2007 05:23:47 +0000 (00:23 -0500)
committerJoshua Ferraro <jmf@liblime.com>
Sat, 6 Oct 2007 06:39:11 +0000 (01:39 -0500)
Signed-off-by: Chris Cormack <crc@liblime.com>
Signed-off-by: Joshua Ferraro <jmf@liblime.com>
cataloguing/value_builder/barcode.pl
cataloguing/value_builder/usmarc_field_952v.pl [deleted file]
installer/data/en/mandatory/sysprefs.sql

index 8e6ccd4..7ad5769 100755 (executable)
@@ -47,43 +47,62 @@ the 3 scripts are inserted after the <input> in the html code
 
 =cut
 sub plugin_javascript {
-my ($dbh,$record,$tagslib,$field_number,$tabloop) = @_;
-my $function_name= "barcode".(int(rand(100000))+1);
+       my ($dbh,$record,$tagslib,$field_number,$tabloop) = @_;
+       my $function_name= "barcode".(int(rand(100000))+1);
 
-# find today's date
-my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) =
+       # find today's date
+       my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) =
                                                                localtime(time);
-$year +=1900;
-$mon +=1;
-if (length($mon)==1) {
-       $mon = "0".$mon;
-}
-if (length($mday)==1) {
-       $mday = "0".$mday;
-}
-if (length($hour)==1) {
-        $hour = "0".$hour;
-}
-if (length($min)==1) {
+       $year +=1900;
+       $mon +=1;
+       if (length($mon)==1) {
+               $mon = "0".$mon;
+       }
+       if (length($mday)==1) {
+               $mday = "0".$mday;
+       }
+       if (length($hour)==1) {
+            $hour = "0".$hour;
+       }
+       if (length($min)==1) {
         $min = "0".$min;
-}
-if (length($sec)==1) {
+       }
+       if (length($sec)==1) {
         $hour = "0".$sec;
-}
+       }
 
-my $dbh = C4::Context->dbh;
-my $date = "$year";
+       my $dbh = C4::Context->dbh;
+       my $date = "$year";
 
-my $query = "select max(abs(barcode)) from items";
-my $sth=$dbh->prepare($query);
-$sth->execute();
-my $nextnum;
-while (my ($count)= $sth->fetchrow_array) {
-       $nextnum = $count;
-       warn "COUNT".$count;
-}
-$nextnum++;
-my $res  = "
+       my ($tag,$subfield) =  GetMarcFromKohaField("items.barcode");
+
+       my $nextnum;
+       my $query;
+       my $autoBarcodeType = C4::Context->preference("autoBarcode");
+       unless ($autoBarcodeType eq 'OFF' or !$autoBarcodeType) {
+
+       if ($autoBarcodeType eq 'annual') {
+               $query = "select max(cast( substring_index(barcode, '-',-1) as signed)) from items where barcode like ?";
+               my $sth=$dbh->prepare($query);
+               $sth->execute("$year%");
+               while (my ($count)= $sth->fetchrow_array) {
+               $nextnum = $count if $count;
+               }
+               $nextnum++;
+               $nextnum = sprintf("%0*d", "4",$nextnum);
+               $nextnum = "$year-$nextnum";
+       }
+       elsif ($autoBarcodeType eq 'incremental') {
+               # not the best, two catalogers could add the same barcode easily this way :/
+               $query = "select max(abs(barcode)) from items";
+        my $sth=$dbh->prepare($query);
+               $sth->execute();
+               while (my ($count)= $sth->fetchrow_array) {
+                       $nextnum = $count;
+               }
+               $nextnum++;
+       }
+               my $res  = "
 <script type=\"text/javascript\">
 //<![CDATA[
 
@@ -93,7 +112,7 @@ function Blur$function_name(index) {
 
 function Focus$function_name(subfield_managed) {
                for (i=0 ; i<document.f.field_value.length ; i++) {
-                       if (document.f.tag[i].value == '952' && document.f.subfield[i].value == 'p') {
+                       if (document.f.tag[i].value == '$tag' && document.f.subfield[i].value == '$subfield') {
                                if (document.f.field_value[i].value == '') {
                                        document.f.field_value[i].value = '$nextnum';
                                }
@@ -107,7 +126,13 @@ function Clic$function_name(subfield_managed) {
 //]]>
 </script>
 ";
-return ($function_name,$res);
+
+       # don't return a value unless we have the appropriate syspref set
+       return ($function_name,$res);
+       }
+       else {
+               return ($function_name,"<script type=\"text/javascript\">function Focus$function_name() { return 0;}</script>");
+       }
 }
 
 =head1
diff --git a/cataloguing/value_builder/usmarc_field_952v.pl b/cataloguing/value_builder/usmarc_field_952v.pl
deleted file mode 100755 (executable)
index 5ff0931..0000000
+++ /dev/null
@@ -1,99 +0,0 @@
-#!/usr/bin/perl
-
-# $Id$
-
-# 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
-
-require Exporter;
-use C4::Auth;
-use C4::Context;
-use C4::Output;
-use CGI;
-use C4::Search;
-use MARC::Record;
-use C4::Koha;
-
-
-=head1
-
-plugin_parameters : other parameters added when the plugin is called by the dopop function
-
-=cut
-sub plugin_parameters {
-my ($dbh,$record,$tagslib,$i,$tabloop) = @_;
-return "";
-}
-
-=head1
-
-plugin_javascript : the javascript function called when the user enters the subfield.
-contain 3 javascript functions :
-* one called when the field is entered (OnFocus). Named FocusXXX
-* one called when the field is leaved (onBlur). Named BlurXXX
-* one called when the ... link is clicked (<a href="javascript:function">) named ClicXXX
-
-returns :
-* XXX
-* a variable containing the 3 scripts.
-the 3 scripts are inserted after the <input> in the html code
-
-=cut
-sub plugin_javascript {
-my ($dbh,$record,$tagslib,$field_number,$tabloop) = @_;
-my $function_name= "210c".(int(rand(100000))+1);
-
-# find today's date
-my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) =
-                                                               localtime(time);
-$year +=1900;
-$mon +=1;
-my $date = "$year-$mon-$mday";
-my $res  = "
-<script>
-function Blur$function_name(index) {
-//need this?
-}
-
-function Focus$function_name(subfield_managed) {
-       for (i=0 ; i<document.f.field_value.length ; i++) {
-                if (document.f.tag[i].value == '952' && document.f.subfield[i].value == 'v') {
-                        document.f.field_value[i].value = '$date';
-                }
-        }
-return 0;
-}
-
-function Clic$function_name(subfield_managed) {
-}
-</script>
-";
-return ($function_name,$res);
-}
-
-=head1
-
-plugin : the true value_builded. The screen that is open in the popup window.
-
-=cut
-
-sub plugin {
-my ($input) = @_;
-return "";
-}
-
-1;
index a5a8929..5a09a29 100644 (file)
@@ -5,7 +5,7 @@ INSERT INTO `systempreferences` (variable,value,explanation,options,type) VALUES
 INSERT INTO `systempreferences` (variable,value,explanation,options,type) VALUES('AmazonDevKey','','See: aws-portal.amazon.com/gp/aws/developer/registration/index.html','','free');
 INSERT INTO `systempreferences` (variable,value,explanation,options,type) VALUES('AnonSuggestions','0','Set to anonymous borrowernumber to enable Anonymous suggestions',NULL,'free');
 INSERT INTO `systempreferences` (variable,value,explanation,options,type) VALUES('authoritysep','--','Used to separate a list of authorities in a display. Usually --','10','free');
-INSERT INTO `systempreferences` (variable,value,explanation,options,type) VALUES('autoBarcode','1','If ON, barcode is auto-calculated','','YesNo');
+INSERT INTO `systempreferences` (variable,value,explanation,options,type) VALUES('autoBarcode','OFF','Used to autogenerate a barcode: incremental will be of the form 1, 2, 3; annual of the form 2007-0001, 2007-0002','incremental|annual|OFF','Choice');
 INSERT INTO `systempreferences` (variable,value,explanation,options,type) VALUES('AutoLocation','0','If ON, IP authentication is enabled, blocking access to the staff client from unauthorized IP addresses',NULL,'YesNo');
 INSERT INTO `systempreferences` (variable,value,explanation,options,type) VALUES('AutomaticItemReturn','1','If ON, items attempt to return to their home branch when checked in',NULL,'YesNo');
 INSERT INTO `systempreferences` (variable,value,explanation,options,type) VALUES('autoMemberNum','1','If ON, patron number is auto-calculated','','YesNo');