Browse Source
- 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>3.8.x
committed by
Paul Poulain
11 changed files with 586 additions and 243 deletions
@ -0,0 +1,68 @@ |
|||
#!/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'; |
@ -0,0 +1,10 @@ |
|||
<script type="text/javascript"> |
|||
//<![CDATA[ |
|||
var MSG_ADDITEM_JS_EDIT = _("Edit"); |
|||
var MSG_ADDITEM_JS_DELETE = _("Delete"); |
|||
var MSG_ADDITEM_JS_CLEAR = _("Clear"); |
|||
var MSG_ADDITEM_JS_CANT_RECEIVE_MORE_ITEMS = _("You can't receive any more items"); |
|||
var MSG_ADDITEM_JS_IS_DUPLICATE = _("is duplicated"); |
|||
var MSG_ADDITEM_JS_ALREADY_EXISTS_IN_DB = _("already exists in database"); |
|||
//]]> |
|||
</script> |
@ -0,0 +1,24 @@ |
|||
<ol> |
|||
[% FOREACH iteminfo IN iteminformation %] |
|||
<li> |
|||
<div class="subfield_line" style="[% iteminfo.hidden %];" id="subfield[% iteminfo.serialid %][% iteminfo.countitems %][% iteminfo.subfield %][% iteminfo.random %]"> |
|||
<label> |
|||
[% iteminfo.subfield %] - |
|||
[% IF ( iteminfo.mandatory ) %] |
|||
<b> |
|||
[% END %] |
|||
[% iteminfo.marc_lib %] |
|||
[% IF ( iteminfo.mandatory ) %] |
|||
*</b> |
|||
[% END %] |
|||
</label> |
|||
[% iteminfo.marc_value %] |
|||
<input type="hidden" name="itemid" value="1" /> |
|||
<input type="hidden" name="kohafield" value="[% iteminfo.kohafield %]" /> |
|||
<input type="hidden" name="tag" value="[% iteminfo.tag %]" /> |
|||
<input type="hidden" name="subfield" value="[% iteminfo.subfield %]" /> |
|||
<input type="hidden" name="mandatory" value="[% iteminfo.mandatory %]" /> |
|||
</div> |
|||
</li> |
|||
[% END %] |
|||
</ol> |
@ -0,0 +1,57 @@ |
|||
#!/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. |
|||
|
|||
=head1 NAME |
|||
|
|||
itemrecorddisplay.pl |
|||
|
|||
=head1 DESCRIPTION |
|||
|
|||
Return a HTML form for Item record modification or creation. |
|||
It uses PrepareItemrecordDisplay |
|||
|
|||
=cut |
|||
|
|||
use strict; |
|||
use warnings; |
|||
|
|||
use CGI; |
|||
use C4::Auth; |
|||
use C4::Output; |
|||
use C4::Items; |
|||
|
|||
my $input = new CGI; |
|||
my ($template, $loggedinuser, $cookie, $flags) = get_template_and_user( { |
|||
template_name => 'services/itemrecorddisplay.tmpl', |
|||
query => $input, |
|||
type => 'intranet', |
|||
authnotrequired => 1, |
|||
} ); |
|||
|
|||
my $biblionumber = $input->param('biblionumber') || ''; |
|||
my $itemnumber = $input->param('itemnumber') || ''; |
|||
my $frameworkcode = $input->param('frameworkcode') || ''; |
|||
|
|||
my $result = PrepareItemrecordDisplay($biblionumber, $itemnumber, undef, $frameworkcode); |
|||
unless($result) { |
|||
$result = PrepareItemrecordDisplay($biblionumber, $itemnumber, undef, ''); |
|||
} |
|||
|
|||
$template->param(%$result); |
|||
|
|||
output_html_with_http_headers $input, $cookie, $template->output; |
Loading…
Reference in new issue