ComplaintCriteria.php 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. <?php
  2. namespace App\Repositories\Criteria\Info;
  3. use Illuminate\Http\Request;
  4. use Prettus\Repository\Contracts\CriteriaInterface;
  5. use Prettus\Repository\Contracts\RepositoryInterface;
  6. class ComplaintCriteria implements CriteriaInterface
  7. {
  8. /**
  9. * @var \Illuminate\Http\Request
  10. */
  11. protected $request;
  12. public function __construct(Request $request)
  13. {
  14. $this->request = $request;
  15. }
  16. /**
  17. * @param $model
  18. * @param RepositoryInterface $repository
  19. *
  20. * @return mixed
  21. */
  22. public function apply($model, RepositoryInterface $repository)
  23. {
  24. if ($this->request->filled('user_id')) {
  25. $user_id = $this->request->get('user_id');
  26. $model = $model->where('user_id', '=', $user_id);
  27. }
  28. if ($this->request->filled('complaint_phone')) {
  29. $complaint_phone = $this->request->get('complaint_phone');
  30. $model = $model->where('complaint_phone', 'like', "%{$complaint_phone}%");
  31. }
  32. if ($this->request->filled('content')) {
  33. $content = $this->request->get('content');
  34. $model = $model->where('content', 'like', "%{$content}%");
  35. }
  36. if ($this->request->filled('deal_department_id')) {
  37. $deal_department_id = $this->request->get('deal_department_id');
  38. $model = $model->where('deal_department_id', '=', $deal_department_id);
  39. }
  40. if ($this->request->filled('deal_status')) {
  41. $deal_status = $this->request->get('deal_status');
  42. $model = $model->where('deal_status', '=', $deal_status);
  43. }
  44. $model = $model->orderBy('created_at', 'desc');
  45. return $model;
  46. }
  47. }