OwnerReportService.php 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. <?php
  2. namespace App\Services;
  3. use App\OwnerReport;
  4. use App\Services\common\QueryService;
  5. use Illuminate\Database\Eloquent\Builder;
  6. use App\Traits\ServiceAppAop;
  7. Class OwnerReportService
  8. {
  9. use ServiceAppAop;
  10. /**
  11. * @param Builder $builder
  12. * @param array $params
  13. * @return Builder
  14. */
  15. private function query(Builder $builder, array $params)
  16. {
  17. $columnQueryRules = [
  18. 'counting_month_start' => ['alias' => 'counting_month', 'startDate' => '-01'],
  19. 'counting_month_end' => ['alias' => 'counting_month', 'endDate' => '-31'],
  20. 'owner_id' => ['multi' => ','],
  21. ];
  22. if ($params["owner_group_id"] ?? false){
  23. $builder->whereHas('owner',function ($query)use(&$params){
  24. /** @var Builder $query */
  25. $query->where("user_owner_group_id",$params["owner_group_id"]);
  26. });
  27. unset($params["owner_group_id"]);
  28. }
  29. if ($params["customer_id"] ?? false){
  30. $builder->whereHas('owner',function ($query)use(&$params){
  31. /** @var Builder $query */
  32. $query->where("customer_id",$params["customer_id"]);
  33. });
  34. unset($params["customer_id"]);
  35. }
  36. if ($params["status"] ?? false){
  37. $builder->whereHas('owner',function ($query)use(&$params){
  38. /** @var Builder $query */
  39. if ($params["status"] == "激活") $query->whereNull("deleted_at");
  40. else $query->whereNotNull("deleted_at");
  41. });
  42. unset($params["status"]);
  43. }
  44. return app(QueryService::class)->query($params, $builder, $columnQueryRules,"owner_reports");
  45. }
  46. public function get(array $params, array $withs = null)
  47. {
  48. $query = OwnerReport::query();
  49. if ($withs)$query->with($withs);
  50. return $this->query($query,$params)->get();
  51. }
  52. public function paginate(array $params, array $withs = null)
  53. {
  54. $query = OwnerReport::query()->orderByDesc('id');
  55. if ($withs)$query->with($withs);
  56. return $this->query($query,$params)->paginate($params["paginate"] ?? 50);
  57. }
  58. }