OrderController.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Handlers\ExpressHandler;
  4. use App\Http\Controllers\Controller;
  5. use App\Models\DwbsUser;
  6. use App\Models\DwbsWarea;
  7. use App\Models\Goods;
  8. use App\Models\OrderCancel;
  9. use App\Models\OrderDetail;
  10. use App\Models\OrderRefund;
  11. use App\Models\Store;
  12. use App\Models\User;
  13. use App\Models\Order;
  14. use App\Models\Admin;
  15. use Illuminate\Http\Request;
  16. use Illuminate\Support\Facades\DB;
  17. use Illuminate\Support\Facades\Auth;
  18. use Illuminate\Support\Facades\Log;
  19. class OrderController extends Controller
  20. {
  21. public function list(Request $request){
  22. $page_index=$request->input('page_index');
  23. $page_size=$request->input('page_size');
  24. $num=$page_size*($page_index-1);
  25. $admin_id=Auth::user()->id;
  26. $admin=Admin::where('id',$admin_id)->first();
  27. if($admin && in_array($admin->role_id,[22,24])){//超级管理员
  28. $data=Order::with(['user','store','address','cancel'=>function($query){$query->where('using',1);}]);
  29. }else{
  30. $warea_ids=DwbsWarea::where('admin_id',$admin_id)->pluck('id');
  31. $agent_ids=DwbsUser::whereIn('warea_id',$warea_ids)->pluck('id');
  32. $store_ids=Store::whereIn('user_id',$agent_ids)->pluck('id');
  33. $data=Order::whereIn('store_id',$store_ids)
  34. ->with(['user','store','address','cancel'=>function($query){$query->where('using',1);}]);
  35. }
  36. //筛选订单号
  37. if($request->has('order_no') && !empty($request->input('order_no'))){
  38. $data->where('order_no',"like","%".$request->input('order_no')."%");
  39. }
  40. //店铺名称手机号筛选
  41. if($request->has('agent_phone') && !empty($request->input('agent_phone'))){
  42. $store_ids=Store::where('phone','like',"%".$request->input('agent_phone')."%")
  43. ->orWhere('name','like',"%".$request->input('agent_phone')."%")->pluck('id');
  44. $data->whereIn('store_id',$store_ids);
  45. }
  46. //客户信息筛选
  47. if($request->has('user_phone') && !empty($request->input('user_phone'))){
  48. $user_ids=User::where('phone','like',"%".$request->input('user_phone')."%")
  49. ->orWhere('nickname','like',"%".$request->input('user_phone')."%")->pluck('id');
  50. $data->whereIn('user_id',$user_ids);
  51. }
  52. //状态筛选
  53. if($request->input('status')!='all'){
  54. if(!empty($request->input('status')) || $request->input('status')==0){
  55. $data->where('status',$request->input('status'));
  56. }
  57. }
  58. //筛选订单类型
  59. if($request->has('type') && !empty($request->input('type'))){
  60. switch($request->input('type')){
  61. case 1:
  62. $data->where('is_pay',1);
  63. $data->where('is_help',1);
  64. $data->where('self_pay',1);
  65. break;
  66. case 2:
  67. $data->where('is_pay',1);
  68. $data->where('is_help',1);
  69. $data->where('self_pay',0);
  70. break;
  71. case 3:
  72. $data->where('is_pay',1);
  73. $data->where('is_help',0);
  74. $data->where('self_pay',0);
  75. break;
  76. case 4:
  77. $data->where('is_pay',1);
  78. $data->where('is_help',0);
  79. $data->where('self_pay',1);
  80. break;
  81. default:
  82. $data->where([]);
  83. }
  84. }
  85. //日期时间筛选
  86. if($request->input('start_time') && $request->input('end_time')){
  87. $data->whereBetween('created_at',[$request->input('start_time'),$request->input('end_time')]);
  88. }
  89. $count=$data->count();
  90. $list=$data->orderBy('id','desc')->skip($num)->limit($page_size)->get();
  91. $wareas=DwbsWarea::pluck('name','id');
  92. $user_ids=Store::pluck('user_id');
  93. $store_user_ids=Store::pluck('user_id','id');
  94. $warea_user_ids=DwbsUser::withTrashed()->whereIn('id',$user_ids)->pluck('warea_id','id');
  95. foreach($list as $key=>$val){
  96. $user_id=$store_user_ids[$val->store_id];
  97. $warea_id=$warea_user_ids[$user_id];
  98. $list[$key]->warea=$wareas[$warea_id];
  99. }
  100. return $this->success_list($list,'成功',$count);
  101. }
  102. public function export(Request $request){
  103. ini_set('memory_limit', '4096M');
  104. // $list=Order::orderBy('id','desc')
  105. // ->select('id','order_no','created_at','user_id','store_id','status','account','total','self_receive','express_receive_time','remark')
  106. //// ->limit(1000)
  107. // ->get();
  108. //return $this->success($list);
  109. $admin_id=Auth::user()->id;
  110. $admin=Admin::where('id',$admin_id)->first();
  111. if($admin && in_array($admin->role_id,[22,24])) {//超级管理员
  112. $data=Order::with(['user','store','address','cancel'=>function($query){$query->where('using',1);}]);
  113. }else{
  114. $warea_ids=DwbsWarea::where('admin_id',$admin_id)->pluck('id');
  115. $agent_ids=DwbsUser::whereIn('warea_id',$warea_ids)->pluck('id');
  116. $store_ids=Store::whereIn('user_id',$agent_ids)->pluck('id');
  117. $data=Order::whereIn('store_id',$store_ids)
  118. ->with(['user:id,nickname,phone','store:id,name,phone','address:id,name,phone,province,city,area,address','cancel'=>function($query){$query->where('using',1);}]);
  119. }
  120. //筛选订单号
  121. if($request->has('order_no') && !empty($request->input('order_no'))){
  122. $data->where('order_no',$request->input('order_no'));
  123. }
  124. //代理手机号筛选
  125. if($request->has('agent_phone') && !empty($request->input('agent_phone'))){
  126. $agent=DwbsUser::where('mobile',$request->input('agent_phone'))->first();
  127. if($agent){
  128. $store=Store::where('user_id',$agent->id)->first();
  129. if($store){
  130. $data->where('store_id',$store->id);
  131. }else{
  132. return $this->error('450001','代理店铺不存在');
  133. }
  134. }else{
  135. return $this->error('450001','代理手机号不存在');
  136. }
  137. }
  138. //用户信息筛选
  139. if($request->has('user_phone') && !empty($request->input('user_phone'))){
  140. $user=User::where('phone',$request->input('user_phone'))->first();
  141. if(empty($user)){
  142. return $this->error('450001','用户手机号不存在');
  143. }
  144. $data->where('user_id',$user->id);
  145. }
  146. //状态筛选
  147. if(!empty($request->input('status'))){
  148. $data->where('status',$request->input('status'));
  149. }
  150. //筛选订单类型
  151. if($request->has('type') && !empty($request->input('type'))){
  152. switch($request->input('type')){
  153. case 1:
  154. $data->where('is_pay',1);
  155. $data->where('is_help',1);
  156. $data->where('self_pay',1);
  157. break;
  158. case 2:
  159. $data->where('is_pay',1);
  160. $data->where('is_help',1);
  161. $data->where('self_pay',0);
  162. break;
  163. case 3:
  164. $data->where('is_pay',1);
  165. $data->where('is_help',0);
  166. $data->where('self_pay',0);
  167. break;
  168. case 4:
  169. $data->where('is_pay',1);
  170. $data->where('is_help',0);
  171. $data->where('self_pay',1);
  172. break;
  173. default:
  174. $data->where([]);
  175. }
  176. }
  177. //日期时间筛选
  178. $start_time=$request->input('start_time');
  179. $end_time=$request->input('end_time');
  180. if($start_time && $end_time){
  181. $data->whereBetween('created_at',[$start_time,$end_time]);
  182. }
  183. $list=$data->orderBy('id','desc')
  184. ->select('id','order_no','created_at','user_id','store_id','status','account','total','self_receive','express_receive_time','remark')
  185. ->get();
  186. $wareas=DwbsWarea::pluck('name','id');
  187. $user_ids=Store::withTrashed()->where('is_failure',0)->pluck('user_id');
  188. $store_user_ids=Store::withTrashed()->where('is_failure',0)->pluck('user_id','id');
  189. $warea_user_ids=DwbsUser::withTrashed()->whereIn('id',$user_ids)->pluck('warea_id','id');
  190. foreach($list as $key=>$val){
  191. $user_id=$store_user_ids[$val->store_id];
  192. $warea_id=$warea_user_ids[$user_id];
  193. $list[$key]->warea=$wareas[$warea_id];
  194. }
  195. return $this->success($list);
  196. }
  197. //获取订单详情
  198. public function getOrderDetail(Request $request){
  199. $order_no=$request->input('order_no');
  200. $goods_ids = OrderDetail::where('order_no', $order_no)->groupBy('goods_id')->pluck('goods_id');
  201. $goods = [];
  202. foreach ($goods_ids as $key => $val) {
  203. $goods[$key] = Goods::where('id', $val)->first();
  204. $goods[$key]->sku = OrderDetail::where('order_no', $order_no)->where('goods_id', $val)->get();
  205. }
  206. $list['goods']=$goods;
  207. $order=Order::where('order_no',$order_no)->first();
  208. if($order->apply_cancel > 1){
  209. $order_cancel=OrderCancel::where('order_id',$order->id)->OrderBy('created_at')->get();
  210. $list['cancel']=$order_cancel;
  211. }
  212. if($order->is_refund > 0){
  213. $refund=OrderRefund::where('order_no',$order->order_no)->OrderBy('created_at')->get();
  214. $list['refund']=$refund;
  215. }
  216. return $this->success($goods);
  217. }
  218. //获取订单详情
  219. public function getOrderDetails(Request $request){
  220. $order_no=$request->input('order_no');
  221. $goods_ids = OrderDetail::where('order_no', $order_no)->groupBy('goods_id')->pluck('goods_id');
  222. $goods = [];
  223. foreach ($goods_ids as $key => $val) {
  224. $goods[$key] = Goods::where('id', $val)->first();
  225. $goods[$key]->sku = OrderDetail::where('order_no', $order_no)->where('goods_id', $val)->get();
  226. }
  227. $list['goods']=$goods;
  228. $order=Order::with('refund:id,order_no')->where('order_no',$order_no)->first();
  229. if($order->apply_cancel > 1){
  230. $order_cancel=OrderCancel::where('order_id',$order->id)->OrderBy('created_at')->get();
  231. $list['cancel']=$order_cancel;
  232. }
  233. if(count($order->refund) >= 1){
  234. $refund=OrderRefund::where('order_no',$order->order_no)->OrderBy('created_at')->get();
  235. $list['refund']=$refund;
  236. }
  237. return $this->success($list);
  238. }
  239. //获取门店、订单日销售额对比
  240. public function getOrderDailySales(Request $request){
  241. $store_id=$request->input('store_id');
  242. $startdate=$request->input('startdate');
  243. $enddate=$request->input('enddate');
  244. $where=$wheres=[];
  245. if($store_id){
  246. $where['store_id']=$store_id;
  247. }
  248. if($startdate && $enddate){
  249. $start=date("Y-m-d",strtotime($startdate));
  250. $end=date("Y-m-d",strtotime($enddate));
  251. }else{
  252. $start=date("Y-m-d",strtotime('-7 days'));
  253. $end=date("Y-m-d");
  254. }
  255. $dates=$this->getDateFromRange($start,$end);
  256. $list=[];
  257. foreach($dates as $key=>$val){
  258. $list[$val]=Order::whereDate('created_at',$val)->where($where)
  259. ->select(DB::raw('ifnull(sum(total),0) as total'),DB::raw('ifnull(sum(account),0) as money'))
  260. ->where('is_pay',1)->where('apply_cancel',[0,1,3])->where('is_refund',[0,1])->first();
  261. }
  262. return $this->success($list);
  263. }
  264. function getDateFromRange($startdate, $enddate){
  265. $stimestamp = strtotime($startdate);
  266. $etimestamp = strtotime($enddate);
  267. // 计算日期段内有多少天
  268. $days = ($etimestamp-$stimestamp)/86400+1;
  269. // 保存每天日期
  270. $date = array();
  271. for($i=0; $i<$days; $i++){
  272. $date[] = date('Y-m-d', $stimestamp+(86400*$i));
  273. }
  274. return $date;
  275. }
  276. //获取店铺销售额前10
  277. public function getStoreTop10(){
  278. $list=Order::with('store:id,name')->select('store_id',DB::raw('sum(account) as money'))
  279. ->where('is_pay',1)->groupBy('store_id')
  280. ->orderByDesc('money')->limit(10)->get();
  281. return $this->success($list);
  282. }
  283. //查询订单物流信息
  284. public function getOrderExpress(Request $request){
  285. $order_no=$request->input('order_no');
  286. $order=Order::with('address')->where('order_no',$order_no)->first();
  287. if(empty($order)){
  288. return $this->error('450001','订单信息有误');
  289. }
  290. if($order->express_state==3){ //已签收
  291. $express=json_decode($order->express_info,true);
  292. }else{ //未签收
  293. $express=new ExpressHandler();
  294. $CustomerName = null;
  295. if($order->express_code=='SF'){
  296. $CustomerName = substr($order->express_phone,-4);
  297. }
  298. $express=$express->getExpress($order->express_no, $order->express_code, $order->order_no, $CustomerName);
  299. }
  300. $data['express']=$express;
  301. $data['express_state']=$order->express_state;
  302. $data['express_company']=$order->express_company;
  303. $data['express_no']=$order->express_no;
  304. $data['express_time']=$order->express_time;
  305. return $this->success($data);
  306. }
  307. }