RejectedBillItemController.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Commodity;
  4. use App\Events\InformWMSReceivedEvent;
  5. use App\Owner;
  6. use App\Rejected;
  7. use App\RejectedBill;
  8. use App\RejectedBillItem;
  9. use App\WMSReflectReceive;
  10. use App\WMSReflectReceiveSku;
  11. use Illuminate\Http\Request;
  12. use Illuminate\Support\Collection;
  13. use Illuminate\Support\Facades\Auth;
  14. use Illuminate\Support\Facades\Gate;
  15. use Illuminate\Support\Facades\Validator;
  16. use Zttp\Zttp;
  17. class RejectedBillItemController extends Controller
  18. {
  19. /**
  20. * Display a listing of the resource.
  21. *
  22. * @return \Illuminate\Http\Response
  23. */
  24. public function index()
  25. {
  26. //
  27. }
  28. /**
  29. * Show the form for creating a new resource.
  30. *
  31. * @return \Illuminate\Http\Response
  32. */
  33. public function create()
  34. {
  35. //
  36. }
  37. /**
  38. * Store a newly created resource in storage.
  39. *
  40. * @param \Illuminate\Http\Request $request
  41. * @return \Illuminate\Http\Response
  42. */
  43. public function store(Request $request)
  44. {
  45. //
  46. }
  47. public function apiStore(Request $request)
  48. {
  49. if(!Gate::allows('退货管理-录入')){
  50. return ['success'=>'false','failure_info'=>'没有权限'];
  51. }
  52. $errorFields= $this->validator($request->all())->errors()->getMessages();
  53. if(!empty($errorFields)){
  54. return ['success'=>'false','error_fields'=>$errorFields,'failure_info'=>'fileds error'];
  55. }
  56. $rejectedBillItem=RejectedBillItem::where('barcode_goods',$request->input('barcode_goods'))
  57. ->where('id_quality_label',$request->input('id_quality_label'))
  58. ->where('id_rejected_bill',$request->input('id_rejected_bill'))->first();
  59. if($rejectedBillItem){
  60. $rejectedBillItem['amount']+=$request->input('amount');
  61. if($request->input('name_goods')){
  62. $rejectedBillItem['name_goods']=$request->input('name_goods');
  63. }
  64. $rejectedBillItem->update();
  65. }else{
  66. $rejectedBillItem=new RejectedBillItem($request->all());
  67. $rejectedBillItem->save();
  68. }
  69. $rejectedBillItem->injectCommodityName();
  70. $this->log(__METHOD__,__FUNCTION__,json_encode($request->toArray()),Auth::user()['id']);
  71. return ['success'=>'true','id'=>$rejectedBillItem['id']];
  72. }
  73. public function apiUpdate(Request $request)
  74. {
  75. if(!Gate::allows('退货管理-编辑')){
  76. return ['success'=>'false','failure_info'=>'没有权限'];
  77. }
  78. $errorFields= $this->validator($request->all())->errors()->getMessages();
  79. if(!empty($errorFields)){
  80. return ['success'=>'false','error_fields'=>$errorFields,'failure_info'=>'fileds error'];
  81. }
  82. $rejectedBillItem=RejectedBillItem::where('id',$request->input('id'))->first();
  83. if(!$rejectedBillItem){
  84. return ['success'=>'false','failure_info'=>'数据库没有相应记录,请刷新后重加'];
  85. }else{
  86. $rejectedBillItem->fill($request->all());
  87. $rejectedBillItem->update();
  88. $rejectedBillItem->injectCommodityName();
  89. $this->log(__METHOD__,__FUNCTION__,json_encode($request->toArray()),Auth::user()['id']);
  90. return ['success'=>'true','id'=>$rejectedBillItem['id']];
  91. }
  92. }
  93. public function collectionsToPackConfirm(Collection $rejectedBillItems)
  94. {
  95. $ids=[];
  96. $rejectedBillItems->each(function ($item)use(&$ids){
  97. $ids[]=$item->id;
  98. });
  99. if(!$ids)return ['success'=>'false','fail_info'=>'没有内容'];
  100. $collections=new Collection($ids);
  101. $i=0;
  102. $collections->each(function ($id)use(&$i,$ids){
  103. $rejectedBillItems=RejectedBillItem::whereIn('id', [$ids[$i]]);
  104. $rejectedBillItems->each(function(RejectedBillItem $rejectedBillItem)use(&$havingFail){
  105. $rejectedBill=RejectedBill::find($rejectedBillItem['id_rejected_bill']);
  106. $owner = Owner::find($rejectedBill['id_owner']);
  107. if(strstr($owner->name??'','笕尚')){
  108. $rejected=new Rejected();
  109. $rejected->fill($rejectedBill->toArray());
  110. $rejected->fill($rejectedBillItem->toArray());
  111. $rejectedJianshang=new api\thirdPart\jianshang\RejectedController();
  112. $sended=$rejectedJianshang->sendRejected($rejected);
  113. if(!$sended){
  114. echo '<h1>数据发送给笕尚失败,请通知IT相关负责人</h1>';
  115. $this->log(__METHOD__,'error','数据发送给笕尚失败');
  116. $havingFail++;
  117. return false;
  118. }
  119. }
  120. });
  121. $i++;
  122. if($i%30==0)
  123. sleep(1);
  124. });
  125. return 'yes'.$i;
  126. }
  127. public function apiPackConfirm(Request $request)
  128. {
  129. if(!Gate::allows('退货管理-录入')){
  130. return ['success'=>'false','fail_info'=>'没有权限'];
  131. }
  132. $ids=$request->input('ids');
  133. if(!$ids)return ['success'=>'false','fail_info'=>'没有内容'];
  134. $rejectedBillItems=RejectedBillItem::whereIn('id', $ids)->get();
  135. if($rejectedBillItems->count()==0){
  136. return ['success'=>'false','fail_info'=>'没有匹配到相应内容'];
  137. }
  138. $item=$rejectedBillItems->first();
  139. $rejectedBill = RejectedBill::find($item['id_rejected_bill']);
  140. $downloadedSkus = WMSReflectReceive::downloadedSkus($rejectedBill['logistic_number_return'],true);
  141. $isGotMoreThenDownloaded=WMSReflectReceiveSku::isItemsOverDownloadedSkus($rejectedBillItems,$downloadedSkus);
  142. $isJianshang=(function($rejectedBill){
  143. $owner = Owner::find($rejectedBill['id_owner']);
  144. if(strstr($owner->name??'','笕尚')){
  145. return true;
  146. }
  147. if(strstr($owner->name??'','万龄')){
  148. return true;
  149. }
  150. return false;
  151. })($rejectedBill);
  152. if(!$isGotMoreThenDownloaded
  153. && !($rejectedBill['is_loaded']==1||$rejectedBill['is_loaded']===null)
  154. &&config('api.api_switch_receive_to_wms')){
  155. $informed=(new InformWMSReceivedEvent($rejectedBill))->directRun();
  156. if(!$informed)return ['success'=>'false','fail_info'=>'提交至WMS错误,请联系相关人员'];
  157. $isLoaded=false;
  158. if($isJianshang){
  159. $isLoaded=true;
  160. }
  161. return ['success'=>'true','bill_is_loaded'=>$isLoaded];
  162. }
  163. if($isJianshang){
  164. $sended=$this->sendRejectedToThirdPart2($rejectedBillItems,$rejectedBill);
  165. if(!$sended)return ['success'=>'false','fail_info'=>"记录没有发送成功"];
  166. }
  167. $this->log(__METHOD__,__FUNCTION__.'_'.$rejectedBill['id'],json_encode($request->toArray()),Auth::user()['id']);
  168. return ['success'=>'true'];
  169. }
  170. public function sendRejectedToThirdPart(Collection $items,$rejectedBill):bool {
  171. $havingFail=0;
  172. if(!config('api.API_FAKING')){
  173. $items->each(function(RejectedBillItem $rejectedBillItem)use(&$havingFail,$rejectedBill){
  174. $rejected=new Rejected();
  175. $rejected->fill($rejectedBill->toArray());
  176. $rejected->fill($rejectedBillItem->toArray());
  177. $rejectedJianshang=new api\thirdPart\jianshang\RejectedController();
  178. $sended=$rejectedJianshang->sendRejected($rejected);
  179. if(!$sended){
  180. echo '<h1>数据发送给笕尚失败,请通知IT相关负责人</h1>';
  181. $this->log(__METHOD__,'error_'.__FUNCTION__.'_'.$rejectedBillItem['id'],'数据发送给笕尚失败');
  182. $havingFail++;
  183. return false;
  184. }
  185. });
  186. $receives=WMSReflectReceive::where('ASNREFERENCE3',$rejectedBill['logistic_number_return'])->where('is_uploaded',0)->get();
  187. $receives->each(function ($receive){
  188. $receive['is_uploaded']=1;
  189. $receive->save();
  190. });
  191. }
  192. if($havingFail>0){
  193. $this->log(__METHOD__,'error_'.__FUNCTION__.'_'.$rejectedBill['id'],"$havingFail/{$items->count()} 条记录没有发送成功",Auth::user()['id']);
  194. return false;
  195. }
  196. return true;
  197. }
  198. public function sendRejectedToThirdPart2(Collection $items,$rejectedBill):bool {
  199. if($rejectedBill['is_loaded']!=0){
  200. return true;
  201. }
  202. $rejected=new Rejected();
  203. $rejected->fill($rejectedBill->toArray());
  204. $goodses=[];
  205. $items->each(function(RejectedBillItem $item)use(&$goodses){
  206. $goodses[]=$item->toArray();
  207. });
  208. $rejectedJianshang=new api\thirdPart\jianshang\RejectedController();
  209. $rejected['goodses']=$goodses;
  210. $sended= $rejectedJianshang->sendRejected2($rejected);
  211. if(!$sended){
  212. $this->log(__METHOD__,'error_'.__FUNCTION__.'_'.$rejectedBill['id'],"记录没有发送成功".json_encode($rejected),Auth::user()['id']);
  213. return false;
  214. }
  215. //
  216. $rejectedBill = find($rejectedBill['id']);
  217. $rejectedBill['is_loaded']=2;
  218. $rejectedBill->update();
  219. $items->each(function(RejectedBillItem $item)use(&$goodses){
  220. $item['is_loaded']='待推单';
  221. $item->save();
  222. });
  223. //标记WMS所有该退单下的作废(为已上传) 。应检查这里是否正确!
  224. $receives=WMSReflectReceive::where('ASNREFERENCE3',$rejectedBill['logistic_number_return'])->where('is_uploaded',0)->get();
  225. $receives->each(function ($receive){
  226. $receive['is_uploaded']=1;
  227. $receive->save();
  228. });
  229. $this->log(__METHOD__,__FUNCTION__.'_'.$rejectedBill['id'],json_encode($rejected),Auth::user()['id']);
  230. return true;
  231. }
  232. public function apiPackDestroy(Request $request)
  233. {
  234. if(!(Gate::allows('退货管理-录入')||Gate::allows('退货管理-编辑'))){
  235. return ['success'=>'false','failure_info'=>'没有权限'];
  236. }
  237. $ids=$request->input('ids');
  238. if(!$ids)return ['success'=>'false','fail_info'=>'没有内容'];
  239. $rejectedBillItems=RejectedBillItem::whereIn('id', $ids);
  240. $rejectedBillItems->each(function(RejectedBillItem $rejectedBillItem){
  241. $rejectedBillItem->delete();
  242. });
  243. $this->log(__METHOD__,__FUNCTION__,json_encode($request->toArray()),Auth::user()['id']);
  244. return ['success'=>'true'];
  245. }
  246. protected function validator(array $data,$isUpdate=false)
  247. {
  248. return Validator::make($data, [
  249. 'id_rejected_bill' => ['required', 'numeric', 'exists:rejected_bills,id'],
  250. 'barcode_goods' => ['required', 'string','max:60'],
  251. 'name_goods' => ['nullable', 'string','max:50'],
  252. 'amount' => ['numeric','nullable', 'max:99999'],
  253. 'id_quality_label' => ['required','numeric', 'max:11'],
  254. 'batch_number' => ['string', 'nullable',],
  255. 'validity_at' => ['nullable','date_format:Y-m-d'],
  256. 'remark' => ['nullable','string','max:191'],
  257. ],[],[
  258. 'id_rejected_bill' =>'退单头',
  259. 'barcode_goods' => '商品条码',
  260. 'name_goods' => '商品名称',
  261. 'amount' => '数量',
  262. 'id_quality_label' => '品质',
  263. 'batch_number' => '批次',
  264. 'validity_at' => '效期',
  265. 'remark' => '备注'
  266. ]);
  267. }
  268. public function apiGet(Request $request)
  269. {
  270. if(!Gate::allows('退货管理-查询')){
  271. return ['success'=>'false','failure_info'=>'没有权限'];}
  272. if(!$request->input('id_rejected_bill')){
  273. return ['success'=>'false','failure_info'=>'表头id不能为空'];
  274. }
  275. $rejectedBillItems = RejectedBillItem::where('id_rejected_bill',$request->input('id_rejected_bill'))->get();
  276. return ['success'=>'true','items'=>$rejectedBillItems->toArray()];
  277. }
  278. public function apiDelete(Request $request)
  279. {
  280. if(!Gate::allows('退货管理-删除')){
  281. return ['success'=>'false','failure_info'=>'没有权限'];}
  282. if(!$request->input('id')){
  283. return ['success'=>'false','failure_info'=>'传入id不能为空'];
  284. }
  285. $rejectedBillItem = RejectedBillItem::find($request->input('id'));
  286. $rejectedBillItem->forceDelete();
  287. return ['success'=>'true','id'=>$request->input('id')];
  288. }
  289. /**
  290. * Display the specified resource.
  291. *
  292. * @param \App\RejectedBillItem $rejectedBillItem
  293. * @return \Illuminate\Http\Response
  294. */
  295. public function show(RejectedBillItem $rejectedBillItem)
  296. {
  297. //
  298. }
  299. /**
  300. * Show the form for editing the specified resource.
  301. *
  302. * @param \App\RejectedBillItem $rejectedBillItem
  303. * @return \Illuminate\Http\Response
  304. */
  305. public function edit(RejectedBillItem $rejectedBillItem)
  306. {
  307. //
  308. }
  309. /**
  310. * Update the specified resource in storage.
  311. *
  312. * @param \Illuminate\Http\Request $request
  313. * @param \App\RejectedBillItem $rejectedBillItem
  314. * @return \Illuminate\Http\Response
  315. */
  316. public function update(Request $request, RejectedBillItem $rejectedBillItem)
  317. {
  318. //
  319. }
  320. /**
  321. * Remove the specified resource from storage.
  322. *
  323. * @param \App\RejectedBillItem $rejectedBillItem
  324. * @return \Illuminate\Http\Response
  325. */
  326. public function destroy(RejectedBillItem $rejectedBillItem)
  327. {
  328. //
  329. }
  330. }