0)"; $sql_contract = "SELECT a.BillNo, a.PayStage, a.PlanPayAmt, a.PlanPayDate,s.BizPartnerId,c.BizPartnerName, s.PersonId, c.EnterpriseName, c.TaxNo, c.ContactAddress FROM salOrderStagePay AS a LEFT JOIN salSalesOrder AS s on a.BillNo = s.BillNo LEFT JOIN comBusinessPartner AS c ON s.BizPartnerId=c.BizPartnerId WHERE s.ModeId = 'M' AND (s.CurrentState=2 OR s.CurrentState=4) "; if (!(in_array(accountidToDepartId($user_id), array('220', '210')))) { $sql_contract .= "AND (s.PersonId = '$user_id'"; $sql_received .= " AND (PersonId = '$user_id'"; if (count($follower) > 0) { $column_str = "('$user_id'" . ",'"; $column_str .= implode("','", $follower); $column_str .= "')"; $sql_contract .= " OR s.PersonId IN $column_str)"; $sql_received .= " OR PersonId IN $column_str)"; } else { $sql_contract .= ")"; $sql_received .= ")"; }; } $sign60 = array('簽訂後60天', '簽約60日', '簽約後60天', '簽訂後60日內', '訂金支付後60天'); $sign90 = array('簽約後90天', '簽約後90日', '簽訂後90天'); $sign120 = array('簽約後120天', '簽約後120日', '簽訂後120天'); $contract = $conn->query($sql_contract); $received_array = $conn->query($sql_received); // 取收款資料 account_received // $received_data = mysqli_query($link, $sql_received); // foreach ($received_data as $received) { // if ($received['BillNo'] == 'SO20230801001') { // $BillNo = 'M230947'; // } elseif ($received['BillNo'] == 'SO20230801002') { // $BillNo = 'M231067'; // } else { // $BillNo = $received['BillNo']; // }; // if (isset($received_array[$BillNo])) { // $received_array[$BillNo][0] += $received['invoice_amount']; // $received_array[$BillNo][1] += $received['received_amount']; // $received['status'] = (intval($received['status']) < 4) ? intval($received['status']) : 0; // if ($received_array[$BillNo][2] < intval($received['status'])) { // $received_array[$BillNo][2] = intval($received['status']); // } // } else { // $received_array[$BillNo][0] = $received['invoice_amount']; // $received_array[$BillNo][1] = $received['received_amount']; // $received_array[$BillNo][2] = (intval($received['status']) < 4) ? intval($received['status']) : 0; // } // } // 將T8合約收款階段資料依據款別分類放進arraData裡 foreach ($contract as $cont) { if ($cont['BillNo'] == 'SO20230801001') { $BillNo = 'M230947'; } elseif ($cont['BillNo'] == 'SO20230801002') { $BillNo = 'M231067'; } else { $BillNo = $cont['BillNo']; }; $PayStage = $cont['PayStage']; $PlanPayDate = $cont['PlanPayDate']; $PayAmount = $cont['PlanPayAmt']; $partnerName = $cont['BizPartnerName']; $EnterpriseName = $cont['EnterpriseName']; $TaxNo = $cont['TaxNo']; $ContactAddress = $cont['ContactAddress']; //['sign'] 0 款項名稱 1 簽約金額 2 簽約日期 ['second'] 0 二次款名 1 二次款金額 2 收款日期 ['arrive'] 0 貨抵工地款名稱 1 貨抵工地款金額 2 貨抵工地收款日期 ['install'] 0 安裝款名 1 安裝金額 2 安裝收款日期 //['tryrun'] 0 試車款名 1試車金額 2 試車收款日期 ['check'] 0 官檢款名 1 官檢金額 2 官檢收款日期 ['delivery'] 0 交車款名 1 交車金額 2 交車收款日期 ['final'] 0 尾款名 1 尾款金額 2 尾款收款日期 if (!(isset($arrayData[$BillNo]))) { // 0 部門id 1 部門名稱 2 經理名稱 3 營業員id 4 營業員名稱 5 客戶名稱 6 抬頭 7 統編 8 通訊地址 $arrayData[$BillNo] = [0, 0, 0, 0, 0, 0, 0, 0, 0]; $arrayData[$BillNo][5] = $partnerName; $arrayData[$BillNo][6] = $EnterpriseName; $arrayData[$BillNo][7] = $TaxNo; $arrayData[$BillNo][8] = $ContactAddress; $arrayData[$BillNo]['received']= array(); $arrayData[$BillNo]['sign'][1] = $arrayData[$BillNo]['second'][1] = $arrayData[$BillNo]['arrive'][1] = $arrayData[$BillNo]['install'][1] = $arrayData[$BillNo]['tryrun'][1] = $arrayData[$BillNo]['check'][1] = $arrayData[$BillNo]['delivery'][1] = $arrayData[$BillNo]['final'][1] = 0; $arrayData[$BillNo]['facilities'] = ""; $arrayData[$BillNo]['total_facility_num'] = $arrayData[$BillNo]['delivery_num'] = $arrayData[$BillNo]['check_num'] = $arrayData[$BillNo]['tryrun_num'] = $arrayData[$BillNo]['install_num'] = $arrayData[$BillNo]['arrive_num'] = $arrayData[$BillNo]['second_num'] = $arrayData[$BillNo]['receivable_budget'] = 0; } if (stristr($PayStage, '二次款') || stristr($PayStage, '出貨前') || stristr($PayStage, '簽約後') || stristr($PayStage, '簽訂後') || stristr($PayStage, '建照核發時') || stristr($PayStage, '簽約60')) { $arrayData[$BillNo]['second'][0] = $PayStage; $arrayData[$BillNo]['second'][1] = $PayAmount; $arrayData[$BillNo]['second'][2] = $PlanPayDate; if (isset($arrayData[$BillNo]['sign'][2]) && !is_null($arrayData[$BillNo]['sign'][2])) { $signtime = strtotime(strval($arrayData[$BillNo]['sign'][2])); if (in_array($PayStage, $sign60)) { $secondtime = $signtime + (60 * 86400); $secondtime = date('Ymd', $secondtime); $arrayData[$BillNo]['second'][2] = intval($secondtime); } elseif (in_array($PayStage, $sign90)) { $secondtime = $signtime + (90 * 86400); $secondtime = date('Ymd', $secondtime); $arrayData[$BillNo]['second'][2] = intval($secondtime); } elseif (in_array($PayStage, $sign120)) { $secondtime = $signtime + (120 * 86400); $secondtime = date('Ymd', $secondtime); $arrayData[$BillNo]['second'][2] = intval($secondtime); } elseif (stristr($PayStage, '簽訂後30天')) { $secondtime = $signtime + (30 * 86400); $secondtime = date('Ymd', $secondtime); $arrayData[$BillNo]['second'][2] = intval($secondtime); } } } elseif ($PayStage == '簽約' || stristr($PayStage, '簽定') || stristr($PayStage, '簽訂') || stristr($PayStage, '訂金') || stristr($PayStage, '工地動工')) { $arrayData[$BillNo]['sign'][0] = $PayStage; $arrayData[$BillNo]['sign'][1] = $PayAmount; $arrayData[$BillNo]['sign'][2] = $PlanPayDate; } elseif (stristr($PayStage, '試車')) { $arrayData[$BillNo]['tryrun'][0] = $PayStage; $arrayData[$BillNo]['tryrun'][1] = $PayAmount; $arrayData[$BillNo]['tryrun'][2] = $PlanPayDate; } elseif (stristr($PayStage, '安裝') || stristr($PayStage, '貨抵工地且完工')) { $arrayData[$BillNo]['install'][0] = $PayStage; $arrayData[$BillNo]['install'][1] = $PayAmount; $arrayData[$BillNo]['install'][2] = $PlanPayDate; } elseif (stristr($PayStage, '貨抵工地') || stristr($PayStage, '貨底工地')) { $arrayData[$BillNo]['arrive'][0] = $PayStage; $arrayData[$BillNo]['arrive'][1] = $PayAmount; $arrayData[$BillNo]['arrive'][2] = $PlanPayDate; } elseif (stristr($PayStage, '得合格函後6個月') || stristr($PayStage, '核可函取得後6個月') || stristr($PayStage, '交車')) { $arrayData[$BillNo]['delivery'][0] = $PayStage; $arrayData[$BillNo]['delivery'][1] = $PayAmount; $arrayData[$BillNo]['delivery'][2] = $PlanPayDate; } elseif (stristr($PayStage, '合格') || stristr($PayStage, '驗收') || stristr($PayStage, '許可') || stristr($PayStage, '核可')) { $arrayData[$BillNo]['check'][0] = $PayStage; $arrayData[$BillNo]['check'][1] = $PayAmount; $arrayData[$BillNo]['check'][2] = $PlanPayDate; } elseif (stristr($PayStage, '驗收完成')) { $arrayData[$BillNo]['final'][0] = $PayStage; $arrayData[$BillNo]['final'][1] = $PayAmount; $arrayData[$BillNo]['final'][2] = $PlanPayDate; } else { $arrayData[$BillNo]['other'][1] = $PayAmount; $arrayData[$BillNo]['other'][2] = $PlanPayDate; } } $sql = "SELECT tmp2.*, d.name AS depart_name FROM( SELECT a.manager, a2.name as manager_name, a.name, a.department_id, w.salesid, w.contractno, w.facilityno, w.estimated_shipping_date, w.actual_tofactory_date, w.real_arrival_date, w.install_end_date, w.tryrun_end_date, w.official_check_date, w.delivery_date from wipwholestatus AS w left join account AS a ON w.salesid = a.accountid left join account AS a2 ON a2.accountid = a.manager where w.status = '1' AND w.contract_type='A' )AS tmp2 left join ( SELECT DISTINCT department_id, name FROM department ) AS d ON d.department_id = tmp2.department_id"; $wipwhole_array = mysqli_query($link, $sql); foreach ($wipwhole_array as $wip) { if (isset($arrayData[$wip['contractno']])) { $arrayData[$wip['contractno']][0] = $wip['department_id'];; $arrayData[$wip['contractno']][1] = $wip['depart_name']; $arrayData[$wip['contractno']][2] = $wip['manager_name']; $arrayData[$wip['contractno']][3] = $wip['salesid']; $arrayData[$wip['contractno']][4] = $wip['name']; $arrayData[$wip['contractno']][10] = $wip['contractno']; if (isset($arrayData[$wip['contractno']]['second'][0]) && stristr($arrayData[$wip['contractno']]['second'][0], '出貨前30天')) { $estimate_delivery_time = strtotime($wip['estimated_shipping_date']); $secondtime = $estimate_delivery_time - (30 * 86400); $secondtime = date('Ymd', $secondtime); $arrayData[$wip['contractno']]['second'][2] = intval($secondtime); } elseif (isset($arrayData[$wip['contractno']]['second'][0]) && stristr($arrayData[$wip['contractno']]['second'][0], '出貨前90天')) { $estimate_delivery_time = strtotime($wip['estimated_shipping_date']); $secondtime = $estimate_delivery_time - (90 * 86400); $secondtime = date('Ymd', $secondtime); $arrayData[$wip['contractno']]['second'][2] = intval($secondtime); } if ($wip['delivery_date'] != NULL) { $arrayData[$wip['contractno']]['facilities'] .= $wip['facilityno'] . " (" . $wip['delivery_date'] . "已移交)
"; $arrayData[$wip['contractno']]['total_facility_num'] += 1; $arrayData[$wip['contractno']]['delivery_num'] += 1; $arrayData[$wip['contractno']]['check_num'] += 1; $arrayData[$wip['contractno']]['tryrun_num'] += 1; $arrayData[$wip['contractno']]['install_num'] += 1; $arrayData[$wip['contractno']]['arrive_num'] += 1; $arrayData[$wip['contractno']]['second_num'] += 1; } elseif ($wip['official_check_date'] != NULL) { $arrayData[$wip['contractno']]['facilities'] .= $wip['facilityno'] . " (" . $wip['official_check_date'] . "官檢完畢)
"; $arrayData[$wip['contractno']]['total_facility_num'] += 1; $arrayData[$wip['contractno']]['check_num'] += 1; $arrayData[$wip['contractno']]['tryrun_num'] += 1; $arrayData[$wip['contractno']]['install_num'] += 1; $arrayData[$wip['contractno']]['arrive_num'] += 1; $arrayData[$wip['contractno']]['second_num'] += 1; } elseif ($wip['tryrun_end_date'] != NULL) { $arrayData[$wip['contractno']]['facilities'] .= $wip['facilityno'] . " (" . $wip['tryrun_end_date'] . "試車完畢)
"; $arrayData[$wip['contractno']]['total_facility_num'] += 1; $arrayData[$wip['contractno']]['tryrun_num'] += 1; $arrayData[$wip['contractno']]['install_num'] += 1; $arrayData[$wip['contractno']]['arrive_num'] += 1; $arrayData[$wip['contractno']]['second_num'] += 1; } elseif ($wip['install_end_date'] != NULL) { $arrayData[$wip['contractno']]['facilities'] .= $wip['facilityno'] . " (" . $wip['install_end_date'] . "安裝完畢)
"; $arrayData[$wip['contractno']]['total_facility_num'] += 1; $arrayData[$wip['contractno']]['install_num'] += 1; $arrayData[$wip['contractno']]['arrive_num'] += 1; $arrayData[$wip['contractno']]['second_num'] += 1; } elseif ($wip['real_arrival_date'] != NULL) { $arrayData[$wip['contractno']]['facilities'] .= $wip['facilityno'] . " (" . $wip['real_arrival_date'] . "貨抵工地)
"; $arrayData[$wip['contractno']]['total_facility_num'] += 1; $arrayData[$wip['contractno']]['arrive_num'] += 1; $arrayData[$wip['contractno']]['second_num'] += 1; } elseif (($arrayData[$wip['contractno']]['second'] != NULL) && (isset($arrayData[$wip['contractno']]['second'][2])) && ($arrayData[$wip['contractno']]['second'][2] <= date('Ymd'))) { if ($wip['estimated_shipping_date'] != NULL) { $arrayData[$wip['contractno']]['facilities'] .= $wip['facilityno'] . " (" . $wip['estimated_shipping_date'] . "預計出貨日)
"; $arrayData[$wip['contractno']]['total_facility_num'] += 1; $arrayData[$wip['contractno']]['second_num'] += 1; } elseif ($wip['actual_tofactory_date'] != NULL) { $arrayData[$wip['contractno']]['facilities'] .= $wip['facilityno'] . " (" . $wip['actual_tofactory_date'] . "實際到觀音日)
"; $arrayData[$wip['contractno']]['total_facility_num'] += 1; $arrayData[$wip['contractno']]['second_num'] += 1; } else { $arrayData[$wip['contractno']]['facilities'] .= $wip['facilityno'] . " (已達二次款收款條件)
"; $arrayData[$wip['contractno']]['total_facility_num'] += 1; $arrayData[$wip['contractno']]['second_num'] += 1; } } elseif ($wip['estimated_shipping_date'] != NULL) { $arrayData[$wip['contractno']]['facilities'] .= $wip['facilityno'] . " (" . $wip['estimated_shipping_date'] . "預計到港)
"; $arrayData[$wip['contractno']]['total_facility_num'] += 1; } else { $arrayData[$wip['contractno']]['facilities'] .= $wip['facilityno'] . " (預計到港日待確認)
"; $arrayData[$wip['contractno']]['total_facility_num'] += 1; } } } foreach ($arrayData as &$value) { if ($value['total_facility_num'] > 0) { $value['receivable_budget'] = $value['sign'][1] + ($value['second'][1] * ($value['second_num'] / $value['total_facility_num'])) + ($value['arrive'][1] * ($value['arrive_num'] / $value['total_facility_num'])) + ($value['install'][1] * ($value['install_num'] / $value['total_facility_num'])) + ($value['tryrun'][1] * ($value['tryrun_num'] / $value['total_facility_num'])) + ($value['check'][1] * ($value['check_num'] / $value['total_facility_num'])) + (($value['delivery'][1] + $value['final'][1]) * ($value['delivery_num'] / $value['total_facility_num'])); } } // array_push($arrayData[$wip['contractno']]['received'], ['assaaa',123124,'sdrfrqa']); foreach($received_array as $received){ if(isset($arrayData[$received['OrderBillNo']])){ array_push($arrayData[$received['OrderBillNo']]['received'], [$received['BillNo'],$received['WriteOffBizPartnerId'],$received['OrderBillNo'],]); } } $data = json_encode($arrayData); ?>
$value) { ?>
合約號 部門 經理 營業員 客戶名稱 目前應收 作番狀態 操作