123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 |
- <?php
- namespace Agent\Lib;
- use Dever;
- class Manage
- {
- public function orderUpdate($id, $name, $data)
- {
- Dever::config('base')->hook = true;
- $audit = Dever::param('audit', $data);
- $status = Dever::param('status', $data);
- $order_id = Dever::param('order_id', $data);
- if ($order_id && $status) {
- if ($status < 3) {
- if ($audit == 1) {
- $update = array('where_id' => $order_id, 'status' => $status+1);
- if ($status == 2) {
- $get_type = Dever::param('get_type', $data);
- $update['get_type'] = $get_type;
- $update['pay_status'] = 2;
-
- $order = Dever::db('agent/order')->find($order_id);
- if ($order['mid'] <= 0) {
-
- $where['mobile'] = $order['mobile'];
- $member = Dever::db('agent/member')->find($where);
- if ($member) {
- $update['mid'] = $member['id'];
- } else {
- $data = $where;
- $data['name'] = $order['name'];
- $data['idcard'] = $order['idcard'];
- $data['idcard_front'] = $order['idcard_front'];
- $data['idcard_back'] = $order['idcard_back'];
- $data['role'] = 1;
- $data['parent_mid'] = $order['parent_mid'];
- $update['mid'] = Dever::db('agent/member')->insert($data);
- }
- }
- }
- Dever::db('agent/order')->update($update);
- } else {
- Dever::db('agent/order')->update(array('where_id' => $order_id, 'status' => 5));
- }
- } elseif ($status == 3) {
- $info = Dever::db('agent/order_process')->find($id);
- if ($info && $info['status'] == 3) {
- $info['type'] = explode(',', $info['type']);
- }
- if (in_array(2, $info['type'])) {
- $goods_status = 3;
- } else {
- $goods_status = 2;
- }
- Dever::db('agent/order')->update(array('where_id' => $order_id, 'fdate' => time(), 'status' => 4, 'goods_status' => $goods_status));
- $order = Dever::db('agent/order')->find($order_id);
- if ($order && $order['mid']) {
- $member = Dever::db('agent/member')->find($order['mid']);
- if ($member && $member['status'] == 1) {
- Dever::db('agent/member')->update(array('where_id' => $order['mid'], 'status' => 2));
- }
- $area_data = array('mid' => $order['mid'], 'order_id' => $order['id'], 'role' => $order['role'], 'area' => $order['area']);
- $area = Dever::db('agent/member_area')->find($area_where);
- if (!$area) {
- $area_data['type'] = $order['get_type'];
- Dever::db('agent/member_area')->insert($area_where);
- }
- }
- }
- }
- }
-
- 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('无发放权限');
- }
- if ($order['mid'] <= 0) {
- $update = array('where_id' => $order_id);
- $where['mobile'] = $order['mobile'];
- $member = Dever::db('agent/member')->find($where);
- if ($member) {
- $update['mid'] = $member['id'];
- } else {
- $data = $where;
- $data['name'] = $order['name'];
- $data['idcard'] = $order['idcard'];
- $data['idcard_front'] = $order['idcard_front'];
- $data['idcard_back'] = $order['idcard_back'];
- $data['role'] = 1;
- $data['parent_mid'] = $order['parent_mid'];
- $update['mid'] = Dever::db('agent/member')->insert($data);
- }
- Dever::db('agent/order')->update($update);
- $order['mid'] = $update['mid'];
- }
- $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);
- }
- }
- return 'reload';
- } else {
- Dever::alert('无发放权限');
- }
- }
- private function setGoods($order)
- {
- $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']));
- }
- if ($goods) {
- $where = array();
- foreach ($goods as $k => $v) {
- $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'];
- Dever::db('agent/member_goods')->update($up);
- } else {
- $up = $where;
- $up['total_num'] = $v['num'];
- Dever::db('agent/member_goods')->insert($up);
- }
- }
- }
- }
- private function setCash($order)
- {
- $param = Dever::input('param');
- if ($param) {
- $param = explode(',', $param);
- foreach ($param as $k => $v) {
- $t = explode('-', $v);
- $where['type'] = $t[0];
- $where['order_id'] = $order['id'];
- $where['mid'] = $order['mid'];
- $where['parent_mid'] = $t[2];
- $info = Dever::db('agent/order_cash')->find($where);
- if (!$info) {
- $insert = $where;
- $insert['cash'] = $t[3];
- Dever::db('agent/order_cash')->insert($insert);
- } else {
- $update['where_id'] = $info['id'];
- $update['cash'] = $t[3];
- Dever::db('agent/order_cash')->update($update);
- }
- if ($where['type'] == 1) {
- Dever::load('agent/lib/member')->up($where['parent_mid'], $t[3], $order['price'], 1);
- } elseif ($where['type'] == 2) {
- Dever::load('agent/lib/member')->up($where['parent_mid'], $t[3], $order['price'], 1, 'upGroupSell');
- }
- }
- }
- }
- }
|