X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=reporting%2Frep201.php;h=2d5eba8dcf0ce2efdf53ef2b556ef33caa6f9d31;hb=d25e06f889d2c81871fcb6edb42e53e2ea316601;hp=e3180acd9adf90cff0c618822b00547a94f4d93c;hpb=a9d55e1c13cbd6a6305b9322ec8621a06516f9f3;p=fa-stable.git diff --git a/reporting/rep201.php b/reporting/rep201.php index e3180acd..2d5eba8d 100644 --- a/reporting/rep201.php +++ b/reporting/rep201.php @@ -29,17 +29,25 @@ print_supplier_balances(); function get_open_balance($supplier_id, $to) { - $to = date2sql($to); + if ($to) + $to = date2sql($to); + + $sql = "SELECT SUM(IF(t.type = ".ST_SUPPINVOICE." OR (t.type IN (".ST_JOURNAL." , ".ST_BANKDEPOSIT.") AND t.ov_amount>0), + -abs(t.ov_amount + t.ov_gst + t.ov_discount), 0)) AS charges,"; + + $sql .= "SUM(IF(t.type != ".ST_SUPPINVOICE." AND NOT(t.type IN (".ST_JOURNAL." , ".ST_BANKDEPOSIT.") AND t.ov_amount>0), + abs(t.ov_amount + t.ov_gst + t.ov_discount) * -1, 0)) AS credits,"; + + $sql .= "SUM(IF(t.type != ".ST_SUPPINVOICE." AND NOT(t.type IN (".ST_JOURNAL." , ".ST_BANKDEPOSIT.")), t.alloc * -1, t.alloc)) + AS Allocated,"; - $sql = "SELECT - SUM(IF(type IN(".ST_SUPPINVOICE.",".ST_BANKDEPOSIT."), (ov_amount + ov_gst + ov_discount), 0)) AS charges, - SUM(IF(type NOT IN(".ST_SUPPINVOICE.",".ST_BANKDEPOSIT."), (ov_amount + ov_gst + ov_discount), 0)) AS credits, - SUM(alloc) AS Allocated, - SUM(IF(type IN(".ST_SUPPINVOICE.",".ST_BANKDEPOSIT."), (ov_amount + ov_gst + ov_discount - alloc), - (ov_amount + ov_gst + ov_discount + alloc))) AS OutStanding - FROM ".TB_PREF."supp_trans - WHERE tran_date < '$to' - AND supplier_id = '$supplier_id' GROUP BY supplier_id"; + $sql .= "SUM(IF(t.type = ".ST_SUPPINVOICE.", 1, -1) * + (abs(t.ov_amount + t.ov_gst + t.ov_discount) - abs(t.alloc))) AS OutStanding + FROM ".TB_PREF."supp_trans t + WHERE t.supplier_id = ".db_escape($supplier_id); + if ($to) + $sql .= " AND t.tran_date < '$to'"; + $sql .= " GROUP BY supplier_id"; $result = db_query($sql,"No transactions were returned"); return db_fetch($result); @@ -102,7 +110,7 @@ function print_supplier_balances() if ($no_zeros) $nozeros = _('Yes'); else $nozeros = _('No'); - $cols = array(0, 100, 130, 190, 250, 320, 385, 450, 515); + $cols = array(0, 95, 140, 200, 250, 320, 385, 450, 515); $headers = array(_('Trans Type'), _('#'), _('Date'), _('Due Date'), _('Charges'), _('Credits'), _('Allocated'), _('Outstanding')); @@ -191,19 +199,20 @@ function print_supplier_balances() $item[0] = round2(abs($trans['TotalAmount']) * $rate, $dec); $rep->AmountCol(4, 5, $item[0], $dec); $accumulate += $item[0]; + $item[2] = round2($trans['Allocated'] * $rate, $dec); } else { $item[1] = round2(abs($trans['TotalAmount']) * $rate, $dec); $rep->AmountCol(5, 6, $item[1], $dec); $accumulate -= $item[1]; + $item[2] = round2($trans['Allocated'] * $rate, $dec) * -1; } - $item[2] = round2($trans['Allocated'] * $rate, $dec); $rep->AmountCol(6, 7, $item[2], $dec); if ($trans['TotalAmount'] > 0.0) $item[3] = $item[0] - $item[2]; else - $item[3] = ($item[1] - $item[2]) * -1; + $item[3] = -$item[1] - $item[2]; if ($show_balance) $rep->AmountCol(7, 8, $accumulate, $dec); else