1 package Koha::Acquisition::Order;
3 # This file is part of Koha.
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
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.
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.
22 use Koha::Acquisition::Baskets;
23 use Koha::Acquisition::Funds;
25 use Koha::DateUtils qw( dt_from_string output_pref );
27 use base qw(Koha::Object);
31 Koha::Acquisition::Order Object class
39 Overloaded I<new> method for backwards compatibility.
44 my ( $self, $params ) = @_;
46 my $schema = Koha::Database->new->schema;
47 my @columns = $schema->source('Aqorder')->columns;
50 { map { exists $params->{$_} ? ( $_ => $params->{$_} ) : () } @columns };
51 return $self->SUPER::new($values);
56 Overloaded I<store> method for backwards compatibility.
63 my $schema = Koha::Database->new->schema;
64 # Override quantity for standing orders
65 $self->quantity(1) if ( $self->basketno && $schema->resultset('Aqbasket')->find( $self->basketno )->is_standing );
67 # if these parameters are missing, we can't continue
68 for my $key (qw( basketno quantity biblionumber budget_id )) {
69 croak "Cannot insert order: Mandatory parameter $key is missing"
73 if (not defined $self->{created_by}) {
74 my $userenv = C4::Context->userenv;
76 $self->created_by($userenv->{number});
80 $self->quantityreceived(0) unless $self->quantityreceived;
81 $self->entrydate(dt_from_string) unless $self->entrydate;
83 $self->ordernumber(undef) unless $self->ordernumber;
84 $self = $self->SUPER::store( $self );
86 unless ( $self->parent_ordernumber ) {
87 $self->set( { parent_ordernumber => $self->ordernumber } );
88 $self = $self->SUPER::store( $self );
96 $order->add_item( $itemnumber );
98 Link an item to this order.
103 my ( $self, $itemnumber ) = @_;
105 my $schema = Koha::Database->new->schema;
106 my $rs = $schema->resultset('AqordersItem');
107 $rs->create({ ordernumber => $self->ordernumber, itemnumber => $itemnumber });
112 my $basket = Koha::Acquisition::Orders->find( $id )->basket;
114 Returns the basket associated to the order.
120 my $basket_rs = $self->_result->basketno;
121 return Koha::Acquisition::Basket->_new_from_dbic( $basket_rs );
126 my $fund = $order->fund
128 Returns the fund (aqbudgets) associated to the order.
134 my $fund_rs = $self->_result->budget;
135 return Koha::Acquisition::Fund->_new_from_dbic( $fund_rs );
138 =head2 Internal methods