Class: Kadmin::Pager

Inherits:
Object
  • Object
show all
Includes:
Presentable
Defined in:
app/components/kadmin/pager.rb,
app/components/kadmin/pager/presenter.rb

Overview

Simple Pager structure, used to paginate collections

Defined Under Namespace

Classes: Presenter

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Presentable

#present

Constructor Details

#initialize(size:, offset:) ⇒ Pager

Returns a new instance of Pager.

Parameters:

  • size (Integer)

    size of a page

  • offset (Integer)

    offset/index for the current page

Raises:



25
26
27
28
29
30
31
32
33
34
# File 'app/components/kadmin/pager.rb', line 25

def initialize(size:, offset:)
  @size = size
  @offset = offset

  raise(Kadmin::Error, 'Page size must be greater than 0!') unless @size.positive?
  raise(Kadmin::Error, 'Offset must be at least 0!') unless @offset >= 0

  @current_page = (@offset / @size.to_f).floor
  self.total = @offset # assume offset is maximum initially
end

Instance Attribute Details

#current_pageInteger (readonly)

Returns the current page.

Returns:

  • (Integer)

    the current page



18
19
20
# File 'app/components/kadmin/pager.rb', line 18

def current_page
  @current_page
end

#offsetInteger (readonly)

Returns current index offset (determines current page).

Returns:

  • (Integer)

    current index offset (determines current page)



12
13
14
# File 'app/components/kadmin/pager.rb', line 12

def offset
  @offset
end

#pagesInteger (readonly)

Returns total number of pages.

Returns:

  • (Integer)

    total number of pages



15
16
17
# File 'app/components/kadmin/pager.rb', line 15

def pages
  @pages
end

#sizeInteger (readonly)

Returns number of items per page.

Returns:

  • (Integer)

    number of items per page



9
10
11
# File 'app/components/kadmin/pager.rb', line 9

def size
  @size
end

#totalInteger

Returns total number of items in the collection.

Returns:

  • (Integer)

    total number of items in the collection



21
22
23
# File 'app/components/kadmin/pager.rb', line 21

def total
  @total
end

Instance Method Details

#contains?(page) ⇒ Boolean

Returns true if ‘page` exists (i.e. would have any data).

Parameters:

  • page (Integer)

    the page to check for

Returns:

  • (Boolean)

    true if ‘page` exists (i.e. would have any data)



64
65
66
# File 'app/components/kadmin/pager.rb', line 64

def contains?(page)
  page.in?(0...@pages)
end

#current_page?(page) ⇒ Boolean

Returns true if ‘page` is the current page.

Parameters:

  • page (Integer)

    the page to check for

Returns:

  • (Boolean)

    true if ‘page` is the current page



58
59
60
# File 'app/components/kadmin/pager.rb', line 58

def current_page?(page)
  return page == @current_page
end

#next_page?(page = nil) ⇒ Boolean

Returns true if there is a next page.

Parameters:

  • page (Integer) (defaults to: nil)

    optional; if given, checks if the page after would have any data, otherwise checks based on the current page

Returns:

  • (Boolean)

    true if there is a next page



88
89
90
91
# File 'app/components/kadmin/pager.rb', line 88

def next_page?(page = nil)
  page ||= @current_page
  return offset_at(page.to_i + 1) < @total
end

#offset_at(page = nil) ⇒ Integer

Returns start offset for the given page.

Parameters:

  • page (Integer) (defaults to: nil)

    the page to get the offset for; if not given, uses the current page

Returns:

  • (Integer)

    start offset for the given page



51
52
53
54
# File 'app/components/kadmin/pager.rb', line 51

def offset_at(page = nil)
  page ||= @current_page
  return @size * page.to_i
end

#page_size(page = nil) ⇒ Integer

Returns the number of items that are on this page.

Parameters:

  • page (Integer) (defaults to: nil)

    optional; if not given, uses the current page

Returns:

  • (Integer)

    the number of items that are on this page



76
77
78
79
80
81
82
83
84
# File 'app/components/kadmin/pager.rb', line 76

def page_size(page = nil)
  page ||= @current_page
  return 0 unless contains?(page)

  page_start = offset_at(page)
  page_end = [offset_at(page.to_i + 1), @total].min

  return page_end - page_start
end

#paginate(collection) ⇒ ActiveRecord::Relation

Returns paginated collection.

Parameters:

  • collection (ActiveRecord::Relation)

    relation to paginate

Returns:

  • (ActiveRecord::Relation)

    paginated collection



38
39
40
41
42
43
44
45
46
47
# File 'app/components/kadmin/pager.rb', line 38

def paginate(collection)
  return nil if collection.nil?

  self.total = collection.count

  collection = collection.offset(@offset)
  collection = collection.limit(@size)

  return collection
end

#previous_page?(page = nil) ⇒ Boolean

Returns true if there is a previous page.

Parameters:

  • page (Integer) (defaults to: nil)

    optional; if given, checks if the page after would have any data, otherwise checks based on the current page

Returns:

  • (Boolean)

    true if there is a previous page



95
96
97
98
99
# File 'app/components/kadmin/pager.rb', line 95

def previous_page?(page = nil)
  page ||= @current_page

  return page.to_i.positive?
end