|
|
|
@ -87,24 +87,33 @@ class CompanyStatementSetController extends Controller {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* TODO:渠道费未进行计算
|
|
|
|
|
* 上游结算
|
|
|
|
|
* @param [string] $type 0:周结 1:月结 2:周结补点
|
|
|
|
|
*/
|
|
|
|
|
public function cpStatement($type,$stime)
|
|
|
|
|
public function cpStatement($type,$stime,$company_id=false)
|
|
|
|
|
{
|
|
|
|
|
$t = $this->setBeginAndEndTime($type,$stime);;
|
|
|
|
|
$begintime = $t[0];
|
|
|
|
|
$endtime = $t[1];
|
|
|
|
|
|
|
|
|
|
if($company_id === false){
|
|
|
|
|
//非重算
|
|
|
|
|
$where = [
|
|
|
|
|
"_string"=>"first_company_type = '1' OR second_company_type = '1'"
|
|
|
|
|
];
|
|
|
|
|
}else{
|
|
|
|
|
$where = [
|
|
|
|
|
"_string"=>"(first_company_type = '1' AND first_company_id = '{$company_id}') OR (second_company_type = '1' AND second_company_id = '{$company_id}')"
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
//获取哪些要结算
|
|
|
|
|
if($type == 1){
|
|
|
|
|
$cpDbRes = M("CompanyRelation","tab_")->where("settlement_type = 2 AND (first_company_type = '1' OR second_company_type = '1')")->select();
|
|
|
|
|
$where['settlement_type']=2;
|
|
|
|
|
$cpDbRes = M("CompanyRelation","tab_")->where($where)->select();
|
|
|
|
|
}else{
|
|
|
|
|
$cpDbRes = M("CompanyRelation","tab_")->where("settlement_type = 1 AND (first_company_type = '1' OR second_company_type = '1')")->select();
|
|
|
|
|
$where['settlement_type']=1;
|
|
|
|
|
$cpDbRes = M("CompanyRelation","tab_")->where($where)->select();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$cpList=[];
|
|
|
|
|
$js_id = [];//己方公司
|
|
|
|
|
foreach ($cpDbRes as $k => $v) {
|
|
|
|
@ -318,7 +327,13 @@ class CompanyStatementSetController extends Controller {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
//添加
|
|
|
|
|
$StatementDb->add($add_data);
|
|
|
|
|
if($company_id === false){
|
|
|
|
|
//非重算
|
|
|
|
|
$StatementDb->add($add_data);
|
|
|
|
|
}else{
|
|
|
|
|
return $add_data;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -374,17 +389,30 @@ class CompanyStatementSetController extends Controller {
|
|
|
|
|
/**
|
|
|
|
|
* 下游结算
|
|
|
|
|
*/
|
|
|
|
|
public function promoteCompanyStatement($type,$stime)
|
|
|
|
|
public function promoteCompanyStatement($type,$stime,$company_id=false)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
$t = $this->setBeginAndEndTime($type,$stime);
|
|
|
|
|
$begintime = $t[0];
|
|
|
|
|
$endtime = $t[1];
|
|
|
|
|
|
|
|
|
|
if($company_id === false){
|
|
|
|
|
//非重算
|
|
|
|
|
$where = [
|
|
|
|
|
"_string"=>"first_company_type = '2' OR second_company_type = '2'"
|
|
|
|
|
];
|
|
|
|
|
}else{
|
|
|
|
|
$where = [
|
|
|
|
|
"_string"=>"(first_company_type = '2' AND first_company_id = '{$company_id}') OR (second_company_type = '2' AND second_company_id = '{$company_id}')"
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
//获取哪些要结算
|
|
|
|
|
if($type == 1){
|
|
|
|
|
$pcDbRes = M("CompanyRelation","tab_")->where("settlement_type = 2 AND (first_company_type = '2' OR second_company_type = '2')")->select();
|
|
|
|
|
$where['settlement_type']=2;
|
|
|
|
|
$pcDbRes = M("CompanyRelation","tab_")->where($where)->select();
|
|
|
|
|
}else{
|
|
|
|
|
$pcDbRes = M("CompanyRelation","tab_")->where("settlement_type = 1 AND (first_company_type = '2' OR second_company_type = '2')")->select();
|
|
|
|
|
$where['settlement_type']=1;
|
|
|
|
|
$pcDbRes = M("CompanyRelation","tab_")->where($where)->select();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$pcList=[];
|
|
|
|
@ -550,7 +578,12 @@ class CompanyStatementSetController extends Controller {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
//添加
|
|
|
|
|
$StatementDb->add($add_data);
|
|
|
|
|
if($company_id === false){
|
|
|
|
|
//非重算
|
|
|
|
|
$StatementDb->add($add_data);
|
|
|
|
|
}else{
|
|
|
|
|
return $add_data;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
//设定开始结束时间
|
|
|
|
@ -610,4 +643,31 @@ class CompanyStatementSetController extends Controller {
|
|
|
|
|
$pcList[$k]['list'] = $v;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 重算接口
|
|
|
|
|
* 不进行结算方式重算
|
|
|
|
|
* @param [type] $id 原数据id
|
|
|
|
|
* @param string $admin_user 操作用户
|
|
|
|
|
* @return void bool
|
|
|
|
|
*/
|
|
|
|
|
public function updateCompanyStatementData($id,$admin_user='system')
|
|
|
|
|
{
|
|
|
|
|
//获取数据
|
|
|
|
|
$StatementDb = M("CompanyStatement","tab_");
|
|
|
|
|
$dbres = $StatementDb->where("id='{$id}'")->find();
|
|
|
|
|
//获取时间
|
|
|
|
|
$stime = $dbres['statement_end_time']-0+1;
|
|
|
|
|
$company_id = $dbres['company_id'];
|
|
|
|
|
if($dbres['company_belong'] == 9){
|
|
|
|
|
//上游
|
|
|
|
|
$savedata = $this->cpStatement($dbres['withdraw_type'],$stime,$company_id);
|
|
|
|
|
}else{
|
|
|
|
|
$savedata = $this->promoteCompanyStatement($dbres['withdraw_type'],$stime,$company_id);
|
|
|
|
|
}
|
|
|
|
|
//重写用户
|
|
|
|
|
$savedata['verify_log'] = json_encode(["create_user"=>$admin_user,"create_time"=>date("Y-m-d H:i:s")]);
|
|
|
|
|
$savedata['id'] = $dbres['id'];
|
|
|
|
|
return $StatementDb->save($savedata);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|