Class: Amazon::Element

Inherits:
Object
  • Object
show all
Defined in:
lib/amazon/ecs.rb

Overview

Internal wrapper class to provide convenient method to access Hpricot element value.

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(element) ⇒ Element

Pass Hpricot::Elements object



231
232
233
# File 'lib/amazon/ecs.rb', line 231

def initialize(element)
  @element = element
end

Class Method Details

.get(element, path = '') ⇒ Object

Similar to #get, except an element object must be passed-in.



278
279
280
281
282
283
# File 'lib/amazon/ecs.rb', line 278

def self.get(element, path='')
  return unless element
  result = element.at(path)
  result = result.inner_html if result
  result
end

.get_array(element, path = '') ⇒ Object

Similar to #get_array, except an element object must be passed-in.



292
293
294
295
296
297
298
299
300
301
302
303
304
305
# File 'lib/amazon/ecs.rb', line 292

def self.get_array(element, path='')
  return unless element
  
  result = element/path
  if (result.is_a? Hpricot::Elements) || (result.is_a? Array)
    parsed_result = []
    result.each {|item|
      parsed_result << Element.get(item)
    }
    parsed_result
  else
    [Element.get(result)]
  end
end

.get_hash(element, path = '') ⇒ Object

Similar to #get_hash, except an element object must be passed-in.



308
309
310
311
312
313
314
315
316
317
318
319
320
# File 'lib/amazon/ecs.rb', line 308

def self.get_hash(element, path='')
  return unless element

  result = element.at(path)
  if result
    hash = {}
    result = result.children
    result.each do |item|
      hash[item.name.to_sym] = item.inner_html
    end 
    hash
  end
end

.get_unescaped(element, path = '') ⇒ Object

Similar to #get_unescaped, except an element object must be passed-in.



286
287
288
289
# File 'lib/amazon/ecs.rb', line 286

def self.get_unescaped(element, path='')
  result = get(element, path)
  CGI::unescapeHTML(result) if result
end

Instance Method Details

#/(path) ⇒ Object

Find Hpricot::Elements matching the given path. Example: element/“author”.



241
242
243
244
245
# File 'lib/amazon/ecs.rb', line 241

def /(path)
  elements = @element/path
  return nil if elements.size == 0
  elements
end

#elemObject

Returns Hpricot::Elments object



236
237
238
# File 'lib/amazon/ecs.rb', line 236

def elem
  @element
end

#get(path = '') ⇒ Object

Get the text value of the given path, leave empty to retrieve current element value.



258
259
260
# File 'lib/amazon/ecs.rb', line 258

def get(path='')
  Element.get(@element, path)
end

#get_array(path = '') ⇒ Object

Get the array values of the given path.



268
269
270
# File 'lib/amazon/ecs.rb', line 268

def get_array(path='')
  Element.get_array(@element, path)
end

#get_hash(path = '') ⇒ Object

Get the children element text values in hash format with the element names as the hash keys.



273
274
275
# File 'lib/amazon/ecs.rb', line 273

def get_hash(path='')
  Element.get_hash(@element, path)
end

#get_unescaped(path = '') ⇒ Object

Get the unescaped HTML text of the given path.



263
264
265
# File 'lib/amazon/ecs.rb', line 263

def get_unescaped(path='')
  Element.get_unescaped(@element, path)
end

#search_and_convert(path) ⇒ Object

Find Hpricot::Elements matching the given path, and convert to Amazon::Element. Returns an array Amazon::Elements if more than Hpricot::Elements size is greater than 1.



249
250
251
252
253
254
255
# File 'lib/amazon/ecs.rb', line 249

def search_and_convert(path)
  elements = self./(path)
  return unless elements
  elements = elements.map{|element| Element.new(element)}
  return elements.first if elements.size == 1
  elements
end

#to_sObject



322
323
324
# File 'lib/amazon/ecs.rb', line 322

def to_s
  elem.to_s if elem
end