WaveController.php 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Batch;
  4. use App\Components\AsyncResponse;
  5. use App\Order;
  6. use App\OrderBin;
  7. use App\Services\WaveService;
  8. use Illuminate\Http\Request;
  9. use Illuminate\Support\Facades\Auth;
  10. use Illuminate\Support\Facades\DB;
  11. use Illuminate\Support\Facades\Gate;
  12. use Oursdreams\Export\Export;
  13. class WaveController extends Controller
  14. {
  15. use AsyncResponse;
  16. public function __construct()
  17. {
  18. app()->bind("WaveService",WaveService::class);
  19. }
  20. // 主页
  21. public function index(Request $request){
  22. if(!Gate::allows('订单管理-波次-查询')){ return redirect(url('/')); }
  23. $waveService = app("WaveService");
  24. $waves = $waveService->queryWave($request);
  25. $param = $waveService->getPageParameter($request);
  26. $search = $waveService->getSearchCondition($request);
  27. foreach ($waves as $index=>$wave){
  28. $wave->pickerPrint = '';
  29. $wave->pickerPrintTime = '';
  30. $wave->expressPrinting = '';
  31. $wave->expressPrintTime = '';
  32. if(!is_null($wave->userdefine1)){
  33. $str = $wave->userdefine1;
  34. $index = strpos($str,'-PK');
  35. $wave->pickerPrint = substr($str,0,$index);
  36. $wave->pickerPrintTime = substr($str,$index+3);
  37. }
  38. if(!is_null($wave->userdefine2)){
  39. $str = $wave->userdefine2;
  40. if(strpos($str,'-EX')){
  41. $index = strpos($str,'-EX');
  42. $wave->expressPrinting = substr($str,0,$index);
  43. $wave->expressPrintTime = substr($str,$index+3);
  44. }else if(strpos($str,'-Auto')){
  45. $index = strpos($str,'-Auto');
  46. $wave->expressPrinting = substr($str,0,$index);
  47. $wave->expressPrintTime = substr($str,$index+5);
  48. }
  49. }
  50. }
  51. return view("order/wave/search",compact('waves','param','search'));
  52. }
  53. public function cancelPrinting(Request $request){
  54. if(!Gate::allows('订单管理-波次-重置打印')){ return ['success'=>false,'fail_info'=>'没有权限,请联系管理员']; }
  55. $waveService = app("WaveService");
  56. $ids = $request->input("ids");
  57. /** @var WaveService $waveService */
  58. $meg = $waveService->cancelPrint($ids);
  59. if($meg['fail_info']){
  60. return $meg;
  61. }
  62. app('LogService')->log(__METHOD__,'重置打印标记'.__FUNCTION__,json_encode($request->toArray()),Auth::user()['id']);
  63. return $meg;
  64. }
  65. public function exportExcelOnParams(Request $request){
  66. $sql = app("WaveService")->getSql($request);
  67. $e = new Export();
  68. $e->setOracleConnection(config('database.connections.oracle.host'),
  69. config('database.connections.oracle.port'),config('database.connections.oracle.database')
  70. ,config('database.connections.oracle.username'),config('database.connections.oracle.password'));
  71. $e->setFileName("波次记录");
  72. return $e->sql($sql,[
  73. "WAVENO"=>"波次号","CODENAME_C"=>"波次状态",
  74. "WAVERULE"=>"波次规则","DESCR"=>"波次描述",
  75. "DESCR_C"=>"承运人","ADDWHO"=>"操作员",
  76. "ADDTIME"=>"创建时间","pickerPrint"=>"拣货单打印人",
  77. "pickerPrintTime"=>"拣货单打印时间","expressPrinting"=>"快递单号打印人",
  78. "expressPrintTime"=>"快递单号打印时间"
  79. ])->direct();
  80. }
  81. public function repairBatch()
  82. {
  83. $error = [];
  84. foreach (\request("codes") as $code){
  85. if (!$code)continue;
  86. $wave = DB::connection("oracle")->selectOne(DB::raw("select * from DOC_WAVE_HEADER where WAVENO = ?"),[$code]);
  87. if (!$wave){
  88. $error[] = $code."FLUX无波次";
  89. continue;
  90. }
  91. $owner = app("OwnerService")->codeGetOwner($wave->customerid);
  92. $obj = [
  93. "wms_status" => $this->wms_status($wave),
  94. "wms_type"=>$wave->descr,
  95. "created_at"=>date("Y-m-d H:i:s"),
  96. "wms_created_at"=>$wave->addtime,
  97. "updated_at"=>$wave->edittime,
  98. "owner_id"=>$owner->id,
  99. ];
  100. $wave = Batch::query()->where("code",$code)->first();
  101. if (!$wave){
  102. $error[] = $code."本地无波次";
  103. $obj["code"] = $code;
  104. $wave = Batch::query()->create($obj);
  105. }else{
  106. Batch::query()->where("code",$code)->update($obj);
  107. }
  108. $ordernos = array_column(DB::connection("oracle")->select(DB::raw("select orderno from DOC_WAVE_DETAILS where WAVENO = ?"),[$code]),"orderno");
  109. $count = Order::query()->whereIn("code",$ordernos)->count();
  110. if (count($ordernos)!=$count)$error[] = $code."本地订单缺失";
  111. Order::query()->whereIn("code",$ordernos)->update([
  112. "batch_id"=>$wave->id
  113. ]);
  114. Order::query()->with(["batch","bin"])->whereIn("code",$ordernos)->get()->each(function ($order){
  115. if (!$order->bin){
  116. $bin = DB::connection("oracle")->selectOne(DB::raw("select seqno from DOC_WAVE_DETAILS where waveno = ? and orderno = ?"),[$order->batch->code,$order->code]);
  117. if ($bin){
  118. OrderBin::query()->create([
  119. 'order_id' => $order->id,
  120. 'number' => $bin->seqno,
  121. ]);
  122. }
  123. }
  124. });
  125. }
  126. $this->success($error);
  127. }
  128. /**
  129. * @param $wave
  130. * @return string
  131. */
  132. private function wms_status($wave): string
  133. {
  134. switch ($wave->wavestatus) {
  135. case 00:
  136. $wms_status = '创建';
  137. break;
  138. case 40:
  139. $wms_status = '部分收货';
  140. break;
  141. case 90:
  142. $wms_status = '取消';
  143. break;
  144. case 99:
  145. $wms_status = '完成';
  146. break;
  147. case 62:
  148. $wms_status = '部分装箱';
  149. break;
  150. default:
  151. $wms_status = (string)$wave->wavestatus;
  152. }
  153. return $wms_status;
  154. }
  155. public function split()
  156. {
  157. $codes = \request("codes",[]);
  158. $splitSize = \request("split");
  159. $splitNumber = \request("number");
  160. if (!$codes || (!$splitSize && !$splitNumber))$this->error("无记录");
  161. if ((!is_numeric($splitSize) || !is_int((int)$splitSize)) && !is_numeric($splitNumber) || !is_int((int)$splitNumber))$this->error("非法输入");
  162. if ($splitSize){
  163. $size = Batch::query()->whereIn("code",$codes)->whereNull("split_size")->count();
  164. if ($size!=count($codes))$this->error("波次不全或不允许二次分割");
  165. Batch::query()->whereIn("code",$codes)->whereNull("split_size")->update([
  166. "split_size" => $splitSize
  167. ]);
  168. }else{
  169. $no = "";
  170. foreach ($codes as $code){
  171. $no .= "'".$code."',";
  172. }
  173. $no = rtrim($no,',');
  174. $sql = <<<SQL
  175. SELECT WAVENO,MAX(SEQNO) count from DOC_WAVE_DETAILS WHERE WAVENO IN ({$no}) GROUP BY WAVENO
  176. SQL;
  177. foreach (DB::connection("oracle")->select(DB::raw($sql)) as $wave){
  178. Batch::query()->where("code",$wave->waveno)->update(["split_size" => (int)ceil($wave->count/$splitNumber)]);
  179. };
  180. }
  181. $this->success();
  182. }
  183. public function printChild()
  184. {
  185. $codes = \request("codes",[]);
  186. if (!$codes)$this->error("无记录");
  187. $batches = [];
  188. foreach (Batch::query()->select("code","split_size","id")
  189. ->whereIn("code",$codes)->whereNotNull("split_size")->get() as $batch){
  190. if ($batch->orders_count==0)continue;
  191. $bin = OrderBin::query()->selectRaw("MAX(number) max")->whereIn("order_id",Order::query()
  192. ->select("id")->where("batch_id",$batch->id))->first();
  193. $batches[$batch->code] = (int)ceil($bin->max/$batch->split_size);
  194. }
  195. $this->success($batches);
  196. }
  197. public function picking()
  198. {
  199. return view("order/wave/picking");
  200. }
  201. public function loadBatch()
  202. {
  203. $code = \request("code");
  204. $batch = null;
  205. if (!$code || !$batch = Batch::query()->select("id","split_size")->where("code",$code)->first())$this->error("无记录");
  206. $sql = <<<SQL
  207. SELECT a.ORDERNO,a.QTY,s.ALTERNATE_SKU1,a.LOCATION,w.SEQNO FROM ACT_ALLOCATION_DETAILS a
  208. LEFT JOIN DOC_ORDER_HEADER o ON a.ORDERNO = o.ORDERNO
  209. LEFT JOIN DOC_WAVE_DETAILS w ON o.ORDERNO = w.ORDERNO
  210. LEFT JOIN BAS_SKU s ON a.SKU = s.SKU
  211. WHERE w.WAVENO = '{$code}' ORDER BY w.SEQNO
  212. SQL;
  213. $orders = DB::connection("oracle")->select(DB::raw($sql));
  214. $result = [];
  215. $currentList = [];
  216. $nodeSign = "";
  217. foreach ($orders as $order){
  218. if ($order->seqno%$batch->split_size==0 && $nodeSign!=$order->orderno){
  219. $result[] = $currentList;
  220. $currentList = [];
  221. $nodeSign = $order->orderno;
  222. }
  223. $currentList[] = ["barcode"=>$order->alternate_sku1,"qty"=>$order->qty,"location"=>$order->location];
  224. }
  225. if ($currentList)$result[] = $currentList;
  226. $this->success($result);
  227. }
  228. }