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



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

def initialize(element)
  @element = element
end

Class Method Details

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

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



316
317
318
319
320
321
# File 'lib/amazon/ecs.rb', line 316

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.



330
331
332
333
334
335
336
337
338
339
340
341
342
343
# File 'lib/amazon/ecs.rb', line 330

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.



346
347
348
349
350
351
352
353
354
355
356
357
358
# File 'lib/amazon/ecs.rb', line 346

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.



324
325
326
327
# File 'lib/amazon/ecs.rb', line 324

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”.



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

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

#elemObject

Returns Hpricot::Elments object



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

def elem
  @element
end

#get(path = '') ⇒ Object

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



296
297
298
# File 'lib/amazon/ecs.rb', line 296

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

#get_array(path = '') ⇒ Object

Get the array values of the given path.



306
307
308
# File 'lib/amazon/ecs.rb', line 306

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.



311
312
313
# File 'lib/amazon/ecs.rb', line 311

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

#get_unescaped(path = '') ⇒ Object

Get the unescaped HTML text of the given path.



301
302
303
# File 'lib/amazon/ecs.rb', line 301

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.



287
288
289
290
291
292
293
# File 'lib/amazon/ecs.rb', line 287

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



360
361
362
# File 'lib/amazon/ecs.rb', line 360

def to_s
  elem.to_s if elem
end