Projekt

Allgemein

Profil

« Zurück | Weiter » 

Revision 4b2e8d68

Von Jan Büren vor mehr als 3 Jahren hinzugefügt

  • ID 4b2e8d6817f9240e9a1fe9e95afb73aaa337c3df
  • Vorgänger a258467b
  • Nachfolger 36867b7b

Feature: Auslagern über Rechnung inkl. Seriennummer Lagermenge berücksichtigen

Unterschiede anzeigen:

SL/WH.pm
1135 1135

  
1136 1136
  my $self     = shift;
1137 1137
  my %params   = @_;
1138
  my %bin_qty;
1138 1139

  
1139 1140
  croak t8('Need charge number!') unless $params{chargenumber};
1140 1141

  
1141
  my $inv_item= SL::DB::Manager::Inventory->get_first(where => [chargenumber => $params{chargenumber} ]);
1142
  my $inv_items = SL::DB::Manager::Inventory->get_all(where => [chargenumber => $params{chargenumber} ]);
1142 1143

  
1143
  croak t8("Invalid charge number: #1", $params{chargenumber}) unless (ref $inv_item eq 'SL::DB::Inventory');
1144
  croak t8("Invalid charge number: #1", $params{chargenumber}) unless (ref @{$inv_items}[0] eq 'SL::DB::Inventory');
1145
  # add all qty for one bin and add wh_id
1146
  ($bin_qty{$_->bin_id}{qty}, $bin_qty{$_->bin_id}{wh}) = ($bin_qty{$_->bin_id}{qty} + $_->qty, $_->warehouse_id) for @{ $inv_items };
1147

  
1148
  while (my ($bin, $value) = each (%bin_qty)) {
1149
    if ($value->{qty} > 0) {
1150
      $main::lxdebug->leave_sub();
1151
      return ($value->{qty}, $value->{wh}, $bin, $params{chargenumber});
1152
    }
1153
  }
1144 1154

  
1145 1155
  $main::lxdebug->leave_sub();
1146
  return ($inv_item->warehouse_id, $inv_item->bin_id, $inv_item->chargenumber);
1156
  return undef;
1147 1157
}
1148 1158
1;
1149 1159

  
......
1301 1311

  
1302 1312
=head2 get_wh_and_bin_for_charge C<$params{chargenumber}>
1303 1313

  
1304
Gets the first inventory entry with the mandatory chargenumber: C<$params{chargenumber}>.
1314
Gets the current qty from the inventory entries with the mandatory chargenumber: C<$params{chargenumber}>.
1305 1315
Croaks if the chargenumber is missing or no entry currently exists.
1306
From the found inventory entry the following values and in this order are returned:
1307
C<warehouse_id>, C<bin_id>, C<chargenumber>.
1316
If there is one bin and warehouse with a positive qty, this fields are returned:
1317
C<qty> C<warehouse_id>, C<bin_id>, C<chargenumber>.
1318
Otherwise returns undef.
1308 1319

  
1309 1320

  
1310 1321
=head3 Prerequisites

Auch abrufbar als: Unified diff