【現状と困っていること】
タイトルの通りですが、全てのデータのトータルを.countで表示したいのですがpagineteごとに.countされてしまいます。
show.html.erb
<div class="user-show"> <% if @user.id == current_user.id %> <div class="col-xs-9"> --.count-- <h2>通知(<%= @entries.count %>)件</h2> <hr> <% @entries.each do |e| %> <div class="box26"> <span class="box_title">No.<%= e.room.id%><small> (<%= e.created_at.strftime('%m月%d日') %>)</small></span> <p><a class="title-text" href="/rooms/<%= e.room.id %>"><%= e.room.name %></a></p> <span class="box_explain">内容:<%= e.room.explain %></span> </div> <hr> <% end %> <%= paginate @entries %> . . .
タイトルに.countを使用しており、全ての@entriesをカウントしたいのですが、paginateごとにカウントしてる現状です。
例をあげると
@entriesが全部で22個
paginate.per(10)で1ページに10個の@entriesを表示
.countの表示は22個となってほしいのですが、paginateごとに10個10個2個と表示されます。
【自分なりに考えた事】
.countをpaginateされる前に集計してしまえば今回のようなことが起きないのかなと思っていますがその方法が正直わかりません。なんとなくcontroller側に関係があるのかなと思っています。
controller
def show @user = User.find(params[:id]) if @user.id == current_user.id @entries = current_user.entries.order(created_at: 'desc').kaminari_page(params[:page]).per(5) else @room = Room.new @entry = Entry.new end end
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。