| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 | <?phpnamespace App\Repositories;use App\Models\Explain;use Prettus\Repository\Eloquent\BaseRepository;/** * Class ExplainRepositoryEloquent. * * @package namespace App\Repositories; */class ExplainRepository extends BaseRepository{    /**     * Specify Model class name     *     * @return string     */    public function model()    {        return Explain::class;    }    /**     * @param $where array     * @return null|\Illuminate\Database\Eloquent\Model     */    public function getLimitExplains($where, $limit)    {        /*return $this->model->when(get_subsite_id()>0, function ($query) {            $query->whereHas('subsites', function ($query) { $query->where('subsite_id', get_subsite_id());});        })->where($where)->orderByRaw('list_order asc, ID desc')->limit($limit)->get();*/        return $this->model->whereHas('subsites', function ($query) {            $query->where('subsite_id', get_subsite_id());        })->where($where)->orderByRaw('list_order desc, created_at desc')->limit($limit)->get();    }    public function getExplainInfo($where)    {        /*return $this->model->when(get_subsite_id()>0, function ($query) {            $query->whereHas('subsites', function ($query) { $query->where('subsite_id', get_subsite_id());});        })->where($where)->first();*/        return $this->model->whereHas('subsites', function ($query) {            $query->where('subsite_id', get_subsite_id());        })->where($where)->first();    }    public function getWhere($where)    {        /*return $this->model->with(['show_category'])->when(get_subsite_id()>0, function ($query) {            $query->whereHas('subsites', function ($query) {                $query->where('subsite_id', get_subsite_id());            });        })->where($where)->orderBy('list_order', 'asc')->orderBy('id', 'desc')->get();*/        return $this->model->with(['show_category'])->whereHas('subsites', function ($query) {                $query->where('subsite_id', get_subsite_id());        })->where($where)->orderBy('list_order', 'desc')->orderBy('created_at', 'desc')->get();    }    public function incrementData($where, $num, $filed)    {        return $this->model->where($where)->increment($filed, $num);    }}
 |