RecordCriteria.php 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <?php
  2. namespace App\Repositories\Criteria\Exam;
  3. use App\Repositories\Enums\ModelStatusEnum;
  4. use App\Repositories\Models\Mentor\Student;
  5. use Illuminate\Http\Request;
  6. use Prettus\Repository\Contracts\CriteriaInterface;
  7. use Prettus\Repository\Contracts\RepositoryInterface;
  8. class RecordCriteria implements CriteriaInterface
  9. {
  10. /**
  11. * @var \Illuminate\Http\Request
  12. */
  13. protected $request;
  14. public function __construct(Request $request)
  15. {
  16. $this->request = $request;
  17. }
  18. /**
  19. * @param $model
  20. * @param RepositoryInterface $repository
  21. *
  22. * @return mixed
  23. */
  24. public function apply($model, RepositoryInterface $repository)
  25. {
  26. if ($this->request->filled('name')) {
  27. $model = $model->where('name', 'like', '%' . $this->request->get('name') . '%');
  28. }
  29. if ($this->request->filled('admin_id')) {
  30. $model = $model->where('admin_id', '=', $this->request->get('admin_id'));
  31. }
  32. if ($this->request->filled('paper_id')) {
  33. $model = $model->where('paper_id', '=', $this->request->get('paper_id'));
  34. }
  35. if ($this->request->filled('mark')) {
  36. $marks = $this->request->get('mark');
  37. if (is_array($marks)) {
  38. $model = $model->where('mark', '>=', $marks[0])->where('mark', '<=', $marks[1]);
  39. } else {
  40. $model = $model->where('mark', '=', $marks);
  41. }
  42. }
  43. if ($this->request->filled('paper_name')) {
  44. $paper_name = $this->request->get('paper_name');
  45. $model = $model->whereHas('paper', function ($query) use ($paper_name) {
  46. return $query->where('name', 'like', "%{$paper_name}%");
  47. });
  48. }
  49. if ($this->request->filled('grade_id')) {
  50. $grade_id = $this->request->get('grade_id');
  51. $model = $model->whereHas('admin', function ($query) use ($grade_id) {
  52. return $query->where('shop_id', '=', $grade_id);
  53. });
  54. }
  55. if ($this->request->filled('admin_username')) {
  56. $username = $this->request->get('admin_username');
  57. $model = $model->whereHas('admin', function ($query) use ($username) {
  58. return $query->where('username', 'like', '%' . $username);
  59. });
  60. }
  61. if ($this->request->filled('admin_name')) {
  62. $username = $this->request->get('admin_name');
  63. $model = $model->whereHas('admin', function ($query) use ($username) {
  64. return $query->where('name', 'like', '%' . $username . '%');
  65. });
  66. }
  67. if ($this->request->filled('status')) {
  68. $model = $model->where('status', '=', $this->request->get('status'));
  69. }
  70. if (!$this->request->filled('orderBy')) {
  71. $model = $model->orderByDesc('id');
  72. }
  73. $admin = login_admin();
  74. if ($admin && !$admin->hasRole('admin')) {
  75. $model = $model->where('admin_id', $admin['id']);
  76. }
  77. return $model;
  78. }
  79. }