Manage.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430
  1. <?php
  2. namespace Agent\Lib;
  3. use Dever;
  4. class Manage
  5. {
  6. # 后台设置区域
  7. public function updateArea($id, $name, $data)
  8. {
  9. Dever::config('base')->hook = true;
  10. $area = Dever::param('area', $data);
  11. if ($area) {
  12. $member = Dever::db('agent/member')->find($id);
  13. $role = Dever::db('setting/role')->one($member['role']);
  14. if ($role && $role['type'] == 2) {
  15. Dever::load('area/api')->upStatus($member['area'], 1);
  16. Dever::load('area/api')->upStatus($area, 2);
  17. }
  18. }
  19. }
  20. # 获取
  21. # 设置上级
  22. public function setParent_commit($id, $name, $data)
  23. {
  24. Dever::config('base')->hook = true;
  25. $mid = Dever::param('mid', $data);
  26. $parent_mobile = trim(Dever::param('parent_mobile', $data));
  27. if ($mid && $parent_mobile) {
  28. $member = Dever::db('agent/member')->find($mid);
  29. $parent = Dever::db('agent/member')->find(array('mobile' => $parent_mobile));
  30. if ($parent && $parent['status'] == 2) {
  31. if ($member['parent_mid'] == $parent['id']) {
  32. Dever::alert('上级代理商设置失败');
  33. return;
  34. }
  35. if ($member['parent_mid'] == $mid) {
  36. Dever::alert('上级代理商不能设置为自己');
  37. return;
  38. }
  39. # 删除之前关系
  40. Dever::load('invite/api')->dropRelation($mid, $parent['id']);
  41. # 获取所有下级
  42. $child = Dever::load('invite/api')->getChild($mid);
  43. if ($child) {
  44. foreach ($child as $k => $v) {
  45. Dever::load('invite/api')->dropRelation($v['to_uid'], $parent['id']);
  46. }
  47. }
  48. # 重新设置关系
  49. Dever::load('invite/api')->setRelation($mid, $parent['id']);
  50. Dever::db('agent/member')->update(array('id' => $mid, 'parent_mid' => $parent['id']));
  51. } else {
  52. Dever::alert('上级代理商还未注册或者已封禁');
  53. }
  54. }
  55. }
  56. public function orderUpdate($id, $name, $data)
  57. {
  58. Dever::config('base')->hook = true;
  59. $audit = Dever::param('audit', $data);
  60. $status = Dever::param('status', $data);
  61. $desc = Dever::param('desc', $data);
  62. $order_id = Dever::param('order_id', $data);
  63. if ($order_id && $status) {
  64. if ($status < 3) {
  65. if ($audit == 1) {
  66. $update = array('where_id' => $order_id, 'status' => $status+1);
  67. if ($status == 2) {
  68. $order = Dever::db('agent/order')->find($order_id);
  69. $price = Dever::param('price', $data);
  70. $prize_type = Dever::param('prize_type', $data);
  71. if ($prize_type == 2) {
  72. # 扣减已有名额,判断一下
  73. $prize = Dever::db('setting/prize')->find(array('type' => 1, 'price' => $order['price']));
  74. if ($prize) {
  75. $member_goods = Dever::db('agent/member_goods')->getOne(array('mid' => $order['mid'], 'type' => 3, 'type_id' => $prize['id']));
  76. if ($member_goods && $member_goods['num'] > 0) {
  77. # 有名额
  78. $price = 0;
  79. # 开始扣减
  80. $member = Dever::db('agent/member')->find($order['mid']);
  81. Dever::load('agent/lib/dhorder')->action($member, $prize['name'], $prize['num'], $prize['price'], array(), -1, 2, 3, $desc);
  82. }
  83. }
  84. }
  85. if ($price <= 0) {
  86. $update['get_type'] = 2;
  87. } else {
  88. $update['get_type'] = 1;
  89. }
  90. $update['price'] = $price;
  91. $update['agent_cash'] = $price;
  92. $update['soft_cash'] = 0;
  93. $cstatus = Dever::param('cstatus', $data);
  94. if ($cstatus && $cstatus == 2 && $price > 0) {
  95. # 拆分代理费
  96. $role = Dever::db('setting/role')->one($order['role']);
  97. if ($role && $role['soft']) {
  98. if (strstr($role['soft'], '%')) {
  99. $role['soft'] = str_replace('%', '', $role['soft']);
  100. $role['soft'] = $price * ($role['soft']/100);
  101. }
  102. $update['agent_cash'] = $price - $role['soft'];
  103. $update['soft_cash'] = $role['soft'];
  104. }
  105. }
  106. $update['pay_status'] = 2;
  107. # 财务终审之后,先生成代理商
  108. if ($order['mid'] <= 0) {
  109. # 生成
  110. $where['mobile'] = $order['mobile'];
  111. $member = Dever::db('agent/member')->find($where);
  112. if ($member) {
  113. $update['mid'] = $member['id'];
  114. } else {
  115. $data = $where;
  116. $data['name'] = $order['name'];
  117. $data['idcard'] = $order['idcard'];
  118. $data['idcard_front'] = $order['idcard_front'];
  119. $data['idcard_back'] = $order['idcard_back'];
  120. $data['company_name'] = $order['company_name'];
  121. $data['company_pic'] = $order['company_pic'];
  122. $data['company_number'] = $order['company_number'];
  123. $data['role'] = 1;
  124. $data['parent_mid'] = $order['parent_mid'];
  125. $data['source_id'] = $order['source_id'];
  126. $update['mid'] = Dever::db('agent/member')->insert($data);
  127. Dever::load('invite/api')->setRelation($update['mid'], $data['parent_mid']);
  128. }
  129. }
  130. }
  131. Dever::db('agent/order')->update($update);
  132. } else {
  133. Dever::db('agent/order')->update(array('where_id' => $order_id, 'status' => 5));
  134. }
  135. } elseif ($status == 3) {
  136. $info = Dever::db('agent/order_process')->find($id);
  137. if ($info && $info['status'] == 3) {
  138. $info['type'] = explode(',', $info['type']);
  139. }
  140. if (in_array(2, $info['type'])) {
  141. $goods_status = 3;
  142. } else {
  143. $goods_status = 2;
  144. }
  145. Dever::db('agent/order')->update(array('where_id' => $order_id, 'fdate' => time(), 'status' => 4, 'goods_status' => $goods_status));
  146. $order = Dever::db('agent/order')->find($order_id);
  147. if ($order && $order['mid']) {
  148. $member = Dever::db('agent/member')->find($order['mid']);
  149. $update['where_id'] = $order['mid'];
  150. if ($member && $member['status'] == 1) {
  151. $update['status'] = 2;
  152. $update['rdate'] = time();
  153. }
  154. $update['area'] = $order['area'];
  155. $update['role'] = $order['role'];
  156. Dever::db('agent/member')->update($update);
  157. # 对区域进行占用
  158. $role = Dever::db('setting/role')->one($order['role']);
  159. if ($role && $role['type'] == 2) {
  160. Dever::load('area/api')->upStatus($order['area'], 2);
  161. }
  162. $area_data = array('mid' => $order['mid'], 'order_id' => $order['id'], 'role' => $order['role'], 'area' => $order['area']);
  163. $area = Dever::db('agent/member_area')->find($area_data);
  164. if (!$area) {
  165. $area_data['type'] = $order['get_type'];
  166. $area_data['price'] = $order['price'];
  167. Dever::db('agent/member_area')->insert($area_data);
  168. } else {
  169. if ($role && $role['type'] == 2) {
  170. Dever::load('area/api')->upStatus($area['area'], 1);
  171. }
  172. }
  173. }
  174. }
  175. }
  176. }
  177. # 发放权益
  178. public function set_commit_api()
  179. {
  180. Dever::config('base')->hook = true;
  181. $type = Dever::input('type', 2);
  182. $order_id = Dever::input('order_id');
  183. # 检测是否发放过了
  184. $order = Dever::db('agent/order')->find($order_id);
  185. if ($order['status'] != 3) {
  186. Dever::alert('无发放权限');
  187. }
  188. if ($order['mid'] <= 0) {
  189. $update = array('where_id' => $order_id);
  190. $where['mobile'] = $order['mobile'];
  191. $member = Dever::db('agent/member')->find($where);
  192. if ($member) {
  193. $update['mid'] = $member['id'];
  194. } else {
  195. $data = $where;
  196. $data['name'] = $order['name'];
  197. $data['idcard'] = $order['idcard'];
  198. $data['idcard_front'] = $order['idcard_front'];
  199. $data['idcard_back'] = $order['idcard_back'];
  200. $data['company_name'] = $order['company_name'];
  201. $data['company_pic'] = $order['company_pic'];
  202. $data['company_number'] = $order['company_number'];
  203. $data['role'] = 1;
  204. $data['parent_mid'] = $order['parent_mid'];
  205. $data['source_id'] = $order['source_id'];
  206. $update['mid'] = Dever::db('agent/member')->insert($data);
  207. Dever::load('invite/api')->setRelation($update['mid'], $data['parent_mid']);
  208. }
  209. Dever::db('agent/order')->update($update);
  210. $order['mid'] = $update['mid'];
  211. }
  212. $order_process = Dever::db('agent/order_process')->find(array('order_id' => $order_id, 'status' => 3));
  213. $yes = -1;
  214. if (!$order_process) {
  215. # 可以发放
  216. $yes = 1;
  217. } elseif ($order_process) {
  218. $order_process['type'] = explode(',', $order_process['type']);
  219. if (!in_array($type, $order_process['type'])) {
  220. # 可以发放
  221. $yes = 2;
  222. }
  223. }
  224. if ($yes > 0) {
  225. if ($yes == 1) {
  226. $data['order_id'] = $order_id;
  227. $data['status'] = 3;
  228. $data['type'] = '1,' . $type;
  229. $state = Dever::db('agent/order_process')->insert($data);
  230. } else {
  231. $data['where_id'] = $order_process['id'];
  232. $order_process['type'][] = $type;
  233. $data['type'] = implode(',', $order_process['type']);
  234. $state = Dever::db('agent/order_process')->update($data);
  235. }
  236. if ($state) {
  237. if ($type == 2) {
  238. $this->setGoods($order);
  239. } elseif ($type == 3) {
  240. $this->setCash($order);
  241. } elseif ($type == 5) {
  242. $this->setAgreement($order);
  243. }
  244. }
  245. return 'reload';
  246. } else {
  247. Dever::alert('无发放权限');
  248. }
  249. }
  250. # 设置多个权益
  251. private function setGoods($order)
  252. {
  253. $goods = Dever::db('agent/order_goods')->getData(array('order_id' => $order['id']));
  254. if (!$goods) {
  255. $goods = Dever::db('setting/role_goods')->getData(array('role_id' => $order['role'], 'give' => $order['order_type']));
  256. }
  257. if ($goods) {
  258. $where = array();
  259. foreach ($goods as $k => $v) {
  260. $this->addGoods($order, $v);
  261. }
  262. }
  263. }
  264. # 新增权益
  265. private function addGoods($order, $v)
  266. {
  267. $where['mid'] = $order['mid'];
  268. $where['type'] = $v['type'];
  269. $where['type_id'] = $v['type_id'];
  270. $where['sku_id'] = $v['sku_id'];
  271. $info = Dever::db('agent/member_goods')->find($where);
  272. if ($info) {
  273. $up['where_id'] = $info['id'];
  274. $up['total_num'] = $info['total_num'] + $v['num'];
  275. $state = Dever::db('agent/member_goods')->update($up);
  276. if ($state) {
  277. 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']);
  278. }
  279. } else {
  280. $up = $where;
  281. $up['total_num'] = $v['num'];
  282. $state = Dever::db('agent/member_goods')->insert($up);
  283. if ($state) {
  284. 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']);
  285. }
  286. }
  287. }
  288. private function setCash($order)
  289. {
  290. $param = Dever::input('param');
  291. if ($param) {
  292. $param = explode(',', $param);
  293. foreach ($param as $k => $v) {
  294. $t = explode('-', $v);
  295. $where['type'] = $t[0];
  296. $where['order_id'] = $order['id'];
  297. $where['mid'] = $order['mid'];
  298. $where['parent_mid'] = $t[2];
  299. $info = Dever::db('agent/order_cash')->find($where);
  300. if (!$info) {
  301. $insert = $where;
  302. $insert['cash'] = $t[3];
  303. $insert['per'] = $t[5];
  304. if (isset($t[6])) {
  305. $insert['prize_id'] = $t[6];
  306. }
  307. Dever::db('agent/order_cash')->insert($insert);
  308. } else {
  309. $update['where_id'] = $info['id'];
  310. $update['cash'] = $t[3];
  311. $update['per'] = $t[5];
  312. if (isset($t[6])) {
  313. $update['prize_id'] = $t[6];
  314. }
  315. Dever::db('agent/order_cash')->update($update);
  316. }
  317. if (isset($t[6]) && isset($t[7])) {
  318. $prize_info = Dever::db('setting/prize')->find($t[6]);
  319. if ($prize_info) {
  320. $prize_insert['order_id'] = $order['order_id'];
  321. $prize_insert['mid'] = $t[2];
  322. $prize_insert['child_num'] = $t[7];
  323. $prize_insert['prize_id'] = $prize_info['id'];
  324. Dever::db('agent/member_prize')->insert($prize_insert);
  325. $prize['type'] = 3;
  326. $prize['type_id'] = $prize_info['id'];
  327. $prize['sku_id'] = -1;
  328. $prize['num'] = $prize_info['num'];
  329. $this->addGoods($order, $prize);
  330. }
  331. }
  332. $member = Dever::db('agent/member')->find($where['mid']);
  333. $desc = $member['name'] . '成为代理商,佣金'.$t[5].'%';
  334. Dever::load('agent/lib/member')->up($member, $order['id'], $order['role'], $where['type'], $where['parent_mid'], $t[3], $order['agent_cash'], $t[4], $desc);
  335. }
  336. }
  337. }
  338. private function setAgreement($order)
  339. {
  340. Dever::load('agent/lib/agreement')->up($order);
  341. }
  342. public function sellOrderUpdate($id, $name, $data)
  343. {
  344. Dever::config('base')->hook = true;
  345. $update = array();
  346. $audit = Dever::param('audit', $data);
  347. $info = Dever::db('agent/dh_order')->one($id);
  348. if ($audit > 1 && $info && $info['status'] == 2) {
  349. if ($audit == 2) {
  350. # 成功
  351. Dever::setInput('order_id', $id);
  352. Dever::load('agent/lib/dhorder.audit_commit');
  353. } else {
  354. Dever::db('agent/dh_order')->update(array('where_id' => $id, 'status' => 7));
  355. }
  356. }
  357. }
  358. # 确认收货
  359. public function setSellOrderStatus_api()
  360. {
  361. $order_id = Dever::input('order_id');
  362. $info = Dever::db('agent/dh_order')->find($order_id);
  363. if ($info) {
  364. Dever::load('agent/lib/dhorder')->finish($info, $info['shop_id']);
  365. return 'reload';
  366. } else {
  367. Dever::alert('错误的订单号');
  368. }
  369. }
  370. # 获取权益名称
  371. public function getGoods($type, $type_id, $sku_id)
  372. {
  373. if ($type == 1) {
  374. if ($sku_id == -2) {
  375. return '商品';
  376. }
  377. $goods_info = Dever::load('goods/lib/info')->getInfoBySku($type_id, $sku_id);
  378. if (isset($goods_info['sku'])) {
  379. $sku = '-' . $goods_info['sku']['string'];
  380. } else {
  381. $sku = '';
  382. }
  383. return array('name' => $goods_info['name'] . $sku, 'price' => $goods_info['price']);
  384. } elseif ($type == 2) {
  385. $card = Dever::db('card/info')->find($type_id);
  386. return array('name' => $card['name'], 'price' => $card['price']);
  387. } elseif ($type == 3) {
  388. $prize = Dever::db('setting/role_goods')->config['set']['prize'];
  389. return array('name' => $prize[$type_id], 'price' => 0);
  390. }
  391. }
  392. }