WarehouseService.php 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. <?php
  2. namespace App\Services;
  3. use App\OracleBasCustomer;
  4. use App\Owner;
  5. use App\Warehouse;
  6. use Illuminate\Support\Collection;
  7. use Carbon\Carbon;
  8. use Illuminate\Support\Facades\Cache;
  9. Class WarehouseService
  10. {
  11. public function firstOrCreate(array $params, array $values = null)
  12. {
  13. if ($values) return Warehouse::query()->firstOrCreate($params, $values);
  14. return Warehouse::query()->firstOrCreate($params);
  15. }
  16. public function getByWmsOrders($orderHeaders)
  17. {
  18. $wareHouse_Ids=array_diff(array_unique(data_get($orderHeaders,'*.warehouseid')),['',' ','*',null]);
  19. $wareHouses=Warehouse::query()->whereIn('code',$wareHouse_Ids)->get();
  20. if(count($wareHouse_Ids)>$wareHouses->count()){
  21. $需要添加_仓库编码=[];
  22. foreach ($wareHouse_Ids as $warehouse_id) {
  23. if($wareHouses->where('code')->count()==0){
  24. $需要添加_仓库编码[]=$warehouse_id;
  25. }
  26. }
  27. $create_wareHouse=$this->syncWmsWareHouse($需要添加_仓库编码);
  28. $wareHouses = $wareHouses->concat($create_wareHouse ?? []);
  29. }
  30. return $wareHouses;
  31. }
  32. public function syncWmsWareHouse($warehouse_ids)
  33. {
  34. $collet = new Collection();
  35. if(!$warehouse_ids)return null;
  36. /** @var Collection $oracleBasCustomers */
  37. $oracleBasCustomers=app(OracleBasCustomerService::class)->getWareHouse($warehouse_ids);
  38. $warehouses=Warehouse::query()->whereIn('code',data_get($oracleBasCustomers,'*.customerid'))->get();
  39. $oracleBasCustomers=$oracleBasCustomers->filter(function($oracleBasCustomer)use($warehouses){
  40. return $warehouses->where('code',$oracleBasCustomer->warehouseid)->count()==0;
  41. });
  42. foreach ($oracleBasCustomers as $oracleBasCustomer){
  43. $params =[
  44. 'code' => $oracleBasCustomer->customerid,
  45. 'name' => $oracleBasCustomer->descr_c
  46. ];
  47. try {
  48. $wereHouse = Warehouse::query()->create($params);
  49. $collet->push($wereHouse);
  50. app('LogService')->log(__METHOD__,__FUNCTION__,'创建 warehouse success'.json_encode($wereHouse));
  51. } catch (\Exception $e) {
  52. app('LogService')->log(__METHOD__,__FUNCTION__,'创建 warehouse error'.json_encode($params).json_encode($e->getMessage()));
  53. }
  54. }
  55. return $collet;
  56. }
  57. public function insert($fillables){
  58. return Warehouse::query()->insert($fillables);
  59. }
  60. public function getWareHouseByCode($codes)
  61. {
  62. $collect = collect();
  63. if(count($codes)==0)return $collect;
  64. foreach ($codes as $code) {
  65. $collect->push(Cache::remember("WareHouse_{$code}",null,function ()use($code){
  66. $wareHouse = Warehouse::query()->where('code',$code)->first();
  67. if($wareHouse)return $wareHouse;
  68. $bas_customer = OracleBasCustomer::query()->selectRaw('Customer_Type,CustomerId,Descr_C')->where('CustomerId',$code)->where('Customer_Type','WH')->first();
  69. if (!$bas_customer) return null;
  70. return Warehouse::query()->create(['name'=>$bas_customer['descr_c'],'code'=>$bas_customer['customerid']]);
  71. }));
  72. }
  73. return $collect;
  74. }
  75. }