X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FPart.pm;h=df0169d9c701e479628261bc5ba530dc98b905ec;hb=2d587c41fc70f959556d33b11a10618b35da1b22;hp=21240a64a86fe35a75614c75b1b9747f961b3fbb;hpb=5d711a25d9257690164f396b25f57095776790d6;p=kivitendo-erp.git diff --git a/SL/DB/Part.pm b/SL/DB/Part.pm index 21240a64a..df0169d9c 100644 --- a/SL/DB/Part.pm +++ b/SL/DB/Part.pm @@ -262,6 +262,36 @@ sub get_chart { return $charts->{$taxzone}->{$type}; } +sub get_stock { + my ($self, %params) = @_; + + return undef unless $self->id; + + my $query = 'SELECT SUM(qty) FROM inventory WHERE parts_id = ?'; + my @values = ($self->id); + + if ( $params{bin_id} ) { + $query .= ' AND bin_id = ?'; + push(@values, $params{bin_id}); + } + + if ( $params{warehouse_id} ) { + $query .= ' AND warehouse_id = ?'; + push(@values, $params{warehouse_id}); + } + + if ( $params{shippingdate} ) { + die unless ref($params{shippingdate}) eq 'DateTime'; + $query .= ' AND shippingdate <= ?'; + push(@values, $params{shippingdate}); + } + + my ($stock) = selectrow_query($::form, $self->db->dbh, $query, @values); + + return $stock || 0; # never return undef +}; + + # this is designed to ignore chargenumbers, expiration dates and just give a list of how much <-> where sub get_simple_stock { my ($self, %params) = @_; @@ -519,6 +549,20 @@ Non-recursive lastcost sum of all the assembly item lastcosts. Non-recursive lastcost sum of all the assortment item lastcosts. +=item C + +Fetches stock qty in the default unit for a part. + +bin_id and warehouse_id may be passed as params. If only a bin_id is passed, +the stock qty for that bin is returned. If only a warehouse_id is passed, the +stock qty for all bins in that warehouse is returned. If a shippingdate is +passed the stock qty for that date is returned. + +Examples: + my $qty = $part->get_stock(bin_id => 52); + + $part->get_stock(shippingdate => DateTime->today->add(days => -5)); + =back =head1 AUTHORS