X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FIC.pm;h=a2703b64f656fc8e93e6326afbb6eba81f41eae1;hb=d0810c4289d895acfb8cf477125c6796c51945e3;hp=3141b805ee622e5aa68d97fdd953faf2566fe5f0;hpb=52fa2d470e9d67be6efd42296b7a4a6d84563308;p=kivitendo-erp.git diff --git a/SL/IC.pm b/SL/IC.pm index 3141b805e..a2703b64f 100644 --- a/SL/IC.pm +++ b/SL/IC.pm @@ -34,6 +34,7 @@ package IC; use Data::Dumper; +use SL::DBUtils; sub get_part { $main::lxdebug->enter_sub(); @@ -53,9 +54,10 @@ sub get_part { LEFT JOIN chart c2 ON (p.income_accno_id = c2.id) LEFT JOIN chart c3 ON (p.expense_accno_id = c3.id) LEFT JOIN partsgroup pg ON (p.partsgroup_id = pg.id) - WHERE p.id = $form->{id}|; + WHERE p.id = ? |; + my @vars = ($form->{id}); my $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); + $sth->execute(@vars) || $form->dberror("$query (" . join(', ', @vars) . ")"); my $ref = $sth->fetchrow_hashref(NAME_lc); # copy to $form variables @@ -78,12 +80,12 @@ sub get_part { FROM parts p JOIN assembly a ON (a.parts_id = p.id) LEFT JOIN partsgroup pg ON (p.partsgroup_id = pg.id) - WHERE a.id = $form->{id} - ORDER BY $oid{$myconfig->{dbdriver}}|; - + WHERE a.id = ? + ORDER BY ?|; + @vars = ($form->{id}, $oid{$myconfig->{dbdriver}}); $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); - + $sth->execute(@vars) || $form->dberror("$query (" . join(', ', @vars) . ")"); + $form->{assembly_rows} = 0; while (my $ref = $sth->fetchrow_hashref(NAME_lc)) { $form->{assembly_rows}++; @@ -105,11 +107,12 @@ sub get_part { # get prices $query = qq|SELECT p.parts_id, p.pricegroup_id, p.price, (SELECT pg.pricegroup FROM pricegroup pg WHERE pg.id=p.pricegroup_id) AS pricegroup FROM prices p - WHERE parts_id = $form->{id} + WHERE parts_id = ? ORDER by pricegroup|; + @vars = ($form->{id}); $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); + $sth->execute(@vars) || $form->dberror("$query (" . join(', ', @vars) . ")"); @pricegroups = (); @pricegroups_not_used = (); @@ -177,10 +180,10 @@ sub get_part { # get makes if ($form->{makemodel}) { $query = qq|SELECT m.make, m.model FROM makemodel m - WHERE m.parts_id = $form->{id}|; - + WHERE m.parts_id = ?|; + @vars = ($form->{id}); $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); + $sth->execute(@vars) || $form->dberror("$query (" . join(', ', @vars) . ")"); my $i = 1; while (($form->{"make_$i"}, $form->{"model_$i"}) = $sth->fetchrow_array) @@ -195,9 +198,10 @@ sub get_part { # get translations $form->{language_values} = ""; - $query = qq|SELECT language_id, translation FROM translation WHERE parts_id = $form->{id}|; + $query = qq|SELECT language_id, translation FROM translation WHERE parts_id = ?|; + @vars = ($form->{id}); $trq = $dbh->prepare($query); - $trq->execute || $form->dberror($query); + $trq->execute(@vars) || $form->dberror("$query (" . join(', ', @vars) . ")"); while ($tr = $trq->fetchrow_hashref(NAME_lc)) { $form->{language_values} .= "---+++---".$tr->{language_id}."--++--".$tr->{translation}; } @@ -310,7 +314,8 @@ sub retrieve_buchungsgruppen { # get buchungsgruppen $query = qq|SELECT id, description - FROM buchungsgruppen|; + FROM buchungsgruppen + ORDER BY sortkey|; $sth = $dbh->prepare($query); $sth->execute || $form->dberror($query); @@ -327,16 +332,6 @@ sub save { $main::lxdebug->enter_sub(); my ($self, $myconfig, $form) = @_; - $form->{IC_expense} = "1000"; - $form->{IC_income} = "2000"; - - if ($form->{item} ne 'service') { - $form->{IC} = $form->{IC_expense}; - } - - ($form->{inventory_accno}) = split(/--/, $form->{IC}); - ($form->{expense_accno}) = split(/--/, $form->{IC_expense}); - ($form->{income_accno}) = split(/--/, $form->{IC_income}); # connect to database, turn off AutoCommit my $dbh = $form->dbconnect_noauto($myconfig); @@ -458,10 +453,10 @@ sub save { $form->{orphaned} = 1; $form->{onhand} = $form->{stock} if $form->{item} eq 'assembly'; - if ($form->{partnumber} eq "" && $form->{inventory_accno} eq "") { + if ($form->{partnumber} eq "" && $form->{"item"} eq "service") { $form->{partnumber} = $form->update_defaults($myconfig, "servicenumber"); } - if ($form->{partnumber} eq "" && $form->{inventory_accno} ne "") { + if ($form->{partnumber} eq "" && $form->{"item"} ne "service") { $form->{partnumber} = $form->update_defaults($myconfig, "articlenumber"); } @@ -472,6 +467,30 @@ sub save { ($partsgroup, $partsgroup_id) = split /--/, $form->{partsgroup}; } + my ($subq_inventory, $subq_expense, $subq_income); + if ($form->{"item"} eq "part") { + $subq_inventory = + qq|(SELECT bg.inventory_accno_id | . + qq| FROM buchungsgruppen bg | . + qq| WHERE bg.id = | . $dbh->quote($form->{"buchungsgruppen_id"}) . qq|)|; + } else { + $subq_inventory = "NULL"; + } + + if ($form->{"item"} ne "assembly") { + $subq_expense = + qq|(SELECT bg.expense_accno_id_0 | . + qq| FROM buchungsgruppen bg | . + qq| WHERE bg.id = | . $dbh->quote($form->{"buchungsgruppen_id"}) . qq|)|; + } else { + $subq_expense = "NULL"; + } + + $subq_income = + qq|(SELECT bg.income_accno_id_0 | . + qq| FROM buchungsgruppen bg | . + qq| WHERE bg.id = | . $dbh->quote($form->{"buchungsgruppen_id"}) . qq|)|; + $query = qq|UPDATE parts SET partnumber = '$form->{partnumber}', description = '$form->{description}', @@ -490,12 +509,9 @@ sub save { bin = '$form->{bin}', buchungsgruppen_id = '$form->{buchungsgruppen_id}', payment_id = '$form->{payment_id}', - inventory_accno_id = (SELECT c.id FROM chart c - WHERE c.accno = '$form->{inventory_accno}'), - income_accno_id = (SELECT c.id FROM chart c - WHERE c.accno = '$form->{income_accno}'), - expense_accno_id = (SELECT c.id FROM chart c - WHERE c.accno = '$form->{expense_accno}'), + inventory_accno_id = $subq_inventory, + income_accno_id = $subq_income, + expense_accno_id = $subq_expense, obsolete = '$form->{obsolete}', image = '$form->{image}', drawing = '$form->{drawing}', @@ -1133,7 +1149,7 @@ sub all_parts { p.priceupdate, p.image, p.drawing, p.microfiche, pg.partsgroup, '' AS invnumber, o.ordnumber, o.quonumber, oi.trans_id, - ct.name|; + ct.name, NULL AS deliverydate|; if ($form->{ordered}) { $query .= qq|$union @@ -1160,7 +1176,7 @@ sub all_parts { p.priceupdate, p.image, p.drawing, p.microfiche, pg.partsgroup, '' AS invnumber, o.ordnumber, o.quonumber, oi.trans_id, - ct.name|; + ct.name, NULL AS deliverydate|; $query .= qq|$union SELECT $flds, 'oe' AS module, 'purchase_order' AS type, @@ -1198,7 +1214,7 @@ sub all_parts { p.priceupdate, p.image, p.drawing, p.microfiche, pg.partsgroup, '' AS invnumber, o.ordnumber, o.quonumber, oi.trans_id, - ct.name|; + ct.name, NULL AS deliverydate|; if ($form->{quoted}) { $query .= qq|$union @@ -1225,7 +1241,7 @@ sub all_parts { p.priceupdate, p.image, p.drawing, p.microfiche, pg.partsgroup, '' AS invnumber, o.ordnumber, o.quonumber, oi.trans_id, - ct.name|; + ct.name, NULL AS deliverydate|; $query .= qq|$union SELECT $flds, 'oe' AS module, 'request_quotation' AS type, @@ -1516,7 +1532,7 @@ sub create_links { # get payment terms $query = qq|SELECT id, description FROM payment_terms - ORDER BY 1|; + ORDER BY sortkey|; $sth = $dbh->prepare($query); $sth->execute || $form->dberror($query); @@ -1730,7 +1746,7 @@ sub retrieve_languages { } sub follow_account_chain { - $main::lxdebug->enter_sub(); + $main::lxdebug->enter_sub(2); my ($self, $form, $dbh, $transdate, $accno_id, $accno) = @_; @@ -1756,13 +1772,13 @@ sub follow_account_chain { push(@visited_accno_ids, $accno_id); } - $main::lxdebug->leave_sub(); + $main::lxdebug->leave_sub(2); return ($accno_id, $accno); } sub retrieve_accounts { - $main::lxdebug->enter_sub(); + $main::lxdebug->enter_sub(2); my ($self, $myconfig, $form, $parts_id, $index, $copy_accnos) = @_; @@ -1815,7 +1831,7 @@ sub retrieve_accounts { if (!$ref) { $dbh->disconnect(); - return $main::lxdebug->leave_sub(); + return $main::lxdebug->leave_sub(2); } $ref->{"inventory_accno_id"} = undef unless ($ref->{"is_part"}); @@ -1842,16 +1858,17 @@ sub retrieve_accounts { "WHERE t.id IN " . " (SELECT tk.tax_id " . " FROM taxkeys tk " . - " WHERE tk.chart_id = $accno_id AND startdate <= $transdate " . + " WHERE tk.chart_id = ? AND startdate <= " . quote_db_date($transdate) . " ORDER BY startdate DESC LIMIT 1) "; + @vars = ($accno_id); $sth = $dbh->prepare($query); - $sth->execute() || $form->dberror($query); + $sth->execute(@vars) || $form->dberror("$query (" . join(', ', @vars) . ")"); $ref = $sth->fetchrow_hashref(); $sth->finish(); $dbh->disconnect(); unless ($ref) { - $main::lxdebug->leave_sub(); + $main::lxdebug->leave_sub(2); return; } @@ -1868,6 +1885,7 @@ sub retrieve_accounts { # " || taxaccounts_$index " . $form->{"taxaccounts_$index"} . # " || taxaccounts " . $form->{"taxaccounts"}); - $main::lxdebug->leave_sub(); + $main::lxdebug->leave_sub(2); } + 1;