GoodsController.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\GoodSku;
  5. use App\Models\OrderDetail;
  6. use App\Models\Order;
  7. use App\Models\Store;
  8. use Illuminate\Http\Request;
  9. use App\Models\Goods;
  10. use App\Models\Region;
  11. use App\Models\Address;
  12. use Illuminate\Support\Facades\DB;
  13. use Illuminate\Support\Facades\Log;
  14. use Illuminate\Support\Facades\Storage;
  15. class GoodsController extends Controller
  16. {
  17. //商品列表
  18. public function list(Request $request){
  19. $page_index=$request->input('page_index');
  20. $page_size=$request->input('page_size');
  21. $num=$page_size*($page_index-1);
  22. $count=Goods::count();
  23. $list=Goods::orderBy('id','desc')->skip($num)->take($page_size)->get();
  24. foreach($list as $key=>$val){
  25. $list[$key]->good_sku=GoodSku::where('goods_id',$val->id)->orderBy('sort','asc')->get();
  26. }
  27. return $this->success_list($list,'成功',$count);
  28. }
  29. //添加商品
  30. public function addGoods(Request $request){
  31. try{
  32. DB::transaction(function()use($request){
  33. //添加商品基本信息
  34. $goods=Goods::create([
  35. 'name'=>$request->input('name'),
  36. 'price'=>$request->input('price'),
  37. 'vip_price'=>$request->input('vip_price'),
  38. 'super_price'=>$request->input('super_price'),
  39. 'top_price'=>$request->input('top_price'),
  40. 'crown_price'=>$request->input('crown_price'),
  41. 'content'=>$request->input('content'),
  42. 'img'=>$request->input('img'),
  43. 'main_attr'=>$request->input('main_attr'),
  44. 'banner'=>json_encode($request->input('banner')),
  45. 'is_delete'=>0,
  46. 'is_shelves'=>0,
  47. ]);
  48. $sku=$request->input('sku');
  49. $data=[];
  50. foreach($sku as $key=>$val){
  51. $data[$key]=$val;
  52. $data[$key]['goods_id']=$goods->id;
  53. $data[$key]['num']=1000;
  54. $data[$key]['sale_num']=0;
  55. $data[$key]['created_at']=date("Y-m-d H:i:s");
  56. $data[$key]['updated_at']=date("Y-m-d H:i:s");
  57. }
  58. GoodSku::insert($data);
  59. });
  60. return $this->success([]);
  61. }catch(\Exception $e){
  62. return $this->error($e->getMessage());
  63. }
  64. }
  65. //编辑商品
  66. public function editGoods(Request $request){
  67. $sku_old=GoodSku::where('goods_id',$request->input('id'))
  68. ->select(DB::raw("CONCAT(type,'-',size,'-',sort) as string"))->pluck('string')->toArray();
  69. $sku_new=[];
  70. foreach($request->input('sku') as $key=>$val){
  71. $sku_new[$key]=$val['type'].'-'.$val['size'].'-'.$val['sort'];
  72. }
  73. Log::info(json_encode($sku_new));
  74. try{
  75. DB::transaction(function()use($request,$sku_new,$sku_old){
  76. //添加商品基本信息
  77. $goods=Goods::where('id',$request->input('id'))->update([
  78. 'name'=>$request->input('name'),
  79. 'price'=>$request->input('price'),
  80. 'vip_price'=>$request->input('vip_price'),
  81. 'super_price'=>$request->input('super_price'),
  82. 'top_price'=>$request->input('top_price'),
  83. 'crown_price'=>$request->input('crown_price'),
  84. 'content'=>$request->input('content'),
  85. 'img'=>$request->input('img'),
  86. 'main_attr'=>$request->input('main_attr'),
  87. 'banner'=>json_encode($request->input('banner')),
  88. 'is_delete'=>0,
  89. 'is_shelves'=>0,
  90. ]);
  91. $increase=array_diff($sku_new,$sku_old);
  92. Log::info('2222'.json_encode($increase));
  93. $increase_data=[];
  94. foreach($increase as $k=>$v){
  95. $increase_data[$k]['type']=explode('-',$v)[0];
  96. $increase_data[$k]['size']=explode('-',$v)[1];
  97. $increase_data[$k]['sort']=explode('-',$v)[2];
  98. $increase_data[$k]['goods_id']=$request->input('id');
  99. $increase_data[$k]['num']=1000;
  100. $increase_data[$k]['sale_num']=0;
  101. $increase_data[$k]['created_at']=date("Y-m-d H:i:s");
  102. $increase_data[$k]['updated_at']=date("Y-m-d H:i:s");
  103. }
  104. GoodSku::insert($increase_data);
  105. $decrease=array_diff($sku_old,$sku_new);
  106. foreach($decrease as $k=>$v){
  107. $type=explode('-',$v)[0];
  108. $size=explode('-',$v)[1];
  109. GoodSku::where('size',$size)->where('type',$type)->delete();
  110. }
  111. },5);
  112. return $this->success([]);
  113. }catch(\Exception $e){
  114. return $this->error($e->getMessage());
  115. }
  116. }
  117. //商品上下架
  118. public function shelves(Request $request){
  119. $goods=Goods::where('id',$request->input('id'))->first();
  120. $goods->is_shelves = $goods->is_shelves ? 0 : 1;
  121. $res=$goods->save();
  122. if($res){
  123. return $this->success([]);
  124. }else{
  125. return $this->error();
  126. }
  127. }
  128. //商品删除
  129. public function destroy(Request $request){
  130. $res=Goods::where('id',$request->input('id'))->delete();
  131. if($res){
  132. return $this->success([]);
  133. }else{
  134. return $this->error();
  135. }
  136. }
  137. //上传图片
  138. public function uploadImg(Request $request){
  139. $path_url = 'public/goods';
  140. $path = $request->file('img')->store($path_url);
  141. if($path){
  142. $url = env('APP_URL').Storage::url($path);
  143. return $this->success($url);
  144. }
  145. return $this->error();
  146. }
  147. //获取当日各商品销量
  148. public function getGoodsSalesValue(){
  149. $list=OrderDetail::with('goods')
  150. ->whereHas('order',function($query){
  151. $query->where('is_pay',1);
  152. })->select('goods_id',DB::raw('sum(num) as total'),DB::raw('sum(account) as amount'))
  153. ->groupBy('goods_id')->get();
  154. // $goods_sku=OrderDetail::whereHas('order',function($query){
  155. // $query->where('is_pay',1);
  156. // })->whereDate('created_at',date("Y-m-d"))
  157. // ->select('goods_id','type','size',DB::raw('sum(num) as total'),DB::raw('sum(account) as amount'))
  158. // ->groupBy('goods_id','type','size')->get();
  159. // $list=GoodSku::whereHas('goods',function($query){
  160. // $query->where('is_shelves',1);
  161. // })->select('goods_id','type','size')->with(['goods:id,name,main_attr'])->get();
  162. // foreach($list as $k=>$v){
  163. // $list[$k]->sale_num=0;
  164. // $list[$k]->sale_money=0;
  165. // foreach($goods_sku as $key=>$val){
  166. // if($v->goods_id==$val->goods_id && $v->type==$val->type && $v->size==$val->size){
  167. // $list[$k]->sale_num=$val->total;
  168. // $list[$k]->sale_money=$val->amount;
  169. // }
  170. // }
  171. // }
  172. return $this->success($list);
  173. }
  174. //获取当日商品单规格销量
  175. public function getGoodsSkuSalesValue(Request $request){
  176. if($request->has('date') && !empty($request->input('date'))){
  177. $date=$request->input('date');
  178. }else{
  179. $date=date("Y-m-d");
  180. }
  181. $where=function($query)use($date){
  182. $query->whereDate('created_at',$date);
  183. };
  184. $goods_sku=OrderDetail::whereHas('order',function($query){
  185. $query->where('is_pay',1)->whereIn('apply_cancel',[0,1,3])->whereIn('is_refund',[0,1]);
  186. })->where($where)
  187. ->select('goods_id','type','size',DB::raw('sum(num) as total'),DB::raw('sum(account) as amount'))
  188. ->groupBy('goods_id','type','size')->get();
  189. $list=GoodSku::whereHas('goods',function($query){
  190. $query->where('is_shelves',1);
  191. })->select('goods_id','type','size')->with(['goods:id,name,main_attr'])->get();
  192. foreach($list as $k=>$v){
  193. $list[$k]->sale_num=0;
  194. $list[$k]->sale_money=0;
  195. foreach($goods_sku as $key=>$val){
  196. if($v->goods_id==$val->goods_id && $v->type==$val->type && $v->size==$val->size){
  197. $list[$k]->sale_num=$val->total;
  198. $list[$k]->sale_money=$val->amount;
  199. }
  200. }
  201. }
  202. return $this->success($list);
  203. }
  204. //获取省级行政单位销售信息
  205. public function getProvinceSalesOrderBy(Request $request,$id=700000)
  206. {
  207. $province = Region::where('level', 1)->where('id','<',$id)->pluck('name');
  208. $list=[];
  209. foreach ($province as $key => $val) {
  210. $pro = $val;
  211. switch ($province) {
  212. case '北京':
  213. $pro = '北京市';
  214. break;
  215. case '天津':
  216. $pro = '天津市';
  217. break;
  218. case '上海':
  219. $pro = '上海市';
  220. break;
  221. case '重庆':
  222. $pro = '重庆市';
  223. break;
  224. }
  225. $addr_ids = Address::where('province', $pro)->pluck('id');
  226. $order_nos=Order::whereHas('address', function ($query) use ($addr_ids) {
  227. $query->whereIn('id', $addr_ids);
  228. })->where('is_pay',1)->pluck('order_no');
  229. $type=$request->input('type');
  230. if(count($order_nos)==0){
  231. $list[$pro]=0;
  232. }else{
  233. $data = OrderDetail::whereIn('order_no',$order_nos);
  234. if($type==1){ //各类型产品销量
  235. $data->with('goods:id,name,main_attr');
  236. $data->select('goods_id', 'size', 'type',DB::raw('sum(num) as total'), DB::raw('sum(account) as amount'));
  237. $data->groupBy('goods_id', 'size', 'type');
  238. }elseif($type==2){ //各产品销量
  239. $data->with('goods:id,name,main_attr');
  240. $data->select('goods_id',DB::raw('sum(num) as total'), DB::raw('sum(account) as amount'));
  241. $data->groupBy('goods_id');
  242. }else{ //各省级总销量
  243. $data->select(DB::raw('ifNull(sum(num),0) as total'), DB::raw('ifNull(sum(account),0) as amount'));
  244. }
  245. $list[$pro]=$data->get();
  246. }
  247. }
  248. return $this->success($list);
  249. }
  250. //获取所有省级单位
  251. public function getProvinceList(){
  252. $province=Region::where('level',1)->where('id','<',700000)->pluck('name','id');
  253. return $this->success($province);
  254. }
  255. //获取市级行政单位销售信息
  256. public function getCitySalesOrderBy(Request $request)
  257. {
  258. $pro=$request->input('province');
  259. $pid=Region::where('level', 1)->where('name',$pro)->value('id');
  260. $cities = Region::where('level', 2)->where('pid',$pid)->pluck('name');
  261. $list=[];
  262. foreach ($cities as $key => $val) {
  263. if($val=='直辖县级'){
  264. $val='省直辖县级行政区划';
  265. $addr_ids = Address::where('city', $val)->where('province',$pro)->pluck('id');
  266. }else{
  267. $addr_ids = Address::where('city', $val)->pluck('id');
  268. }
  269. $order_nos=Order::whereHas('address', function ($query) use ($addr_ids) {
  270. $query->whereIn('id', $addr_ids);
  271. })->where('is_pay',1)->pluck('order_no');
  272. $type=$request->input('type');
  273. $data = OrderDetail::whereIn('order_no',$order_nos);
  274. if($type==1){ //各类型产品销量
  275. $data->with('goods:id,name,main_attr');
  276. $data->select('goods_id', 'size', 'type',DB::raw('sum(num) as total'), DB::raw('sum(account) as amount'));
  277. $data->groupBy('goods_id', 'size', 'type');
  278. }elseif($type==2){ //各产品销量
  279. $data->with('goods:id,name,main_attr');
  280. $data->select('goods_id',DB::raw('sum(num) as total'), DB::raw('sum(account) as amount'));
  281. $data->groupBy('goods_id');
  282. }else{ //各省级总销量
  283. $data->select(DB::raw('ifNull(sum(num),0) as total'), DB::raw('ifNull(sum(account),0) as amount'));
  284. }
  285. $list[$val]=$data->get();
  286. }
  287. return $this->success($list);
  288. }
  289. }