lib/harvesting/models/time_entries.rb in harvesting-0.2.0 vs lib/harvesting/models/time_entries.rb in harvesting-0.3.0

- old
+ new

@@ -1,45 +1,18 @@ module Harvesting module Models - class TimeEntries < Base - include Harvesting::Enumerable - extend Forwardable + class TimeEntries < HarvestRecordCollection - attributed :per_page, - :total_pages, - :total_entries, - :next_page, - :previous_page, - :page, - :links - - attr_reader :entries - - def initialize(attrs, opts = {}) - super(attrs.reject {|k,v| k == "time_entries" }, opts) - @api_page = attrs + def initialize(attrs, query_opts = {}, opts = {}) + super(attrs.reject {|k,v| k == "time_entries" }, query_opts, opts) @entries = attrs["time_entries"].map do |entry| TimeEntry.new(entry, client: opts[:client]) end end - # def each - # @entries.each_with_index do |time_entry, index| - # yield(time_entry) - # end - # end - def page - @attributes['page'] - end - - def size - total_entries - end - def fetch_next_page - new_page = page + 1 - @entries += @client.time_entries(page: new_page).entries - @attributes['page'] = new_page + @entries += harvest_client.time_entries(next_page_query_opts).entries + @attributes['page'] = page + 1 end end end end