DrugCriteria.php 1.8 KB

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