| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224 | <?phpnamespace Agent\Lib;use Dever;class Manage{    public function import($file)    {        $file = Dever::local($file);        echo $file;die;    }    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;            $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::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) {                $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']);            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 && $order['get_type'] == 1) {                # 关闭订单                $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);    }}
 |