From 179e3c4c9270c013ad411cae843fe842a1af3ec8 Mon Sep 17 00:00:00 2001 From: "G. Richardson" Date: Tue, 17 Jan 2017 08:41:38 +0100 Subject: [PATCH] SL::DB::Part - neue Methode get_stock um den aktuellen Lagerbestand eines Artikels in einem bestimmten Lagerplatz oder in einem bestimmten Lager zu einem bestimmten Stichtag in der Standardeinheit auszulesen. --- SL/DB/Part.pm | 44 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) 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 -- 2.20.1