Class: FellowshipOne::PersonList

Inherits:
Object
  • Object
show all
Includes:
Enumerable
Defined in:
lib/api/person_list.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(options) ⇒ PersonList

Constructor.

Options: :page - (optional) The page number to get. :reader - (optional) The Reader to use to load the data.

Parameters:

  • options

    A hash of options for loading the list.



17
18
19
20
21
22
23
24
25
26
# File 'lib/api/person_list.rb', line 17

def initialize(options)
  #options[:page] ||= 1
  reader = options[:reader] || FellowshipOne::PersonListReader.new(options)
  @json_data = reader.load_feed

  @count = @json_data['@count'].to_i
  @page_number = @json_data['@pageNumber'].to_i
  @total_records = @json_data['@totalRecords'].to_i
  @additional_pages = @json_data['@additionalPages'].to_i
end

Instance Attribute Details

#additional_pagesObject (readonly)

Returns the value of attribute additional_pages.



7
8
9
# File 'lib/api/person_list.rb', line 7

def additional_pages
  @additional_pages
end

#countObject (readonly) Also known as: size

Returns the value of attribute count.



7
8
9
# File 'lib/api/person_list.rb', line 7

def count
  @count
end

#page_numberObject (readonly)

Returns the value of attribute page_number.



7
8
9
# File 'lib/api/person_list.rb', line 7

def page_number
  @page_number
end

#total_recordsObject (readonly)

Returns the value of attribute total_records.



7
8
9
# File 'lib/api/person_list.rb', line 7

def total_records
  @total_records
end

Instance Method Details

#[](index) ⇒ Person

Get the specified person.

Parameters:

  • index

    The index of the person to get.

Returns:



45
46
47
# File 'lib/api/person_list.rb', line 45

def [](index)
  Person.new( @json_data['person'][index] ) if @json_data['person'] and @json_data['person'][index]
end

#all_namesObject Also known as: names

All the people in the list.

Returns:

  • array of names (first last).



32
33
34
35
# File 'lib/api/person_list.rb', line 32

def all_names
  return [] unless @json_data['person']
  @json_data['person'].collect { |person| [person['firstName'], person['lastName']].join(' ') }
end

#each(&block) ⇒ Object

This method is needed for Enumerable.



51
52
53
# File 'lib/api/person_list.rb', line 51

def each &block
  @json_data['person'].each{ |person| yield( Person.new(person) )}
end

#empty?Boolean

Checks if the list is empty.

Returns:

  • (Boolean)

    True on empty, false otherwise.



61
62
63
64
# File 'lib/api/person_list.rb', line 61

def empty?
  #@json_data['person'].empty?
  self.count == 0 ? true : false
end

#idsObject

Get all the people ids in the list.

Returns:

  • An array of people ids.



70
71
72
# File 'lib/api/person_list.rb', line 70

def ids
  (@json_data['person'].collect { |person| person['@id'] }).uniq
end

#raw_dataObject

Access to the raw JSON data. This method is needed for merging lists.



78
79
80
# File 'lib/api/person_list.rb', line 78

def raw_data
  @json_data
end