Manage.php 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537
  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. $role = Dever::param('role', $data);
  12. if ($area) {
  13. $area_string = implode(',', $area);
  14. if (strstr($area_string, '-1')) {
  15. Dever::alert('请选择正确的区域');
  16. }
  17. $member = Dever::db('agent/member')->find($id);
  18. $member_role = Dever::db('setting/role')->one($member['role']);
  19. if ($member_role && $member_role['type'] == 2) {
  20. Dever::load('area/api')->upStatus($member['area'], 1);
  21. }
  22. $role = Dever::db('setting/role')->one($role);
  23. if ($role && $role['type'] == 2) {
  24. $num = count($area);
  25. if ($role['area'] == 1 && $num < 2) {
  26. Dever::alert('请选择城市');
  27. } elseif ($role['area'] == 2 && $num < 3) {
  28. Dever::alert('请选择区县');
  29. } elseif ($role['area'] == 3 && $num < 4) {
  30. Dever::alert('请选择街道');
  31. }
  32. Dever::load('area/api')->upStatus($area_string, 2);
  33. }
  34. }
  35. }
  36. # 获取
  37. # 设置上级
  38. public function setParent_commit($id, $name, $data)
  39. {
  40. Dever::config('base')->hook = true;
  41. $mid = Dever::param('mid', $data);
  42. $parent_mobile = trim(Dever::param('parent_mobile', $data));
  43. if ($mid && $parent_mobile) {
  44. $member = Dever::db('agent/member')->find($mid);
  45. $parent = Dever::db('agent/member')->find(array('mobile' => $parent_mobile));
  46. if ($parent && $parent['status'] == 2) {
  47. if ($member['parent_mid'] == $parent['id']) {
  48. Dever::alert('上级代理商设置失败');
  49. return;
  50. }
  51. if ($member['parent_mid'] == $mid) {
  52. Dever::alert('上级代理商不能设置为自己');
  53. return;
  54. }
  55. # 删除之前关系
  56. Dever::load('invite/api')->dropRelation($mid, $parent['id']);
  57. # 获取所有下级
  58. $child = Dever::load('invite/api')->getChild($mid);
  59. if ($child) {
  60. foreach ($child as $k => $v) {
  61. Dever::load('invite/api')->dropRelation($v['to_uid'], $parent['id']);
  62. }
  63. }
  64. # 重新设置关系
  65. Dever::load('invite/api')->setRelation($mid, $parent['id']);
  66. Dever::db('agent/member')->update(array('id' => $mid, 'parent_mid' => $parent['id']));
  67. } else {
  68. Dever::alert('上级代理商还未注册或者已封禁');
  69. }
  70. }
  71. }
  72. public function orderUpdate($id, $name, $data)
  73. {
  74. Dever::config('base')->hook = true;
  75. $audit = Dever::param('audit', $data);
  76. $status = Dever::param('status', $data);
  77. $desc = Dever::param('desc', $data);
  78. $order_id = Dever::param('order_id', $data);
  79. if ($order_id && $status) {
  80. if ($status < 3) {
  81. if ($audit == 1) {
  82. $update = array('where_id' => $order_id, 'status' => $status+1);
  83. if ($status == 2) {
  84. $order = Dever::db('agent/order')->find($order_id);
  85. $price = Dever::param('price', $data);
  86. $prize_type = Dever::param('prize_type', $data);
  87. if ($prize_type == 2) {
  88. # 扣减已有名额,判断一下
  89. $prize = Dever::db('setting/prize')->find(array('type' => 1, 'price' => $order['price']));
  90. if ($prize) {
  91. $member_goods = Dever::db('agent/member_goods')->getOne(array('mid' => $order['mid'], 'type' => 3, 'type_id' => $prize['id']));
  92. if ($member_goods && $member_goods['num'] > 0) {
  93. # 有名额
  94. $price = 0;
  95. # 开始扣减
  96. $member = Dever::db('agent/member')->find($order['mid']);
  97. Dever::load('agent/lib/dhorder')->action($member, $prize['name'], $prize['num'], $prize['price'], array(), -1, 2, 3, $desc);
  98. }
  99. }
  100. }
  101. if ($price <= 0) {
  102. $update['get_type'] = 2;
  103. } else {
  104. $update['get_type'] = 1;
  105. }
  106. $update['price'] = $price;
  107. $update['agent_cash'] = $price;
  108. $update['soft_cash'] = 0;
  109. $cstatus = Dever::param('cstatus', $data);
  110. if ($cstatus && $cstatus == 2 && $price > 0) {
  111. # 拆分代理费
  112. $role = Dever::db('setting/role')->one($order['role']);
  113. if ($role && $role['soft']) {
  114. if (strstr($role['soft'], '%')) {
  115. $role['soft'] = str_replace('%', '', $role['soft']);
  116. $role['soft'] = $price * ($role['soft']/100);
  117. }
  118. $update['agent_cash'] = $price - $role['soft'];
  119. $update['soft_cash'] = $role['soft'];
  120. }
  121. }
  122. $update['pay_status'] = 2;
  123. # 财务终审之后,先生成代理商
  124. if ($order['mid'] <= 0) {
  125. # 生成
  126. $where['mobile'] = $order['mobile'];
  127. $member = Dever::db('agent/member')->find($where);
  128. if ($member) {
  129. $update['mid'] = $member['id'];
  130. } else {
  131. $data = $where;
  132. $data['name'] = $order['name'];
  133. $data['idcard'] = $order['idcard'];
  134. $data['idcard_front'] = $order['idcard_front'];
  135. $data['idcard_back'] = $order['idcard_back'];
  136. $data['company_name'] = $order['company_name'];
  137. $data['company_pic'] = $order['company_pic'];
  138. $data['company_number'] = $order['company_number'];
  139. $data['role'] = 1;
  140. $data['parent_mid'] = $order['parent_mid'];
  141. $data['source_id'] = $order['source_id'];
  142. $update['mid'] = Dever::db('agent/member')->insert($data);
  143. Dever::load('invite/api')->setRelation($update['mid'], $data['parent_mid']);
  144. }
  145. }
  146. }
  147. Dever::db('agent/order')->update($update);
  148. } else {
  149. Dever::db('agent/order')->update(array('where_id' => $order_id, 'status' => 5));
  150. if (Dever::project('sms')) {
  151. $order = Dever::db('agent/order')->find($order_id);
  152. Dever::load('sms/api')->send('daili_reg_no', $order['mobile'], array('name' => $order['name'], 'content' => $desc));
  153. }
  154. }
  155. } elseif ($status == 3) {
  156. $info = Dever::db('agent/order_process')->find($id);
  157. if ($info && $info['status'] == 3) {
  158. $info['type'] = explode(',', $info['type']);
  159. }
  160. if (in_array(2, $info['type'])) {
  161. $goods_status = 3;
  162. } else {
  163. $goods_status = 2;
  164. }
  165. Dever::db('agent/order')->update(array('where_id' => $order_id, 'fdate' => time(), 'status' => 4, 'goods_status' => $goods_status));
  166. # 通知短信
  167. if (Dever::project('sms')) {
  168. $order = Dever::db('agent/order')->find($order_id);
  169. Dever::load('sms/api')->send('daili_reg_yes', $order['mobile'], array('name' => $order['name']));
  170. }
  171. $order = Dever::db('agent/order')->find($order_id);
  172. if ($order && $order['mid']) {
  173. $member = Dever::db('agent/member')->find($order['mid']);
  174. $update['where_id'] = $order['mid'];
  175. if ($member && $member['status'] == 1) {
  176. $update['status'] = 2;
  177. $update['rdate'] = time();
  178. }
  179. $update['area'] = $order['area'];
  180. $update['role'] = $order['role'];
  181. Dever::db('agent/member')->update($update);
  182. # 对区域进行占用
  183. $role = Dever::db('setting/role')->one($order['role']);
  184. if ($role && $role['type'] == 2) {
  185. Dever::load('area/api')->upStatus($order['area'], 2);
  186. }
  187. $area_data = array('mid' => $order['mid'], 'order_id' => $order['id'], 'role' => $order['role'], 'area' => $order['area']);
  188. $area = Dever::db('agent/member_area')->find($area_data);
  189. if (!$area) {
  190. $area_data['type'] = $order['get_type'];
  191. $area_data['price'] = $order['price'];
  192. $area_data['status'] = 1;
  193. Dever::db('agent/member_area')->insert($area_data);
  194. } else {
  195. Dever::db('agent/member_area')->update(array('where_id' => $area['id'], 'state' => 2));
  196. if ($role && $role['type'] == 2) {
  197. Dever::load('area/api')->upStatus($area['area'], 1);
  198. }
  199. }
  200. }
  201. }
  202. }
  203. }
  204. # 发放权益
  205. public function set_commit_api()
  206. {
  207. Dever::config('base')->hook = true;
  208. $type = Dever::input('type', 2);
  209. $order_id = Dever::input('order_id');
  210. # 检测是否发放过了
  211. $order = Dever::db('agent/order')->find($order_id);
  212. if ($order['status'] != 3) {
  213. Dever::alert('无发放权限');
  214. }
  215. if ($order['mid'] <= 0) {
  216. $update = array('where_id' => $order_id);
  217. $where['mobile'] = $order['mobile'];
  218. $member = Dever::db('agent/member')->find($where);
  219. if ($member) {
  220. $update['mid'] = $member['id'];
  221. } else {
  222. $data = $where;
  223. $data['name'] = $order['name'];
  224. $data['idcard'] = $order['idcard'];
  225. $data['idcard_front'] = $order['idcard_front'];
  226. $data['idcard_back'] = $order['idcard_back'];
  227. $data['company_name'] = $order['company_name'];
  228. $data['company_pic'] = $order['company_pic'];
  229. $data['company_number'] = $order['company_number'];
  230. $data['role'] = 1;
  231. $data['parent_mid'] = $order['parent_mid'];
  232. $data['source_id'] = $order['source_id'];
  233. $update['mid'] = Dever::db('agent/member')->insert($data);
  234. Dever::load('invite/api')->setRelation($update['mid'], $data['parent_mid']);
  235. }
  236. Dever::db('agent/order')->update($update);
  237. $order['mid'] = $update['mid'];
  238. }
  239. $order_process = Dever::db('agent/order_process')->find(array('order_id' => $order_id, 'status' => 3));
  240. $yes = -1;
  241. if (!$order_process) {
  242. # 可以发放
  243. $yes = 1;
  244. } elseif ($order_process) {
  245. $order_process['type'] = explode(',', $order_process['type']);
  246. if (!in_array($type, $order_process['type'])) {
  247. # 可以发放
  248. $yes = 2;
  249. }
  250. }
  251. if ($yes > 0) {
  252. if ($yes == 1) {
  253. $data['order_id'] = $order_id;
  254. $data['status'] = 3;
  255. $data['type'] = '1,' . $type;
  256. $state = Dever::db('agent/order_process')->insert($data);
  257. } else {
  258. $data['where_id'] = $order_process['id'];
  259. $order_process['type'][] = $type;
  260. $data['type'] = implode(',', $order_process['type']);
  261. $state = Dever::db('agent/order_process')->update($data);
  262. }
  263. if ($state) {
  264. if ($type == 2) {
  265. $this->setGoods($order);
  266. } elseif ($type == 3) {
  267. $this->setCash($order);
  268. } elseif ($type == 5) {
  269. $this->setAgreement($order);
  270. }
  271. }
  272. return 'reload';
  273. } else {
  274. Dever::alert('无发放权限');
  275. }
  276. }
  277. # 设置多个权益
  278. private function setGoods($order)
  279. {
  280. $goods = Dever::db('agent/order_goods')->getData(array('order_id' => $order['id']));
  281. if (!$goods) {
  282. $goods = Dever::db('setting/role_goods')->getData(array('role_id' => $order['role'], 'give' => $order['order_type']));
  283. }
  284. if ($goods) {
  285. $where = array();
  286. $goods_cash = 0;
  287. foreach ($goods as $k => $v) {
  288. $price = $this->addGoods($order, $v);
  289. if ($price && $v['type'] < 3) {
  290. # 计算商品价值
  291. $goods_cash += $price;
  292. }
  293. }
  294. if ($goods_cash) {
  295. Dever::db('agent/order')->update(array('where_id' => $order['id'], 'goods_cash' => $goods_cash));
  296. }
  297. }
  298. }
  299. # 新增权益
  300. private function addGoods($order, $v)
  301. {
  302. $price = 0;
  303. $t = intval($order['price']/10000);
  304. if ($v['type'] == 1) {
  305. $v['num'] = $v['num'] * $t;
  306. $goods_info = Dever::load('goods/lib/info')->getInfoBySku($v['type_id'], $v['sku_id']);
  307. $price = $goods_info['price'] * $v['num'];
  308. } elseif ($v['type'] == 2) {
  309. $v['sku_id'] = -1;
  310. # 生成一个电子券
  311. $card = Dever::db('card/info')->find($v['type_id']);
  312. if (!$card) {
  313. return false;
  314. }
  315. $price = $card['price']*$v['num'] * $t;
  316. $v['sku_id'] = Dever::load('card/lib/code')->create($card, 2, $order['mid'], $order['id'], $price);
  317. if (!$v['sku_id']) {
  318. return false;
  319. }
  320. } elseif ($v['type'] == 3) {
  321. $prize = Dever::db('setting/prize')->find($v['type_id']);
  322. $price = $prize['price']*$v['num'];
  323. }
  324. $where['mid'] = $order['mid'];
  325. $where['type'] = $v['type'];
  326. $where['type_id'] = $v['type_id'];
  327. $where['sku_id'] = $v['sku_id'];
  328. $info = Dever::db('agent/member_goods')->find($where);
  329. if ($info) {
  330. $up['where_id'] = $info['id'];
  331. $up['total_num'] = $info['total_num'] + $v['num'];
  332. $up['cash'] = $price;
  333. $state = Dever::db('agent/member_goods')->update($up);
  334. if ($state) {
  335. 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']);
  336. }
  337. } else {
  338. $up = $where;
  339. $up['total_num'] = $v['num'];
  340. $up['cash'] = $price;
  341. $state = Dever::db('agent/member_goods')->insert($up);
  342. if ($state) {
  343. 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']);
  344. }
  345. }
  346. return $price;
  347. }
  348. private function setCash($order)
  349. {
  350. $param = Dever::input('param');
  351. if ($param) {
  352. $param = explode(',', $param);
  353. foreach ($param as $k => $v) {
  354. $t = Dever::array_decode($v);
  355. $where['type'] = $t['type'];
  356. $where['order_id'] = $order['id'];
  357. $where['mid'] = $order['mid'];
  358. $where['parent_mid'] = $t['parent_mid'];
  359. $info = Dever::db('agent/order_cash')->find($where);
  360. if (!$info) {
  361. $insert = $where;
  362. $insert['cash'] = $t['cash'];
  363. $insert['per'] = $t['per'];
  364. if (isset($t['prize_id'])) {
  365. $insert['prize_id'] = $t['prize_id'];
  366. }
  367. Dever::db('agent/order_cash')->insert($insert);
  368. } else {
  369. $update['where_id'] = $info['id'];
  370. $update['cash'] = $t['cash'];
  371. $update['per'] = $t['per'];
  372. if (isset($t['prize_id'])) {
  373. $update['prize_id'] = $t['prize_id'];
  374. }
  375. Dever::db('agent/order_cash')->update($update);
  376. }
  377. if (isset($t['prize_id']) && isset($t['child_num'])) {
  378. $prize_info = Dever::db('setting/prize')->find($t['prize_id']);
  379. if ($prize_info) {
  380. $prize_insert['order_id'] = $order['order_id'];
  381. $prize_insert['mid'] = $t['parent_mid'];
  382. $prize_insert['child_num'] = $t['child_num'];
  383. $prize_insert['prize_id'] = $prize_info['id'];
  384. Dever::db('agent/member_prize')->insert($prize_insert);
  385. $prize['type'] = 3;
  386. $prize['type_id'] = $prize_info['id'];
  387. $prize['sku_id'] = -1;
  388. $prize['num'] = $prize_info['num'];
  389. $this->addGoods($order, $prize);
  390. }
  391. }
  392. if (isset($t['parent_goods_id'])) {
  393. $parent_goods = Dever::db('agent/member_goods')->getOne(array('id' => $t['parent_goods_id']));
  394. if ($parent_goods && $parent_goods['num'] > 0) {
  395. $parent_prize = Dever::db('setting/prize')->find($parent_goods['type_id']);
  396. $member = Dever::db('agent/member')->find($t['parent_mid']);
  397. if ($member) {
  398. $desc = $parent_prize['name'] . '名额使用';
  399. Dever::load('agent/lib/dhorder')->action($member, $parent_prize['name'], $parent_prize['num'], $parent_prize['price'], array(), -1, 2, 3, $desc);
  400. }
  401. }
  402. }
  403. if (!isset($t['parent_level'])) {
  404. $t['parent_level'] = false;
  405. }
  406. if (!isset($t['child_num'])) {
  407. $t['child_num'] = 0;
  408. }
  409. $member = Dever::db('agent/member')->find($where['mid']);
  410. $desc = $member['name'] . '成为代理商,佣金'.$t['per'].'%';
  411. Dever::load('agent/lib/member')->up($member, $order['id'], $order['role'], $where['type'], $where['parent_mid'], $t['cash'], $order['agent_cash'], $t['parent_level'], $desc, $t['child_num']);
  412. }
  413. }
  414. }
  415. private function setAgreement($order)
  416. {
  417. Dever::load('agent/lib/agreement')->up($order);
  418. }
  419. public function sellOrderUpdate($id, $name, $data)
  420. {
  421. Dever::config('base')->hook = true;
  422. $update = array();
  423. $audit = Dever::param('audit', $data);
  424. $desc = Dever::param('audit_desc', $data);
  425. $info = Dever::db('agent/dh_order')->one($id);
  426. if ($audit > 1 && $info && $info['status'] == 2) {
  427. if ($audit == 2) {
  428. # 成功
  429. Dever::setInput('order_id', $id);
  430. Dever::load('agent/lib/dhorder.audit_commit');
  431. } else {
  432. Dever::db('agent/dh_order')->update(array('where_id' => $id, 'status' => 7));
  433. Dever::load('agent/lib/dhorder')->updateSell($info, 2);
  434. if (Dever::project('sms')) {
  435. $member = Dever::db('agent/member')->find($info['mid']);
  436. Dever::load('sms/api')->send('daili_goods_no', $member['mobile'], array('name' => $member['name'], 'content' => $desc));
  437. }
  438. }
  439. }
  440. }
  441. # 确认收货
  442. public function setSellOrderStatus_api()
  443. {
  444. $order_id = Dever::input('order_id');
  445. $info = Dever::db('agent/dh_order')->find($order_id);
  446. if ($info) {
  447. Dever::load('agent/lib/dhorder')->finish($info, $info['shop_id']);
  448. return 'reload';
  449. } else {
  450. Dever::alert('错误的订单号');
  451. }
  452. }
  453. # 获取权益名称
  454. public function getGoods($type, $type_id, $sku_id)
  455. {
  456. if ($type == 1) {
  457. if ($sku_id == -2) {
  458. return '商品';
  459. }
  460. $goods_info = Dever::load('goods/lib/info')->getInfoBySku($type_id, $sku_id);
  461. if (isset($goods_info['sku'])) {
  462. $sku = '-' . $goods_info['sku']['string'];
  463. } else {
  464. $sku = '';
  465. }
  466. return array('name' => $goods_info['name'] . $sku, 'price' => $goods_info['price']);
  467. } elseif ($type == 2) {
  468. $code = Dever::db('card/code')->find($sku_id);
  469. $card = Dever::db('card/info')->find($code['card_id']);
  470. return array('name' => $card['name'], 'price' => $code['total_cash']);
  471. } elseif ($type == 3) {
  472. $prize = Dever::db('setting/prize')->find($type_id);
  473. return array('name' => $prize['name'], 'price' => $prize['price']);
  474. }
  475. }
  476. public function setOrderStatus_api()
  477. {
  478. $where['where_id'] = Dever::input('id');
  479. $order = Dever::db('agent/order')->find($where['where_id']);
  480. if ($order) {
  481. $where['status'] = Dever::input('value');
  482. if ($where['status'] == 6) {
  483. $where['history_status'] = $order['status'];
  484. }
  485. Dever::db('agent/order')->update($where);
  486. }
  487. return 'reload';
  488. }
  489. }