views:

342

answers:

4

Hi community, me again...

I need show 10 or 20 or 50 results number of results per page with a select options in my list of posts using will_paginate plugin

Can you help me please?

Thanks!

+1  A: 

To set a class wide Default

class Post < ActiveRecord::Base

  def self.per_page
    25
  end

end

Or on a query by query basis use the per_page in your call

class Post <ActiveRecord::Base

  def self.posts_by_paginate
    paginate(:all, :per_page => 25, :conditions => ["published = ?", true])
  end

end
railsninja
A: 

Shameless self blog post.. but see if it helps
http://madcoderspeak.blogspot.com/2008/02/showmethemoney-17-i-will-paginate-with.html

Gishu
has nothing to do with the question at all.
sbwoodside
+1  A: 

Here is what I will do

Class UsersController < ApplicationController
    def index
        @users = User.paginate(:all, :page => params[:page], :per_page => params[:number_of_records])
    end
end
ez
If OP wants to ensure that only 10, 20 and 50 are valid per page options, you could extend this method to enforce that constraint. Something like ['10', '20', '50'].include?(params[:page])
Tate Johnson
A: 

Looks like the OP also asked here: http://railsforum.com/viewtopic.php?id=33793 and got much better answers.

To adapt the best solution there, here's what I like:

(in the view)

<%= select_tag :per_page, options_for_select([10,20,50], params[:per_page].to_i),
               :onchange => "if(this.value){window.location='?per_page='+this.value;}" %>

(in the controller)

@per_page = params[:per_page] || Post.per_page || 20
@posts = Post.paginate( :per_page => @per_page, :page => params[:page])
sbwoodside