PackageStatisticsService.php 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. <?php
  2. namespace App\Services;
  3. use App\OrderPackage;
  4. use App\Services\common\QueryService;
  5. use Illuminate\Database\Eloquent\Builder;
  6. use Illuminate\Support\Facades\Auth;
  7. use Illuminate\Support\Facades\DB;
  8. use App\Traits\ServiceAppAop;
  9. class PackageStatisticsService
  10. {
  11. use ServiceAppAop;
  12. /**
  13. * @param array $params
  14. * @return Builder
  15. */
  16. private function conditionQuery(array $params){
  17. $ownerIds = app('UserService')->getPermittingOwnerIds(auth()->user());
  18. $query = DB::table('order_packages')->select(DB::raw('COUNT(*) AS count'))
  19. ->whereIn('order_packages.owner_id',$ownerIds)
  20. ->whereNotNull('logistic_id')
  21. ->leftJoin('orders','order_packages.order_id','orders.id')
  22. ->selectRaw('orders.owner_id,logistic_id');
  23. if ($params["logistic_id"] ?? false){
  24. $logistics = explode(",",$params["logistic_id"]);
  25. $query->whereIn("logistic_id",$logistics);
  26. unset($params["logistic_id"]);
  27. }
  28. $columnQueryRules=[
  29. 'created_at_start' => ['alias' => 'weighed_at','startDate' => ":00"],
  30. 'created_at_end' => ['alias' => 'weighed_at','endDate' => ":59"],
  31. 'owner_id' => ['multi' => ','],
  32. ];
  33. $query = $query->groupBy('order_packages.owner_id','logistic_id');
  34. return app(QueryService::class)->query($params,$query,$columnQueryRules,'order_packages');
  35. }
  36. public function get(array $params){
  37. return $this->conditionQuery($params)->get();
  38. }
  39. public function getPackageStatistic(array $params)
  40. {
  41. $query = $this->conditionQuery($params);
  42. return DB::table(DB::raw("({$query->sql()}) AS p"))->selectRaw('p.*')
  43. ->leftJoin('owners','p.owner_id','owners.id')
  44. ->selectRaw('owners.name owner_name')
  45. ->leftJoin('logistics','p.logistic_id','logistics.id')
  46. ->selectRaw('logistics.name logistic_name')
  47. ->get();
  48. }
  49. }