InventoryService.php 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. <?php
  2. namespace App\Services;
  3. use App\Commodity;
  4. use App\Http\Controllers\Controller;
  5. use App\Inventory;
  6. use App\inventoryDailyLog;
  7. use App\InventoryDailyLoggingOwner;
  8. use App\InventoryMission;
  9. use App\OraccleBasCustomer;
  10. use App\OracleActTransactionLog;
  11. use App\Owner;
  12. use App\Services\common\QueryService;
  13. use Illuminate\Http\Request;
  14. use Illuminate\Support\Facades\Auth;
  15. use Illuminate\Support\Facades\DB;
  16. use Illuminate\Support\Facades\Gate;
  17. class InventoryService
  18. {
  19. //库存体积条件
  20. private function conditionQueryDailyLog(array $param){
  21. $inventoryDailyLogs = InventoryDailyLog::query()->with(['owner','commodity'=>function($query){
  22. $query->with('barcodes');
  23. }])->orderByDesc('id');
  24. $columnQueryRules=[
  25. 'owner_id' => ['multi' => ','],
  26. 'created_at_start' => ['alias' => 'created_at' , 'startDate' => ' 00:00:00'],
  27. 'created_at_end' => ['alias' => 'created_at' , 'endDate' => ' 23:59:59'],
  28. ];
  29. $inventoryDailyLogs = app(QueryService::class)->query($param,$inventoryDailyLogs,$columnQueryRules);
  30. return $inventoryDailyLogs;
  31. }
  32. //库存体积
  33. public function getInventoryDailyLog(array $param){
  34. return $this->conditionQueryDailyLog($param)->paginate($param['paginate'] ?? 50);
  35. }
  36. //获取开启监听记录货主
  37. public function getInventoryDailyLoggingOwner($column = ['id','owner_id'], $status = "启用"){
  38. if (!is_array($column)) {
  39. $column = [$column];
  40. }
  41. return InventoryDailyLoggingOwner::query()->select($column)->where('status',$status)->get();
  42. }
  43. //录入监听记录货主
  44. public function firstOrCreate($param,$column = null){
  45. if ($column)return InventoryDailyLoggingOwner::query()->firstOrCreate($param,$column);
  46. return InventoryDailyLoggingOwner::query()->firstOrCreate($param);
  47. }
  48. }