123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- <?php
- namespace App\Repositories;
- use App\Models\Policy;
- use Prettus\Repository\Eloquent\BaseRepository;
- /**
- * Class ArticleRepositoryEloquent.
- *
- * @package namespace App\Repositories;
- */
- class PolicyRepository extends BaseRepository
- {
- /**
- * Specify Model class name
- *
- * @return string
- */
- public function model()
- {
- return Policy::class;
- }
- /**
- * @param $where array
- * @return null|\Illuminate\Database\Eloquent\Model
- */
- public function getPolicys($where, $page)
- {
- $res = $this->model->where($where)->orderByRaw('article_order desc,created_at desc');
- if ($page) {
- return $res->paginate($page);
- } else {
- return $res->get();
- }
- }
- /*
- *根据分类查询
- */
- public function getPolicy($where,$page)
- {
- return $this->model->whereHas('show_category',function ($query) use ($where){
- $query->where($where);
- })->paginate($page);
- }
- /**
- * @param $where array
- * @return null|\Illuminate\Database\Eloquent\Model
- */
- public function getAllPolicys($where, $orWhere, $page)
- {
- $res = $this->model->where(function ($query) use ($where, $orWhere) {
- $query->where($where)->orwhere($orWhere);
- })->orderByRaw('article_order desc,created_at desc');
- if ($page) {
- return $res->paginate($page);
- } else {
- return $res->get();
- }
- }
- public function getFocosPolicys($focos, $limit)
- {
- $where = array('is_display'=>'1','focos'=>$focos);
- return $this->model->where($where)->orderByRaw('article_order desc,created_at desc,id desc')->limit($limit)->get();
- }
- public function firstWhere($where)
- {
- return $this->model->where($where)->first();
- }
- public function incrementData($where, $num, $filed)
- {
- return $this->model->where($where)->increment($filed, $num);
- }
- public function filterPolicys($where = array(), $whereIn = array(), $order = array())
- {
-
- $rst = $this->model->where($where);
- if ($whereIn) {
- foreach ($whereIn as $k => $v) {
- $rst->whereIn($k, $v);
- }
- }
- if ($order) {
- if (is_array($order)) {
- foreach ($order as $k => $v) {
- $rst->orderBy($k, $v);
- }
- } else {
- $rst->orderbyRaw($order);
- }
- }
- return $rst->get();
- }
- }
|