Bug 15531: (followup) Use a quantity of 1, not null, for standing orders
[koha.git] / Koha / Acquisition / Order.pm
blobede8ddf415f23ca6c7cbdaa2c9b25f047a05d68e
1 package Koha::Acquisition::Order;
3 use Modern::Perl;
5 use Koha::Database;
6 use Koha::DateUtils qw( dt_from_string output_pref );
8 use Carp qw( croak );
10 use base qw( Class::Accessor );
12 # TODO fetch order from itemnumber (GetOrderFromItemnnumber)
13 # TODO Move code from GetOrder
14 sub fetch {
15 my ( $class, $params ) = @_;
16 my $ordernumber = $params->{ordernumber};
17 return unless $ordernumber;
18 my $schema = Koha::Database->new->schema;
20 my $order =
21 $schema->resultset('Aqorder')->find( { ordernumber => $ordernumber },
22 { result_class => 'DBIx::Class::ResultClass::HashRefInflator' } );
23 return $class->new( $order );
26 sub insert {
27 my ($self) = @_;
29 my $schema = Koha::Database->new->schema;
30 # Override quantity for standing orders
31 $self->{quantity} = 1 if ( $self->{basketno} && $schema->resultset('Aqbasket')->find( $self->{basketno} )->is_standing );
33 # if these parameters are missing, we can't continue
34 for my $key (qw( basketno quantity biblionumber budget_id )) {
35 croak "Cannot insert order: Mandatory parameter $key is missing"
36 unless $self->{$key};
39 $self->{quantityreceived} ||= 0;
40 $self->{entrydate} ||=
41 output_pref( { dt => dt_from_string, dateformat => 'iso' } );
43 my @columns = $schema->source('Aqorder')->columns;
45 $self->{ordernumber} ||= undef;
47 my $rs = $schema->resultset('Aqorder')->create(
49 map {
50 exists $self->{$_} ? ( $_ => $self->{$_} ) : ()
51 } @columns
54 $self->{ordernumber} = $rs->id;
56 unless ( $self->{parent_ordernumber} ) {
57 $self->{parent_ordernumber} = $self->{ordernumber};
58 $rs->update( { parent_ordernumber => $self->{parent_ordernumber} } );
61 return $self;
64 sub add_item {
65 my ( $self, $itemnumber ) = @_;
66 my $schema = Koha::Database->new->schema;
67 my $rs = $schema->resultset('AqordersItem');
68 $rs->create({ ordernumber => $self->{ordernumber}, itemnumber => $itemnumber });
71 # TODO Move code from ModItemOrder
72 sub update_item {
73 die "not implemented yet";
76 sub del_item {
77 die "not implemented yet";
80 # TODO Move code from ModOrder
81 sub update {
82 die "not implemented yet";
85 # TODO Move code from DelOrder
86 sub delete {
87 die "not implemented yet";
90 # TODO Move code from TransferOrder
91 sub transfer {
92 die "not implemented yet";