-
Notifications
You must be signed in to change notification settings - Fork 1
/
html_output.go
154 lines (133 loc) · 3.24 KB
/
html_output.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
package html5
// HTMLOutput represents HTML <output> tag
type HTMLOutput struct {
HTMLElement
}
// Output creates an HTML <output> tag element
func Output() *HTMLOutput {
e := &HTMLOutput{}
e.a = make(map[string]interface{})
e.tagName = "output"
return e
}
// S sets the element's CSS properties
func (e *HTMLOutput) S(style StyleMap) *HTMLOutput {
e.HTMLElement.S(style)
return e
}
// Key sets virtual dom's special property to instruct the diffing mechanism
// to reorder the node instead of replacing it
func (e *HTMLOutput) Key(key interface{}) *HTMLOutput {
e.key = F(key)
return e
}
// Ref marks the dest pointer to receive the real DOM element on render.
// Useful for getting live value of an input element, for example.
func (e *HTMLOutput) Ref(dest *DOMElement) *HTMLOutput {
e.ref = dest
return e
}
// Name sets the element's "name" attribute
func (e *HTMLOutput) Name(v string) *HTMLOutput {
e.a["name"] = v
return e
}
// DefaultValue sets the element's "defaultvalue" attribute
func (e *HTMLOutput) DefaultValue(v string) *HTMLOutput {
e.a["defaultvalue"] = v
return e
}
// Value sets the element's "value" attribute
func (e *HTMLOutput) Value(v string) *HTMLOutput {
e.a["value"] = v
return e
}
// CheckValidity sets the element's "checkvalidity" attribute
func (e *HTMLOutput) CheckValidity(v bool) *HTMLOutput {
if v {
e.a["checkvalidity"] = ""
} else {
delete(e.a, "checkvalidity")
}
return e
}
// ReportValidity sets the element's "reportvalidity" attribute
func (e *HTMLOutput) ReportValidity(v bool) *HTMLOutput {
if v {
e.a["reportvalidity"] = ""
} else {
delete(e.a, "reportvalidity")
}
return e
}
// ID sets the element's "id" attribute
func (e *HTMLOutput) ID(v string) *HTMLOutput {
e.a["id"] = v
return e
}
// Class sets the element's "class" attribute
func (e *HTMLOutput) Class(v string) *HTMLOutput {
e.a["class"] = v
return e
}
// Title sets the element's "title" attribute
func (e *HTMLOutput) Title(v string) *HTMLOutput {
e.a["title"] = v
return e
}
// Lang sets the element's "lang" attribute
func (e *HTMLOutput) Lang(v string) *HTMLOutput {
e.a["lang"] = v
return e
}
// Translate sets the element's "translate" attribute
func (e *HTMLOutput) Translate(v bool) *HTMLOutput {
if v {
e.a["translate"] = ""
} else {
delete(e.a, "translate")
}
return e
}
// Dir sets the element's "dir" attribute
func (e *HTMLOutput) Dir(v string) *HTMLOutput {
e.a["dir"] = v
return e
}
// Hidden sets the element's "hidden" attribute
func (e *HTMLOutput) Hidden(v bool) *HTMLOutput {
if v {
e.a["hidden"] = ""
} else {
delete(e.a, "hidden")
}
return e
}
// TabIndex sets the element's "tabindex" attribute
func (e *HTMLOutput) TabIndex(v int) *HTMLOutput {
e.a["tabindex"] = v
return e
}
// AccessKey sets the element's "accesskey" attribute
func (e *HTMLOutput) AccessKey(v string) *HTMLOutput {
e.a["accesskey"] = v
return e
}
// Draggable sets the element's "draggable" attribute
func (e *HTMLOutput) Draggable(v bool) *HTMLOutput {
if v {
e.a["draggable"] = ""
} else {
delete(e.a, "draggable")
}
return e
}
// Spellcheck sets the element's "spellcheck" attribute
func (e *HTMLOutput) Spellcheck(v bool) *HTMLOutput {
if v {
e.a["spellcheck"] = ""
} else {
delete(e.a, "spellcheck")
}
return e
}