InventoryDailyLogService.php 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. <?php
  2. namespace App\Services;
  3. use App\InventoryDailyLog;
  4. use App\InventoryDailyLoggingOwner;
  5. use App\Services\common\BatchUpdateService;
  6. use App\Services\common\QueryService;
  7. use App\Traits\ServiceAppAop;
  8. Class InventoryDailyLogService
  9. {
  10. use ServiceAppAop;
  11. //库存体积条件
  12. function conditionQuery(array $param){
  13. $inventoryDailyLogs = InventoryDailyLog::query()->with(['depository','owner','commodity'=>function($query){
  14. $query->with('barcodes');
  15. }])->orderByDesc('inventory_daily_logs.id');
  16. $columnQueryRules=[
  17. 'owner_id' => ['multi' => ','],
  18. 'created_at_start' => ['alias' => 'created_at' , 'startDate' => ' 00:00:00'],
  19. 'created_at_end' => ['alias' => 'created_at' , 'endDate' => ' 23:59:59'],
  20. 'id' => ['multi' => ','],
  21. ];
  22. $inventoryDailyLogs = app(QueryService::class)->query($param,$inventoryDailyLogs,$columnQueryRules,"inventory_daily_logs");
  23. return $inventoryDailyLogs;
  24. }
  25. public function getSql(array $params){
  26. return $this->conditionQuery($params)->selectRaw("inventory_daily_logs.id,inventory_daily_logs.created_at,inventory_daily_logs.amount,inventory_daily_logs.volumn_occupied,inventory_daily_logs.gross_weight")
  27. ->leftJoin('owners','inventory_daily_logs.owner_id','owners.id')
  28. ->selectRaw('owners.name owner_name')
  29. ->leftJoin('depositories','inventory_daily_logs.depository_id','depositories.id')
  30. ->selectRaw('depositories.name depository_name')
  31. ->leftJoin('commodities','inventory_daily_logs.commodity_id','commodities.id')
  32. ->selectRaw('commodities.name commodity_name,commodities.sku commodity_sku,commodities.length commodity_length,commodities.width commodity_width,commodities.height commodity_height,commodities.volumn commodity_volumn')
  33. ->leftJoin('commodity_barcodes','commodity_barcodes.commodity_id','commodities.id')
  34. ->selectRaw("GROUP_CONCAT(commodity_barcodes.code) commodity_barcode_code")
  35. ->groupBy('id')
  36. ->sql();
  37. }
  38. //库存体积
  39. public function paginate(array $params){
  40. return $this->conditionQuery($params)->paginate($params['paginate'] ?? 50);
  41. }
  42. //获取开启监听记录货主
  43. public function getInventoryDailyLoggingOwner($column = ['id','owner_id'], $status = "启用"){
  44. if (!is_array($column)) {
  45. $column = [$column];
  46. }
  47. return InventoryDailyLoggingOwner::query()->select($column)->where('status',$status)->get();
  48. }
  49. //录入监听记录货主
  50. public function firstOrCreate($param,$column = null){
  51. if ($column)return InventoryDailyLoggingOwner::query()->firstOrCreate($param,$column);
  52. return InventoryDailyLoggingOwner::query()->firstOrCreate($param);
  53. }
  54. public function batchUpdateItself($column, array $params)
  55. {
  56. return app(BatchUpdateService::class)->batchUpdateItself('inventory_daily_logs', $column, $params);
  57. }
  58. }