Manage.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  1. <?php
  2. namespace Agent\Lib;
  3. use Dever;
  4. class Manage
  5. {
  6. public function orderUpdate($id, $name, $data)
  7. {
  8. Dever::config('base')->hook = true;
  9. $audit = Dever::param('audit', $data);
  10. $status = Dever::param('status', $data);
  11. $order_id = Dever::param('order_id', $data);
  12. if ($order_id && $status) {
  13. if ($status < 3) {
  14. if ($audit == 1) {
  15. $update = array('where_id' => $order_id, 'status' => $status+1);
  16. if ($status == 2) {
  17. $order = Dever::db('agent/order')->find($order_id);
  18. $price = Dever::param('price', $data);
  19. if ($price <= 0) {
  20. $update['get_type'] = 2;
  21. } else {
  22. $update['get_type'] = 1;
  23. }
  24. $update['price'] = $price;
  25. $update['agent_cash'] = $price;
  26. $update['soft_cash'] = 0;
  27. $cstatus = Dever::param('cstatus', $data);
  28. if ($cstatus && $cstatus == 2 && $price > 0) {
  29. # 拆分代理费
  30. $role = Dever::db('setting/role')->one($order['role']);
  31. if ($role && $role['soft']) {
  32. if (strstr($role['soft'], '%')) {
  33. $role['soft'] = str_replace('%', '', $role['soft']);
  34. $role['soft'] = $price * ($role['soft']/100);
  35. }
  36. $update['agent_cash'] = $price - $role['soft'];
  37. $update['soft_cash'] = $role['soft'];
  38. }
  39. }
  40. $update['pay_status'] = 2;
  41. # 财务终审之后,先生成代理商
  42. if ($order['mid'] <= 0) {
  43. # 生成
  44. $where['mobile'] = $order['mobile'];
  45. $member = Dever::db('agent/member')->find($where);
  46. if ($member) {
  47. $update['mid'] = $member['id'];
  48. } else {
  49. $data = $where;
  50. $data['name'] = $order['name'];
  51. $data['idcard'] = $order['idcard'];
  52. $data['idcard_front'] = $order['idcard_front'];
  53. $data['idcard_back'] = $order['idcard_back'];
  54. $data['company_name'] = $order['company_name'];
  55. $data['company_pic'] = $order['company_pic'];
  56. $data['company_number'] = $order['company_number'];
  57. $data['role'] = 1;
  58. $data['parent_mid'] = $order['parent_mid'];
  59. $update['mid'] = Dever::db('agent/member')->insert($data);
  60. Dever::load('invite/api')->setRelation($update['mid'], $data['parent_mid']);
  61. }
  62. }
  63. }
  64. Dever::db('agent/order')->update($update);
  65. } else {
  66. Dever::db('agent/order')->update(array('where_id' => $order_id, 'status' => 5));
  67. }
  68. } elseif ($status == 3) {
  69. $info = Dever::db('agent/order_process')->find($id);
  70. if ($info && $info['status'] == 3) {
  71. $info['type'] = explode(',', $info['type']);
  72. }
  73. if (in_array(2, $info['type'])) {
  74. $goods_status = 3;
  75. } else {
  76. $goods_status = 2;
  77. }
  78. Dever::db('agent/order')->update(array('where_id' => $order_id, 'fdate' => time(), 'status' => 4, 'goods_status' => $goods_status));
  79. $order = Dever::db('agent/order')->find($order_id);
  80. if ($order && $order['mid']) {
  81. $member = Dever::db('agent/member')->find($order['mid']);
  82. $update['where_id'] = $order['mid'];
  83. if ($member && $member['status'] == 1) {
  84. $update['status'] = 2;
  85. }
  86. $update['area'] = $order['area'];
  87. $update['role'] = $order['role'];
  88. Dever::db('agent/member')->update($update);
  89. $area_data = array('mid' => $order['mid'], 'order_id' => $order['id'], 'role' => $order['role'], 'area' => $order['area']);
  90. $area = Dever::db('agent/member_area')->find($area_data);
  91. if (!$area) {
  92. $area_data['type'] = $order['get_type'];
  93. $area_data['price'] = $order['price'];
  94. Dever::db('agent/member_area')->insert($area_data);
  95. }
  96. }
  97. }
  98. }
  99. }
  100. # 发放权益
  101. public function set_commit_api()
  102. {
  103. Dever::config('base')->hook = true;
  104. $type = Dever::input('type', 2);
  105. $order_id = Dever::input('order_id');
  106. # 检测是否发放过了
  107. $order = Dever::db('agent/order')->find($order_id);
  108. if ($order['status'] != 3) {
  109. Dever::alert('无发放权限');
  110. }
  111. if ($order['mid'] <= 0) {
  112. $update = array('where_id' => $order_id);
  113. $where['mobile'] = $order['mobile'];
  114. $member = Dever::db('agent/member')->find($where);
  115. if ($member) {
  116. $update['mid'] = $member['id'];
  117. } else {
  118. $data = $where;
  119. $data['name'] = $order['name'];
  120. $data['idcard'] = $order['idcard'];
  121. $data['idcard_front'] = $order['idcard_front'];
  122. $data['idcard_back'] = $order['idcard_back'];
  123. $data['company_name'] = $order['company_name'];
  124. $data['company_pic'] = $order['company_pic'];
  125. $data['company_number'] = $order['company_number'];
  126. $data['role'] = 1;
  127. $data['parent_mid'] = $order['parent_mid'];
  128. $update['mid'] = Dever::db('agent/member')->insert($data);
  129. Dever::load('invite/api')->setRelation($update['mid'], $data['parent_mid']);
  130. }
  131. Dever::db('agent/order')->update($update);
  132. $order['mid'] = $update['mid'];
  133. }
  134. $order_process = Dever::db('agent/order_process')->find(array('order_id' => $order_id, 'status' => 3));
  135. $yes = -1;
  136. if (!$order_process) {
  137. # 可以发放
  138. $yes = 1;
  139. } elseif ($order_process) {
  140. $order_process['type'] = explode(',', $order_process['type']);
  141. if (!in_array($type, $order_process['type'])) {
  142. # 可以发放
  143. $yes = 2;
  144. }
  145. }
  146. if ($yes > 0) {
  147. if ($yes == 1) {
  148. $data['order_id'] = $order_id;
  149. $data['status'] = 3;
  150. $data['type'] = '1,' . $type;
  151. $state = Dever::db('agent/order_process')->insert($data);
  152. } else {
  153. $data['where_id'] = $order_process['id'];
  154. $order_process['type'][] = $type;
  155. $data['type'] = implode(',', $order_process['type']);
  156. $state = Dever::db('agent/order_process')->update($data);
  157. }
  158. if ($state) {
  159. if ($type == 2) {
  160. $this->setGoods($order);
  161. } elseif ($type == 3) {
  162. $this->setCash($order);
  163. }
  164. }
  165. return 'reload';
  166. } else {
  167. Dever::alert('无发放权限');
  168. }
  169. }
  170. private function setGoods($order)
  171. {
  172. $goods = Dever::db('agent/order_goods')->getData(array('order_id' => $order['id']));
  173. if (!$goods) {
  174. $goods = Dever::db('setting/role_goods')->getData(array('role_id' => $order['role'], 'give' => $order['order_type']));
  175. }
  176. if ($goods) {
  177. $where = array();
  178. foreach ($goods as $k => $v) {
  179. $where['mid'] = $order['mid'];
  180. $where['type'] = $v['type'];
  181. $where['type_id'] = $v['type_id'];
  182. $where['sku_id'] = $v['sku_id'];
  183. $info = Dever::db('agent/member_goods')->find($where);
  184. if ($info) {
  185. $up['where_id'] = $info['id'];
  186. $up['total_num'] = $info['total_num'] + $v['num'];
  187. Dever::db('agent/member_goods')->update($up);
  188. } else {
  189. $up = $where;
  190. $up['total_num'] = $v['num'];
  191. Dever::db('agent/member_goods')->insert($up);
  192. }
  193. }
  194. }
  195. }
  196. private function setCash($order)
  197. {
  198. $param = Dever::input('param');
  199. if ($param) {
  200. $param = explode(',', $param);
  201. foreach ($param as $k => $v) {
  202. $t = explode('-', $v);
  203. $where['type'] = $t[0];
  204. $where['order_id'] = $order['id'];
  205. $where['mid'] = $order['mid'];
  206. $where['parent_mid'] = $t[2];
  207. $info = Dever::db('agent/order_cash')->find($where);
  208. if (!$info) {
  209. $insert = $where;
  210. $insert['cash'] = $t[3];
  211. $insert['per'] = $t[5];
  212. Dever::db('agent/order_cash')->insert($insert);
  213. } else {
  214. $update['where_id'] = $info['id'];
  215. $update['cash'] = $t[3];
  216. $update['per'] = $t[5];
  217. Dever::db('agent/order_cash')->update($update);
  218. }
  219. $member = Dever::db('agent/member')->find($where['mid']);
  220. $desc = $member['name'] . '成为代理商,佣金'.$t[5].'%';
  221. Dever::load('agent/lib/member')->up($order['id'], $order['role'], $where['type'], $where['parent_mid'], $t[3], $order['agent_cash'], $t[4], $desc);
  222. }
  223. }
  224. }
  225. public function sellOrderUpdate($id, $name, $data)
  226. {
  227. Dever::config('base')->hook = true;
  228. $update = array();
  229. $audit = Dever::param('audit', $data);
  230. $info = Dever::db('agent/dh_order')->one($id);
  231. if ($audit > 1 && $info && $info['status'] == 2) {
  232. if ($audit == 2) {
  233. # 成功
  234. Dever::setInput('order_id', $id);
  235. Dever::load('agent/lib/dhorder.audit_commit');
  236. } else {
  237. Dever::db('agent/dh_order')->update(array('where_id' => $id, 'status' => 7));
  238. }
  239. }
  240. }
  241. # 确认收货
  242. public function setSellOrderStatus_api()
  243. {
  244. $order_id = Dever::input('order_id');
  245. $info = Dever::db('agent/dh_order')->find($order_id);
  246. if ($info) {
  247. Dever::load('agent/lib/dhorder')->finish($info, $info['shop_id']);
  248. return 'reload';
  249. } else {
  250. Dever::alert('错误的订单号');
  251. }
  252. }
  253. }