StoreController.php 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Depository;
  4. use App\Http\Controllers\Api\thirdPart\flux\StoreController as FStoreController;
  5. use App\Owner;
  6. use App\Store;
  7. use App\StoreItems;
  8. use App\Warehouse;
  9. use App\WMSReflectReceive;
  10. use Illuminate\Http\Request;
  11. use Illuminate\Support\Facades\Validator;
  12. class StoreController extends Controller
  13. {
  14. /**
  15. * Display a listing of the resource.
  16. *
  17. * @return \Illuminate\Http\Response
  18. */
  19. public function index()
  20. {
  21. $stores=Store::orderBy('id','DESC')->paginate(50);
  22. return view('store.index',['stores'=>$stores]);
  23. }
  24. /**
  25. * Show the form for creating a new resource.
  26. *
  27. * @return \Illuminate\Http\Response
  28. */
  29. public function create()
  30. {
  31. return view('store.fast.create');
  32. }
  33. /**
  34. * Store a newly created resource in storage.
  35. *
  36. * @param \Illuminate\Http\Request $request
  37. * @return \Illuminate\Http\RedirectResponse|\Illuminate\Http\Response|\Illuminate\Routing\Redirector
  38. */
  39. public function store(Request $request)
  40. {
  41. $this->validator($request);
  42. $WMSReflectReceive=WMSReflectReceive::with('skus')->where('ASNNO',$request->input('asn_code'))->first();
  43. if (!$WMSReflectReceive)return redirect('store/fast/create')->with('successError','ASN编号不存在!');
  44. $warehouse=Warehouse::where('code',$WMSReflectReceive->WAREHOUSEID)->first();
  45. if (!$warehouse&&$WMSReflectReceive->WAREHOUSEID){
  46. $warehouse=new Warehouse([
  47. 'name'=>$WMSReflectReceive->WAREHOUSEID,
  48. 'code'=>$WMSReflectReceive->WAREHOUSEID
  49. ]);
  50. $warehouse->save();
  51. }
  52. $owner=Owner::where('code',$WMSReflectReceive->CUSTOMERID)->first();
  53. if (!$owner&&$WMSReflectReceive->CUSTOMERID){
  54. $owner=new Warehouse([
  55. 'name'=>$WMSReflectReceive->CUSTOMERID,
  56. 'code'=>$WMSReflectReceive->CUSTOMERID
  57. ]);
  58. $owner->save();
  59. }
  60. $store=Store::where('asn_code',$WMSReflectReceive->ASNNO)->first();
  61. if(!$store){
  62. $store=new Store([
  63. 'asn_code'=>$WMSReflectReceive->ASNNO,
  64. 'warehouse_id'=>$warehouse->id,
  65. 'owner_id'=>$owner->id,
  66. 'stored_method'=>'快速入库',
  67. 'status'=>'未入库',
  68. 'remark'=>$WMSReflectReceive->NOTES,
  69. ]);
  70. $store->save();
  71. $customDepository=(function()use($request){
  72. $customDepository=Depository::where('code',$request->input('depository_code'))->first();
  73. if($request->input('depository_code')){
  74. if (!$customDepository){
  75. $depository=new Depository([
  76. 'name'=>$request->input('depository_code'),
  77. 'code'=>$request->input('depository_code')
  78. ]);
  79. $depository->save();
  80. }
  81. }
  82. return $customDepository;
  83. })();
  84. if ($WMSReflectReceive->skus){
  85. foreach ($WMSReflectReceive->skus as $sku){
  86. $depository=(function()use($sku,$customDepository){
  87. if($customDepository)return $customDepository;
  88. $depository=Depository::where('code',$sku->LOTATT05)->first();
  89. if (!$depository){
  90. $depository=new Depository([
  91. 'name'=>$sku->LOTATT05,
  92. 'code'=>$sku->LOTATT05
  93. ]);
  94. $depository->save();
  95. }
  96. return $depository;
  97. })();
  98. $storeItem=new StoreItems([
  99. 'store_id'=>$store->id,
  100. 'asn_line_code'=>$sku->ASNLINENO,
  101. 'name'=>$sku->SKUDESCRC,
  102. 'sku'=>$sku->SKU,
  103. 'barcode'=>$sku->ALTERNATE_SKU1,
  104. 'depository_id'=>$depository->id,
  105. 'quality'=>$request->input('quality'),
  106. 'status'=>'未入库',
  107. ]);
  108. $storeItem->save();
  109. }
  110. }
  111. }
  112. $store=Store::with('storeItems')->where('asn_code',$request->input('asn_code'))->first();
  113. $storeApi=new FStoreController();
  114. $result=$storeApi->accomplishToWMS($store,[
  115. 'quality'=>$request->input('quality'),
  116. 'depository_code'=>$request->input('depository_code'),
  117. 'follow_code'=>$store['id'],
  118. ]);
  119. if ($result){
  120. $store->status='已入库';
  121. $store->save();
  122. if ($store->storeItems){
  123. $quality=$request->input('quality');
  124. $store->storeItems->each(function ($storeItem)use($quality){
  125. $storeItem->status='已入库';
  126. $storeItem->quality=$quality;
  127. $storeItem->save();
  128. });
  129. }
  130. return redirect('store/fast/create')->with('successTip','成功!');
  131. }
  132. return redirect('store/fast/create')->with('successError','失败!请检查错误日志');
  133. }
  134. /**
  135. * Display the specified resource.
  136. *
  137. * @param \App\Store $store
  138. * @return \Illuminate\Http\Response
  139. */
  140. public function show(Store $store)
  141. {
  142. //
  143. }
  144. /**
  145. * Show the form for editing the specified resource.
  146. *
  147. * @param \App\Store $store
  148. * @return \Illuminate\Http\Response
  149. */
  150. public function edit(Store $store)
  151. {
  152. //
  153. }
  154. /**
  155. * Update the specified resource in storage.
  156. *
  157. * @param \Illuminate\Http\Request $request
  158. * @param \App\Store $store
  159. * @return \Illuminate\Http\Response
  160. */
  161. public function update(Request $request, Store $store)
  162. {
  163. //
  164. }
  165. /**
  166. * Remove the specified resource from storage.
  167. *
  168. * @param \App\Store $store
  169. * @return \Illuminate\Http\Response
  170. */
  171. public function destroy(Store $store)
  172. {
  173. //
  174. }
  175. public function validator(Request $request){
  176. $validator=Validator::make($request->input(),[
  177. // 'asn_code'=>['required','unique:stores,asn_code'],
  178. 'asn_code'=>['required'],
  179. 'quality'=>['required'],
  180. 'depository_code'=>['nullable','string'],
  181. ],[
  182. 'required'=>':attribute 为必填项',
  183. 'unique'=>':attribute 已存在',
  184. ],[
  185. 'asn_code'=>'ASN编号',
  186. 'quality'=>'货物类型'
  187. ])->validate();
  188. return $validator;
  189. }
  190. }