Bug 18501: wip - need to know it has been refunded
authorJonathan Druart <jonathan.druart@bugs.koha-community.org>
Fri, 14 Aug 2020 07:56:41 +0000 (09:56 +0200)
committerJonathan Druart <jonathan.druart@bugs.koha-community.org>
Thu, 20 Aug 2020 10:31:59 +0000 (12:31 +0200)
Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>

Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>

Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>

C4/Circulation.pm

index dfdbb1a..fcd0cee 100644 (file)
@@ -2012,8 +2012,18 @@ sub AddReturn {
         $item->holdingbranch($branch)->store;
     }
 
+    my $item_was_lost = $item->itemlost;
     my $leave_item_lost = C4::Context->preference("BlockReturnOfLostItems") ? 1 : 0;
-    ModDateLastSeen( $item->itemnumber, $leave_item_lost );
+    ModDateLastSeen( $item->itemnumber, $leave_item_lost ); # will unset itemlost if needed
+
+    # fix up the accounts.....
+    if ( $item_was_lost ) {
+        $messages->{'WasLost'} = 1;
+        unless ( C4::Context->preference("BlockReturnOfLostItems") ) {
+            #my $refunded = Koha::Account::Lines->search{(itemnumber => $item->itemnumber, type => 'LOST_FOUND', # FIXME which other parameters to know it has been refunded?
+            $messages->{'LostItemFeeRefunded'} = 1;
+        }
+    }
 
     # check if we have a transfer for this document
     my ($datesent,$frombranch,$tobranch) = GetTransfers( $item->itemnumber );
@@ -2035,14 +2045,6 @@ sub AddReturn {
         }
     }
 
-    # fix up the accounts.....
-    if ( $item->itemlost ) {
-        $messages->{'WasLost'} = 1;
-        unless ( C4::Context->preference("BlockReturnOfLostItems") ) {
-            $messages->{'LostItemFeeRefunded'} = $refunded;
-        }
-    }
-
     # fix up the overdues in accounts...
     if ($borrowernumber) {
         my $fix = _FixOverduesOnReturn( $borrowernumber, $item->itemnumber, $exemptfine, 'RETURNED' );