eefc774e27
- Display a unique item block at once On orderreceive.pl when AcqCreateItem is 'receiving', and on neworderempty.pl when AcqCreateItem is 'ordering' it displays an item block with item infos to fill, and a '+' button. When user clicks on '+', the block is hidden and a list shows up with the items that will be received. User can then edit or delete items in the list and click 'Save' to receive items. - PrepareItemrecordDisplay is now used for cloning block Previous cloning function was duplicating ids, the side effect is that plugins didn't work when several items were displayed. PrepareItemrecordDisplay regenerate the form with new ids - New system preference UniqueItemFields Contains a space-separated list of sql column names (of items table). This syspref is used in two ways: - Values corresponding to fields in syspref are not duplicated when adding a new item (button 'Add') - When saving the form, a check is made on fields in syspref for detecting duplicate (in DB and in the form) Signed-off-by: Katrin Fischer <Katrin.Fischer.83@web.de> All tests done are noted on the bug report. 2012-03-23: Fixed conflict in updatedatabase. Signed-off-by: Paul Poulain <paul.poulain@biblibre.com>
68 lines
2.2 KiB
Perl
Executable file
68 lines
2.2 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# Copyright 2011 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.
|
|
|
|
# This script search in items table if a value for a given field exists.
|
|
# It is used in check_additem (additem.js)
|
|
# Parameters are a list of 'field', which must be field names in items table
|
|
# and a list of 'value', which are the corresponding value to check
|
|
# Eg. @field = ('barcode', 'barcode', 'stocknumber')
|
|
# @value = ('1234', '1235', 'ABC')
|
|
# The script will check if there is already an item with barcode '1234',
|
|
# then an item with barcode '1235', and finally check if there is an item
|
|
# with stocknumber 'ABC'
|
|
# It returns a JSON string which contains what have been found
|
|
# Eg. { barcode: ['1234', '1235'], stocknumber: ['ABC'] }
|
|
|
|
use Modern::Perl;
|
|
|
|
use CGI;
|
|
use JSON;
|
|
use C4::Context;
|
|
use C4::Output;
|
|
use C4::Auth;
|
|
|
|
my $input = new CGI;
|
|
my @field = $input->param('field');
|
|
my @value = $input->param('value');
|
|
|
|
my $dbh = C4::Context->dbh;
|
|
|
|
my $query = "SHOW COLUMNS FROM items";
|
|
my $sth = $dbh->prepare($query);
|
|
$sth->execute;
|
|
my $results = $sth->fetchall_hashref('Field');
|
|
my @columns = keys %$results;
|
|
|
|
my $r = {};
|
|
my $index = 0;
|
|
for my $f ( @field ) {
|
|
if(0 < grep /^$f$/, @columns) {
|
|
$query = "SELECT $f FROM items WHERE $f = ?";
|
|
$sth = $dbh->prepare( $query );
|
|
$sth->execute( $value[$index] );
|
|
my @values = $sth->fetchrow_array;
|
|
|
|
if ( @values ) {
|
|
push @{ $r->{$f} }, $values[0];
|
|
}
|
|
}
|
|
$index++;
|
|
}
|
|
|
|
output_with_http_headers $input, undef, to_json($r), 'json';
|