Manage.php 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  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. $get_type = Dever::param('get_type', $data);
  18. $update['get_type'] = $get_type;
  19. $update['pay_status'] = 2;
  20. # 财务终审之后,先生成代理商
  21. $order = Dever::db('agent/order')->find($order_id);
  22. if ($order['mid'] <= 0) {
  23. # 生成
  24. $where['mobile'] = $order['mobile'];
  25. $member = Dever::db('agent/member')->find($where);
  26. if ($member) {
  27. $update['mid'] = $member['id'];
  28. } else {
  29. $data = $where;
  30. $data['name'] = $order['name'];
  31. $data['idcard'] = $order['idcard'];
  32. $data['idcard_front'] = $order['idcard_front'];
  33. $data['idcard_back'] = $order['idcard_back'];
  34. $data['role'] = 1;
  35. $data['parent_mid'] = $order['parent_mid'];
  36. $update['mid'] = Dever::db('agent/member')->insert($data);
  37. }
  38. }
  39. }
  40. Dever::db('agent/order')->update($update);
  41. } else {
  42. Dever::db('agent/order')->update(array('where_id' => $order_id, 'status' => 5));
  43. }
  44. } elseif ($status == 3) {
  45. $info = Dever::db('agent/order_process')->find($id);
  46. if ($info && $info['status'] == 3) {
  47. $info['type'] = explode(',', $info['type']);
  48. }
  49. if (in_array(2, $info['type'])) {
  50. $goods_status = 3;
  51. } else {
  52. $goods_status = 2;
  53. }
  54. Dever::db('agent/order')->update(array('where_id' => $order_id, 'fdate' => time(), 'status' => 4, 'goods_status' => $goods_status));
  55. $order = Dever::db('agent/order')->find($order_id);
  56. if ($order && $order['mid']) {
  57. $member = Dever::db('agent/member')->find($order['mid']);
  58. if ($member && $member['status'] == 1) {
  59. Dever::db('agent/member')->update(array('where_id' => $order['mid'], 'status' => 2));
  60. }
  61. $area_data = array('mid' => $order['mid'], 'order_id' => $order['id'], 'role' => $order['role'], 'area' => $order['area']);
  62. $area = Dever::db('agent/member_area')->find($area_where);
  63. if (!$area) {
  64. $area_data['type'] = $order['get_type'];
  65. Dever::db('agent/member_area')->insert($area_where);
  66. }
  67. }
  68. }
  69. }
  70. }
  71. # 发放权益
  72. public function set_commit_api()
  73. {
  74. Dever::config('base')->hook = true;
  75. $type = Dever::input('type', 2);
  76. $order_id = Dever::input('order_id');
  77. # 检测是否发放过了
  78. $order = Dever::db('agent/order')->find($order_id);
  79. if ($order['status'] != 3) {
  80. Dever::alert('无发放权限');
  81. }
  82. if ($order['mid'] <= 0) {
  83. $update = array('where_id' => $order_id);
  84. $where['mobile'] = $order['mobile'];
  85. $member = Dever::db('agent/member')->find($where);
  86. if ($member) {
  87. $update['mid'] = $member['id'];
  88. } else {
  89. $data = $where;
  90. $data['name'] = $order['name'];
  91. $data['idcard'] = $order['idcard'];
  92. $data['idcard_front'] = $order['idcard_front'];
  93. $data['idcard_back'] = $order['idcard_back'];
  94. $data['role'] = 1;
  95. $data['parent_mid'] = $order['parent_mid'];
  96. $update['mid'] = Dever::db('agent/member')->insert($data);
  97. }
  98. Dever::db('agent/order')->update($update);
  99. $order['mid'] = $update['mid'];
  100. }
  101. $order_process = Dever::db('agent/order_process')->find(array('order_id' => $order_id, 'status' => 3));
  102. $yes = -1;
  103. if (!$order_process) {
  104. # 可以发放
  105. $yes = 1;
  106. } elseif ($order_process) {
  107. $order_process['type'] = explode(',', $order_process['type']);
  108. if (!in_array($type, $order_process['type'])) {
  109. # 可以发放
  110. $yes = 2;
  111. }
  112. }
  113. if ($yes > 0) {
  114. if ($yes == 1) {
  115. $data['order_id'] = $order_id;
  116. $data['status'] = 3;
  117. $data['type'] = '1,' . $type;
  118. $state = Dever::db('agent/order_process')->insert($data);
  119. } else {
  120. $data['where_id'] = $order_process['id'];
  121. $order_process['type'][] = $type;
  122. $data['type'] = implode(',', $order_process['type']);
  123. $state = Dever::db('agent/order_process')->update($data);
  124. }
  125. if ($state) {
  126. if ($type == 2) {
  127. $this->setGoods($order);
  128. } elseif ($type == 3) {
  129. $this->setCash($order);
  130. }
  131. }
  132. return 'reload';
  133. } else {
  134. Dever::alert('无发放权限');
  135. }
  136. }
  137. private function setGoods($order)
  138. {
  139. $goods = Dever::db('agent/order_goods')->getData(array('order_id' => $order['id']));
  140. if (!$goods) {
  141. $goods = Dever::db('setting/role_goods')->getData(array('role_id' => $order['role'], 'give' => $order['order_type']));
  142. }
  143. if ($goods) {
  144. $where = array();
  145. foreach ($goods as $k => $v) {
  146. $where['mid'] = $order['mid'];
  147. $where['type'] = $v['type'];
  148. $where['type_id'] = $v['type_id'];
  149. $where['sku_id'] = $v['sku_id'];
  150. $info = Dever::db('agent/member_goods')->find($where);
  151. if ($info) {
  152. $up['where_id'] = $info['id'];
  153. $up['total_num'] = $info['total_num'] + $v['num'];
  154. Dever::db('agent/member_goods')->update($up);
  155. } else {
  156. $up = $where;
  157. $up['total_num'] = $v['num'];
  158. Dever::db('agent/member_goods')->insert($up);
  159. }
  160. }
  161. }
  162. }
  163. private function setCash($order)
  164. {
  165. $param = Dever::input('param');
  166. if ($param) {
  167. $param = explode(',', $param);
  168. foreach ($param as $k => $v) {
  169. $t = explode('-', $v);
  170. $where['type'] = $t[0];
  171. $where['order_id'] = $order['id'];
  172. $where['mid'] = $order['mid'];
  173. $where['parent_mid'] = $t[2];
  174. $info = Dever::db('agent/order_cash')->find($where);
  175. if (!$info) {
  176. $insert = $where;
  177. $insert['cash'] = $t[3];
  178. Dever::db('agent/order_cash')->insert($insert);
  179. } else {
  180. $update['where_id'] = $info['id'];
  181. $update['cash'] = $t[3];
  182. Dever::db('agent/order_cash')->update($update);
  183. }
  184. if ($where['type'] == 1) {
  185. Dever::load('agent/lib/member')->up($where['parent_mid'], $t[3], $order['price'], 1);
  186. } elseif ($where['type'] == 2) {
  187. Dever::load('agent/lib/member')->up($where['parent_mid'], $t[3], $order['price'], 1, 'upGroupSell');
  188. }
  189. }
  190. }
  191. }
  192. }