You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
820 lines
32 KiB
PHP
820 lines
32 KiB
PHP
<?php
|
|
|
|
namespace Admin\Controller;
|
|
|
|
use mysql_xdevapi\Exception;
|
|
use User\Api\UserApi as UserApi;
|
|
use OSS\OssClient;
|
|
use OSS\Core\OSsException;
|
|
use Think\Controller;
|
|
|
|
/**
|
|
* 后台首页控制器
|
|
* @author 麦当苗儿 <zuojiazi@vip.qq.com>
|
|
*/
|
|
class PromoteCompanyController extends ThinkController
|
|
{
|
|
private $modelName = 'PromoteCompany';
|
|
|
|
//列表
|
|
public function lists()
|
|
{
|
|
$model = M($this->modelName, 'tab_');
|
|
$is_export= false;
|
|
if (isset($_REQUEST['export']) && $_REQUEST['export']==1){
|
|
$is_export = true;
|
|
}
|
|
$map = [];
|
|
$promotemap=[];
|
|
$company_name = trim(I('company_name'));
|
|
if($company_name) $map['tab_promote_company.company_name'] = array('like',"%{$company_name}%");
|
|
if (isset($_REQUEST['status']) && $_REQUEST['status'] !== '') {
|
|
$status = intval($_REQUEST['status']);
|
|
$map['tab_promote_company.status'] = $status;
|
|
$parameter['status'] = $status;
|
|
}
|
|
if (isset($_REQUEST['promote_id'])) {
|
|
$map['id'] = M("Promote","tab_")->field("company_id")->where("id={$_REQUEST['promote_id']}")->find()['company_id'];
|
|
$promotemap['id']=$_REQUEST['promote_id'];
|
|
}
|
|
if (isset($_REQUEST['company_type'])) {
|
|
$map['company_type'] = $_REQUEST['company_type'];
|
|
}
|
|
if (isset($_REQUEST['company_belong'])) {
|
|
$map['company_belong'] = $_REQUEST['company_belong'];
|
|
}
|
|
|
|
|
|
$page = intval(I('get.p', 0));
|
|
$page = $page ? $page : 1; //默认显示第一页数据
|
|
$row = intval(I('row', 0));
|
|
$row = empty($row) ? 10 : $row;//每页条数
|
|
|
|
//获取分页公司数据
|
|
$companyres = $model->field("*")
|
|
->where($map)
|
|
->order("last_up_time desc");
|
|
if($is_export){
|
|
$companyres = $companyres->select();
|
|
}else{
|
|
$companyres = $companyres->page($page,$row)->select();
|
|
}
|
|
//获取公司id
|
|
$companyids = implode(',', array_column($companyres, 'id'));
|
|
//获取所属会长及其游戏分成
|
|
$promotemap['company_id']=["in",$companyids];
|
|
$promotemap['level'] = 1;
|
|
|
|
$promoteres = M("Promote","tab_")
|
|
->field("id,company_id,account,settlement_type")
|
|
->where($promotemap)
|
|
->select();
|
|
//获取会长id
|
|
$promoteids = implode(',', array_column($promoteres, 'id'));
|
|
//获取游戏比例
|
|
$gameradiores = M("PromoteGameRatio","tab_")
|
|
->alias("pg")
|
|
->field("pg.ratio,pg.relation_game_id,pg.turnover_ratio,pg.game_id,pg.promote_id,ga.relation_game_name,ga.game_type_name")
|
|
->join("tab_game ga ON pg.game_id = ga.id")
|
|
->where(array(
|
|
"status"=>1,
|
|
"promote_id"=>["in",$promoteids]
|
|
))
|
|
->group("relation_game_id,promote_id")
|
|
->select();
|
|
//比例数据处理
|
|
$gameradiotemp = array();
|
|
foreach($gameradiores as $k=>$v){
|
|
$turnover_ratio = json_decode($v['turnover_ratio'],true);
|
|
$v['turnover_ratio'] = array(
|
|
array("ratio"=>$v['ratio']."%","name"=>"默认比例")
|
|
);
|
|
|
|
foreach($turnover_ratio as $ke=>$va){
|
|
$t=array("ratio"=>$va["ratio"]."%");
|
|
if(array_key_exists("instanceof",$va)){
|
|
//存在
|
|
if($va['instanceof']=='1'){
|
|
$t['name']="月流水≥".$va['turnover'];
|
|
}else{
|
|
$t['name']="月流水>".$va['turnover'];
|
|
}
|
|
}else{
|
|
$t['name']="月流水≥".$va['turnover'];
|
|
}
|
|
$v['turnover_ratio'][]=$t;
|
|
}
|
|
$v['row'] = count($v['turnover_ratio']);
|
|
unset($v["ratio"]);
|
|
unset($v["relation_game_id"]);
|
|
unset($v["game_id"]);
|
|
$gameradiotemp[$v['promote_id']][]=$v;
|
|
}
|
|
unset($gameradiores);
|
|
//会长数据处理
|
|
$promoterestemp=[];
|
|
foreach($promoteres as $k=>$v){
|
|
if(array_key_exists($v['id'],$gameradiotemp)){
|
|
//存在
|
|
$v['list'] = $gameradiotemp[$v['id']];
|
|
foreach($gameradiotemp[$v['id']] as $ke=>$va){
|
|
$v['row'] += $va['row'];
|
|
}
|
|
}else{
|
|
$v['list']=[
|
|
["relation_game_name"=>"--","game_type_name"=>"--",
|
|
"turnover_ratio"=>[
|
|
["name"=>"--","ratio"=>"--"]
|
|
],
|
|
"row"=>1
|
|
]
|
|
];
|
|
$v["row"]=1;
|
|
}
|
|
if($v['settlement_type'] == 1){
|
|
$v['settlement_type']="周结";
|
|
}else{
|
|
$v['settlement_type']="月结";
|
|
}
|
|
$promoterestemp[$v['company_id']]["list"][]=$v;
|
|
}
|
|
unset($promoteres);
|
|
|
|
//处理公司数据
|
|
foreach($companyres as $k=>&$v){
|
|
if(array_key_exists($v['id'],$promoterestemp)){
|
|
//存在
|
|
$v['list'] = $promoterestemp[$v['id']]['list'];
|
|
foreach($promoterestemp[$v['id']] as $ke=>$va){
|
|
foreach($va as $key=>$val){
|
|
$v['row'] += $val['row'];
|
|
}
|
|
|
|
}
|
|
$v['can_del'] = 0;
|
|
}else{
|
|
//空值
|
|
$v['can_del'] = 1;
|
|
$v['list']=[
|
|
[
|
|
"account"=>"--",
|
|
"settlement_type"=>"--",
|
|
'list'=>[
|
|
[
|
|
"relation_game_name"=>"--",
|
|
"game_type_name"=>"--",
|
|
"turnover_ratio"=>[
|
|
["name"=>"--","ratio"=>"--"]
|
|
],
|
|
"row"=>1
|
|
]
|
|
]
|
|
]
|
|
];
|
|
$v['row'] += 1;
|
|
}
|
|
if( $v["contact_begin"] >0 ){
|
|
$v["contact_begin"] = date('Y/m/d', $v["contact_begin"]);
|
|
}else{
|
|
$v["contact_begin"] = "--";
|
|
}
|
|
if( $v["contact_end"] > 0){
|
|
$v["contact_end"] = date('Y/m/d', $v["contact_end"]);
|
|
}else{
|
|
$v["contact_end"] = "--";
|
|
}
|
|
if($v['platform_name'] == '' || $v['platform_name'] == "0"){
|
|
$v['platform_name'] = "--";
|
|
}
|
|
|
|
$v["is_sign_contact"] = ($v["is_sign_contact"]=="1" ? "是" :'否');
|
|
$v["company_type"] = ($v["company_type"]=="1" ? "公司" :'个人');
|
|
$v["company_belong"] = ($v["company_belong"]=="0" ? "内团" : ($v["company_belong"]=="1" ? "外团" : ($v["company_belong"]=="2" ? "外团分发" : '无')));
|
|
}
|
|
|
|
// dd($companyres);
|
|
|
|
|
|
//公司及会长数量统计
|
|
$companycount = $model->field("id")->where($map)->select();
|
|
$count = count($companycount);
|
|
$companyallids = implode(',', array_column($companycount, 'id'));
|
|
$promotemap['company_id']=["in",$companyallids];
|
|
$promotecount = M("Promote","tab_")->where($promotemap)->count();
|
|
|
|
$this->assign('listData', $companyres);
|
|
$this->assign('count', $count);
|
|
$this->assign('promotecount', $promotecount);
|
|
if($is_export){
|
|
|
|
$getData = $_GET;
|
|
unset($getData['export']);
|
|
|
|
addOperationLog(['op_type'=>3,'key'=>getNowDate(),'op_name'=>'导出推广公司','url'=>U('PromoteCompany/lists'),'menu'=>'推广员-推广员管理-推广公司管理-导出推广公司']);
|
|
|
|
//导出
|
|
$this->display("export");
|
|
die();
|
|
}
|
|
//分页
|
|
$parameter['p'] = $page;
|
|
$parameter['row'] = $row;
|
|
$page = set_pagination($count, $row);
|
|
if ($page) {
|
|
$this->assign('_page', $page);
|
|
}
|
|
//分配其他页面需要参数
|
|
$this->assign('promoteList', getPromoteByLevel(1));
|
|
$this->assign('commonset', M('Kuaijieicon')->where(['url' => 'Partner/lists'])->find());
|
|
$this->meta_title = '推广公司';
|
|
$this->display();
|
|
}
|
|
|
|
//添加
|
|
public function add()
|
|
{
|
|
if ($_POST) {
|
|
$time = time();
|
|
$save = I('post.');//前端已经验证
|
|
$this->checkData($save);
|
|
$save['create_time'] = $time;
|
|
$save['turnover_ratio'] = $this->setTurnoverRatio($save);
|
|
$res = M("promote_company","tab_")->add($save);
|
|
if ($res) {
|
|
addOperationLog(['op_type'=>0,'key'=>$save['company_name'],'op_name'=>'新增推广公司','url'=>U('PromoteCompany/lists')]);
|
|
\Think\Log::actionLog('PromoteCompany/add', 'partner', $res);
|
|
$array=array(
|
|
"info"=>"添加成功",
|
|
"status"=>1
|
|
);
|
|
$this->ajaxReturn($array);
|
|
} else {
|
|
$this->ajaxReturn(array(
|
|
'status' => 0,
|
|
'info' => "保存失败"
|
|
));
|
|
}
|
|
} else {
|
|
$this->assign('serviceAgreements', M('service_agreement', 'tab_')->select());
|
|
$this->assign('commonset', M('Kuaijieicon')->where(['url' => 'PromoteCompany/add'])->find());
|
|
$this->meta_title = '新增推广公司';
|
|
$this->display();
|
|
}
|
|
}
|
|
//查看
|
|
public function view()
|
|
{
|
|
$model = M($this->modelName, 'tab_');
|
|
$id = $_REQUEST['id'] ?: 0;
|
|
$map['id'] = $id;
|
|
$data = $model->field('*')->find($id);
|
|
if (empty($data)) {
|
|
$this->error('数据异常', U('lists'));
|
|
}
|
|
if($data['contact_begin'] >0){
|
|
$data['contact_begin']=date("Y-m-d",$data['contact_begin']);
|
|
}else{
|
|
$data['contact_begin']='';
|
|
}
|
|
if($data['contact_end'] >0){
|
|
$data['contact_end']=date("Y-m-d",$data['contact_end']);
|
|
}else{
|
|
$data['contact_end']='';
|
|
}
|
|
if($data['resources'] == ''){
|
|
$data['resources'] ="[]";
|
|
}
|
|
$this->assign('data', $data);
|
|
$this->display();
|
|
}
|
|
|
|
public function marketingDirectorShow($ids=[], $isShow=0)
|
|
{
|
|
$upt = M('promote_company','tab_')->where(['id'=>['in', $ids]])->save(['marketing_director_show'=>$isShow]);
|
|
return $upt ? $this->success('更新成功'): $this->error('更新失败');
|
|
}
|
|
|
|
|
|
//编辑
|
|
public function edit()
|
|
{
|
|
$model = M($this->modelName, 'tab_');
|
|
|
|
if ($_POST) {
|
|
$time = time();
|
|
$save = I('post.');//前端已经验证
|
|
$save['create_time'] = $time;
|
|
$save['last_up_time'] = $time;
|
|
$save['contact_begin']=strtotime($save['contact_begin']);
|
|
$save['contact_end']=strtotime($save['contact_end']);
|
|
|
|
if(isset($save['resources'])){
|
|
$save['resources'] = json_encode($save['resources'],JSON_UNESCAPED_UNICODE);
|
|
}
|
|
//判断内外团是否修改
|
|
$is_change_belong = false;
|
|
$company_id = $save['id'];
|
|
$y_belong = $model->field("company_belong")->where("id = {$save['id']}")->find()['company_belong'];
|
|
if(isset($save['company_belong']) && ($y_belong != $save['company_belong'])){
|
|
$is_change_belong = true;
|
|
}
|
|
if(empty($save['contact_phone'])){
|
|
$save['contact_phone'] = 0;
|
|
}
|
|
$res = $model->save($save);
|
|
if ($res) {
|
|
\Think\Log::actionLog('PromoteCompany/edit', 'partner', $res);
|
|
//处理底下所有会长的公会属性
|
|
if($is_change_belong){
|
|
$savedata = array(
|
|
"company_belong"=>$save['company_belong']
|
|
);
|
|
|
|
// 权限跟随
|
|
$authGroup = M('sys_auth_group')->where(['title'=>'市场总监'])->find();
|
|
$subPromoteIds = M('promote', 'tab_')->where(['level' => 1, 'company_id' => $company_id])->getField('id', true);
|
|
$dataPresident = explode(',', $authGroup['data_president']);
|
|
if ($save['company_belong'] == 1 || $save['company_belong'] == 2) {
|
|
$dataPresident = array_unique(array_merge($dataPresident, $subPromoteIds));
|
|
} else {
|
|
$dataPresident = array_diff($dataPresident, $subPromoteIds);
|
|
}
|
|
M('sys_auth_group')->where(['title'=>'市场总监'])->save(['data_president'=>implode(',', $dataPresident)]);
|
|
|
|
M("Promote","tab_")->where("company_id = '{$company_id}'")->save($savedata);
|
|
}
|
|
addOperationLog(['op_type'=>1,'key'=>$_POST['company_name'],'op_name'=>'编辑推广公司','url'=>U('PromoteCompany/lists'),'menu'=>'推广员-推广员管理-推广公司管理-编辑推广公司']);
|
|
|
|
$array=array(
|
|
"info"=>"修改成功",
|
|
"status"=>1
|
|
);
|
|
$this->ajaxReturn($array);
|
|
} else {
|
|
$this->ajaxReturn(array(
|
|
'status' => 0,
|
|
'info' => "修改失败"
|
|
));
|
|
}
|
|
} else {
|
|
$id = $_REQUEST['id'] ?: 0;
|
|
$map['id'] = $id;
|
|
$data = $model->field('*')->find($id);
|
|
if (empty($data)) {
|
|
$this->error('数据异常', U('lists'));
|
|
}
|
|
if($data['contact_begin'] >0){
|
|
$data['contact_begin']=date("Y-m-d",$data['contact_begin']);
|
|
}else{
|
|
$data['contact_begin']='';
|
|
}
|
|
if(empty($data['contact_phone'])){
|
|
$data['contact_phone'] = '';
|
|
}
|
|
if($data['contact_end'] >0){
|
|
$data['contact_end']=date("Y-m-d",$data['contact_end']);
|
|
}else{
|
|
$data['contact_end']='';
|
|
}
|
|
if($data['resources'] == ''){
|
|
$data['resources'] ="[]";
|
|
}
|
|
$this->assign('serviceAgreements', M('service_agreement', 'tab_')->select());
|
|
$this->assign('data', $data);
|
|
$this->display();
|
|
}
|
|
}
|
|
|
|
//删除
|
|
public function del()
|
|
{
|
|
$model = M($this->modelName, 'tab_');
|
|
if (!empty($_POST['id'])) {
|
|
if (!is_array($_POST['id'])) {
|
|
$this->error('参数异常');
|
|
}
|
|
|
|
$id = $_POST['id'];
|
|
} else {
|
|
$id = intval(I('get.id', 0));
|
|
if ($id == 0) {
|
|
$this->error('参数异常');
|
|
}
|
|
}
|
|
//删除所有资源
|
|
$data = $model->field('resources')->find($id)['resources'];
|
|
$data = json_encode($data,true);
|
|
if(is_array($data) && count($data) >0){
|
|
foreach($data as $k=>$v){
|
|
unlink("./".$v['file_path']);
|
|
}
|
|
}
|
|
|
|
$companyData = M('promote_company','tab_')->field('company_name')->where(['id'=>$_REQUEST['id']])->find();
|
|
|
|
$res = $model->delete($id);
|
|
//删除对应的推广员
|
|
if ($res === false) {
|
|
$this->error('删除失败');
|
|
}
|
|
|
|
// echo M()->_sql();die();
|
|
|
|
addOperationLog(['op_type'=>2,'key'=>$companyData['company_name'],'op_name'=>'删除推广公司','url'=>U('PromoteCompany/lists'),'menu'=>'推广员-推广员管理-推广公司管理-删除推广公司']);
|
|
|
|
$this->success('删除成功', U('lists'));
|
|
}
|
|
//处理上传图片
|
|
public function saveFile()
|
|
{
|
|
$path = '/Uploads/';
|
|
$upload = new \Think\Upload();// 实例化上传类
|
|
$upload->maxSize = 0 ;// 设置附件上传大小
|
|
$upload->exts = '';// 设置附件上传类型
|
|
$upload->rootPath = '.'.$path; // 设置附件上传根目录
|
|
$upload->savePath = ''; // 设置附件上传(子)目录
|
|
// 上传文件
|
|
$info = $upload->upload();
|
|
// dump($info);
|
|
if(!$info) {// 上传错误提示错误信息
|
|
$msg = $upload->getError();
|
|
$array= array('status' => 0, 'info' => $msg);
|
|
}else{// 上传成功
|
|
$array=array(
|
|
"info"=>"上传成功",
|
|
"status"=>1,
|
|
"file_path"=>$path.$info['file']['savepath'].$info['file']['savename'],
|
|
"file_name"=>$_POST['file_name'],
|
|
"file_type"=>$_FILES['file']['type'],
|
|
"file_size"=>$_FILES['file']['size'],
|
|
"upload_time"=>date("Y-m-d H:i:s",time())
|
|
);
|
|
}
|
|
$this->ajaxReturn($array);
|
|
}
|
|
//删除图片
|
|
public function delFile()
|
|
{
|
|
$id = $_REQUEST['id'];
|
|
$file_path = $_REQUEST['file_path'] ?: false;
|
|
unlink("./".$file_path);
|
|
if($id == 0){
|
|
$this->ajaxReturn(array(
|
|
'status' => 1,
|
|
'info' => "删除成功"
|
|
));
|
|
}else{
|
|
//需要修改
|
|
$array = array(
|
|
"resources"=>json_encode($_REQUEST['resources'],JSON_UNESCAPED_UNICODE)
|
|
);
|
|
$res = M($this->modelName, 'tab_')->where("id='{$id}'")->save($array);
|
|
if($res === false){
|
|
$this->ajaxReturn(array(
|
|
'status' => 0,
|
|
'info' => "删除保存失败"
|
|
));
|
|
}else{
|
|
$this->ajaxReturn(array(
|
|
'status' => 1,
|
|
'info' => "删除成功"
|
|
));
|
|
}
|
|
}
|
|
# code...
|
|
}
|
|
|
|
public function promoteDataConfigIndex() {
|
|
|
|
if (IS_POST) {
|
|
|
|
$changeData = I('post.','');
|
|
|
|
$promoteData = M("promote","tab_")
|
|
->field("id")
|
|
->where(['company_belong'=>2])
|
|
->select();
|
|
|
|
$promoteData = implode(',',array_column($promoteData,'id'));
|
|
|
|
if ($changeData['admin_type'] == 1) {
|
|
|
|
|
|
$num_pend = 0;
|
|
$num_deposit = 0;
|
|
if ($promoteData) {
|
|
|
|
$sql_spend = "UPDATE `tab_spend` SET `old_change_promote_id`=`promote_id`,`old_change_promote_account`=`promote_account`,`promote_id`=0,`promote_account`='无' WHERE promote_id in({$promoteData})";
|
|
$sql_deposit = "UPDATE `tab_deposit` SET `old_change_promote_id`=`promote_id`,`old_change_promote_account`=`promote_account`,`promote_id`=0,`promote_account`='无' WHERE promote_id in({$promoteData})";
|
|
|
|
$model = new \Think\Model();
|
|
$num_pend = $model->execute($sql_spend,true);
|
|
$num_deposit = $model->execute($sql_deposit,true);
|
|
|
|
$this->ajaxReturn(['info'=>"处理订单数据".($num_pend+$num_deposit).'条']);
|
|
|
|
}
|
|
|
|
} else if ($changeData['admin_type'] == 2){
|
|
$num_pend = 0;
|
|
$num_deposit = 0;
|
|
|
|
if ($promoteData) {
|
|
|
|
$sql_spend = "UPDATE `tab_spend` SET `promote_id`=`old_change_promote_id`,`promote_account`=`old_change_promote_account`,`old_change_promote_id`=0,`old_change_promote_account`=''
|
|
WHERE old_change_promote_id in ({$promoteData})";
|
|
$sql_deposit = "UPDATE `tab_deposit` SET `promote_id`=`old_change_promote_id`,`promote_account`=`old_change_promote_account`,`old_change_promote_id`=0,`old_change_promote_account`=''
|
|
WHERE old_change_promote_id in ({$promoteData})";
|
|
|
|
$model = new \Think\Model();
|
|
$num_pend = $model->execute($sql_spend,true);
|
|
$num_deposit = $model->execute($sql_deposit,true);
|
|
|
|
$this->ajaxReturn(['info'=>"将数据还原,处理订单数据".($num_pend+$num_deposit).'条']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$promoteData = M("promote","tab_")
|
|
->field("id")
|
|
->where(['company_belong'=>2])
|
|
->select();
|
|
|
|
$promoteData = implode(',',array_column($promoteData,'id'));
|
|
|
|
$spendData = M('spend','tab_')->field("old_change_promote_account")->where(['old_change_promote_id'=>['in',$promoteData]])->find();
|
|
|
|
// var_dump($spendData);die();
|
|
|
|
if ($spendData['old_change_promote_account']) {
|
|
$this->assign('old_change_promote_account',1);
|
|
}
|
|
|
|
$this->display('promotedataconfigindex');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
public function serviceAgreementList($row = 10, $p = 1)
|
|
{
|
|
$map = [];
|
|
$map['_string'] = " 1=1 ";
|
|
if (isset($_GET['time-start'])) {
|
|
$map['_string'] .= " and created_time >= " . strtotime($_GET['time-start']);
|
|
}
|
|
if (isset($_GET['time-end'])) {
|
|
$map['_string'] .= " and created_time < " . (strtotime($_GET['time-end']) + 86400);
|
|
}
|
|
if (isset($_GET['type'])) {
|
|
$map['type'] = $_GET['type'];
|
|
}
|
|
if (!empty($_GET['title'])) {
|
|
$map['title'] = ['like', "%{$_GET['title']}%"];
|
|
}
|
|
$list = M('service_agreement', 'tab_')
|
|
->field("tab_service_agreement.*, group_concat(distinct(tab_promote_company.company_name)) as company_name")
|
|
->join('tab_promote_company on tab_promote_company.service_agreement_show = tab_service_agreement.id', 'LEFT')->where($map)->group('tab_service_agreement.id asc')->page($p, $row)->order("status desc")->select();
|
|
$count = M('service_agreement', 'tab_')->where($map)->count();
|
|
$page = set_pagination($count, $row);
|
|
if ($page) {
|
|
$this->assign('_page', $page);
|
|
}
|
|
$this->assign('list_data', $list);
|
|
$this->display('service_agreement_list');
|
|
}
|
|
|
|
public function serviceAgreementSave($id=0, $delete=0)
|
|
{
|
|
if (IS_POST) {
|
|
if (!empty(I('ids'))) {
|
|
$ids = is_array(I('ids')) ? I('ids') : [I('ids')];
|
|
if ($delete) {
|
|
// 获取默认合同id
|
|
$defaultService = M('service_agreement', 'tab_')->where(['status'=>2])->find();
|
|
if(in_array($defaultService['id'], $ids)) {
|
|
return $this->error('无法删除默认模板');
|
|
}
|
|
$usingService = M('promote_company', 'tab_')->where(['service_agreement_show'=>['in', $ids]])->find();
|
|
if (!empty($usingService)) return $this->error('有正在使用该服务合同的公司,无法删除');
|
|
$result = M('service_agreement', 'tab_')->where(['id'=>['in', $ids]])->delete();
|
|
return $result ? $this->success('删除完成') : $this->error('删除失败');
|
|
}
|
|
}
|
|
if (empty($_POST['name']) || empty($_POST['content'])) {
|
|
return $this->error('请填写完整内容');
|
|
}
|
|
if ($id) {
|
|
$result = M('service_agreement', 'tab_')->where(['id'=>$id])->save($_POST);
|
|
return $result ? $this->success('更新完成') : $this->error('更新失败');
|
|
} else {
|
|
$data = $_POST;
|
|
$data['creator'] = is_login();
|
|
$data['created_time'] = time();
|
|
$result = M('service_agreement', 'tab_')->add($data);
|
|
return $result ? $this->success('生成协议完成') : $this->error('生成协议失败');
|
|
}
|
|
} else {
|
|
if (!empty($id)) {
|
|
if ($delete) {
|
|
$ids = [$id];
|
|
// 获取默认合同id
|
|
$defaultService = M('service_agreement', 'tab_')->where(['status'=>2])->find();
|
|
if(in_array($defaultService['id'], $ids)) {
|
|
return $this->error('无法删除默认模板');
|
|
}
|
|
$usingService = M('promote_company', 'tab_')->where(['service_agreement_show'=>['in', $ids]])->find();
|
|
if (!empty($usingService)) return $this->error('有正在使用该服务合同的公司,无法删除');
|
|
$result = M('service_agreement', 'tab_')->where(['id'=>['in', $ids]])->delete();
|
|
return $result ? $this->success('删除完成') : $this->error('删除失败');
|
|
}
|
|
$info = M('service_agreement', 'tab_')->where(['id'=>$id])->find();
|
|
if (empty($info)) return $this->error('未找到协议');
|
|
$this->assign('info', $info);
|
|
}
|
|
$this->display('service_agreement_save');
|
|
}
|
|
}
|
|
|
|
public function serviceAgreementSetDefault($id)
|
|
{
|
|
M('service_agreement', 'tab_')->where('id > 0')->save(['status'=>1]);
|
|
M('service_agreement', 'tab_')->where(['id'=>$id])->save(['status'=>2]);
|
|
return $this->success('设置完成');
|
|
}
|
|
|
|
//
|
|
public function getCompanyGame()
|
|
{
|
|
if (IS_AJAX) {
|
|
//获取所有游戏
|
|
$game_list = M('game', 'tab_')->field('relation_game_id id,relation_game_name game_name,short')->where(['game_status'=>1,'down_port'=>1])->group("relation_game_id")->select();
|
|
$data['data']['game_list'] = empty($game_list) ? '' : $game_list;
|
|
//获取推广员信息
|
|
$promote_info = M('promote_company', 'tab_')->field('id,company_name,game_ids')->where(['id'=>I('id', 0, 'intval')])->find();
|
|
if (!empty($promote_info['game_ids'])) {
|
|
$promote_info['game_ids'] = explode(',', $promote_info['game_ids']);
|
|
}
|
|
$data['data']['promote_info'] = empty($promote_info) ? '' : $promote_info;
|
|
$data['msg'] = '请求成功';
|
|
$data['code'] = 1;
|
|
|
|
$this->ajaxReturn($data);
|
|
exit;
|
|
}
|
|
}
|
|
//更新推广员可推广游戏
|
|
public function saveCompanyGame()
|
|
{
|
|
if (IS_AJAX) {
|
|
$id = I('promote_id', 0, 'intval');
|
|
if (empty($id)) {
|
|
$this->ajaxReturn(['code'=>0,'msg'=>'请选择推广公司']);
|
|
}
|
|
$promoter = M('promote_company', 'tab_')->where(['id'=>$id])->find();
|
|
if (empty($promoter)) {
|
|
$this->ajaxReturn(['code'=>0,'msg'=>'未找到推广公司']);
|
|
}
|
|
$game_ids = I('game_ids', '');
|
|
if (!empty($game_ids)) {
|
|
$game_ids = implode(',', $game_ids);
|
|
} else {
|
|
$game_ids = '';
|
|
}
|
|
// 获取下级id
|
|
$res = M('promote_company', 'tab_')->where(['id'=>$id])->save(['game_ids'=>$game_ids]);
|
|
if ($res) {
|
|
$this->ajaxReturn(['code'=>1,'msg'=>'更新成功']);
|
|
} else {
|
|
$this->ajaxReturn(['code'=>0,'msg'=>'数据未发生变化']);
|
|
}
|
|
}
|
|
}
|
|
//
|
|
protected function setTurnoverRatio($params)
|
|
{
|
|
$save['turnover_ratio'] = [];
|
|
if (!empty(array_filter($params['turnover'])) || !empty(array_filter($params['turnover_ratio'])) ) {
|
|
if (is_array($params['turnover']) && is_array($params['turnover_ratio']) && is_array($params['instanceof'])) {
|
|
foreach ($params['turnover'] as $turnover) {
|
|
if (empty($turnover)) {
|
|
$this->error('月流水不能为空');
|
|
}
|
|
}
|
|
foreach ($params['turnover_ratio'] as $turnoverRatio) {
|
|
if (empty($turnoverRatio)) {
|
|
$this->error('月流水分成比例不能为空');
|
|
}
|
|
}
|
|
foreach ($params['instanceof'] as $intervalClosedStatus) {
|
|
if (!in_array($intervalClosedStatus, [1, 2])) {
|
|
$this->error('月流水分符号不能为空');
|
|
}
|
|
}
|
|
$turnoverCount = count($params['turnover']);
|
|
$sortTurnover = $params['turnover'];
|
|
sort($sortTurnover);
|
|
if ($params['turnover'] != $sortTurnover || $turnoverCount != count(array_unique($params['turnover']))) {
|
|
$this->error('月流水必须以正序的方式填写,且必须大于上一个月流水');
|
|
}
|
|
$ratio = $params['ratio'] ?? 0;
|
|
// if ($params['turnover_ratio'][0] <= $ratio) {
|
|
// $this->error('月流水分成比例必须大于默认分成比例');
|
|
// }
|
|
$turnoverRatioCount = count($params['turnover_ratio']);
|
|
$sortTurnoverRatio = $params['turnover_ratio'];
|
|
sort($sortTurnoverRatio);
|
|
// if ($params['turnover_ratio'] != $sortTurnoverRatio || $turnoverRatioCount != count(array_unique($params['turnover_ratio']))) {
|
|
// $this->error('月流水分成比例必须以正序的方式填写,且必须大于上一个月流水分成比例');
|
|
// }
|
|
|
|
foreach ($params['turnover'] as $key => $turnover) {
|
|
$save['turnover_ratio'][] = [
|
|
'turnover' => bcdiv($turnover, 1, 2),
|
|
'ratio' => bcdiv($params['turnover_ratio'][$key], 1, 2),
|
|
'instanceof' => (isset($params['instanceof'][$key]) ? $params['instanceof'][$key] : 1),
|
|
];
|
|
}
|
|
}
|
|
}
|
|
return json_encode($save['turnover_ratio']);
|
|
}
|
|
protected function checkData(&$save)
|
|
{
|
|
$company_name = trim($save["company_name"]);
|
|
$status = intval($save['status']);
|
|
|
|
if (empty($company_name)) {
|
|
$this->error('请输入推广公司名称');
|
|
}
|
|
|
|
$model = M("promote_company", 'tab_');
|
|
$map['company_name'] = $company_name;
|
|
$res = $model->where($map)->field("id")->find();
|
|
|
|
if ($res) {
|
|
if(isset($save['id'])){
|
|
if($save['id'] !=$res['id']){
|
|
$this->error('推广公司已存在');
|
|
}
|
|
}else{
|
|
$this->error('推广公司已存在');
|
|
}
|
|
}
|
|
|
|
if(!empty(I("contact_phone")) && !checkPhone(I('contact_phone'))) {
|
|
$this->error('联系电话格式不正确');
|
|
}
|
|
if(!empty(I('reg_phone')) && !checkPhone(I('reg_phone'))) {
|
|
$this->error('注册电话格式不正确');
|
|
}
|
|
if(!empty(I('taxation_rate')) && I('taxation_rate') > 0) {
|
|
if(!checkNumber(I('taxation_rate'))){
|
|
$this->error('税费费率格式错误');
|
|
}else{
|
|
$save['taxation_rate'] = ($save['taxation_rate'] ?: 0);
|
|
}
|
|
}else{
|
|
$save['taxation_rate']=0;
|
|
}
|
|
if(!empty(I('channel_rate')) && I('channel_rate') > 0) {
|
|
if(!checkNumber(I('channel_rate'))){
|
|
$this->error('渠道费率格式不对');
|
|
}else{
|
|
$save['channel_rate'] = ($save['channel_rate'] ?: 0);
|
|
}
|
|
}else{
|
|
$save['channel_rate']=0;
|
|
}
|
|
if(!empty(I('fax_ratio')) && I('fax_ratio') > 0) {
|
|
if(!checkNumber(I('fax_ratio'))){
|
|
$this->error('开票税点格式不对');
|
|
}else{
|
|
$save['fax_ratio'] = ($save['fax_ratio'] ?: 0);
|
|
}
|
|
}else{
|
|
$save['fax_ratio']=0;
|
|
}
|
|
if(!empty(I('server_fee')) && !checkNumber(I('server_fee')) && I("has_server_fee") == 1) {
|
|
$this->error('服务器费用格式不对');
|
|
}else{
|
|
if(empty(I('server_fee'))){
|
|
$save['server_fee']=0;
|
|
}else{
|
|
$save['server_fee']=I('server_fee');
|
|
}
|
|
}
|
|
$time =time();
|
|
$save['contact_begin'] = strtotime($save['contact_begin']);
|
|
$save['contact_end'] = strtotime($save['contact_end']);
|
|
$save['validity_start_time'] = strtotime($save['validity_start_time']);
|
|
$save['validity_end_time'] = strtotime($save['validity_end_time']);
|
|
$save['last_up_time'] = $time;
|
|
}
|
|
|
|
|
|
}
|