Bug 16011: $VERSION - Remove the $VERSION init
[koha.git] / C4 / SIP / ILS / Transaction / Hold.pm
blobda3ad83da3b81e7381b63c030e28a87df6b373cd
2 # status of a Hold transaction
4 package C4::SIP::ILS::Transaction::Hold;
6 use warnings;
7 use strict;
9 use C4::SIP::ILS::Transaction;
11 use C4::Reserves; # AddReserve
12 use C4::Members; # GetMember
13 use C4::Biblio; # GetBiblioFromItemNumber GetBiblioItemByBiblioNumber
14 use parent qw(C4::SIP::ILS::Transaction);
18 my %fields = (
19 expiration_date => 0,
20 pickup_location => undef,
21 constraint_type => undef,
24 sub new {
25 my $class = shift;
26 my $self = $class->SUPER::new();
27 foreach my $element (keys %fields) {
28 $self->{_permitted}->{$element} = $fields{$element};
30 @{$self}{keys %fields} = values %fields;
31 return bless $self, $class;
34 sub queue_position {
35 my $self = shift;
36 return $self->item->hold_queue_position($self->patron->id);
39 sub do_hold {
40 my $self = shift;
41 unless ( $self->{patron} ) {
42 $self->screen_msg('do_hold called with undefined patron');
43 $self->ok(0);
44 return $self;
46 my $borrower = GetMember( 'cardnumber' => $self->{patron}->id );
47 unless ($borrower) {
48 $self->screen_msg( 'No borrower matches cardnumber "' . $self->{patron}->id . '".' );
49 $self->ok(0);
50 return $self;
52 my $bib = GetBiblioFromItemNumber( undef, $self->{item}->id );
53 unless ($bib) {
54 $self->screen_msg( 'No biblio record matches barcode "' . $self->{item}->id . '".' );
55 $self->ok(0);
56 return $self;
58 my $branch = ( $self->pickup_location || $self->{patron}->branchcode );
59 unless ($branch) {
60 $self->screen_msg('No branch specified (or found w/ patron).');
61 $self->ok(0);
62 return $self;
64 my $bibno = $bib->{biblionumber};
65 AddReserve( $branch, $borrower->{borrowernumber}, $bibno, GetBiblioItemByBiblioNumber($bibno) );
67 # unfortunately no meaningful return value
68 $self->ok(1);
69 return $self;
72 sub drop_hold {
73 my $self = shift;
74 unless ($self->{patron}) {
75 $self->screen_msg('drop_hold called with undefined patron');
76 $self->ok(0);
77 return $self;
79 my $borrower = GetMember( 'cardnumber'=>$self->{patron}->id);
80 unless ($borrower) {
81 $self->screen_msg('No borrower matches cardnumber "' . $self->{patron}->id . '".');
82 $self->ok(0);
83 return $self;
85 my $bib = GetBiblioFromItemNumber(undef, $self->{item}->id);
87 CancelReserve({
88 biblionumber => $bib->{biblionumber},
89 itemnumber => $self->{item}->id,
90 borrowernumber => $borrower->{borrowernumber}
91 });
93 $self->ok(1);
94 return $self;
97 sub change_hold {
98 my $self = shift;
99 unless ($self->{patron}) {
100 $self->screen_msg('change_hold called with undefined patron');
101 $self->ok(0);
102 return $self;
104 my $borrower = GetMember( 'cardnumber'=>$self->{patron}->id);
105 unless ($borrower) {
106 $self->screen_msg('No borrower matches cardnumber "' . $self->{patron}->id . '".');
107 $self->ok(0);
108 return $self;
110 my $bib = GetBiblioFromItemNumber(undef, $self->{item}->id);
111 unless ($bib) {
112 $self->screen_msg('No biblio record matches barcode "' . $self->{item}->id . '".');
113 $self->ok(0);
114 return $self;
116 my $branch = ($self->pickup_location || $self->{patron}->branchcode);
117 unless ($branch) {
118 $self->screen_msg('No branch specified (or found w/ patron).');
119 $self->ok(0);
120 return $self;
122 my $bibno = $bib->{biblionumber};
123 ModReserve({ biblionumber => $bibno, borrowernumber => $borrower->{borrowernumber}, branchcode => $branch });
125 $self->ok(1);
126 return $self;
130 __END__