-  # soweit alles gut. Jetzt noch die wirkliche Lagerbewegung für das Erzeugnis ausführen ...
-  my $transferAssemblySQL = qq|INSERT INTO inventory (parts_id, warehouse_id, bin_id, chargenumber, bestbefore,
-                                                      comment, employee_id, qty, trans_id, trans_type_id, shippingdate)
-                               VALUES (?, ?, ?, ?, ?, ?, (SELECT id FROM employee WHERE login = ?), ?, nextval('id'),
-                               (SELECT id FROM transfer_type WHERE direction = 'in' AND description = 'assembled'),
-                               (select current_date))|;
-  my $sthTransferAssemblySQL   = prepare_query($form, $dbh, $transferAssemblySQL);
-  do_statement($form, $sthTransferAssemblySQL, $transferAssemblySQL, $params{assembly_id}, $params{dst_warehouse_id},
-               $params{dst_bin_id}, $params{chargenumber}, conv_date($params{bestbefore}), $params{comment}, $params{login}, $params{qty});
-  $dbh->commit();
+      # Eine kurze Vorabfrage, um den Lagerplatz, Chargennummer und die Mindesthaltbarkeit zu bestimmen
+      # Offen: Die Summe über alle Lagerplätze wird noch nicht gebildet
+      # Gelöst: Wir haben vorher schon die Abfrage durchgeführt, ob wir fertigen können.
+      # Noch besser gelöst: Wir laufen durch alle benötigten Waren zum Fertigen und geben eine Rückmeldung an den Benutzer was noch fehlt
+      # und lösen den Rest dann so wie bei xplace im Barcode-Programm
+      # S.a. Kommentar im bin/mozilla-Code mb übernimmt und macht das in ordentlich
+
+      my $tempquery = qq|SELECT SUM(qty), bin_id, chargenumber, bestbefore   FROM inventory
+                         WHERE warehouse_id = ? AND parts_id = ?  GROUP BY bin_id, chargenumber, bestbefore having SUM(qty)>0|;
+      my $tempsth   = prepare_execute_query($form, $dbh, $tempquery, $currentPart_WH_ID, $currentPart_ID);
+
+      # Alle Werte zu dem einzelnen Artikel, die wir später auslagern
+      my $tmpPartsQTY = $partsQTY;
+
+      while (my $temphash_ref = $tempsth->fetchrow_hashref()) {
+        my $temppart_bin_id       = $temphash_ref->{bin_id}; # kann man hier den quelllagerplatz beim verbauen angeben?
+        my $temppart_chargenumber = $temphash_ref->{chargenumber};
+        my $temppart_bestbefore   = conv_date($temphash_ref->{bestbefore});
+        my $temppart_qty          = $temphash_ref->{sum};
+
+        if ($tmpPartsQTY > $temppart_qty) {  # wir haben noch mehr waren zum wegbuchen.
+                                             # Wir buchen den kompletten Lagerplatzbestand und zählen die Hilfsvariable runter
+          $tmpPartsQTY = $tmpPartsQTY - $temppart_qty;
+          $temppart_qty = $temppart_qty * -1; # TODO beim analyiseren des sql-trace, war dieser wert positiv,
+                                              # wenn * -1 als berechnung in der parameter-übergabe angegeben wird.
+                                              # Dieser Wert IST und BLEIBT positiv!! Hilfe.
+                                              # Liegt das daran, dass dieser Wert aus einem SQL-Statement stammt?
+          do_statement($form, $sthTransferPartSQL, $transferPartSQL, $currentPart_ID, $currentPart_WH_ID,
+                       $temppart_bin_id, $temppart_chargenumber, $temppart_bestbefore, 'Verbraucht für ' .
+                       $self->get_part_description(parts_id => $params{assembly_id}), $params{login}, $temppart_qty);
+
+          # hier ist noch ein fehler am besten mit definierten erzeugnissen debuggen 02/2009 jb
+          # idee: ausbuch algorithmus mit rekursion lösen und an- und abschaltbar machen
+          # das problem könnte sein, dass strict nicht an war und sth global eine andere zuweisung bekam
+          # auf jeden fall war der internal-server-error nach aktivierung von strict und warnings plus ein paar my-definitionen weg
+        } else { # okay, wir haben weniger oder gleich Waren die wir wegbuchen müssen, wir können also aufhören
+          $tmpPartsQTY *=-1;
+          do_statement($form, $sthTransferPartSQL, $transferPartSQL, $currentPart_ID, $currentPart_WH_ID,
+                       $temppart_bin_id, $temppart_chargenumber, $temppart_bestbefore, 'Verbraucht für ' .
+                       $self->get_part_description(parts_id => $params{assembly_id}), $params{login}, $tmpPartsQTY);
+          last; # beendet die schleife (springt zum letzten element)
+        }
+      }  # ende while SELECT SUM(qty), bin_id, chargenumber, bestbefore   FROM inventory  WHERE warehouse_id
+    } #ende while select parts_id,qty from assembly where id = ?
+
+    if ($schleife_durchlaufen==0){  # falls die schleife nicht durchlaufen wurde, wurden auch
+                                    # keine einzelteile definiert
+        $kannNichtFertigen ="Für dieses Erzeugnis sind keine Einzelteile definiert.
+                             Dementsprechend kann auch nichts hergestellt werden";
+   }
+    # gibt die Fehlermeldung zurück. A.) Keine Teile definiert
+    #                                B.) Artikel und Anzahl der fehlenden Teile/Dienstleistungen
+    die "<br><br>" . $kannNichtFertigen if ($kannNichtFertigen);
+
+    # soweit alles gut. Jetzt noch die wirkliche Lagerbewegung für das Erzeugnis ausführen ...
+    my $transferAssemblySQL = qq|INSERT INTO inventory (parts_id, warehouse_id, bin_id, chargenumber, bestbefore,
+                                                        comment, employee_id, qty, trans_id, trans_type_id, shippingdate)
+                                 VALUES (?, ?, ?, ?, ?, ?, (SELECT id FROM employee WHERE login = ?), ?, nextval('id'),
+                                 (SELECT id FROM transfer_type WHERE direction = 'in' AND description = 'assembled'),
+                                 (select current_date))|;
+    my $sthTransferAssemblySQL   = prepare_query($form, $dbh, $transferAssemblySQL);
+    do_statement($form, $sthTransferAssemblySQL, $transferAssemblySQL, $params{assembly_id}, $params{dst_warehouse_id},
+                 $params{dst_bin_id}, $params{chargenumber}, conv_date($params{bestbefore}), $params{comment}, $params{login}, $params{qty});
+    1;
+  }) or do { return $kannNichtFertigen };