Bug 15494: Update display of renewal errors
[koha.git] / C4 / SIP / ILS / Transaction / Renew.pm
1 #
2 # Status of a Renew Transaction
3 #
4
5 package C4::SIP::ILS::Transaction::Renew;
6
7 use warnings;
8 use strict;
9
10 use C4::Circulation;
11 use Koha::Patrons;
12 use Koha::DateUtils;
13
14 use parent qw(C4::SIP::ILS::Transaction);
15
16 my %fields = (
17     renewal_ok => 0,
18 );
19
20 sub new {
21     my $class = shift;
22     my $self = $class->SUPER::new();
23
24     foreach my $element (keys %fields) {
25         $self->{_permitted}->{$element} = $fields{$element};
26     }
27
28     @{$self}{keys %fields} = values %fields;    # overkill?
29     return bless $self, $class;
30 }
31
32 sub do_renew_for  {
33     my $self = shift;
34     my $borrower = shift;
35     my ($renewokay,$renewerror) = CanBookBeRenewed($borrower->{borrowernumber},$self->{item}->{itemnumber});
36     if ($renewokay) { # ok so far check charges
37         my ($fee, undef) = GetIssuingCharges($self->{item}->{itemnumber}, $self->{patron}->{borrowernumber});
38         if ($fee > 0) {
39             $self->{sip_fee_type} = '06';
40             $self->{fee_amount} = sprintf '%.2f',$fee;
41             if ($self->{fee_ack} eq 'N') {
42                 $renewokay = 0;
43             }
44         }
45
46     }
47     if ($renewokay){
48         my $issue = AddIssue( $borrower, $self->{item}->id, undef, 0 );
49         $self->{due} = $self->duedatefromissue($issue, $self->{item}->{itemnumber});
50         $self->renewal_ok(1);
51     } else {
52         $renewerror=~s/on_reserve/Item unavailable due to outstanding holds/;
53         $renewerror=~s/too_many/Item has reached maximum renewals/;
54         $renewerror=~s/item_denied_renewal/Item renewal is not allowed/;
55         $self->screen_msg($renewerror);
56         $self->renewal_ok(0);
57     }
58     $self->ok(1);
59     return;
60 }
61
62 sub do_renew {
63     my $self = shift;
64     my $patron = Koha::Patrons->find( { cardnumber => $self->{patron}->id } );
65     return $self->do_renew_for($patron->unblessed);
66 }
67
68 1;