Class: Wedge::DOM
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
if dom.respond_to? method, true
dom.send method, *args, &block
else
super
end
end
|
Instance Attribute Details
Returns the value of attribute dom.
5
6
7
|
# File 'lib/wedge/dom.rb', line 5
def dom
@dom
end
|
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
Shortcut for creating dom
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
|
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
|
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
|