Class: Knockapi::Internal::ItemsCursor
- Inherits:
-
Object
- Object
- Knockapi::Internal::ItemsCursor
- Includes:
- Type::BasePage
- Defined in:
- lib/knockapi/internal/items_cursor.rb
Overview
Defined Under Namespace
Classes: PageInfo
Instance Attribute Summary collapse
Instance Method Summary collapse
- #auto_paging_each(&blk) {|| ... } ⇒ Object
-
#initialize(client:, req:, headers:, page_data:) ⇒ ItemsCursor
constructor
private
A new instance of ItemsCursor.
- #inspect ⇒ String private
- #next_page ⇒ self
- #next_page? ⇒ Boolean
Methods included from Type::BasePage
Constructor Details
#initialize(client:, req:, headers:, page_data:) ⇒ ItemsCursor
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Returns a new instance of ItemsCursor.
65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 |
# File 'lib/knockapi/internal/items_cursor.rb', line 65 def initialize(client:, req:, headers:, page_data:) super case page_data in {items: Array => items} @items = items.map { Knockapi::Internal::Type::Converter.coerce(@model, _1) } else end case page_data in {page_info: Hash | nil => page_info} @page_info = Knockapi::Internal::Type::Converter.coerce(Knockapi::Internal::ItemsCursor::PageInfo, page_info) else end end |
Instance Attribute Details
#items ⇒ Array<generic<Elem>>?
20 21 22 |
# File 'lib/knockapi/internal/items_cursor.rb', line 20 def items @items end |
#page_info ⇒ PageInfo
23 24 25 |
# File 'lib/knockapi/internal/items_cursor.rb', line 23 def page_info @page_info end |
Instance Method Details
#auto_paging_each(&blk) {|| ... } ⇒ Object
45 46 47 48 49 50 51 52 53 54 55 56 57 |
# File 'lib/knockapi/internal/items_cursor.rb', line 45 def auto_paging_each(&blk) unless block_given? raise ArgumentError.new("A block must be given to ##{__method__}") end page = self loop do page.items&.each(&blk) break unless page.next_page? page = page.next_page end end |
#inspect ⇒ String
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
84 85 86 87 88 |
# File 'lib/knockapi/internal/items_cursor.rb', line 84 def inspect model = Knockapi::Internal::Type::Converter.inspect(@model, depth: 1) "#<#{self.class}[#{model}]:0x#{object_id.to_s(16)}>" end |
#next_page ⇒ self
32 33 34 35 36 37 38 39 40 |
# File 'lib/knockapi/internal/items_cursor.rb', line 32 def next_page unless next_page? = "No more pages available. Please check #next_page? before calling ##{__method__}" raise RuntimeError.new() end req = Knockapi::Internal::Util.deep_merge(@req, {query: {after: page_info&.after}}) @client.request(req) end |
#next_page? ⇒ Boolean
26 27 28 |
# File 'lib/knockapi/internal/items_cursor.rb', line 26 def next_page? !items.to_a.empty? && !page_info&.after.to_s.empty? end |