-use C4::Bookseller;
-
-my $input = new CGI;
-
-my ( $template, $borrowernumber, $cookie ) = get_template_and_user(
- {
- template_name => "acqui/finishreceive.tmpl",
- query => $input,
- type => "intranet",
- authnotrequired => 0,
- flagsrequired => { editcatalogue => 1 },
- debug => 1,
- }
-);
-
-my @biblionumber = $input->param('biblionumber');
-my @ordnum = $input->param('ordernumber');
-my $cost = $input->param('invoicetotal');
-my $locacost = $input->param('localtotal');
-my $invoiceno = $input->param('invoice');
-my @replacement = $input->param('actual');
-my @gst = $input->param('gstrate');
-my $freight = $input->param('actualfreight');
-my @freightperitem = $input->param('freight');
-my $supplierid = $input->param('supplierid');
-my @title = $input->param('title');
-my $currencyrate=$input->param('currencyrate');
-my @bookfund = $input->param('bookfund');
-my @discount = $input->param('discount');
-my @quantrec = $input->param('received');
-my $totalreceived=$input->param('totalreceived');
-my $incgst=$input->param('incgst');
-my $ecost;
-my $unitprice;
-my $listprice;
-
-my @supplier=GetBookSeller($supplierid);
-my $count=scalar @quantrec;
-my @additems;
-
- for (my $i=0; $i<$count;$i++){
- $freightperitem[$i]=$freight/$totalreceived unless $freightperitem[$i];
-$listprice=$replacement[$i];
- $replacement[$i]= $replacement[$i]*$currencyrate;
- if ($incgst){
- $ecost= ($replacement[$i]*100/($gst[$i]+100))*(100 - $discount[$i])/100;
- }else{
- $ecost= $replacement[$i]*(100 - $discount[$i])/100;
+use C4::Output;
+use C4::Context;
+use C4::Acquisition;
+use C4::Biblio;
+use C4::Items;
+use C4::Search;
+
+my $input=new CGI;
+my $flagsrequired = { acquisition => 1};
+my ($loggedinuser, $cookie, $sessionID) = checkauth($input, 0, $flagsrequired, 'intranet');
+my $user=$input->remote_user;
+my $biblionumber = $input->param('biblionumber');
+my $biblioitemnumber=$input->param('biblioitemnumber');
+my $ordnum=$input->param('ordnum');
+my $origquantityrec=$input->param('origquantityrec');
+my $quantityrec=$input->param('quantityrec');
+my $quantity=$input->param('quantity');
+my $cost=$input->param('cost');
+my $invoiceno=$input->param('invoice');
+my $datereceived=$input->param('datereceived');
+my $replacement=$input->param('rrp');
+my $gst=$input->param('gst');
+my $freight=$input->param('freight');
+my $supplierid = $input->param('supplierid');
+my @branch=$input->param('homebranch');
+my @barcode=$input->param('barcode');
+my @ccode=$input->param('ccode');
+my @itemtype=$input->param('itemtype');
+my @location=$input->param('location');
+my @enumchron=$input->param('volinf');
+my $cnt=0;
+my $error_url_str;
+
+if ($quantityrec > $origquantityrec ) {
+ foreach my $bc (@barcode) {
+ if ($bc) {
+ my $item_hash = {
+ "items.replacementprice" => $replacement,
+ "items.price" => $cost,
+ "items.booksellerid" => $supplierid,
+ "items.homebranch" => $branch[$cnt],
+ "items.holdingbranch" => $branch[$cnt],
+ "items.barcode" => $barcode[$cnt],
+ "items.ccode" => $ccode[$cnt],
+ "items.itype" => $itemtype[$cnt],
+ "items.location" => $location[$cnt],
+ "items.enumchron" => $enumchron[$cnt], # FIXME : No integration here with serials module.
+ "items.loan" => 0,
+ };
+ $item_hash->{'items.cn_source'} = C4::Context->preference('DefaultClassificationSource') if(C4::Context->preference('DefaultClassificationSource') );
+ # FIXME : cn_sort is populated by Items::_set_derived_columns_for_add , which is never called with AddItemFromMarc . Bug 2403
+ my $itemRecord = TransformKohaToMarc($item_hash);
+ $cnt++;
+ $item_hash = TransformMarcToKoha(undef,$itemRecord,'','items');
+ # FIXME: possible race condition. duplicate barcode check should happen in AddItem, but for now we have to do it here.
+ my %err = CheckItemPreSave($item_hash);
+ if(%err) {
+ for my $err_cnd (keys %err) {
+ $error_url_str .= "&error=" . $err_cnd . "&error_param=" . $err{$err_cnd};
+ }
+ $quantityrec--;
+ } else {
+ AddItemFromMarc($itemRecord,$biblionumber);
+ }
+ }