Bug 12495 - Include streetnumber in hold alert address
[koha_fer] / opac / opac-renew.pl
index c699b35..ca58f3d 100755 (executable)
@@ -27,8 +27,10 @@ use warnings;
 use CGI;
 use C4::Circulation;
 use C4::Auth;
+use C4::Context;
 use C4::Items;
 use C4::Members;
+use Date::Calc qw( Today Date_to_Days );
 my $query = new CGI;
 
 my ( $template, $borrowernumber, $cookie ) = get_template_and_user(
@@ -46,33 +48,43 @@ my @items          = $query->param('item');
 my $opacrenew = C4::Context->preference("OpacRenewalAllowed");
 
 my $errorstring='';
-for my $itemnumber ( @items ) {
-    my ($status,$error) = CanBookBeRenewed( $borrowernumber, $itemnumber );
-    if ( $status == 1 && $opacrenew == 1 ) {
-       my $renewalbranch = C4::Context->preference('OpacRenewalBranch');
-       my $branchcode;
-       if ($renewalbranch eq 'itemhomebranch'){
-           my $item = GetItem($itemnumber);
-           $branchcode=$item->{'homebranch'};
-       }
-       elsif ($renewalbranch eq 'patronhomebranch'){
-           my $borrower = GetMemberDetails($borrowernumber);
-           $branchcode = $borrower->{'branchcode'};
-       }
-       elsif ($renewalbranch eq 'checkoutbranch'){
-           my $issue = GetOpenIssue($itemnumber);
-           $branchcode = $issue->{'branchcode'};
-       }
-       elsif ($renewalbranch eq 'NULL'){
-           $branchcode='';
-       }
-       else {
-           $branchcode='OPACRenew'
-       }
-        AddRenewal( $borrowernumber, $itemnumber, $branchcode);
-    }
-    else {
-       $errorstring .= $error ."|";
+my $member_details = GetMemberDetails($borrowernumber);
+
+if (   $member_details->{'BlockExpiredPatronOpacActions'}
+    && $member_details->{'is_expired'} )
+{
+    $errorstring = 'card_expired';
+}
+else {
+    for my $itemnumber (@items) {
+        my ( $status, $error ) =
+          CanBookBeRenewed( $borrowernumber, $itemnumber );
+        if ( $status == 1 && $opacrenew == 1 ) {
+            my $renewalbranch = C4::Context->preference('OpacRenewalBranch');
+            my $branchcode;
+            if ( $renewalbranch eq 'itemhomebranch' ) {
+                my $item = GetItem($itemnumber);
+                $branchcode = $item->{'homebranch'};
+            }
+            elsif ( $renewalbranch eq 'patronhomebranch' ) {
+                my $borrower = GetMemberDetails($borrowernumber);
+                $branchcode = $borrower->{'branchcode'};
+            }
+            elsif ( $renewalbranch eq 'checkoutbranch' ) {
+                my $issue = GetOpenIssue($itemnumber);
+                $branchcode = $issue->{'branchcode'};
+            }
+            elsif ( $renewalbranch eq 'NULL' ) {
+                $branchcode = '';
+            }
+            else {
+                $branchcode = 'OPACRenew';
+            }
+            AddRenewal( $borrowernumber, $itemnumber, $branchcode );
+        }
+        else {
+            $errorstring .= $error . "|";
+        }
     }
 }