Добрый вечер всем, у меня проблема с lagvel paginator, у меня есть запрос, который состоит из трех запросов, которые следующие:
public static function getActu($user_id){
// 1 select all the articles published by the shop followed by a user
$res = DB::table('users')
->join('user_folow_boutiques', 'user_folow_boutiques.user_id', '=', 'users.id')
->join('boutique', 'boutique.id', '=', 'user_folow_boutiques.boutique_id')
->join('type_article', 'type_article.boutique_id', '=', 'boutique.id')
->join('article', 'type_article.id', '=', 'article.type_article_id')
->where('users.id','=',$user_id)
->select(DB::raw('article.*,article.created_at as date,null as nbrlik'));
// 2 Select all the products that are liked by the users I followed
$res2 = DB::table('users')
->join('user_follow_user', 'user_follow_user.user_id_1', '=', 'users.id')
->join('user_aime_article', 'user_follow_user.user_id_2', '=', 'user_aime_article.user_id')
->join('article', 'user_aime_article.article_id', '=', 'article.id')
->where('users.id','=',$user_id)
->select(DB::raw('article.*,user_aime_article.created_at as date, null as nbrlik') )
->distinct();
// 3 Select all the products of the shop followed by the user and who have exactly 50 likes
$res3 = DB::table('users')
->join('user_folow_boutiques', 'user_folow_boutiques.user_id', '=', 'users.id')
->join('boutique', 'boutique.id', '=', 'user_folow_boutiques.boutique_id')
->join('type_article', 'type_article.boutique_id', '=', 'boutique.id')
->join('article', 'type_article.id', '=', 'article.type_article_id')
->join(DB::raw('(SELECT article.id c_id, count(user_aime_article.id) as nbrlik FROM article JOIN user_aime_article on user_aime_article.article_id = article.id GROUP BY user_aime_article.article_id) e'),'article.id','=','e.c_id')
->where('users.id','=',$user_id)
->where('e.nbrlik','=',50)
->select(DB::raw('article.*,article.created_at as date, e.nbrlik'))
->union($res)
->union($res2)
->groupBy('article.id')
->orderBy('date','desc')
->paginate(20)
->get();
return $res3;
}
Мне нужна эта информация, чтобы создать новостную ленту в моемклиентский сайт, и мне нужна нумерация страниц для создания бесконечной прокрутки, но она не работает
Я искал эту проблему в сети и обнаружил, что использование метода paginate (x)
с групповым доступом невозможно,и чтобы обойти это, я должен создать себе пейджинг, и я попробовал, что следует, но это не работает
$paginate = 5;
$list_news = User::getActu(Auth::user()->id);// without ->paginate(20);
$slice = array_slice($list_news->toArray(), $paginate * ($page - 1), $paginate);
$result = new Paginator($slice, 20);