| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489 | <?phpnamespace Agent\Lib;use Dever;class Manage{    public function import($file)    {        $file = Dever::local($file);        echo $file;die;    }    # 生成合同    public function createAgreement_api()    {        $order_id = Dever::input('order_id');        $order = Dever::db('agent/order')->find($order_id);        if ($order) {            $agreement = Dever::db('agent/member_agreement')->getData(array('order_id' => $order['id']));            if (!$agreement) {                if ($order['sign']) {                    $status = 2;                } else {                    $status = 1;                }                Dever::load('agent/lib/agreement')->up($order, $status);            }        }                return 'reload';    }    #代理商归店直推数据导出    public function agentGuiout($data)    {        $file = Dever::input('excel_name');        $header = array('姓名', '手机号', '所属店铺', '代理角色', '代理商区域', '代理费', '余额', '直推业绩', '团队业绩', '注册时间', '注册完成时间', '推荐人', '推荐人电话', '推荐人代理角色');                $body = array();        if ($data) {            foreach ($data as $k => $v) {                $shop_name = '';                if ($v['shop_id'] && $v['shop_id'] > 0) {                    $shop = Dever::db('shop/info')->find($v['shop_id']);                    if ($shop) {                        $shop_name = $shop['name'];                    }                }                $prize_type = '';                if (is_array($v)) {                    if ($v['role']) {                        $role = Dever::db('setting/role')->find($v['role']);                        if($v['role'] == 8){                            if($v['prize_type'] == 1){                                $prize_type = '-名额外';                            }elseif($v['prize_type'] == 2){                                $prize_type = '-名额内';                            }                        }                    } else {                        $role = array('name' => '普通代理',);                    }                    $order = Dever::db('agent/order')->find(array('mid' => $v['id']));                    $agent_cash = 0;                    if ($order) {                        $agent_cash = $order['agent_cash'];                    }                                        $area = Dever::load("area/api.string", $v['area']);                    if ($v['rdate']) {                        $rdate = date('Y-m-d H:i',$v['rdate']);                    } else {                        $rdate = '-';                    }                    $parent_name = '';                    $parent_mobile = '';                    $parent_rolename = '';                    if ($v['parent_mid'] && $v['parent_mid'] > 0) {                        $parent = Dever::db('agent/member')->find(array('id'=>$v['parent_mid']));                        if ($parent) {                            if($parent['role']){                                $parent_role = Dever::db('setting/role')->find(array('id'=>$parent['role']));                                if($parent_role){                                    $parent_rolename = $parent_role['name'];                                }                            }                            if($parent['name']){                                $parent_name = $parent['name'];                            }                            if($parent['mobile']){                                $parent_mobile = $parent['mobile'];                            }                        }                    }                                        $d = array                    (                        $v['name'],                        $v['mobile'],                        $shop_name,                        $role['name'].$prize_type,                        $area,                        $agent_cash,                        $v['cash'],                        $v['sell'],                        $v['group_sell'],                        date('Y-m-d H:i',$v['cdate']),                        $rdate,                        $parent_name,                        $parent_mobile,                        $parent_rolename,                    );                    $body[] = $d;                }            }        }        return Dever::excelExport($body, $header, $file);    }    public function agentOut($data)    {        $file = Dever::input('excel_name');        $header = array('姓名', '手机号', '身份证号', '代理角色', '代理商区域', '代理费', '余额', '直推业绩', '团队业绩', '注册时间', '注册完成时间', '推荐人', '推荐人电话', '推荐人代理角色');                $body = array();        if ($data) {            foreach ($data as $k => $v) {                $prize_type = '';                if (is_array($v)) {                    if ($v['role']) {                        $role = Dever::db('setting/role')->find($v['role']);                        if($v['role'] == 8){                            if($v['prize_type'] == 1){                                $prize_type = '-名额外';                            }elseif($v['prize_type'] == 2){                                $prize_type = '-名额内';                            }                        }                    } else {                        $role = array('name' => '普通代理',);                    }                    $order = Dever::db('agent/order')->find(array('mid' => $v['id']));                    $agent_cash = 0;                    if ($order) {                        $agent_cash = $order['agent_cash'];                    }                                        $area = Dever::load("area/api.string", $v['area']);                    if ($v['rdate']) {                        $rdate = date('Y-m-d H:i',$v['rdate']);                    } else {                        $rdate = '-';                    }                    $parent_name = '';                    $parent_mobile = '';                    $parent_rolename = '';                    if ($v['parent_mid'] && $v['parent_mid'] > 0) {                        $parent = Dever::db('agent/member')->find(array('id'=>$v['parent_mid']));                        if ($parent) {                            if($parent['role']){                                $parent_role = Dever::db('setting/role')->find(array('id'=>$parent['role']));                                if($parent_role){                                    $parent_rolename = $parent_role['name'];                                }                            }                            if($parent['name']){                                $parent_name = $parent['name'];                            }                            if($parent['mobile']){                                $parent_mobile = $parent['mobile'];                            }                        }                    }                                        $d = array                    (                        $v['name'],                        $v['mobile'],                        $v['idcard'],                        $role['name'].$prize_type,                        $area,                        $agent_cash,                        $v['cash'],                        $v['sell'],                        $v['group_sell'],                        date('Y-m-d H:i',$v['cdate']),                        $rdate,                        $parent_name,                        $parent_mobile,                        $parent_rolename,                    );                    $body[] = $d;                }            }        }        return Dever::excelExport($body, $header, $file);    }    public function agentCashOut($data)    {        $db = Dever::db('agent/test:old');        $file = Dever::input('excel_name');        $header = array('姓名', '手机号', '代理角色', '交款金额', '直推佣金', '团队佣金', '注册时间');                $body = array();        if ($data) {            foreach ($data as $k => $v) {                if ($v['rdate'] > 0) {                    if ($v['role']) {                        $role = Dever::db('setting/role')->find($v['role']);                    } else {                        $role = array('name' => '普通代理',);                    }                    $order = Dever::db('agent/order')->find(array('mid' => $v['id']));                    $price = 0;                    if ($order) {                        $price = $order['price'];                    }                    $cash_zt = 0;                    $cash_group = 0;                    $cash = Dever::db('bill/cash')->getCash(array('type' => 1, 'mid' => $v['id']));                    if ($cash) {                        $cash_zt = $cash['total'];                    }                    $cash = Dever::db('bill/cash')->getCash(array('type' => 2, 'mid' => $v['id']));                    if ($cash) {                        $cash_group = $cash['total'];                    }                    if (!$cash_group) {                        $cash_group = 0;                    }                    if ($v['id'] < 50000) {                        $info = $db->fetch('select * from ims_ewei_shop_member where id = ' . $v['id']);                        if ($info) {                            $member = $db->fetch('select * from ims_mc_members where uid = ' . $info['uid']);                            $cash_zt += ($member && $member['credit2']) ? $member['credit2'] : $info['credit2'];                        }                    }                    $cdate = date('Y-m-d H:i', $v['rdate']);                                        $d = array                    (                        $v['name'],                        $v['mobile'],                        $role['name'],                        $price,                        $cash_zt,                        $cash_group,                        $cdate,                    );                    $body[] = $d;                }            }        }        return Dever::excelExport($body, $header, $file);    }    public function relation_api()    {        $admin = Dever::load('manage/auth.data');        if ($admin['role'] != 1) {            Dever::alert('无法访问');        }        $data = array();        $data['mobile'] = Dever::input('mobile');        $member = Dever::db('agent/member')->find(array('mobile' => $data['mobile']));        $data['mid'] = $member['id'];        // Dever::input('mid');        $data['link'] = Dever::decode(Dever::input('refer'));        return Dever::render('index', $data);    }    # 后台设置区域    public function updateArea($id, $name, $data)    {        Dever::config('base')->hook = true;        $id = $id['where_id'];        $is_area = Dever::param('is_area', $data);        $area = Dever::param('area', $data);#修改后        $role = Dever::param('role', $data);        $level_id = Dever::param('level_id', $data);                $member = Dever::db('agent/member')->find($id);        if (!$member) {            return;        }        if (!$is_area) {            $is_area = 1;        }        if ($is_area == 1) {            if ($area && is_array($area) && $role) {                $role = Dever::db('setting/role')->find($role);                $area_string = array();                if ($role && $role['type'] == 2) {                    $area_string = Dever::load('agent/lib/order')->checkArea($area, $role, $member['id']);                } else {                    $area_string = implode(',', $area);                }                $area_string = str_replace(',-1', '', $area_string);                                $data['set_area'] = $area_string;                if ($area_string == $member['area']) {                    $area_string = '';                }                $this->upLog($member, $role, $area_string, -1, 3);            }        } else {            # 清理区域            $role = Dever::db('setting/role')->find($member['role']);            if ($role && $role['type'] == 2) {                $area = $member['area'];                Dever::load('area/api')->upStatus($area, 1);                $area_data['mid'] = $member['id'];                $area_data['area'] = $area;                $area_info = Dever::db('agent/member_area')->find($area_data);                if ($area_info) {                    Dever::db('agent/member_area')->update(array('where_id' => $area_info['id'], 'state' => 2));                    Dever::db('agent/member')->update(array('where_id' => $member['id'], 'area' => ''));                    //Dever::load('agent/lib/order')->editArea($member, '');                    $this->area_log($member['id'], -1, $member['area'], '');                }                $data['set_area'] = 'null';            }        }                if ($level_id && $level_id != $member['level_id']) {            $group_num = Dever::load('invite/api')->getChildNum($member['id'], 1);            Dever::load('agent/lib/level_log')->up($member['id'], -1, $member['level_id'], $level_id, 0, 0, $group_num);        }        $name = Dever::param('name', $data);        if ($name) {            $order = Dever::db('agent/order')->select(array('mid' => $member['id']));            if ($order) {                foreach ($order as $k => $v) {                    if ($v['status'] <= 2) {                        Dever::db('agent/order')->update(array('where_id' => $v['id'], 'name' => $name));                    }                }            }        }        $mobile = Dever::param('mobile', $data);        if ($mobile) {            # 验证手机号是否可以修改            $mobile_member = Dever::db('agent/member')->find(array('mobile' => $mobile));            if ($mobile_member && $mobile_member['id'] != $member['id']) {                Dever::alert('无法修改手机号,当前手机号已被代理商'.$mobile_member['name'].'使用');            }            # 是否同步修改期权表            $option_member = Dever::db('option/member')->find(array('mobile' => $member['mobile'], 'main' => 2));            if ($option_member) {                $mobile_member = Dever::db('option/member')->find(array('mobile' => $mobile));                if ($mobile_member && $mobile_member['id'] != $option_member['id']) {                    Dever::alert('无法修改手机号,当前手机号已被代理商期权账户'.$mobile_member['name'].'使用');                }                Dever::db('option/member')->update(array('where_id' => $option_member['id'], 'mobile' => $mobile));            }            # 同步修改其他表的手机号            Dever::db('agent/member_agreement')->updates(array('option_mid' => $member['id'], 'set_mobile' => $mobile));            Dever::db('agent/dh_order')->updates(array('option_mid' => $member['id'], 'set_mobile' => $mobile));            Dever::db('agent/order')->updates(array('option_mid' => $member['id'], 'set_mobile' => $mobile));            Dever::db('agent/user_bind')->updates(array('option_mid' => $member['id'], 'set_mobile' => $mobile));            Dever::db('agent/soft_cash')->updates(array('option_mid' => $member['id'], 'set_mobile' => $mobile));            //Dever::db('active/user')->updates(array('option_mobile' => $member['mobile'], 'set_mobile' => $mobile));        }        $shop_id = Dever::param('shop_id', $data);        if ($shop_id && $member['shop_id'] != $shop_id) {            $insert['mid'] = $member['id'];            $insert['new_shop_id'] = $shop_id;            $insert['clear'] = true;            $info = Dever::db('agent/member_shop_log')->find($insert);            if (!$info) {                $insert['old_shop_id'] = $member['shop_id'];                Dever::db('agent/member_shop_log')->insert($insert);            }        }        return $data;    }    # 更改日志    private function upLog($member, $role, $area, $order_id = -1, $type = 3, $price = 0)    {        if (is_numeric($role)) {            $role = Dever::db('setting/role')->find($role);        }        if (!$role) {            return;        }        $this->upRole($member, $role, $area, $order_id);        if ($area) {            $this->upArea($member, $role, $area, $order_id, $type, $price);        }    }    private function upRole($member, $role, $area, $order_id = -1)    {        if ($role['id'] == $member['role']) {            return;        }        $data['mid'] = $member['id'];        $data['order_id'] = $order_id;        $data['old_role'] = $member['role'];        $data['new_role'] = $role['id'];                if ($area) {            $data['area'] = $area;        } else {            $data['area'] = $member['area'];        }                if ($order_id && $order_id > 0) {            $data['type'] = 1;            $order = Dever::db('agent/order')->find($order_id);            $data['price'] = $order['price'];        } else {            $data['type'] = 2;            $admin = Dever::load('manage/auth.info');            $data['audit_admin'] = $admin['id'];        }                Dever::db('agent/member_account_log')->insert($data);    }    public function upArea($member, $role, $area, $order_id = -1, $type = 3, $price = 0)    {        if (!$role) {            return;        }        if ($area == $member['area']) {            //return;        }        $area_data = array('mid' => $member['id']);        $area_info = Dever::db('agent/member_area')->getOne($area_data);        if ($area_info) {            Dever::load('area/api')->upStatus($area_info['area'], 1);            Dever::db('agent/member_area')->update(array('where_id' => $area_info['id'], 'state' => 2));        }        if ($role && $role['type'] == 2) {            Dever::load('area/api')->upStatus($area, 2);            $area_data['order_id'] = $order_id;            $area_data['role'] = $role['id'];            $area_data['area'] = $area;            $area_data['type'] = $type;            $area_data['price'] = $price;            $area_data['status'] = 1;            Dever::db('agent/member_area')->insert($area_data);            //Dever::load('agent/lib/order')->editArea($v, $area);        }        $this->area_log($member['id'], $order_id, $member['area'], $area);    }         # 获取    # 设置上级    public function setParent_commit($id, $name, $data)    {        //Dever::alert('暂未开放');        Dever::config('base')->hook = true;        $mid = Dever::param('mid', $data);        $parent_mobile = trim(Dever::param('parent_mobile', $data));        if ($mid && $parent_mobile) {            $member = Dever::db('agent/member')->find($mid);            $parent = Dever::db('agent/member')->find(array('mobile' => $parent_mobile));            if ($parent && $parent['status'] == 2) {                if ($member['parent_mid'] == $parent['id']) {                    Dever::alert('上级代理商设置失败');                    return;                }                if ($member['parent_mid'] == $mid) {                    Dever::alert('上级代理商不能设置为自己');                    return;                }                # 重置关系                Dever::load('invite/api')->resetRelation($mid, $parent['id']);                /*                # 删除之前关系                Dever::load('invite/api')->dropRelation($mid, $parent['id']);                # 获取所有下级                $child = Dever::load('invite/api')->getChild($mid);                if ($child) {                    foreach ($child as $k => $v) {                        Dever::load('invite/api')->dropRelation($v['to_uid'], $parent['id']);                    }                }                # 重新设置关系                Dever::load('invite/api')->setRelation($mid, $parent['id']);                */                Dever::db('agent/member')->update(array('where_id' => $mid, 'parent_mid' => $parent['id']));            } else {                Dever::alert('上级代理商还未注册或者已封禁');            }        }    }    public function orderUpdateParent($id, $name, $data)    {        Dever::config('base')->hook = true;        $id = $id['where_id'];        $order = Dever::db('agent/order')->find($id);        if (!$order) {            return;        }        $area = Dever::param('area', $data);#修改后        $role = Dever::param('role', $data);        $invite_type = Dever::param('invite_type', $data);        $parent_code = Dever::param('parent_code', $data);        if ($invite_type == 1 && $parent_code) {            $parent_mid = Dever::load('invite/api')->getUid($parent_code);            if ($parent_mid) {                $parent_member = Dever::db('agent/member')->find($parent_mid);                if (!$parent_member) {                    Dever::alert('错误的邀请码');                }                if ($order['mid'] == $parent_member['id']) {                    Dever::alert('邀请人不能是自己');                }                $data['set_parent_mid'] = $parent_mid;                //Dever::db('agent/member')->update(array('where_id' => $order['mid'], 'parent_mid' => $parent_mid));            } else {                Dever::alert('错误的邀请码');            }        }        if ($area && is_array($area) && $role) {            $role = Dever::db('setting/role')->find($role);            $area_string = array();            if ($role && $role['type'] == 2) {                $area_string = Dever::load('agent/lib/order')->checkArea($area, $role, $order['mid']);            } else {                $area_string = implode(',', $area);                $area_string = str_replace(',-1', '', $area_string);            }            if ($role['type'] == 1) {                $data['set_f_price'] = $data['set_price'] = $role['price'];            } elseif ($role['type'] == 2) {                $data['set_f_price'] = $data['set_price'] = Dever::load('area/api')->getPrice($role['area'], $area_string);            } else {                $data['set_f_price'] = $data['set_price'] = 0;            }                        $data['set_area'] = $area_string;        }        return $data;    }    public function orderStartUpdate($id, $name, $data)    {        $order_id = Dever::param('order_id', $data);        if ($order_id) {            $order = Dever::db('agent/order')->find($order_id);            if ($order && $order['source_id'] < 0) {                if ($order['parent_mid'] > 0) {                    $member = Dever::db('agent/member')->find($order['parent_mid']);                    if ($member['status'] == 2) {                        return $data;                    }                }                Dever::alert('直属上级未认证,无法进行初审');            }        }    }    public function orderUpdate($id, $name, $data)    {        Dever::config('base')->hook = true;        $audit = Dever::param('audit', $data);        $status = Dever::param('status', $data);        $desc = Dever::param('desc', $data);        $order_id = Dever::param('order_id', $data);        $order = Dever::db('agent/order')->find($order_id);        if ($order_id && $order && $status) {            $admin = Dever::load('manage/auth.info');            if ($admin) {                Dever::db('agent/order_process')->update(array('where_id' => $id, 'admin' => $admin['id']));            }                        if ($status < 3) {                if ($audit == 1) {                    $update = array('where_id' => $order_id, 'status' => $status+1);                    if ($status == 1) {                        $soft_price = Dever::param('soft_price', $data);                        $price = Dever::param('price', $data);                        $prize_type = Dever::param('prize_type', $data);                        $option_price = Dever::param('option_price', $data);                        if ($prize_type == 2) {                            # 扣减已有名额,判断一下 暂时废弃                            $prize = Dever::db('setting/prize')->find(array('type' => 1, 'price' => $order['price']));                            if ($prize) {                                $member_goods = Dever::db('agent/member_goods')->getOne(array('mid' => $order['mid'], 'type' => 3, 'type_id' => $prize['id']));                                if ($member_goods && $member_goods['num'] > 0) {                                    # 有名额                                    $price = 0;                                    # 开始扣减                                    $member = Dever::db('agent/member')->find($order['mid']);                                    Dever::load('agent/lib/dhorder')->action($member, $prize['name'], $prize['num'], $prize['price'], array(), -1, 2, 3, $prize['id'], $desc);                                }                            }                        }                        if ($price <= 0) {                            $update['get_type'] = 2;                        } else {                            $update['get_type'] = 1;                        }                        $update['price'] = $price;                        $update['agent_cash'] = $price;                        $update['soft_cash'] = 0;                        $update['option_price']=$option_price;                        $cstatus = Dever::param('cstatus', $data);                        if ($cstatus && $cstatus == 2 && $price > 0) {                            # 拆分代理费                            if ($soft_price > 0) {                                $update['agent_cash'] = $price - $soft_price;                                $update['soft_cash'] = $soft_price;                            } else {                                $role = Dever::db('setting/role')->one($order['role']);                                if ($role && $role['soft']) {                                    if (strstr($role['soft'], '%')) {                                        $role['soft'] = str_replace('%', '', $role['soft']);                                        $role['soft'] = $price * ($role['soft']/100);                                    }                                    $update['agent_cash'] = $price - $role['soft'];                                    $update['soft_cash'] = $role['soft'];                                }                            }                        }                        # 增加业绩                        //Dever::load('bill/lib/sell')->up($order['mid'], 2, $order['price'], $order['role'], $order['id'], $order['name'] . '成为代理商');                    } elseif ($status == 2) {                        if ($order['mid'] && $order['mid'] > 0 && $order['parent_mid'] && $order['parent_mid'] > 0) {                            Dever::load('invite/api')->setRelation($order['mid'], $order['parent_mid']);                            Dever::db('agent/member')->update(array('where_id' => $order['mid'], 'parent_mid' => $order['parent_mid']));                        }                        $update['pay_status'] = 2;                        Dever::load('agent/lib/member')->create($order);                    }                    Dever::db('agent/order')->update($update);                } else {                                        Dever::db('agent/order')->update(array('where_id' => $order_id, 'status' => 5, 'history_status' => $order['status'], 'audit_desc' => $desc));                    if (Dever::project('sms')) {                        Dever::load('sms/api')->send('daili_reg_no', $order['mobile'], array('name' => $order['name'], 'content' => $desc));                    }                }            } elseif ($status == 3) {                $info = Dever::db('agent/order_process')->find(array('id' => $id, 'clear' => true));                if ($info && $info['status'] == 3) {                    $info['type'] = explode(',', $info['type']);                }                if (in_array(2, $info['type'])) {                    $goods_status = 3;                } else {                    $goods_status = 2;                }                $curtime = time();                Dever::db('agent/order')->update(array('where_id' => $order_id, 'fdate' => $curtime, 'status' => 4, 'goods_status' => $goods_status));                # 通知短信                if (Dever::project('sms')) {                     $order = Dever::db('agent/order')->find($order_id);                     Dever::load('sms/api')->send('daili_reg_yes', $order['mobile'], array('name' => $order['name']));                }                $order = Dever::db('agent/order')->find($order_id);                if ($order && $order['mid']) {                    $member = Dever::db('agent/member')->find($order['mid']);                    $update['where_id'] = $order['mid'];                    if ($member && $member['status'] == 1) {                        $update['status'] = 2;                        $update['rdate'] = $curtime;                    }                    $update['area'] = $order['area'];                    $update['role'] = $order['role'];                    $update['udate'] = $curtime;                    Dever::db('agent/member')->update($update);                    if ($order['price'] > 0) {                        $type = 1;                    } else {                        $type = 2;                    }                    $this->upLog($member, $order['role'], $order['area'], $order['id'], $type, $order['price']);                }            }        }    }    #区域日志    public function area_log($mid,$order_id,$old_area, $area) {        $data['mid']=$mid;        $data['order_id']=$order_id;        $data['old_area']=$old_area;        $data['area']=$area;        if ($order_id && $order_id > 0) {            $data['type'] = 1;        } else {            $admin = Dever::load('manage/auth.info');            $data['audit_admin'] = $admin['id'];            $data['type'] = 2;        }                $id = Dever::db('agent/member_area_log')->insert($data);        return $id;    }    # 发放权益    public function set_commit_api()    {        Dever::config('base')->hook = true;        $type = Dever::input('type', 2);        $order_id = Dever::input('order_id');        # 检测是否发放过了        $order = Dever::db('agent/order')->find($order_id);        if ($order['status'] != 3) {            //Dever::alert('无发放权限');        }        $order_process = Dever::db('agent/order_process')->find(array('order_id' => $order_id, 'status' => 3));        $yes = -1;        if (!$order_process) {            # 可以发放            $yes = 1;        } elseif ($order_process) {            $order_process['type'] = explode(',', $order_process['type']);            if (!in_array($type, $order_process['type'])) {                # 可以发放                $yes = 2;            }        }        if ($yes > 0) {            if ($yes == 1) {                $data['order_id'] = $order_id;                $data['status'] = 3;                $data['type'] = '1,' . $type;                $state = Dever::db('agent/order_process')->insert($data);            } else {                $data['where_id'] = $order_process['id'];                $order_process['type'][] = $type;                $data['type'] = implode(',', $order_process['type']);                $state = Dever::db('agent/order_process')->update($data);            }            if ($state) {                if ($type == 2) {                    $this->setGoods($order);                } elseif ($type == 3) {                    $this->setCash($order);                } elseif ($type == 5) {                    $this->setAgreement($order);                }            }            return 'reload';        } else {            Dever::alert('无发放权限');        }    }    # 设置多个权益    private function setGoods($order)    {        $t = 1;        $goods = Dever::db('agent/order_goods')->getData(array('order_id' => $order['id']));        if (!$goods) {            $goods = Dever::db('setting/role_goods')->getData(array('role_id' => $order['role'], 'give' => $order['order_type']));            $t = intval($order['agent_cash']/10000);            if ($t <= 0) {                $t = 1;            }        }        if ($goods) {            $where = array();            $goods_cash = 0;            foreach ($goods as $k => $v) {                $order_goods = array();                $order_goods['order_id'] = $order['id'];                $order_goods['type'] = $v['type'];                $order_goods['type_id'] = $v['type_id'];                $order_goods['sku_id'] = $v['sku_id'];                $order_goods['num'] = $v['num'];                Dever::db('agent/order_goods')->insert($order_goods);                $price = $this->addGoods($order, $v, $t);                if ($price && $v['type'] < 3) {                    # 计算商品价值                    $goods_cash += $price;                }            }            $update = array();            if ($goods_cash) {                $update['goods_cash'] = $goods_cash;                            }            $update['goods_status'] = 3;            $update['where_id'] = $order['id'];            Dever::db('agent/order')->update($update);        }    }    # 新增权益    private function addGoods($order, $v, $t)    {        $cash = $price = 0;                if ($v['type'] == 1) {            $v['num'] = $v['num'] * $t;            $goods_info = Dever::load('goods/lib/info')->getInfoBySku($v['type_id'], $v['sku_id']);            $price = $goods_info['price'];            $cash = $goods_info['price'] * $v['num'];            if (isset($goods_info['sku'])) {                $sku = '-' . $goods_info['sku']['string'];            } else {                $sku = '';            }            $name = $goods_info['name'] . $sku;        } elseif ($v['type'] == 2) {            $v['sku_id'] = -1;            # 生成一个电子券            $card = Dever::db('card/info')->find($v['type_id']);            if (!$card) {                return false;            }            $name = $card['name'];            if ($card['create_type'] == 2) {                $cash = $card['value']*$v['num'] * $t;                $price = $cash;                $v['num'] = 1;                $v['sku_id'] = Dever::load('card/lib/code')->create($card, 2, $order['mid'], $order['id'], $cash);                if (!$v['sku_id']) {                    return false;                }            } elseif ($card['create_type'] == 3) {                $cash = round($order['agent_cash']*($v['num']/100), 2);                $price = $cash;                $v['num'] = 1;                $v['sku_id'] = Dever::load('card/lib/code')->create($card, 2, $order['mid'], $order['id'], $cash);                if (!$v['sku_id']) {                    return false;                }            } else {                $cash = $card['value'];                $price = $cash;                $total = $t*$v['num'];                $t = 1;                for($i=0; $i<$total;$i++) {                    $v['sku_id'] = Dever::load('card/lib/code')->create($card, 2, $order['mid'], $order['id'], $cash);                    if ($v['sku_id']) {                        $where['mid'] = $order['mid'];                        $where['type'] = $v['type'];                        $where['type_id'] = $v['type_id'];                        $where['sku_id'] = $v['sku_id'];                        $info = Dever::db('agent/member_goods')->find($where);                                                if (!$info) {                            $up = $where;                            $up['total_num'] = $t;                            $up['cash'] = $cash;                            $up['price'] = $price;                            $up['name'] = $name;                            $state = Dever::db('agent/member_goods')->insert($up);                            if ($state) {                                Dever::load('agent/lib/member_set')->log($order['mid'], $order['order_num'], $v['type'], $v['type_id'], $v['sku_id'], $t, 0, $t, $name);                            }                        }                    }                }                return $cash * $total;            }                    } elseif ($v['type'] == 3) {            $prize = Dever::db('setting/prize')->find($v['type_id']);            $v['num'] = $v['num'] * $t;            $role = Dever::db('setting/role')->find($order['role']);            if ($role && $role['max_me_num'] && $role['max_me_num'] < $v['num']) {                $v['num'] = $role['max_me_num'];            }            $price = $prize['price'];            $cash = $prize['price']*$v['num'];            $name = $prize['name'];        }        $where['mid'] = $order['mid'];        $where['type'] = $v['type'];        $where['type_id'] = $v['type_id'];        $where['sku_id'] = $v['sku_id'];        $info = Dever::db('agent/member_goods')->find($where);                if ($info) {            $up['where_id'] = $info['id'];            $up['total_num'] = $info['total_num'] + $v['num'];            $up['cash'] = $cash;            $up['price'] = $price;            $up['name'] = $name;            $state = Dever::db('agent/member_goods')->update($up);            if ($state) {                Dever::load('agent/lib/member_set')->log($order['mid'], $order['order_num'], $v['type'], $v['type_id'], $v['sku_id'], $v['num'], $info['total_num'], $up['total_num'], $name);            }                    } else {            $up = $where;            $up['total_num'] = $v['num'];            $up['cash'] = $cash;            $up['price'] = $price;            $up['name'] = $name;            $state = Dever::db('agent/member_goods')->insert($up);            if ($state) {                Dever::load('agent/lib/member_set')->log($order['mid'], $order['order_num'], $v['type'], $v['type_id'], $v['sku_id'], $v['num'], 0, $up['total_num'], $name);            }        }        return $cash;    }    private function setCash($order)    {        $param = Dever::input('param');        if ($param) {            $param = explode(',', $param);            foreach ($param as $k => $v) {                $t = Dever::array_decode($v);                # 判断是否名额内                if (isset($t['prize_type']) && $t['prize_type'] == 2) {                    Dever::db('agent/member')->update(array('where_id' => $order['mid'], 'prize_type' => $t['prize_type']));                }                $parent_order = $order;                $parent_order['mid'] = $t['parent_mid'];                $where['type'] = $t['type'];                $where['order_id'] = $order['id'];                $where['mid'] = $order['mid'];                $where['parent_mid'] = $t['parent_mid'];                $info = Dever::db('agent/order_cash')->find($where);                if (!$info) {                    $insert = $where;                    $insert['cash'] = $t['cash'];                    $insert['per'] = $t['per'];                    if (isset($t['prize_id'])) {                        $insert['prize_id'] = $t['prize_id'];                    }                    if (isset($t['goods'])) {                        $insert['goods'] = Dever::array_encode($t['goods']);                    }                    Dever::db('agent/order_cash')->insert($insert);                } else {                    $update['where_id'] = $info['id'];                    $update['cash'] = $t['cash'];                    $update['per'] = $t['per'];                    if (isset($t['prize_id'])) {                        $update['prize_id'] = $t['prize_id'];                    }                    if (isset($t['goods'])) {                        $update['goods'] = Dever::array_encode($t['goods']);                    }                    Dever::db('agent/order_cash')->update($update);                }                if (isset($t['prize_id']) && isset($t['child_num'])) {                    $prize_info = Dever::db('setting/prize')->find($t['prize_id']);                    if ($prize_info) {                        $prize_insert['order_id'] = $order['order_id'];                        $prize_insert['mid'] = $t['parent_mid'];                        $prize_insert['child_num'] = $t['child_num'];                        $prize_insert['prize_id'] = $prize_info['id'];                        Dever::db('agent/member_prize')->insert($prize_insert);                        $prize['type'] = 3;                        $prize['type_id'] = $prize_info['id'];                        $prize['sku_id'] = -1;                        $prize['num'] = $prize_info['num'];                        $this->addGoods($parent_order, $prize, 1);                    }                }                if (isset($t['parent_goods_id'])) {                    $parent_goods = Dever::db('agent/member_goods')->getOne(array('id' => $t['parent_goods_id']));                    if ($parent_goods && $parent_goods['num'] > 0) {                        $parent_prize = Dever::db('setting/prize')->find($parent_goods['type_id']);                        if ($parent_prize) {                            # 检测有没有名额权益                            $prize_goods = Dever::db('setting/prize_goods')->select(array('prize_id' => $parent_prize['id']));                            if ($prize_goods) {                                # 赠送权益                                foreach ($prize_goods as $k1 => $v1) {                                    $this->addGoods($parent_order, $v1, 1);                                }                            }                            $member = Dever::db('agent/member')->find($t['parent_mid']);                            if ($member) {                                $desc = $parent_prize['name'] . '名额使用';                                Dever::load('agent/lib/dhorder')->action($member, $parent_prize['name'], $parent_prize['num'], $parent_prize['price'], array(), -1, 2, 3, $parent_goods['type_id'], $desc);                            }                        }                    }                }                if (!isset($t['parent_level'])) {                    $t['parent_level'] = false;                }                if (!isset($t['child_num'])) {                    $t['child_num'] = 0;                }                $member = Dever::db('agent/member')->find($where['mid']);                $desc = $member['name'] . '成为代理商,佣金'.$t['per'].'%';                                Dever::load('agent/lib/member')->up($member, $where['parent_mid'], $order['id'], $order['role'], $where['type'], $t['cash'], $order['agent_cash'], $t['parent_level'], $desc, $t['child_num']);                # 自动升级                if (isset($t['role_up']) && $t['role_up']) {                    $member = Dever::db('agent/member')->find(array('id' => $where['parent_mid']));                    $role = Dever::db('setting/role')->find($t['role_up']['t_role_id']);                    Dever::db('agent/member')->update(array('where_id' => $where['parent_mid'], 'role' => $t['role_up']['t_role_id']));                    if ($member && $role) {                        $this->upRole($member, $role, '', $order['id']);                    }                }            }        }    }    private function setAgreement($order)    {        Dever::load('agent/lib/agreement')->up($order);    }    public function sellOrderUpdate($id, $name, $data)    {        Dever::config('base')->hook = true;        $update = array();        $audit = Dever::param('audit', $data);        $desc = Dever::param('audit_desc', $data);        $info = Dever::db('agent/dh_order')->one($id);        if ($audit > 1 && $info && $info['status'] == 2) {            if ($audit == 2) {                # 成功                Dever::setInput('order_id', $id);                Dever::load('agent/lib/dhorder.audit_commit');            } else {                Dever::db('agent/dh_order')->update(array('where_id' => $id, 'status' => 7));                Dever::load('agent/lib/dhorder')->updateSell($info, 2);                if (Dever::project('sms')) {                    $member = Dever::db('agent/member')->find($info['mid']);                    Dever::load('sms/api')->send('daili_goods_no', $member['mobile'], array('name' => $member['name'], 'content' => $desc));                }            }        }    }    public function sellOrderUpdateMul($id, $name, $data)    {        Dever::config('base')->hook = true;        $status = Dever::param('status', $data);        if ($status == 5) {            $list = explode(',', $id);            if ($list) {                foreach ($list as $k => $v) {                    if (is_array($v)) {                        $id = $v['id'];                        $info = Dever::db('agent/dh_order')->one($id);                    } else {                        $id = $v;                        $info = Dever::db('agent/dh_order')->one($id);                    }                    $info['status'] = 4;                    Dever::load('agent/lib/dhorder')->finish($info, $info['shop_id']);                }            }        }    }    # 确认收货    public function setDhOrderStatus_api()    {        $order_id = Dever::input('order_id');        $info = Dever::db('agent/dh_order')->find($order_id);        if ($info) {            Dever::load('agent/lib/dhorder')->finish($info, $info['shop_id']);            return 'reload';        } else {            Dever::alert('错误的订单号');        }    }    # 获取权益名称    public function getGoods($type, $type_id, $sku_id, $name = '')    {        if ($type == 1) {            if ($name) {                return array('name' => $name . '('.$type_id.')');            }            if ($sku_id == -2) {                return '商品';            }            $goods_info = Dever::load('goods/lib/info')->getInfoBySku($type_id, $sku_id);            if (isset($goods_info['sku'])) {                $sku = '-' . $goods_info['sku']['string'];            } else {                $sku = '';            }            return array('name' => $goods_info['name'] . $sku . '('.$type_id.')', 'price' => $goods_info['price']);        } elseif ($type == 2) {            $code = Dever::db('card/code')->find($sku_id);            $card = Dever::db('card/info')->find($code['card_id']);            if ($name){                $card['name'] = $name;            }             return array('name' => $card['name'] . '('.$type_id.') <br /> ' . $code['card'], 'price' => $code['total_cash']);        } elseif ($type == 3) {            if ($name) {                return array('name' => $name . '('.$type_id.')');            }            $prize = Dever::db('setting/prize')->find($type_id);            return array('name' => $prize['name'] . '('.$type_id.')', 'price' => $prize['price']);        }    }    public function setOrderStatus_api()    {        $where['where_id'] = Dever::input('id');        $order = Dever::db('agent/order')->find($where['where_id']);        if ($order) {            $where['status'] = Dever::input('status');            if ($where['status'] == 6) {                $where['history_status'] = $order['status'];            }            Dever::db('agent/order')->update($where);            if ($where['status'] == 7) {                $data = Dever::db('agent/order')->getClose(array('mid' => $order['mid'], 'status' => 7, 'clear' => true));                if (!$data) {                    # 关闭订单                    $member = Dever::db('agent/member')->find($order['mid']);                    if ($member) {                        Dever::db('agent/member')->update(array('where_id' => $member['id'], 'state' => 2));                    }                }            }        }                return 'reload';    }    public function upSignAgreement_api()    {        $id = Dever::input('id');        if ($id) {            Dever::load('agent/lib/agreement')->upContent($id, true);        }        return 'reload';    }    public function upAgreement_api()    {        $id = Dever::input('id');        if ($id) {            Dever::load('agent/lib/agreement')->upContent($id);        }                return 'reload';    }    public function dropAgreement_api()    {        $id = Dever::input('id');        if ($id) {            Dever::load('agent/lib/agreement')->drop($id);        }                return 'reload';    }    public function memberShop_api(){        $data = Dever::db('agent/member')->getShopAll(array('shop_id'=>1,'state'=>1));        if($data){            foreach($data as $k=>$v){                $log = Dever::db('agent/member_shop_log')->find(array('mid'=>$v['id']));                if($log){                 }else{                    Dever::db('agent/member_shop_log')->insert(array('mid'=>$v['id'],'new_shop_id'=>$v['shop_id'],'cdate'=>'1651680000'));                }            }        }        return 'ok';    }    public function updateUserBind($id, $name, $data)    {        Dever::config('base')->hook = true;        $update = array();        $audit = Dever::param('audit', $data);        $desc = Dever::param('audit_desc', $data);        $info = Dever::db('agent/user_bind')->one($id);        if ($info) {            if ($audit) {                $update['where_id'] = $info['id'];                $update['audit_date'] = time();                $update['status'] = $audit;                $admin = Dever::load('manage/auth.info');                $update['admin'] = $admin['id'];                Dever::db('agent/user_bind')->update($update);            }        }    }    public function search_api()    {        $where = array();        return Dever::search('agent/member', $where);    }    public function out_arealog($data){        $header = array('区域名称', '区域价值', '售出时间');        $body = array();        foreach($data as $k1=> $v1){            $member = Dever::db('agent/member')->find($v1['mid']);            $role = Dever::db('setting/role')->find($member['role']);            if ($role['type'] == 1) {                $data[$k1]['price'] = $role['price'];            }             if(isset($data[$k1]['price']) && $data[$k1]['price']<1){                unset($data[$k1]);            }        }        $res = array_values($data);        foreach($res as $k=>$v){            $res[$k]['areas'] = Dever::load("area/api.string", $v['area']);            $member = Dever::db('agent/member')->find($v['mid']);            $role = Dever::db('setting/role')->find($member['role']);            $res[$k]['cdate'] = date('Y-m-d H:i',$v['cdate']);            if ($role['type'] == 1) {                $res[$k]['price'] = $role['price'];            } elseif ($role['type'] == 2) {                $res[$k]['price'] = Dever::load('area/api')->getPrice($role['area'], $v['area']);            }                       $d = array           (                $res[$k]['areas'],                $res[$k]['price'],                $res[$k]['cdate']            );           $body[] = $d;        }        $file = Dever::input('excel_name');        return Dever::excelExport($body, $header, $file);    }    public function out_zhitui($data){        $header = array('推荐人姓名', '手机号', '身份证', '角色', '被推荐人姓名', '手机号', '身份证', '角色','代理费','奖励金','时间');        $body = array();        foreach($data as $k => $v){            if($v['parent_mid']>0){                $member = Dever::db('agent/member')->find($v['parent_mid']);                $prole_name = '';                if($member && $member['role']){                    $prole = Dever::db('setting/role')->find($member['role']);                    if($prole && $prole['name']){                        $prole_name = $prole['name'];                    }                }                $role_name = '';                if($v['role']){                    $role = Dever::db('setting/role') ->find($v['role']);                    if($role && $role['name']){                        $role_name = $role['name'];                    }                }                                $order = Dever::db('agent/order')->find(array('mid'=>$v['id']));                $cdate = '';                if($v['cdate']){                    $cdate = date('Y-m-d H:i',$v['cdate']);                }                if($member){                    $d = array                    (                        $member['name'],                        $member['mobile'],                        $member['idcard'],                        $prole_name,                        $v['name'],                        $v['mobile'],                        $v['idcard'],                        $role['name'],                        $order['agent_cash'],                        $v['cash'],                        $cdate,                    );                    $body[] = $d;                }            }        }        $file = Dever::input('excel_name');        return Dever::excelExport($body, $header, $file);    }    public function out_touxian($data){        $header = array('姓名', '手机号', '身份证', '角色', '头衔', '代理费', '推荐人姓名', '推荐人手机号', '推荐人身份证', '推荐人角色', '推荐人头衔', '战略委/决策委姓名', '战略委/决策委手机号', '战略委/决策委身份证', '战略委/决策委角色', '战略委/决策委头衔', '时间');        $body = array();        foreach($data as $k => $v) {            if ($v['parent_mid'] > 0) {                $v['role_name'] = '';                if ($v['role']) {                    $role = Dever::db('setting/role')->find($v['role']);                    if($role && $role['name']) {                        $v['role_name'] = $role['name'];                    }                }                $v['title_name'] = '';                if ($v['title_id']) {                    $title = Dever::db('setting/title')->getDataByIds(array('id' => $v['title_id']));                    if($title) {                        $v['title_name'] = array();                        foreach ($title as $k1 => $v1) {                            $v['title_name'][$v1['id']] = $v1['name'];                        }                        $v['title_name'] = implode('、', $v['title_name']);                    }                }                $v['agent_cash'] = 0;                $order = Dever::db('agent/order')->find(array('mid'=>$v['id']));                if ($order) {                    $v['agent_cash'] = $order['agent_cash'];                }                $v['cdate'] = date('Y-m-d H:i',$v['cdate']);                $parent = Dever::db('agent/member')->find($v['parent_mid']);                if (!$parent) {                    continue;                }                $parent['role_name'] = '';                if ($parent && $parent['role']) {                    $role = Dever::db('setting/role')->find($parent['role']);                    if ($role) {                        $parent['role_name'] = $role['name'];                    }                }                $group = array();                $parent['title_name'] = '';                if ($parent['title_id']) {                    $title = Dever::db('setting/title')->getDataByIds(array('id' => $parent['title_id']));                    if ($title) {                        $parent['title_name'] = array();                        foreach ($title as $k1 => $v1) {                            $parent['title_name'][$v1['id']] = $v1['name'];                            if ($v1['id'] == 2 || $v1['id'] == 3) {                                $group = $parent;                                $group['title_name'] = $v1['name'];                            }                        }                        $parent['title_name'] = implode('、', $parent['title_name']);                    }                }                if (!$group) {                    $top = Dever::load('invite/api')->getParentAll($v['id'], 100);                    if ($top) {                        foreach ($top as $k1 => $v1) {                            if ($v1['uid'] != $parent['id']) {                                $p = Dever::db('agent/member')->one($v1['uid']);                                if ($p && $p['title_id']) {                                    $t = explode(',', $p['title_id']);                                    if (in_array(2, $t)) {                                        $group = $p;                                        $group['title_name'] = '战略委';                                        $group['role_name'] = '';                                        if ($group['role']) {                                            $role = Dever::db('setting/role')->find($group['role']);                                            if ($role) {                                                $group['role_name'] = $role['name'];                                            }                                        }                                        break;                                    }                                    if (in_array(3, $t)) {                                        $group = $p;                                        $group['title_name'] = '决策委';                                        $group['role_name'] = '';                                        if ($group['role']) {                                            $role = Dever::db('setting/role')->find($group['role']);                                            if ($role) {                                                $group['role_name'] = $role['name'];                                            }                                        }                                        break;                                    }                                }                            }                                                    }                    }                }                if (!$group) {                    $group['name'] = $group['mobile'] = $group['idcard'] = $group['role_name'] = $group['title_name'] = '';                }                                if($v){                    $d = array                    (                        $v['name'],                        $v['mobile'],                        $v['idcard'],                        $v['role_name'],                        $v['title_name'],                        $v['agent_cash'],                        $parent['name'],                        $parent['mobile'],                        $parent['idcard'],                        $parent['role_name'],                        $parent['title_name'],                        $group['name'],                        $group['mobile'],                        $group['idcard'],                        $group['role_name'],                        $group['title_name'],                        $v['cdate'],                    );                    $body[] = $d;                }            }        }        $file = Dever::input('excel_name');        return Dever::excelExport($body, $header, $file);    }}
 |