WaveController.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  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. }