ExplainRepository.php 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. <?php
  2. namespace App\Repositories;
  3. use App\Models\Explain;
  4. use Prettus\Repository\Eloquent\BaseRepository;
  5. /**
  6. * Class ExplainRepositoryEloquent.
  7. *
  8. * @package namespace App\Repositories;
  9. */
  10. class ExplainRepository extends BaseRepository
  11. {
  12. /**
  13. * Specify Model class name
  14. *
  15. * @return string
  16. */
  17. public function model()
  18. {
  19. return Explain::class;
  20. }
  21. /**
  22. * @param $where array
  23. * @return null|\Illuminate\Database\Eloquent\Model
  24. */
  25. public function getLimitExplains($where, $limit)
  26. {
  27. /*return $this->model->when(get_subsite_id()>0, function ($query) {
  28. $query->whereHas('subsites', function ($query) { $query->where('subsite_id', get_subsite_id());});
  29. })->where($where)->orderByRaw('list_order asc, ID desc')->limit($limit)->get();*/
  30. return $this->model->whereHas('subsites', function ($query) {
  31. $query->where('subsite_id', get_subsite_id());
  32. })->where($where)->orderByRaw('list_order desc, created_at desc')->limit($limit)->get();
  33. }
  34. public function getExplainInfo($where)
  35. {
  36. /*return $this->model->when(get_subsite_id()>0, function ($query) {
  37. $query->whereHas('subsites', function ($query) { $query->where('subsite_id', get_subsite_id());});
  38. })->where($where)->first();*/
  39. return $this->model->whereHas('subsites', function ($query) {
  40. $query->where('subsite_id', get_subsite_id());
  41. })->where($where)->first();
  42. }
  43. public function getWhere($where)
  44. {
  45. /*return $this->model->with(['show_category'])->when(get_subsite_id()>0, function ($query) {
  46. $query->whereHas('subsites', function ($query) {
  47. $query->where('subsite_id', get_subsite_id());
  48. });
  49. })->where($where)->orderBy('list_order', 'asc')->orderBy('id', 'desc')->get();*/
  50. return $this->model->with(['show_category'])->whereHas('subsites', function ($query) {
  51. $query->where('subsite_id', get_subsite_id());
  52. })->where($where)->orderBy('list_order', 'desc')->orderBy('created_at', 'desc')->get();
  53. }
  54. public function incrementData($where, $num, $filed)
  55. {
  56. return $this->model->where($where)->increment($filed, $num);
  57. }
  58. }