Class: Wedge::DOM

Inherits:
Object show all
Includes:
Methods
Defined in:
lib/wedge/dom.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods included from Methods

#client?, included, #server?

Constructor Details

#initialize(html) ⇒ DOM

Returns a new instance of DOM.



16
17
18
19
20
21
22
23
24
# File 'lib/wedge/dom.rb', line 16

def initialize html
  @raw_html = html

  if server?
    @dom = raw_html.is_a?(String) ? HTML[raw_html.dup] : raw_html
  else
    @dom = raw_html.is_a?(String) ? Element[raw_html.dup] : raw_html
  end
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(method, *args, &block) ⇒ Object

This allows you to use all the nokogiri or opal jquery methods if a global one isn’t set



130
131
132
133
134
135
136
137
# File 'lib/wedge/dom.rb', line 130

def method_missing method, *args, &block
  # respond_to?(symbol, include_all=false)
  if dom.respond_to? method, true
    dom.send method, *args, &block
  else
    super
  end
end

Instance Attribute Details

#domObject

Returns the value of attribute dom.



5
6
7
# File 'lib/wedge/dom.rb', line 5

def dom
  @dom
end

#raw_htmlObject

Returns the value of attribute raw_html.



5
6
7
# File 'lib/wedge/dom.rb', line 5

def raw_html
  @raw_html
end

Class Method Details

.[](html) ⇒ Object

Shortcut for creating dom

Parameters:



11
12
13
# File 'lib/wedge/dom.rb', line 11

def [] html
  new html
end

Instance Method Details

#add_class(classes) ⇒ Object



63
64
65
66
67
# File 'lib/wedge/dom.rb', line 63

def add_class classes
  classes = (classes || '').split ' ' unless classes.is_a? Array
  new_classes =  ((node.attr('class') || '').split(' ') << classes).uniq.join(' ')
  node['class'] = new_classes
end

#attr(key, value = false) ⇒ Object



74
75
76
77
78
79
80
81
# File 'lib/wedge/dom.rb', line 74

def attr key, value = false
  if value
    value = value.join ' ' if value.is_a? Array
    node[key] = value
  else
    super key
  end
end

#data(key = false, value = false) ⇒ Object



47
48
49
50
51
52
53
54
55
56
57
# File 'lib/wedge/dom.rb', line 47

def data key = false, value = false
  d = Hash[node.xpath("@*[starts-with(name(), 'data-')]").map{|a| [a.name, a.value]}]

  if !key
    d
  elsif key && !value
    d[key]
  else
    node["data-#{key}"] = value
  end
end

#find(string, &block) ⇒ Object



26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# File 'lib/wedge/dom.rb', line 26

def find string, &block
  if client?
    node = DOM.new dom.find(string)
  elsif server?
    if block_given?
      node = DOM.new dom.css(string)
    else
      node = DOM.new dom.at(string)
    end
  end

  if block_given?
    node.each_with_index do |n, i|
      block.call DOM.new(n), i
    end
  end

  node
end

#html(content = false) ⇒ Object



112
113
114
115
116
117
118
119
120
121
122
# File 'lib/wedge/dom.rb', line 112

def html content = false
  if !content
    if server?
      node.inner_html
    else
      node ? node.html : dom.html
    end
  else
    self.html = content
  end
end

#html=(content) ⇒ Object



84
85
86
87
88
89
90
91
92
93
# File 'lib/wedge/dom.rb', line 84

def html= content
  if server?
    node.inner_html = content
  else
    content = content.dom if content.is_a? Wedge::DOM
    node.html content
  end

  node
end

#nodeObject



124
125
126
# File 'lib/wedge/dom.rb', line 124

def node
  @node || dom
end

#remove_class(classes) ⇒ Object



69
70
71
72
# File 'lib/wedge/dom.rb', line 69

def remove_class classes
  classes = (classes || '').split ' ' unless classes.is_a? Array
  (node.attr('class') || '').split(' ').reject { |n| n =~ /active|asc|desc/i }.join(' ')
end

#to_htmlObject



105
106
107
108
109
# File 'lib/wedge/dom.rb', line 105

def to_html
  @dom ||= DOM.new '<div>'
  el = dom.first
  DOM.new('<div>').append(el).html
end

#val(value) ⇒ Object



59
60
61
# File 'lib/wedge/dom.rb', line 59

def val value
  node.content = value
end