From ecc1e94f35491ba392aa3bfd17118c55fa14e55b Mon Sep 17 00:00:00 2001 From: Srdjan Jankovic Date: Wed, 8 Feb 2012 15:12:05 +1300 Subject: [PATCH] bug_7458: A call number plugin Signed-off-by: Melia Meggs A library using an inhouse callnumbering system wants to be able to generate the next available call number not already in use. This custom call number plugin returns the next callnumber not already in use once a correct prefix has been entered. The prefixes are four to six letters, space, then one or two numbers. --- cataloguing/value_builder/callnumber-KU.pl | 135 +++++++++++++++++++++ 1 file changed, 135 insertions(+) create mode 100755 cataloguing/value_builder/callnumber-KU.pl diff --git a/cataloguing/value_builder/callnumber-KU.pl b/cataloguing/value_builder/callnumber-KU.pl new file mode 100755 index 0000000000..e0fa4445ea --- /dev/null +++ b/cataloguing/value_builder/callnumber-KU.pl @@ -0,0 +1,135 @@ +#!/usr/bin/perl + +# Copyright 2012 CatalystIT Ltd +# +# 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; +use C4::Auth; +use CGI; +use C4::Context; + +=head1 DESCRIPTION + +Is used for callnumber computation. + +User must supply a letter prefix (unspecified length) followed by an empty space followed by a "number". +"Number" is 4 character long, and is either a number sequence which is 01 padded. +If input does not conform with this format any processing is omitted. + +Some examples of legal values that trigger auto allocation: + +AAA 0 - returns first unused number AAA 0xxx starting with AAA 0001 +BBB 12 - returns first unused number BBB 12xx starting with BBB 1201 +CCC QW - returns first unused number CCC QWxx starting with CCC QW01 + +=cut + +sub plugin_parameters { +} + +sub plugin_javascript { + my ($dbh,$record,$tagslib,$field_number,$tabloop) = @_; + my $res=" + + "; + + return ($field_number,$res); +} + +my $BASE_CALLNUMBER_RE = qr/^(\w+) (\w+)$/; +sub plugin { + my ($input) = @_; + my $code = $input->param('code'); + + my ($template, $loggedinuser, $cookie) = get_template_and_user({ + template_name => "cataloguing/value_builder/ajax.tmpl", + query => $input, + type => "intranet", + authnotrequired => 0, + flagsrequired => {editcatalogue => '*'}, + debug => 1, + }); + + my $ret; + my ($alpha, $num) = ($code =~ $BASE_CALLNUMBER_RE); + if (defined $num) { # otherwise no point + my ($num_alpha, $num_num) = ($num =~ m/^(\D+)?(\d+)?$/); + $num_alpha ||= ''; + my $pad_len = 4 - length($num); + + if ($pad_len > 0) { + my $num_padded = $num_num; + $num_padded .= "0" x ($pad_len - 1) if $pad_len > 1; + $num_padded .= "1"; + my $padded = "$alpha $num_alpha" . $num_padded; + + my $dbh = C4::Context->dbh; + if ( my $first = $dbh->selectrow_array("SELECT itemcallnumber + FROM items + WHERE itemcallnumber = ?", undef, $padded) ) { + my $icn = $dbh->selectcol_arrayref("SELECT itemcallnumber + FROM items + WHERE itemcallnumber LIKE ? + AND itemcallnumber > ? + ORDER BY itemcallnumber", undef, "$alpha $num_alpha%", $first); + my $next = $num_padded + 1; + my $len = length($num_padded); + foreach (@$icn) { + my ($num1) = ( m/(\d+)$/o ); + if ($num1 > $next) { # a hole in numbering found, stop + last; + } + $next++; + } + $ret = "$alpha $num_alpha" . sprintf("%0${len}d", $next) if length($next) <= $len; # no overflow + } + else { + $ret = $padded; + } + } + } + + $template->param( + return => $ret || $code + ); + output_html_with_http_headers $input, $cookie, $template->output; +} + +1; -- 2.39.5