InventoryService.php 1.6 KB

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