OrderController.php 12 KB

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