Methods

Included Modules

Class/Module Index [+]

Quicksearch

Ramaze::Helper::Paginate

Helper for pagination and pagination-navigation.

See {Ramaze::Helper::Paginate#paginate} for more information.

Public Instance Methods

paginate(dataset, options = {}) click to toggle source

Returns a new Paginator instance.

Note that the pagination relies on being inside a Ramaze request to gain necessary metadata about the page it resides on, you cannot use it outside of Ramaze yet.

The examples below are meant to be used within your controller or view.

Usage with Array:

data = (1..100).to_a
@pager = paginate(data, :limit => 30, :page => 2)
@pager.navigation
@pager.each{|e| puts(e) }

Usage with Sequel:

data = Article.filter(:public => true)
@pager = paginate(data, :limit => 5)
@pager.navigation
@pager.each{|e| puts(e)

Note that you must first extend Sequel with the pagination extension"

Sequel.extension :pagination

@param [Sequel::Dataset|Array] dataset May be a Sequel dataset or an

Array

@param [Hash] options A hash containing custom options that takes

precedence to ``trait[:paginate].

@option options [Fixnum] :limit The number of elements used when you

call #each on the paginator

@option options [String] :var The variable name being used in the

request, this is helpful if you want to use two or more independent
paginations on the same page.

@option options [Fixnum] :page The page you are currently on, if not

given it will be retrieved from current request variables. Defaults to
1 if neither exists.
# File lib/ramaze/helper/paginate.rb, line 60
def paginate(dataset, options = {})
  options = ancestral_trait[:paginate].merge(options)
  limit = options[:limit]
  var   = options[:var]
  page  = options[:page] || (request[var] || 1).to_i

  Paginator.new(dataset, page, limit, var)
end

[Validate]

Generated with the Darkfish Rdoc Generator 2.