OrderController.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Exports\Export;
  4. use App\OracleBasCustomer;
  5. use App\OracleDOCOrderHeader;
  6. use App\OracleDOCWaveDetails;
  7. use Illuminate\Database\Eloquent\Collection;
  8. use Illuminate\Http\Request;
  9. use Illuminate\Support\Facades\DB;
  10. use Illuminate\Support\Facades\Gate;
  11. use Maatwebsite\Excel\Facades\Excel;
  12. class OrderController extends Controller
  13. {
  14. public function delivering(Request $request){
  15. if(!Gate::allows('订单管理-发运')){ return redirect(url('/')); }
  16. $paginate=$request->input('paginate')??50;
  17. $page=$request->input('page')??1;
  18. $ordertime_start=$request->input('ordertime_start');
  19. $ordertime_end=$request->input('ordertime_end');
  20. $customerid=$request->input('customerid');
  21. $orderno=$request->input('orderno');
  22. $soreference5=$request->input('soreference5');
  23. $codename_c=$request->input('codename_c');
  24. $carriername=$request->input('carriername');
  25. $soreference1=$request->input('soreference1');
  26. $issuepartyname=$request->input('issuepartyname');
  27. $notes=$request->input('notes');
  28. $addtime=$request->input('addtime');
  29. $checkData=$request->input('checkData');
  30. $export=$request->input('export');
  31. $sql="select ACT_ALLOCATION_DETAILS.CHECKTIME,DOC_ORDER_HEADER.addtime,DOC_ORDER_HEADER.C_PROVINCE,DOC_ORDER_HEADER.C_CITY,DOC_ORDER_HEADER.C_DISTRICT,DOC_ORDER_HEADER.C_CONTACT,DOC_ORDER_HEADER.OrderNo,DOC_ORDER_HEADER.SOStatus,DOC_ORDER_HEADER.WAREHOUSEID,DOC_ORDER_HEADER.CustomerID
  32. ,DOC_ORDER_HEADER.C_Tel1,DOC_ORDER_HEADER.CarrierName,DOC_ORDER_HEADER.IssuePartyName,
  33. DOC_ORDER_HEADER.WaveNo,DOC_ORDER_HEADER.SOReference1
  34. ,DOC_ORDER_HEADER.soreference5,DOC_ORDER_HEADER.EDISENDFLAG2,DOC_ORDER_HEADER.EDISendTime2,DOC_ORDER_HEADER.Notes,DOC_ORDER_HEADER.ERPCANCELFLAG,
  35. DOC_ORDER_HEADER.Picking_Print_Flag,DOC_ORDER_HEADER.EDISENDFLAG
  36. ,DOC_ORDER_HEADER.ReleaseStatus,DOC_ORDER_HEADER.C_Address1,DOC_ORDER_HEADER.OrderTime,DOC_Order_Details.CustomerID,
  37. DOC_Order_Details.SKU,DOC_Order_Details.QtyOrdered,DOC_Order_Details.OrderLineNo,BAS_Codes.codename_c,BAS_Customer.descr_c as customer_descr_c,
  38. BAS_SKU.Alternate_SKU1,BAS_SKU.Descr_C,(select count(*) from DOC_ORDER_HEADER) as counted
  39. from (";
  40. if (!$request->input('export')&&!$request->input('export'))$sql.=" select * from (";
  41. $sql.=" select ROWNUM as rn,DOC_ORDER_HEADER.addtime,DOC_ORDER_HEADER.C_PROVINCE,DOC_ORDER_HEADER.C_CITY,DOC_ORDER_HEADER.C_DISTRICT,DOC_ORDER_HEADER.C_CONTACT,DOC_ORDER_HEADER.OrderNo,DOC_ORDER_HEADER.SOStatus,DOC_ORDER_HEADER.WAREHOUSEID,DOC_ORDER_HEADER.CustomerID
  42. ,DOC_ORDER_HEADER.C_Tel1,DOC_ORDER_HEADER.CarrierName,DOC_ORDER_HEADER.IssuePartyName,
  43. DOC_ORDER_HEADER.WaveNo,DOC_ORDER_HEADER.SOReference1
  44. ,DOC_ORDER_HEADER.soreference5,DOC_ORDER_HEADER.EDISENDFLAG2,DOC_ORDER_HEADER.EDISendTime2,DOC_ORDER_HEADER.Notes,DOC_ORDER_HEADER.ERPCANCELFLAG,
  45. DOC_ORDER_HEADER.Picking_Print_Flag,DOC_ORDER_HEADER.EDISENDFLAG
  46. ,DOC_ORDER_HEADER.ReleaseStatus,DOC_ORDER_HEADER.C_Address1,DOC_ORDER_HEADER.OrderTime from (select * from DOC_ORDER_HEADER order by ADDTIME desc )DOC_ORDER_HEADER where 1=1 ";
  47. if ($ordertime_start)$sql.=" and ordertime>='".$ordertime_start." 00:00:00'";
  48. if ($ordertime_end)$sql.=" and ordertime<='".$ordertime_end." 23:59:59'";
  49. if ($customerid)$sql.=" and customerid='".$customerid."'";
  50. if ($orderno)$sql.=" and orderno like '".$orderno."%'";
  51. if ($codename_c)$sql.=" and sostatus = '".$codename_c."'";
  52. if ($carriername)$sql.=" and carriername like '".$carriername."%'";
  53. if ($soreference1){
  54. $arr=array_filter(preg_split('/[,, ]+/is', $soreference1));
  55. if (count($arr)>0){
  56. $sql.=" and soreference1 in (";
  57. foreach ($arr as $index=>$str){
  58. if ($index==0){
  59. $sql.="'".$str."'";
  60. continue;
  61. }
  62. $sql.=",'".$str."'";
  63. }
  64. $sql.=")";
  65. }
  66. } //$sql.=" and soreference1 like '".$soreference1."%'";
  67. if ($issuepartyname)$sql.=" and issuepartyname like '".$issuepartyname."%'";
  68. if ($notes){
  69. if ($addtime&&$addtime!=0)$sql.=" and addtime >= '".date('Y-m-d H:i:s',strtotime("-".$addtime." day"))."'";
  70. $sql.=" and notes like '%".$notes."%'";
  71. }
  72. if ($soreference5){
  73. $arr=array_filter(preg_split('/[,, ]+/is', $soreference5));
  74. if (count($arr)>0){
  75. $sql.=" and soreference5 in (";
  76. foreach ($arr as $index=>$str){
  77. if ($index==0){
  78. $sql.="'".$str."'";
  79. continue;
  80. }
  81. $sql.=",'".$str."'";
  82. }
  83. $sql.=")";
  84. }
  85. }
  86. if ($checkData){
  87. $checkData=explode(',',$checkData);
  88. if (count($checkData)>0){
  89. $sql.=" and orderno in (";
  90. foreach ($checkData as $index=>$str){
  91. if ($index==0){
  92. $sql.="'".$str."'";
  93. continue;
  94. }
  95. $sql.=",'".$str."'";
  96. }
  97. $sql.=")";
  98. }
  99. }
  100. if (!$request->input('export')&&!$request->input('export'))$sql.=" and ROWNUM<='".$page*$paginate."' order by ordertime)";
  101. if (!$request->input('export')&&!$request->input('export'))$sql.=" header where header.rn>'".($page-1)*$paginate."' ";
  102. $sql.=")DOC_ORDER_HEADER left join DOC_ORDER_DETAILS on DOC_ORDER_DETAILS.ORDERNO=DOC_ORDER_HEADER.ORDERNO
  103. left join BAS_CODES on BAS_CODES.CODE=DOC_ORDER_HEADER.sostatus and BAS_CODES.codeid='SO_STS'
  104. left join BAS_Customer on BAS_Customer.customerid=DOC_ORDER_HEADER.customerid
  105. left join BAS_SKU on DOC_Order_Details.CustomerID=BAS_SKU.CustomerID and DOC_Order_Details.SKU=BAS_SKU.SKU
  106. left join ACT_ALLOCATION_DETAILS on DOC_Order_Details.orderno=ACT_ALLOCATION_DETAILS.orderno and DOC_Order_Details.orderlineno=ACT_ALLOCATION_DETAILS.orderlineno
  107. group by DOC_ORDER_HEADER.addtime,DOC_ORDER_HEADER.C_PROVINCE,DOC_ORDER_HEADER.C_CITY,DOC_ORDER_HEADER.C_DISTRICT,DOC_ORDER_HEADER.C_CONTACT,DOC_ORDER_HEADER.OrderNo,DOC_ORDER_HEADER.SOStatus,DOC_ORDER_HEADER.WAREHOUSEID,DOC_ORDER_HEADER.CustomerID
  108. ,DOC_ORDER_HEADER.C_Tel1,DOC_ORDER_HEADER.CarrierName,DOC_ORDER_HEADER.IssuePartyName,
  109. DOC_ORDER_HEADER.WaveNo,DOC_ORDER_HEADER.SOReference1
  110. ,DOC_ORDER_HEADER.soreference5,DOC_ORDER_HEADER.EDISENDFLAG2,DOC_ORDER_HEADER.EDISendTime2,DOC_ORDER_HEADER.Notes,DOC_ORDER_HEADER.ERPCANCELFLAG,
  111. DOC_ORDER_HEADER.Picking_Print_Flag,DOC_ORDER_HEADER.EDISENDFLAG
  112. ,DOC_ORDER_HEADER.ReleaseStatus,DOC_ORDER_HEADER.C_Address1,DOC_ORDER_HEADER.OrderTime,DOC_Order_Details.CustomerID,
  113. DOC_Order_Details.SKU,DOC_Order_Details.QtyOrdered,DOC_Order_Details.OrderLineNo,
  114. BAS_SKU.Alternate_SKU1,BAS_SKU.Descr_C,BAS_Codes.codename_c,BAS_Customer.descr_c,ACT_ALLOCATION_DETAILS.CHECKTIME order by ordertime" ;
  115. $orders=DB::connection('oracle')->select(DB::raw($sql));
  116. $commodities=[];
  117. foreach ($orders as $index=>$order){
  118. if (isset($commodities[$order->orderno])){
  119. array_push($commodities[$order->orderno],
  120. ["sku"=>$order->sku,"alternate_sku1"=>$order->alternate_sku1,"descr_c"=>$order->descr_c,"qtyordered"=>$order->qtyordered
  121. ,"checktime"=>$order->checktime]);
  122. unset($orders[$index]);
  123. continue;
  124. }
  125. $commodities[$order->orderno]=[["sku"=>$order->sku,"alternate_sku1"=>$order->alternate_sku1,
  126. "descr_c"=>$order->descr_c,"qtyordered"=>$order->qtyordered,"checktime"=>$order->checktime]];
  127. }
  128. $orders=array_values($orders);
  129. $orders = new Collection($orders);
  130. $commodities=new Collection($commodities);
  131. if ($checkData || $export)return $this->export($orders,$commodities);
  132. $customers=OracleBasCustomer::select('customerid','descr_c')->where('customer_type','OW')->where('active_flag','Y')->get();
  133. $request=$request->input();
  134. $codes=DB::connection('oracle')->table('BAS_CODES')->select('code','codename_c')->where('codeid','SO_STS')->get();
  135. return view('order/index/delivering',compact('orders','customers','request','codes','commodities','page'));
  136. }
  137. public function batchComments(Request $request){
  138. if(!Gate::allows('订单管理-批量备注')){ return redirect(url('/')); }
  139. $checkData=$request->input('checkData');
  140. $content=$request->input('content');
  141. $ordersNotNull=OracleDOCOrderHeader::select('OrderNo','Notes')->whereIn('orderno',$checkData)
  142. ->whereNotNull('notes')->get();
  143. OracleDOCOrderHeader::select('OrderNo','Notes')->whereIn('orderno',$checkData)
  144. ->whereNull('notes')->update(['notes'=>$content]);
  145. $ordersNotNullArr=array_column($ordersNotNull->toArray(),'orderno');
  146. $ordersNullArr=array_diff($checkData,$ordersNotNullArr);
  147. $data=[];
  148. foreach ($ordersNotNull as $order){
  149. OracleDOCOrderHeader::where('orderno',$order->orderno)->update(["notes"=>($order->notes).",".$content]);
  150. $order->notes=($order->notes).",".$content;
  151. array_push($data,$order);
  152. }
  153. foreach ($ordersNullArr as $order){
  154. array_push($data,["orderno"=>$order,'notes'=>$content]);
  155. }
  156. return $data;
  157. }
  158. public function freeze(Request $request){
  159. if(!Gate::allows('订单管理-编辑')){ return redirect(url('/')); }
  160. $orderno=$request->input('orderno');
  161. $waveno=$request->input('waveno');
  162. $order=OracleDOCOrderHeader::where('orderno',$orderno)->first();
  163. if(!($order['codename_c']==='创建订单'||$order['codename_c']==='分配完成'||$order['codename_c']==='拣货完成'||$order['codename_c']==='播种完成')){
  164. return ['success'=>false];
  165. }
  166. OracleDOCOrderHeader::where('orderno',$orderno)->update(['releasestatus'=>'H','waveno'=>'*']);
  167. if ($waveno && $waveno!='*'){
  168. OracleDOCWaveDetails::where('waveno',$waveno)->where('orderno',$orderno)->delete();
  169. }
  170. return ['success'=>true];
  171. }
  172. public function thaw(Request $request){
  173. if(!Gate::allows('订单管理-编辑')){ return redirect(url('/')); }
  174. $orderno=$request->input('orderno');
  175. OracleDOCOrderHeader::where('orderno',$orderno)->update(['releasestatus'=>'N']);
  176. return ['success'=>true];
  177. }
  178. function export($orders,$commodities){
  179. if(!Gate::allows('订单管理')){ return redirect(url('/')); }
  180. ini_set('max_execution_time',3500);
  181. ini_set('memory_limit','3526M');
  182. $row=[[
  183. 'orderno'=>'编号',
  184. 'sostatus'=>'订单状态',
  185. 'notes'=>'备注',
  186. 'addtime'=>'接口下发时间',
  187. 'issuepartyname'=>'店铺名称',
  188. 'oracleBASCustomer_descr_c'=>'客户',
  189. 'soreference1'=>'客户订单号',
  190. 'carriername'=>'承运人',
  191. 'soreference5'=>'快递单号',
  192. 'c_contact'=>'收货人名称',
  193. 'c_tel1'=>'收货人电话',
  194. 'c_province'=>'省',
  195. 'c_city'=>'市',
  196. 'c_district'=>'区',
  197. 'c_address1'=>'收货人地址',
  198. 'waveno'=>'波次编号',
  199. 'warehouseid'=>'仓库',
  200. 'edisendflag2'=>'快递获取标记',
  201. 'edisendtime2'=>'快递获取时间',
  202. 'sku'=>'产品代码',
  203. 'alternate_sku1'=>'产品条码',
  204. 'descr_c'=>'产品名称',
  205. 'qtyordered'=>'订单数量',
  206. 'erpcancelflag'=>'接口取消标记',
  207. 'picking_print_flag'=>'拣货单打印标记',
  208. 'edisendflag'=>'接口回传标记',
  209. 'releasestatus'=>'订单冻结标记',
  210. ]];
  211. $list=[];
  212. $sign=[];
  213. $mergeCell=[];
  214. foreach ($orders as $order){
  215. $data=[
  216. 'orderno'=>$order->orderno,
  217. 'addtime'=>$order->addtime,
  218. 'sostatus'=>$order->codename_c,
  219. 'warehouseid'=>$order->warehouseid,
  220. 'oracleBASCustomer_descr_c'=>$order->customer_descr_c,
  221. 'c_contact'=>$order->c_contact,
  222. 'c_tel1'=>$order->c_tel1,
  223. 'c_province'=>$order->c_province,
  224. 'c_city'=>$order->c_city,
  225. 'c_district'=>$order->c_district,
  226. 'carriername'=>$order->carriername,
  227. 'issuepartyname'=>$order->issuepartyname,
  228. 'waveno'=>$order->waveno,
  229. 'soreference1'=>$order->soreference1,
  230. 'soreference5'=>$order->soreference5,
  231. 'edisendflag2'=>$order->edisendflag2,
  232. 'edisendtime2'=>$order->edisendtime2,
  233. 'notes'=>$order->notes,
  234. 'erpcancelflag'=>$order->erpcancelflag,
  235. 'picking_print_flag'=>$order->picking_print_flag,
  236. 'edisendflag'=>$order->edisendflag,
  237. 'releasestatus'=>$order->releasestatus,
  238. 'c_address1'=>$order->c_address1,
  239. ];
  240. if (count($commodities[$order->orderno])<1){
  241. $data['sku']='';
  242. $data['alternate_sku1']='';
  243. $data['descr_c']='';
  244. $data['qtyordered']='';
  245. array_push($list,$data);
  246. continue;
  247. }
  248. foreach ($commodities[$order->orderno] as $oracleDOCOrderDetail){
  249. $data['sku']=$oracleDOCOrderDetail['sku'];
  250. $data['alternate_sku1']=$oracleDOCOrderDetail['alternate_sku1'];
  251. $data['descr_c']=$oracleDOCOrderDetail['descr_c'];
  252. $data['qtyordered']=$oracleDOCOrderDetail['qtyordered'];
  253. if (isset($sign[$order->orderno])){
  254. $data['orderno']='';$data['sostatus']='';$data['warehouseid']='';$data['oracleBASCustomer_descr_c']='';$data['c_contact']='';$data['addtime']='';
  255. $data['c_tel1']='';$data['carriername']='';$data['issuepartyname']='';$data['waveno']='';$data['soreference1']='';$data['soreference5']='';
  256. $data['edisendflag2']='';$data['edisendtime2']='';$data['notes']='';$data['erpcancelflag']='';$data['picking_print_flag']='';$data['edisendflag']='';
  257. $data['releasestatus']='';$data['c_address1']='';$data['c_province']='';$data['c_city']='';$data['c_district']='';
  258. array_push($list,$data);
  259. continue;
  260. }
  261. array_push($list,$data);
  262. $sign[$order->orderno]=count($list)+1;
  263. }
  264. if (count($commodities[$order->orderno])>1){
  265. $mergeCell[$sign[$order->orderno]]=$sign[$order->orderno]+(count($commodities[$order->orderno])-1);
  266. }
  267. }
  268. $columnName=["A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","X"];
  269. return Excel::download(new Export($row,$list,$mergeCell,$columnName),date('YmdHis', time()).'-出库发运单.xlsx');
  270. }
  271. }