WarehouseService.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  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. Class WarehouseService
  9. {
  10. public function firstOrCreate(array $params, array $values = null)
  11. {
  12. if ($values) return Warehouse::query()->firstOrCreate($params, $values);
  13. return Warehouse::query()->firstOrCreate($params);
  14. }
  15. public function getByWmsOrders($orderHeaders)
  16. {
  17. $wareHouse_Ids=array_diff(array_unique(data_get($orderHeaders,'*.warehouseid')),['',' ','*',null]);
  18. $wareHouses=Warehouse::query()->whereIn('code',$wareHouse_Ids)->get();
  19. if(count($wareHouse_Ids)>$wareHouses->count()){
  20. $需要添加_仓库编码=[];
  21. foreach ($wareHouse_Ids as $warehouse_id) {
  22. if($wareHouses->where('code')->count()==0){
  23. $需要添加_仓库编码[]=$warehouse_id;
  24. }
  25. }
  26. $create_wareHouse=$this->syncWmsWareHouse($需要添加_仓库编码);
  27. $wareHouses = $wareHouses->concat($create_wareHouse ?? []);
  28. }
  29. return $wareHouses;
  30. }
  31. public function syncWmsWareHouse($warehouse_ids)
  32. {
  33. $collet = new Collection();
  34. if(!$warehouse_ids)return null;
  35. /** @var Collection $oracleBasCustomers */
  36. $oracleBasCustomers=app(OracleBasCustomerService::class)->getWareHouse($warehouse_ids);
  37. $warehouses=Warehouse::query()->where('code',data_get($oracleBasCustomers,'*.CustomerID'))->get();
  38. $oracleBasCustomers=$oracleBasCustomers->filter(function($oracleBasCustomer)use($warehouses){
  39. return $warehouses->where('code',$oracleBasCustomer->warehouseid)->count()==0;
  40. });
  41. foreach ($oracleBasCustomers as $oracleBasCustomer){
  42. $wereHouse=Warehouse::query()->create([
  43. 'code'=>$oracleBasCustomer->customerid,
  44. 'name'=>$oracleBasCustomer->descr_c
  45. ]);
  46. $collet->push($wereHouse);
  47. }
  48. return $collet;
  49. }
  50. public function getByWms($asnHerders)
  51. {
  52. $warehouseids = array_unique(data_get($asnHerders, '*.warehouseid'));
  53. $warehouseids = array_diff($warehouseids, [null, '', '*']);
  54. $warehouses = Warehouse::query()->whereIn('code', $warehouseids)->get();
  55. if ($warehouses->count() < count($warehouseids)) {
  56. $warehouseids = array_diff($warehouseids, data_get($warehouses, '*.code'));
  57. $warehouse_list = $this->createWarehouseByWms($warehouseids);
  58. $warehouses=$warehouses->concat($warehouse_list);
  59. }
  60. return $warehouses;
  61. }
  62. public function createWarehouseByWms($codes)
  63. {
  64. if(!$codes) {return [];}
  65. $insert_params = [];
  66. $created_at = Carbon::now()->format('Y-m-d H:i:s');
  67. foreach ($codes as $item) {
  68. $insert_params[] = [
  69. 'code' => $item,
  70. 'name' => $item,
  71. 'created_at' => $created_at,
  72. ];
  73. }
  74. try {
  75. if (count($insert_params) > 0) {
  76. $this->insert($insert_params);
  77. LogService::log(__METHOD__, __FUNCTION__, '批量创建 warehouse success' . count($insert_params) . json_encode($insert_params) );
  78. }
  79. } catch (\Exception $e) {
  80. LogService::log(__METHOD__, __FUNCTION__, '批量创建 warehouse error' . json_encode($insert_params) . '||' . $e->getMessage() . '||' . $e->getTraceAsString());
  81. } finally {
  82. return Warehouse::query()->whereIn('code', $codes)->get();
  83. }
  84. }
  85. public function insert($fillables){
  86. return Warehouse::query()->insert($fillables);
  87. }
  88. }