WaveController.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  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 Exception;
  9. use Illuminate\Http\Request;
  10. use Illuminate\Support\Facades\Auth;
  11. use Illuminate\Support\Facades\DB;
  12. use Illuminate\Support\Facades\Gate;
  13. use Illuminate\Support\Facades\Http;
  14. use Oursdreams\Export\Export;
  15. class WaveController extends Controller
  16. {
  17. use AsyncResponse;
  18. public function __construct()
  19. {
  20. app()->bind("WaveService",WaveService::class);
  21. }
  22. // 主页
  23. public function index(Request $request){
  24. if(!Gate::allows('订单管理-波次-查询')){ return redirect(url('/')); }
  25. $waveService = app("WaveService");
  26. $waves = $waveService->queryWave($request);
  27. $param = $waveService->getPageParameter($request);
  28. $search = $waveService->getSearchCondition($request);
  29. foreach ($waves as $index=>$wave){
  30. $wave->pickerPrint = '';
  31. $wave->pickerPrintTime = '';
  32. $wave->expressPrinting = '';
  33. $wave->expressPrintTime = '';
  34. if(!is_null($wave->userdefine1)){
  35. $str = $wave->userdefine1;
  36. $index = strpos($str,'-PK');
  37. $wave->pickerPrint = substr($str,0,$index);
  38. $wave->pickerPrintTime = substr($str,$index+3);
  39. }
  40. if(!is_null($wave->userdefine2)){
  41. $str = $wave->userdefine2;
  42. if(strpos($str,'-EX')){
  43. $index = strpos($str,'-EX');
  44. $wave->expressPrinting = substr($str,0,$index);
  45. $wave->expressPrintTime = substr($str,$index+3);
  46. }else if(strpos($str,'-Auto')){
  47. $index = strpos($str,'-Auto');
  48. $wave->expressPrinting = substr($str,0,$index);
  49. $wave->expressPrintTime = substr($str,$index+5);
  50. }
  51. }
  52. }
  53. return view("order/wave/search",compact('waves','param','search'));
  54. }
  55. public function cancelPrinting(Request $request){
  56. if(!Gate::allows('订单管理-波次-重置打印')){ return ['success'=>false,'fail_info'=>'没有权限,请联系管理员']; }
  57. $waveService = app("WaveService");
  58. $ids = $request->input("ids");
  59. /** @var WaveService $waveService */
  60. $meg = $waveService->cancelPrint($ids);
  61. if($meg['fail_info']){
  62. return $meg;
  63. }
  64. app('LogService')->log(__METHOD__,'重置打印标记'.__FUNCTION__,json_encode($request->toArray()),Auth::user()['id']);
  65. return $meg;
  66. }
  67. public function exportExcelOnParams(Request $request){
  68. $sql = app("WaveService")->getSql($request);
  69. $e = new Export();
  70. $e->setOracleConnection(config('database.connections.oracle.host'),
  71. config('database.connections.oracle.port'),config('database.connections.oracle.database')
  72. ,config('database.connections.oracle.username'),config('database.connections.oracle.password'));
  73. $e->setFileName("波次记录");
  74. return $e->sql($sql,[
  75. "WAVENO"=>"波次号","CODENAME_C"=>"波次状态",
  76. "WAVERULE"=>"波次规则","DESCR"=>"波次描述",
  77. "DESCR_C"=>"承运人","ADDWHO"=>"操作员",
  78. "ADDTIME"=>"创建时间","pickerPrint"=>"拣货单打印人",
  79. "pickerPrintTime"=>"拣货单打印时间","expressPrinting"=>"快递单号打印人",
  80. "expressPrintTime"=>"快递单号打印时间"
  81. ])->direct();
  82. }
  83. public function repairBatch()
  84. {
  85. $error = [];
  86. foreach (\request("codes") as $code){
  87. if (!$code)continue;
  88. $wave = DB::connection("oracle")->selectOne(DB::raw("select * from DOC_WAVE_HEADER where WAVENO = ?"),[$code]);
  89. if (!$wave){
  90. $error[] = $code."FLUX无波次";
  91. continue;
  92. }
  93. $owner = app("OwnerService")->codeGetOwner($wave->customerid);
  94. $obj = [
  95. "wms_status" => $this->wms_status($wave),
  96. "wms_type"=>$wave->descr,
  97. "created_at"=>date("Y-m-d H:i:s"),
  98. "wms_created_at"=>$wave->addtime,
  99. "updated_at"=>$wave->edittime,
  100. "owner_id"=>$owner->id,
  101. ];
  102. $wave = Batch::query()->where("code",$code)->first();
  103. if (!$wave){
  104. $error[] = $code."本地无波次";
  105. $obj["code"] = $code;
  106. $wave = Batch::query()->create($obj);
  107. }else{
  108. Batch::query()->where("code",$code)->update($obj);
  109. }
  110. $ordernos = array_column(DB::connection("oracle")->select(DB::raw("select orderno from DOC_WAVE_DETAILS where WAVENO = ?"),[$code]),"orderno");
  111. $count = Order::query()->whereIn("code",$ordernos)->count();
  112. if (count($ordernos)!=$count)$error[] = $code."本地订单缺失";
  113. Order::query()->whereIn("code",$ordernos)->update([
  114. "batch_id"=>$wave->id
  115. ]);
  116. Order::query()->with(["batch","bin"])->whereIn("code",$ordernos)->get()->each(function ($order){
  117. if (!$order->bin){
  118. $bin = DB::connection("oracle")->selectOne(DB::raw("select seqno from DOC_WAVE_DETAILS where waveno = ? and orderno = ?"),[$order->batch->code,$order->code]);
  119. if ($bin){
  120. OrderBin::query()->create([
  121. 'order_id' => $order->id,
  122. 'number' => $bin->seqno,
  123. ]);
  124. }
  125. }
  126. });
  127. }
  128. $this->success($error);
  129. }
  130. /**
  131. * @param $wave
  132. * @return string
  133. */
  134. private function wms_status($wave): string
  135. {
  136. switch ($wave->wavestatus) {
  137. case 00:
  138. $wms_status = '创建';
  139. break;
  140. case 40:
  141. $wms_status = '部分收货';
  142. break;
  143. case 90:
  144. $wms_status = '取消';
  145. break;
  146. case 99:
  147. $wms_status = '完成';
  148. break;
  149. case 62:
  150. $wms_status = '部分装箱';
  151. break;
  152. default:
  153. $wms_status = (string)$wave->wavestatus;
  154. }
  155. return $wms_status;
  156. }
  157. }