Order.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364
  1. <?php
  2. namespace app\admin\controller\shopro\commission;
  3. use app\admin\controller\shopro\Base;
  4. use think\Db;
  5. use think\exception\PDOException;
  6. use think\exception\ValidateException;
  7. use Exception;
  8. /**
  9. * 分销订单管理
  10. *
  11. * @icon fa fa-circle-o
  12. */
  13. class Order extends Base
  14. {
  15. /**
  16. * Order模型对象
  17. * @var \app\admin\model\shopro\commission\Order
  18. */
  19. protected $model = null;
  20. public function _initialize()
  21. {
  22. $this->loadlang('shopro/order/order_item');
  23. $this->loadlang('shopro/order/order');
  24. parent::_initialize();
  25. $this->model = new \app\admin\model\shopro\commission\Order;
  26. $this->rewardModel = new \app\admin\model\shopro\commission\Reward;
  27. }
  28. /**
  29. * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
  30. * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
  31. * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
  32. */
  33. /**
  34. * 查看
  35. */
  36. public function index()
  37. {
  38. //设置过滤方法
  39. $this->request->filter(['strip_tags']);
  40. if ($this->request->isAjax()) {
  41. $nobuildfields = [
  42. 'buyer_nickname','buyer_mobile',
  43. 'agent_nickname','agent_mobile',
  44. 'commission_user_id', 'commission_nickname', 'commission_mobile',
  45. 'order_createtime', 'order_sn','goods_title',
  46. ];
  47. list($where, $sort, $order, $offset, $limit) = $this->custombuildparams(null, $nobuildfields);
  48. // 查询所有数据,计算统计数据
  49. $total = $this->buildSearch()
  50. ->where($where)
  51. ->order($sort, $order)
  52. ->count();
  53. // 查询分页数据
  54. $list = $this->buildSearch()
  55. ->with(['order' => function ($query) {
  56. $query->removeOption('soft_delete')->field('id,type,order_sn,user_id,activity_type,goods_amount,status,total_amount,score_amount,total_fee,pay_fee,score_fee,pay_type,paytime,platform,ext,createtime,updatetime');
  57. }, 'item' => function ($query) {
  58. $query->field('id,user_id,order_id,goods_id,goods_type,activity_id,activity_type,goods_sku_text,goods_title,goods_image,goods_original_price,discount_fee,goods_price,goods_num,dispatch_status,dispatch_fee,dispatch_type,aftersale_status,comment_status,refund_status,refund_fee,ext,createtime,updatetime');
  59. }, 'agent', 'reward.agent', 'buyer' => function ($query) {
  60. $query->field('id,nickname,avatar,mobile,prevtime,logintime,jointime');
  61. }])
  62. ->where($where)
  63. ->order($sort, $order)
  64. ->limit($offset, $limit)
  65. ->select();
  66. $list = collection($list)->toArray();
  67. // 处理分页数据格式
  68. $newList = [];
  69. foreach ($list as $key => $data) {
  70. $rewards = $data['reward'];
  71. $commission_total = 0;
  72. $commissioned_total = 0;
  73. foreach ($rewards as $reward) {
  74. if ($reward['status'] == 1) {
  75. $commissioned_total += $reward['commission'];
  76. }
  77. $commission_total += $reward['commission'];
  78. }
  79. $data['commission_total'] = number_format($commission_total, 2, '.', '');
  80. $data['commissioned_total'] = number_format($commissioned_total, 2, '.', '');
  81. $newList[] = $data;
  82. }
  83. // 处理顶部统计数据
  84. $amount_total = 0; // 商品结算总金额
  85. $commission_total = 0; // 分佣总金额
  86. $commission_waiting_total = 0; // 待结算
  87. $commissioned_total = 0; // 已结算
  88. $commission_back_total = 0; // 已退回
  89. $commission_cancel_total = 0; // 已取消
  90. $total_page = intval(ceil($total / 1000));
  91. for ($i = 0; $i < $total_page; $i++) {
  92. $totalList = $this->buildSearch()
  93. ->with(['reward' => function ($query) {
  94. $query->field('id,status,commission,commission_order_id');
  95. }])
  96. ->field('id,amount,commission_reward_status,commission_event')
  97. ->where($where)
  98. ->order($sort, $order)
  99. ->limit(($i * 1000), 1000)
  100. ->select();
  101. foreach ($totalList as $key => $li) {
  102. $amount_total += $li['amount'];
  103. foreach ($li['reward'] as $reward) {
  104. if ($reward['status'] == 1) {
  105. $commissioned_total += $reward['commission'];
  106. } else if ($reward['status'] == -1) {
  107. $commission_back_total += $reward['commission'];
  108. } else if ($reward['status'] == 0) {
  109. $commission_waiting_total += $reward['commission'];
  110. } else if ($reward['status'] == -2) {
  111. $commission_cancel_total += $reward['commission'];
  112. }
  113. $commission_total += $reward['commission'];
  114. }
  115. }
  116. }
  117. $result = [
  118. "total" => $total,
  119. "rows" => $newList,
  120. "amount_total" => number_format($amount_total, 2, '.', ''),
  121. "commission_total" => number_format($commission_total, 2, '.', ''),
  122. "commissioned_total" => number_format($commissioned_total, 2, '.', ''),
  123. "commission_back_total" => number_format($commission_back_total, 2, '.', ''),
  124. "commission_waiting_total" => number_format($commission_waiting_total, 2, '.', ''),
  125. "commission_cancel_total" => number_format($commission_cancel_total, 2, '.', '')
  126. ];
  127. $this->success('分销订单', null, $result);
  128. }
  129. return $this->view->fetch();
  130. }
  131. /**
  132. * 分销订单结算
  133. *
  134. * @param int $id 分销订单ID
  135. */
  136. public function runCommission($id = null) {
  137. if (!$id) {
  138. $id = $this->request->get('id');
  139. }
  140. $row = $this->model->get($id);
  141. $result = Db::transaction(function () use ($row) {
  142. return (new \addons\shopro\library\commission\Reward)->runCommissionRewardByOrder('admin', $row);
  143. });
  144. if ($result) {
  145. $this->success('结算成功');
  146. } else {
  147. $this->error('订单已结算或没有要结算的佣金');
  148. }
  149. }
  150. /**
  151. * 分销订单退回
  152. *
  153. * @param int $id 分销订单ID
  154. * @param int $delete 是否删除业绩
  155. */
  156. public function backCommission($id = null, $delete = 0)
  157. {
  158. if (!$id) {
  159. $id = $this->request->get('id');
  160. }
  161. $row = $this->model->get($id);
  162. $result = Db::transaction(function () use ($row, $delete) {
  163. return (new \addons\shopro\library\commission\Reward)->backCommissionRewardByOrder('admin', $row, $delete);
  164. });
  165. if ($result) {
  166. $this->success('退回成功');
  167. } else {
  168. $this->error('订单已退回或未结算');
  169. }
  170. }
  171. /**
  172. * 分销订单取消
  173. *
  174. * @param int $id 分销订单ID
  175. * @param int $delete 是否删除业绩
  176. */
  177. public function cancelCommission($id = null, $delete = 0)
  178. {
  179. if (!$id) {
  180. $id = $this->request->get('id');
  181. }
  182. $row = $this->model->get($id);
  183. $result = Db::transaction(function () use ($row, $delete) {
  184. return (new \addons\shopro\library\commission\Reward)->backCommissionRewardByOrder('admin', $row, $delete);
  185. });
  186. if ($result) {
  187. $this->success('退回成功');
  188. } else {
  189. $this->error('订单已退回或未结算');
  190. }
  191. }
  192. private function buildSearch()
  193. {
  194. $filter = $this->request->get("filter", '');
  195. $filter = (array)json_decode($filter, true);
  196. $filter = $filter ? $filter : [];
  197. // 用户'parent_nickname','parent_mobile',
  198. // 购买人
  199. $buyer_nickname = isset($filter['buyer_nickname']) ? $filter['buyer_nickname'] : '';
  200. $buyer_mobile = isset($filter['buyer_mobile']) ? $filter['buyer_mobile'] : '';
  201. // 推广用户
  202. $agent_nickname = isset($filter['agent_nickname']) ? $filter['agent_nickname'] : '';
  203. $agent_mobile = isset($filter['agent_mobile']) ? $filter['agent_mobile'] : '';
  204. // 分销用户
  205. $commission_user_id = isset($filter['commission_user_id']) ? $filter['commission_user_id'] : 0;
  206. $commission_nickname = isset($filter['commission_nickname']) ? $filter['commission_nickname'] : '';
  207. $commission_mobile = isset($filter['commission_mobile']) ? $filter['commission_mobile'] : '';
  208. // 时间区间
  209. $order_createtime = isset($filter['order_createtime']) ? $filter['order_createtime'] : '';
  210. $order_createtime = array_filter(explode(' - ', $order_createtime));
  211. // 订单 & 商品
  212. $order_sn = isset($filter['order_sn']) ? $filter['order_sn'] : '';
  213. $goods_title = isset($filter['goods_title']) ? $filter['goods_title'] : '';
  214. // 当前表名
  215. $tableName = $this->model->getQuery()->getTable();
  216. $orders = $this->model;
  217. // 购买人查询
  218. if ($buyer_nickname || $buyer_mobile) {
  219. $orders = $orders->whereExists(function ($query) use ($buyer_nickname, $buyer_mobile, $tableName) {
  220. $userTableName = (new \app\admin\model\User())->getQuery()->getTable();
  221. $query = $query->table($userTableName)->where($userTableName . '.id=' . $tableName . '.buyer_id');
  222. if ($buyer_nickname) {
  223. $query = $query->where('nickname', 'like', "%{$buyer_nickname}%");
  224. }
  225. if ($buyer_mobile) {
  226. $query = $query->where('mobile', 'like', "%{$buyer_mobile}%");
  227. }
  228. return $query;
  229. });
  230. }
  231. // 推广人昵称,手机号
  232. if ($agent_nickname || $agent_mobile) {
  233. $orders = $orders->whereExists(function ($query) use ($agent_nickname, $agent_mobile, $tableName) {
  234. $userTableName = (new \app\admin\model\User())->getQuery()->getTable();
  235. $query = $query->table($userTableName)->where($userTableName . '.id=' . $tableName . '.agent_id');
  236. if ($agent_nickname) {
  237. $query = $query->where('nickname', 'like', "%{$agent_nickname}%");
  238. }
  239. if ($agent_mobile) {
  240. $query = $query->where('mobile', 'like', "%{$agent_mobile}%");
  241. }
  242. return $query;
  243. });
  244. }
  245. // 分销用户查询
  246. if ($commission_user_id || $commission_nickname || $commission_mobile) {
  247. $orders = $orders->whereExists(function ($query) use ($commission_user_id, $commission_nickname, $commission_mobile, $tableName) {
  248. $rewardTableName = (new \app\admin\model\shopro\commission\Reward())->getQuery()->getTable();
  249. $query = $query->table($rewardTableName)->where($rewardTableName . '.commission_order_id=' . $tableName . '.id');
  250. $query->where(function ($query) use ($commission_user_id, $commission_nickname, $commission_mobile, $rewardTableName) {
  251. $is_or = false;
  252. if ($commission_user_id) {
  253. $is_or = true;
  254. $query = $query->where('agent_id', $commission_user_id);
  255. }
  256. if ($commission_nickname || $commission_mobile) {
  257. $query->whereOr(function ($query) use ($commission_nickname, $commission_mobile, $rewardTableName) {
  258. $query->whereExists(function ($query) use ($commission_nickname, $commission_mobile, $rewardTableName) {
  259. $userTableName = (new \app\admin\model\User())->getQuery()->getTable();
  260. $query = $query->table($userTableName)->where($userTableName . '.id=' . $rewardTableName . '.agent_id');
  261. if ($commission_nickname) {
  262. $query = $query->whereOr('nickname', 'like', "%{$commission_nickname}%");
  263. }
  264. if ($commission_mobile) {
  265. $query = $query->whereOr('mobile', 'like', "%{$commission_mobile}%");
  266. }
  267. return $query;
  268. });
  269. return $query;
  270. });
  271. }
  272. return $query;
  273. });
  274. });
  275. }
  276. // 订单号查询
  277. if ($order_sn || $order_createtime) {
  278. $orders = $orders->whereExists(function ($query) use ($order_sn, $order_createtime, $tableName) {
  279. $orderTableName = (new \app\admin\model\shopro\order\Order())->getQuery()->getTable();
  280. $query = $query->table($orderTableName)->where($orderTableName . '.id=' . $tableName . '.order_id');
  281. if ($order_sn) {
  282. $query = $query->where('order_sn', 'like', "%{$order_sn}%");
  283. }
  284. if ($order_createtime) {
  285. $query = $query->where('createtime', 'BETWEEN time', $order_createtime);
  286. }
  287. return $query;
  288. });
  289. }
  290. // 商品名称
  291. if ($goods_title) {
  292. $orders = $orders->whereExists(function ($query) use ($goods_title, $tableName) {
  293. $orderTableName = (new \app\admin\model\shopro\order\OrderItem())->getQuery()->getTable();
  294. $query = $query->table($orderTableName)->where($orderTableName . '.id=' . $tableName . '.order_item_id');
  295. $query = $query->where('goods_title', 'like', "%{$goods_title}%");
  296. return $query;
  297. });
  298. }
  299. return $orders;
  300. }
  301. }