Module | Sequel::DatasetPagination |
In: |
lib/sequel/extensions/pagination.rb
|
Yields a paginated dataset for each page and returns the receiver. Does a count to find the total number of records for this dataset.
# File lib/sequel/extensions/pagination.rb, line 32 32: def each_page(page_size) 33: raise(Error, "You cannot paginate a dataset that already has a limit") if @opts[:limit] 34: record_count = count 35: total_pages = (record_count / page_size.to_f).ceil 36: (1..total_pages).each{|page_no| yield paginate(page_no, page_size, record_count)} 37: self 38: end
Returns a paginated dataset. The returned dataset is limited to the page size at the correct offset, and extended with the Pagination module. If a record count is not provided, does a count of total number of records for this dataset.
# File lib/sequel/extensions/pagination.rb, line 23 23: def paginate(page_no, page_size, record_count=nil) 24: raise(Error, "You cannot paginate a dataset that already has a limit") if @opts[:limit] 25: paginated = limit(page_size, (page_no - 1) * page_size) 26: paginated.extend(Dataset::Pagination) 27: paginated.set_pagination_info(page_no, page_size, record_count || count) 28: end