CategoryCriteria.php 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. <?php
  2. namespace App\Repositories\Criteria\Course;
  3. use App\Repositories\Enums\ModelStatusEnum;
  4. use Illuminate\Http\Request;
  5. use Prettus\Repository\Contracts\CriteriaInterface;
  6. use Prettus\Repository\Contracts\RepositoryInterface;
  7. /**
  8. * Class CourseCategoryCriteria.
  9. *
  10. * @package namespace App\Repositories\Criteria;
  11. */
  12. class CategoryCriteria implements CriteriaInterface
  13. {
  14. /**
  15. * @var \Illuminate\Http\Request
  16. */
  17. protected $request;
  18. public function __construct(Request $request = null)
  19. {
  20. if (is_null($request)) {
  21. $this->request = \request();
  22. } else {
  23. $this->request = $request;
  24. }
  25. }
  26. /**
  27. * Apply criteria in query repository
  28. *
  29. * @param string $model
  30. * @param RepositoryInterface $repository
  31. *
  32. * @return mixed
  33. */
  34. public function apply($model, RepositoryInterface $repository)
  35. {
  36. if ($this->request->filled('name')) {
  37. $name = $this->request->get('name');
  38. $model = $model->where('name', 'like', "%{$name}%");
  39. }
  40. if ($this->request->filled('status')) {
  41. $status = $this->request->get('status', false);
  42. $model = $model->where('status', '=', $status);
  43. }
  44. if ($this->request->filled('category_id')) {
  45. $category_id = $this->request->get('category_id');
  46. $model = $model->where('category_id', '=', $category_id);
  47. }
  48. if ($this->request->filled('parent_id')) {
  49. $parent_id = $this->request->get('parent_id');
  50. $model = $model->where('parent_id', '=', $parent_id);
  51. }
  52. if (!$this->request->filled('orderBy')) {
  53. $model = $model->orderByDesc('sort')->orderByDesc('id');
  54. }
  55. if (isApi()) {
  56. $model = $model->where('status', ModelStatusEnum::OK);
  57. }
  58. return $model;
  59. }
  60. }