Manage.php 24 KB

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