f89feaefe04379feae6ef4838bdf45310a616666
[srvgit] / Koha / Old / Checkout.pm
1 package Koha::Old::Checkout;
2
3 # This file is part of Koha.
4 #
5 # Koha is free software; you can redistribute it and/or modify it under the
6 # terms of the GNU General Public License as published by the Free Software
7 # Foundation; either version 3 of the License, or (at your option) any later
8 # version.
9 #
10 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
11 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
12 # A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
13 #
14 # You should have received a copy of the GNU General Public License along
15 # with Koha; if not, write to the Free Software Foundation, Inc.,
16 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
17
18 use Modern::Perl;
19
20 use Koha::Database;
21
22 use base qw(Koha::Object);
23
24 =head1 NAME
25
26 Koha::Old:Checkout - Koha checkout object for returned items
27
28 =head1 API
29
30 =head2 Class methods
31
32 =head3 item
33
34 my $item = $checkout->item;
35
36 Return the checked out item
37
38 =cut
39
40 sub item {
41     my ( $self ) = @_;
42     my $item_rs = $self->_result->item;
43     return Koha::Item->_new_from_dbic( $item_rs );
44 }
45
46 =head3 patron
47
48 my $patron = $checkout->patron
49
50 Return the patron for who the checkout has been done
51
52 =cut
53
54 sub patron {
55     my ( $self ) = @_;
56     my $patron_rs = $self->_result->borrower;
57     return unless $patron_rs;
58     return Koha::Patron->_new_from_dbic( $patron_rs );
59 }
60
61 =head3 to_api_mapping
62
63 This method returns the mapping for representing a Koha::Old::Checkout object
64 on the API.
65
66 =cut
67
68 sub to_api_mapping {
69     return {
70         issue_id        => 'checkout_id',
71         borrowernumber  => 'patron_id',
72         itemnumber      => 'item_id',
73         date_due        => 'due_date',
74         branchcode      => 'library_id',
75         returndate      => 'checkin_date',
76         lastreneweddate => 'last_renewed_date',
77         issuedate       => 'checkout_date',
78         notedate        => 'note_date',
79     };
80 }
81
82 =head2 Internal methods
83
84 =head3 _type
85
86 =cut
87
88 sub _type {
89     return 'OldIssue';
90 }
91
92 1;