PaperCriteria.php 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  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 PaperCriteria 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('grade_id')) {
  30. $grade_id = $this->request->get('grade_id');
  31. $model = $model->whereHas('models', function ($query) use ($grade_id) {
  32. return $query->where('mentor_grades.id', $grade_id);
  33. });
  34. }
  35. if ($this->request->filled('status')) {
  36. $model = $model->where('status', '=', $this->request->get('status'));
  37. }
  38. if (!$this->request->filled('orderBy')) {
  39. $model = $model->orderByDesc('id');
  40. }
  41. $admin = login_admin();
  42. if ($admin && !$admin->hasRole('admin')) {
  43. $grade_id = Student::query()->where('admin_id', $admin['id'])->value('grade_id') ?? 0;
  44. $model = $model->whereHas('models', function ($query) use ($grade_id) {
  45. return $query->where('mentor_grades.id', $grade_id);
  46. })->where('status', ModelStatusEnum::OK);
  47. }
  48. return $model;
  49. }
  50. }