bivouac 0.1.3 → 0.1.4
Sign up to get free protection for your applications and to get access to all the features.
- data/README +18 -1
- data/bin/bivouac +10 -6
- data/lib/bivouac/commands/generate.rb +2 -0
- data/lib/bivouac/commands/plugin.rb +47 -0
- data/lib/bivouac/helpers/view/goh/html.rb +17 -0
- data/lib/bivouac/template/application/postamble.rb +26 -4
- data/lib/bivouac/template/application_goh.rb +2 -1
- data/{examples/blog_erb/script/generate → lib/bivouac/template/plugin.rb} +1 -1
- data/lib/bivouac/template/static/index.html +3 -2
- metadata +95 -172
- data/doc/rdoc/classes/BivouacHelpers/BaseView.html +0 -178
- data/doc/rdoc/classes/BivouacHelpers/FormView.html +0 -398
- data/doc/rdoc/classes/BivouacHelpers/HtmlView.html +0 -274
- data/doc/rdoc/classes/BivouacHelpers/JavaScriptView.html +0 -573
- data/doc/rdoc/classes/BivouacHelpers/ScriptAculoUsView.html +0 -258
- data/doc/rdoc/classes/BivouacHelpers/TooltipView.html +0 -158
- data/doc/rdoc/classes/BivouacHelpers.html +0 -117
- data/doc/rdoc/classes/JavaScriptGenerator.html +0 -564
- data/doc/rdoc/created.rid +0 -1
- data/doc/rdoc/files/AUTHORS.html +0 -109
- data/doc/rdoc/files/COPYING.html +0 -533
- data/doc/rdoc/files/README.html +0 -379
- data/doc/rdoc/files/lib/bivouac/helpers/view/goh/base_rb.html +0 -109
- data/doc/rdoc/files/lib/bivouac/helpers/view/goh/form_rb.html +0 -109
- data/doc/rdoc/files/lib/bivouac/helpers/view/goh/html_rb.html +0 -109
- data/doc/rdoc/files/lib/bivouac/helpers/view/goh/javascript_rb.html +0 -113
- data/doc/rdoc/files/lib/bivouac/helpers/view/goh/scriptaculous_rb.html +0 -113
- data/doc/rdoc/files/lib/bivouac/helpers/view/goh/tooltip_rb.html +0 -109
- data/doc/rdoc/index.html +0 -10
- data/doc/rdoc/permalink.gif +0 -0
- data/doc/rdoc/rdoc-style.css +0 -106
- data/doc/rdoc/rubyfr.png +0 -0
- data/examples/blog_erb/app/blog.rb +0 -84
- data/examples/blog_erb/app/controllers/add.rb +0 -19
- data/examples/blog_erb/app/controllers/comment.rb +0 -9
- data/examples/blog_erb/app/controllers/edit.rb +0 -18
- data/examples/blog_erb/app/controllers/index.rb +0 -8
- data/examples/blog_erb/app/controllers/info.rb +0 -11
- data/examples/blog_erb/app/controllers/login.rb +0 -15
- data/examples/blog_erb/app/controllers/logout.rb +0 -8
- data/examples/blog_erb/app/controllers/view.rb +0 -9
- data/examples/blog_erb/app/models/comment.rb +0 -5
- data/examples/blog_erb/app/models/post.rb +0 -5
- data/examples/blog_erb/app/models/user.rb +0 -4
- data/examples/blog_erb/app/views/add.html +0 -18
- data/examples/blog_erb/app/views/edit.html +0 -18
- data/examples/blog_erb/app/views/index.html +0 -12
- data/examples/blog_erb/app/views/layout.html +0 -12
- data/examples/blog_erb/app/views/login.html +0 -2
- data/examples/blog_erb/app/views/logout.html +0 -2
- data/examples/blog_erb/app/views/view.html +0 -20
- data/examples/blog_erb/config/environment.rb +0 -27
- data/examples/blog_erb/db/Blog.db +0 -0
- data/examples/blog_erb/db/create.rb +0 -8
- data/examples/blog_erb/db/migrate/comment.rb +0 -15
- data/examples/blog_erb/db/migrate/post.rb +0 -15
- data/examples/blog_erb/db/migrate/user.rb +0 -15
- data/examples/blog_erb/log/Blog.log +0 -57
- data/examples/blog_erb/public/images/camping.png +0 -0
- data/examples/blog_erb/public/index.html +0 -242
- data/examples/blog_erb/public/stylesheets/style.css +0 -10
- data/examples/blog_erb/script/server +0 -5
- data/lib/bivouac/commands/server.rb +0 -9
- data/lib/bivouac/template/application/helpers_erb.rb +0 -11
- data/lib/bivouac/template/application_erb.rb +0 -77
- data/lib/bivouac/template/application_jof.rb +0 -42
- data/lib/bivouac/template/generate/scaffold_view_create_erb.rb +0 -7
- data/lib/bivouac/template/generate/scaffold_view_list_erb.rb +0 -7
- data/lib/bivouac/template/generate/scaffold_view_view_erb.rb +0 -10
- data/lib/bivouac/template/generate/view_erb.rb +0 -2
@@ -1,573 +0,0 @@
|
|
1
|
-
|
2
|
-
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
|
3
|
-
<html>
|
4
|
-
<head>
|
5
|
-
<title>
|
6
|
-
Bivouac, the Documentation » Module: BivouacHelpers::JavaScriptView
|
7
|
-
</title>
|
8
|
-
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
9
|
-
<link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
|
10
|
-
<script language="JavaScript" type="text/javascript">
|
11
|
-
// <![CDATA[
|
12
|
-
|
13
|
-
function toggleSource( id )
|
14
|
-
{
|
15
|
-
var elem
|
16
|
-
var link
|
17
|
-
|
18
|
-
if( document.getElementById )
|
19
|
-
{
|
20
|
-
elem = document.getElementById( id )
|
21
|
-
link = document.getElementById( "l_" + id )
|
22
|
-
}
|
23
|
-
else if ( document.all )
|
24
|
-
{
|
25
|
-
elem = eval( "document.all." + id )
|
26
|
-
link = eval( "document.all.l_" + id )
|
27
|
-
}
|
28
|
-
else
|
29
|
-
return false;
|
30
|
-
|
31
|
-
if( elem.style.display == "block" )
|
32
|
-
{
|
33
|
-
elem.style.display = "none"
|
34
|
-
link.innerHTML = "show source"
|
35
|
-
}
|
36
|
-
else
|
37
|
-
{
|
38
|
-
elem.style.display = "block"
|
39
|
-
link.innerHTML = "hide source"
|
40
|
-
}
|
41
|
-
}
|
42
|
-
|
43
|
-
function openCode( url )
|
44
|
-
{
|
45
|
-
window.open( url, "SOURCE_CODE", "width=400,height=400,scrollbars=yes" )
|
46
|
-
}
|
47
|
-
// ]]>
|
48
|
-
</script>
|
49
|
-
</head>
|
50
|
-
<body>
|
51
|
-
<!--
|
52
|
-
<div id="menu">
|
53
|
-
<h3 class="title">Module: BivouacHelpers::JavaScriptView</h3>
|
54
|
-
</div>
|
55
|
-
-->
|
56
|
-
<div id="fullpage">
|
57
|
-
<div id="pager">
|
58
|
-
<table>
|
59
|
-
<tr><td><img src="../../rubyfr.png" /></td>
|
60
|
-
<td id="pagertd">
|
61
|
-
<strong># Module: BivouacHelpers::JavaScriptView<br />
|
62
|
-
[
|
63
|
-
"<a href="../../files/README.html" value="File: README">README</a>",
|
64
|
-
"<a href="../../files/AUTHORS.html" value="File: AUTHORS">AUTHORS</a>",
|
65
|
-
"<a href="../../files/COPYING.html" value="File: COPYING">COPYING</a>",
|
66
|
-
"<a href="../../files/lib/bivouac/helpers/view/goh/base_rb.html" value="File: base.rb">lib/bivouac/helpers/view/goh/base.rb</a>",
|
67
|
-
"<a href="../../files/lib/bivouac/helpers/view/goh/form_rb.html" value="File: form.rb">lib/bivouac/helpers/view/goh/form.rb</a>",
|
68
|
-
"<a href="../../files/lib/bivouac/helpers/view/goh/html_rb.html" value="File: html.rb">lib/bivouac/helpers/view/goh/html.rb</a>",
|
69
|
-
"<a href="../../files/lib/bivouac/helpers/view/goh/tooltip_rb.html" value="File: tooltip.rb">lib/bivouac/helpers/view/goh/tooltip.rb</a>",
|
70
|
-
"<a href="../../files/lib/bivouac/helpers/view/goh/scriptaculous_rb.html" value="File: scriptaculous.rb">lib/bivouac/helpers/view/goh/scriptaculous.rb</a>",
|
71
|
-
"<a href="../../files/lib/bivouac/helpers/view/goh/javascript_rb.html" value="File: javascript.rb">lib/bivouac/helpers/view/goh/javascript.rb</a>",
|
72
|
-
<a href="http://greg.rubyfr.net">nil</a>].each do<br />
|
73
|
-
<a href="../../classes/JavaScriptGenerator.html" title="Class: JavaScriptGenerator">JavaScriptGenerator</a>.view_html<br />
|
74
|
-
<a href="../../classes/BivouacHelpers.html" title="Module: BivouacHelpers">BivouacHelpers</a>.view_html<br />
|
75
|
-
<a href="../../classes/BivouacHelpers/TooltipView.html" title="Module: BivouacHelpers::TooltipView">BivouacHelpers::TooltipView</a>.view_html<br />
|
76
|
-
<a href="../../classes/BivouacHelpers/ScriptAculoUsView.html" title="Module: BivouacHelpers::ScriptAculoUsView">BivouacHelpers::ScriptAculoUsView</a>.view_html<br />
|
77
|
-
<a href="../../classes/BivouacHelpers/BaseView.html" title="Module: BivouacHelpers::BaseView">BivouacHelpers::BaseView</a>.view_html<br />
|
78
|
-
<a href="../../classes/BivouacHelpers/JavaScriptView.html" title="Module: BivouacHelpers::JavaScriptView">BivouacHelpers::JavaScriptView</a>.view_html<br />
|
79
|
-
<a href="../../classes/BivouacHelpers/HtmlView.html" title="Module: BivouacHelpers::HtmlView">BivouacHelpers::HtmlView</a>.view_html<br />
|
80
|
-
<a href="../../classes/BivouacHelpers/FormView.html" title="Module: BivouacHelpers::FormView">BivouacHelpers::FormView</a>.view_html<br />
|
81
|
-
end</strong>
|
82
|
-
</td></tr>
|
83
|
-
</table>
|
84
|
-
</ul>
|
85
|
-
</div>
|
86
|
-
|
87
|
-
|
88
|
-
<div id="BivouacHelpers::JavaScriptView" class="page_shade">
|
89
|
-
<div class="page">
|
90
|
-
<h3>Module BivouacHelpers::JavaScriptView < Object</h3>
|
91
|
-
|
92
|
-
(in files
|
93
|
-
<a href="../../files/lib/bivouac/helpers/view/goh/javascript_rb.html">lib/bivouac/helpers/view/goh/javascript.rb</a>
|
94
|
-
)
|
95
|
-
|
96
|
-
<p>
|
97
|
-
bivouac/helpers/view/html
|
98
|
-
</p>
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
<h2 class="ruled">Methods</h2>
|
105
|
-
<h4 class="ruled">Public Instance method:
|
106
|
-
<strong><a name="M000029">escape_javascript(javascript)</a></strong> <a href="#M000029"><img src="../../permalink.gif" border="0" title="Permalink to Public Instance method: escape_javascript" /></a></h4>
|
107
|
-
|
108
|
-
<p>
|
109
|
-
Escape carrier returns and single and double quotes for JavaScript
|
110
|
-
segments.
|
111
|
-
</p>
|
112
|
-
|
113
|
-
<div class="sourcecode">
|
114
|
-
<p class="source-link">[ <a href="javascript:toggleSource('M000029_source')" id="l_M000029_source">show source</a> ]</p>
|
115
|
-
<div id="M000029_source" class="dyn-source">
|
116
|
-
<pre>
|
117
|
-
<span class="ruby-comment cmt"># File lib/bivouac/helpers/view/goh/javascript.rb, line 202</span>
|
118
|
-
202: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">escape_javascript</span>(<span class="ruby-identifier">javascript</span>)
|
119
|
-
203: (<span class="ruby-identifier">javascript</span> <span class="ruby-operator">||</span> <span class="ruby-value str">''</span>).<span class="ruby-identifier">gsub</span>(<span class="ruby-value str">'\\'</span>,<span class="ruby-value str">'\0\0'</span>).<span class="ruby-identifier">gsub</span>(<span class="ruby-regexp re">/\r\n|\n|\r/</span>, <span class="ruby-value str">"\\n"</span>).<span class="ruby-identifier">gsub</span>(<span class="ruby-regexp re">/["']/</span>) { <span class="ruby-operator">|</span><span class="ruby-identifier">m</span><span class="ruby-operator">|</span> <span class="ruby-node">"\\#{m}"</span> }
|
120
|
-
204: <span class="ruby-keyword kw">end</span>
|
121
|
-
</pre>
|
122
|
-
</div>
|
123
|
-
</div>
|
124
|
-
<h4 class="ruled">Public Instance method:
|
125
|
-
<strong><a name="M000030">javascript_tag( content, options = {} )</a></strong> <a href="#M000030"><img src="../../permalink.gif" border="0" title="Permalink to Public Instance method: javascript_tag" /></a></h4>
|
126
|
-
|
127
|
-
<p>
|
128
|
-
Returns a JavaScript tag with the <tt>block</tt> inside. Example:
|
129
|
-
</p>
|
130
|
-
<pre>
|
131
|
-
javascript_tag( "alert('Hello World!')", :defer => 'true' )
|
132
|
-
</pre>
|
133
|
-
<p>
|
134
|
-
Returns:
|
135
|
-
</p>
|
136
|
-
<pre>
|
137
|
-
<script defer="true" type="text/javascript">
|
138
|
-
//<![CDATA[
|
139
|
-
alert('Hello World!')
|
140
|
-
//]]>
|
141
|
-
</script>
|
142
|
-
</pre>
|
143
|
-
|
144
|
-
<div class="sourcecode">
|
145
|
-
<p class="source-link">[ <a href="javascript:toggleSource('M000030_source')" id="l_M000030_source">show source</a> ]</p>
|
146
|
-
<div id="M000030_source" class="dyn-source">
|
147
|
-
<pre>
|
148
|
-
<span class="ruby-comment cmt"># File lib/bivouac/helpers/view/goh/javascript.rb, line 218</span>
|
149
|
-
218: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">javascript_tag</span>( <span class="ruby-identifier">content</span>, <span class="ruby-identifier">options</span> = {} )
|
150
|
-
219: <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:type</span>] = <span class="ruby-value str">"text/javascript"</span>
|
151
|
-
220: <span class="ruby-identifier">script</span>( <span class="ruby-identifier">options</span> ) <span class="ruby-keyword kw">do</span>
|
152
|
-
221: <span class="ruby-value str">"//<![CDATA[\n"</span> <span class="ruby-operator">+</span> <span class="ruby-identifier">content</span> <span class="ruby-operator">+</span> <span class="ruby-value str">"\n//]]>"</span>
|
153
|
-
222: <span class="ruby-keyword kw">end</span>
|
154
|
-
223: <span class="ruby-keyword kw">end</span>
|
155
|
-
</pre>
|
156
|
-
</div>
|
157
|
-
</div>
|
158
|
-
<h4 class="ruled">Public Instance method:
|
159
|
-
<strong><a name="M000033">link_to_function( name, *args, &block )</a></strong> <a href="#M000033"><img src="../../permalink.gif" border="0" title="Permalink to Public Instance method: link_to_function" /></a></h4>
|
160
|
-
|
161
|
-
<p>
|
162
|
-
Returns a link that will trigger a JavaScript function using the onclick
|
163
|
-
handler and return false after the fact.
|
164
|
-
</p>
|
165
|
-
<p>
|
166
|
-
The function argument can be omitted in favor of an <a
|
167
|
-
href="JavaScriptView.html#M000031">update_page</a> block, which evaluates
|
168
|
-
to a string when the template is rendered (instead of making an Ajax
|
169
|
-
request first).
|
170
|
-
</p>
|
171
|
-
<p>
|
172
|
-
Examples:
|
173
|
-
</p>
|
174
|
-
<pre>
|
175
|
-
link_to_function "Greeting", "alert('Hello world!')"
|
176
|
-
</pre>
|
177
|
-
<p>
|
178
|
-
Produces:
|
179
|
-
</p>
|
180
|
-
<pre>
|
181
|
-
<a onclick="alert('Hello world!'); return false;" href="#">Greeting</a>
|
182
|
-
|
183
|
-
link_to_function(image_tag("delete"), "if (confirm('Really?')) do_delete()")
|
184
|
-
</pre>
|
185
|
-
<p>
|
186
|
-
Produces:
|
187
|
-
</p>
|
188
|
-
<pre>
|
189
|
-
<a onclick="if (confirm('Really?')) do_delete(); return false;" href="#">
|
190
|
-
<img src="/images/delete.png?" alt="Delete"/>
|
191
|
-
</a>
|
192
|
-
|
193
|
-
link_to_function("Show me more", nil, :id => "more_link") do |page|
|
194
|
-
page[:details].visual_effect :toggle_blind
|
195
|
-
page[:more_link].replace_html "Show me less"
|
196
|
-
end
|
197
|
-
</pre>
|
198
|
-
<p>
|
199
|
-
Produces:
|
200
|
-
</p>
|
201
|
-
<pre>
|
202
|
-
<a href="#" id="more_link" onclick="try {
|
203
|
-
$(&quot;details&quot;).visualEffect(&quot;toggle_blind&quot;);
|
204
|
-
$(&quot;more_link&quot;).update(&quot;Show me less&quot;);
|
205
|
-
}
|
206
|
-
catch (e) {
|
207
|
-
alert('RJS error:\n\n' + e.toString());
|
208
|
-
alert('$(\&quot;details\&quot;).visualEffect(\&quot;toggle_blind\&quot;);
|
209
|
-
\n$(\&quot;more_link\&quot;).update(\&quot;Show me less\&quot;);');
|
210
|
-
throw e
|
211
|
-
};
|
212
|
-
return false;">Show me more</a>
|
213
|
-
</pre>
|
214
|
-
|
215
|
-
<div class="sourcecode">
|
216
|
-
<p class="source-link">[ <a href="javascript:toggleSource('M000033_source')" id="l_M000033_source">show source</a> ]</p>
|
217
|
-
<div id="M000033_source" class="dyn-source">
|
218
|
-
<pre>
|
219
|
-
<span class="ruby-comment cmt"># File lib/bivouac/helpers/view/goh/javascript.rb, line 273</span>
|
220
|
-
273: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">link_to_function</span>( <span class="ruby-identifier">name</span>, <span class="ruby-operator">*</span><span class="ruby-identifier">args</span>, <span class="ruby-operator">&</span><span class="ruby-identifier">block</span> )
|
221
|
-
274: <span class="ruby-identifier">html_options</span> = <span class="ruby-identifier">args</span>.<span class="ruby-identifier">last</span>.<span class="ruby-identifier">is_a?</span>(<span class="ruby-constant">Hash</span>) <span class="ruby-operator">?</span> <span class="ruby-identifier">args</span>.<span class="ruby-identifier">pop</span> <span class="ruby-operator">:</span> {}
|
222
|
-
275: <span class="ruby-identifier">function</span> = <span class="ruby-identifier">args</span>[<span class="ruby-value">0</span>] <span class="ruby-operator">||</span> <span class="ruby-value str">''</span>
|
223
|
-
276:
|
224
|
-
277: <span class="ruby-identifier">function</span> = <span class="ruby-identifier">update_page</span>( <span class="ruby-operator">&</span><span class="ruby-identifier">block</span> ) <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">block_given?</span>
|
225
|
-
278:
|
226
|
-
279: <span class="ruby-identifier">a</span>( <span class="ruby-identifier">html_options</span>.<span class="ruby-identifier">merge</span>({
|
227
|
-
280: <span class="ruby-identifier">:href</span> =<span class="ruby-operator">></span> <span class="ruby-identifier">html_options</span>[<span class="ruby-identifier">:href</span>] <span class="ruby-operator">||</span> <span class="ruby-value str">"#"</span>,
|
228
|
-
281: <span class="ruby-identifier">:onclick</span> =<span class="ruby-operator">></span> (<span class="ruby-identifier">html_options</span>[<span class="ruby-identifier">:onclick</span>] <span class="ruby-operator">?</span> <span class="ruby-node">"#{html_options[:onclick]}; "</span> <span class="ruby-operator">:</span> <span class="ruby-value str">""</span>) <span class="ruby-operator">+</span> <span class="ruby-node">"#{function}; return false;"</span>
|
229
|
-
282: }) ) <span class="ruby-keyword kw">do</span>
|
230
|
-
283: <span class="ruby-identifier">name</span>
|
231
|
-
284: <span class="ruby-keyword kw">end</span>
|
232
|
-
285: <span class="ruby-keyword kw">end</span>
|
233
|
-
</pre>
|
234
|
-
</div>
|
235
|
-
</div>
|
236
|
-
<h4 class="ruled">Public Instance method:
|
237
|
-
<strong><a name="M000034">link_to_remote(name, options = {}, html_options = {})</a></strong> <a href="#M000034"><img src="../../permalink.gif" border="0" title="Permalink to Public Instance method: link_to_remote" /></a></h4>
|
238
|
-
|
239
|
-
<p>
|
240
|
-
Returns a link to a remote action defined by <tt>options[:url]</tt>
|
241
|
-
that‘s called in the background using XMLHttpRequest. The result of
|
242
|
-
that request can then be inserted into a DOM object whose id can be
|
243
|
-
specified with <tt>options[:update]</tt>. Usually, the result would be a
|
244
|
-
partial prepared by the controller.
|
245
|
-
</p>
|
246
|
-
<p>
|
247
|
-
Examples:
|
248
|
-
</p>
|
249
|
-
<pre>
|
250
|
-
link_to_remote "Delete this post", :update => "posts",
|
251
|
-
:url => R(Destroy, 1)
|
252
|
-
link_to_remote(image_tag("refresh"), :update => "emails",
|
253
|
-
:url => R(ListEmails)
|
254
|
-
</pre>
|
255
|
-
<p>
|
256
|
-
You can also specify a hash for <tt>options[:update]</tt> to allow for easy
|
257
|
-
redirection of output to an other DOM element if a server-side error
|
258
|
-
occurs:
|
259
|
-
</p>
|
260
|
-
<p>
|
261
|
-
Example:
|
262
|
-
</p>
|
263
|
-
<pre>
|
264
|
-
link_to_remote "Delete this post",
|
265
|
-
:url => R(Destroy, 1)
|
266
|
-
:update => { :success => "posts", :failure => "error" }
|
267
|
-
</pre>
|
268
|
-
<p>
|
269
|
-
Optionally, you can use the <tt>options[:position]</tt> parameter to
|
270
|
-
influence how the target DOM element is updated. It must be one of
|
271
|
-
<tt>:before</tt>, <tt>:top</tt>, <tt>:bottom</tt>, or <tt>:after</tt>.
|
272
|
-
</p>
|
273
|
-
<p>
|
274
|
-
To access the server response, use <tt>request.responseText</tt>, to find
|
275
|
-
out the HTTP status, use <tt>request.status</tt>.
|
276
|
-
</p>
|
277
|
-
<p>
|
278
|
-
Example:
|
279
|
-
</p>
|
280
|
-
<pre>
|
281
|
-
link_to_remote word,
|
282
|
-
:url => R(Undo, word_counter)
|
283
|
-
:complete => "undoRequestCompleted(request)"
|
284
|
-
</pre>
|
285
|
-
<p>
|
286
|
-
The callbacks that may be specified are (in order):
|
287
|
-
</p>
|
288
|
-
<table>
|
289
|
-
<tr><td valign="top"><tt>:loading</tt>:</td><td>Called when the remote document is being loaded with data by the browser.
|
290
|
-
|
291
|
-
</td></tr>
|
292
|
-
<tr><td valign="top"><tt>:loaded</tt>:</td><td>Called when the browser has finished loading the remote document.
|
293
|
-
|
294
|
-
</td></tr>
|
295
|
-
<tr><td valign="top"><tt>:interactive</tt>:</td><td>Called when the user can interact with the remote document, even though it
|
296
|
-
has not finished loading.
|
297
|
-
|
298
|
-
</td></tr>
|
299
|
-
<tr><td valign="top"><tt>:success</tt>:</td><td>Called when the XMLHttpRequest is completed, and the HTTP status code is in
|
300
|
-
the 2XX range.
|
301
|
-
|
302
|
-
</td></tr>
|
303
|
-
<tr><td valign="top"><tt>:failure</tt>:</td><td>Called when the XMLHttpRequest is completed, and the HTTP status code is
|
304
|
-
not in the 2XX range.
|
305
|
-
|
306
|
-
</td></tr>
|
307
|
-
<tr><td valign="top"><tt>:complete</tt>:</td><td>Called when the XMLHttpRequest is complete (fires after success/failure if
|
308
|
-
they are present).
|
309
|
-
|
310
|
-
</td></tr>
|
311
|
-
</table>
|
312
|
-
<p>
|
313
|
-
You can further refine <tt>:success</tt> and <tt>:failure</tt> by adding
|
314
|
-
additional callbacks for specific status codes.
|
315
|
-
</p>
|
316
|
-
<p>
|
317
|
-
Example:
|
318
|
-
</p>
|
319
|
-
<pre>
|
320
|
-
link_to_remote word,
|
321
|
-
:url => R(Action),
|
322
|
-
404 => "alert('Not found...? Wrong URL...?')",
|
323
|
-
:failure => "alert('HTTP Error ' + request.status + '!')"
|
324
|
-
</pre>
|
325
|
-
<p>
|
326
|
-
A status code callback overrides the success/failure handlers if present.
|
327
|
-
</p>
|
328
|
-
<p>
|
329
|
-
If you for some reason or another need synchronous processing
|
330
|
-
(that‘ll block the browser while the request is happening), you can
|
331
|
-
specify <tt>options[:type] = :synchronous</tt>.
|
332
|
-
</p>
|
333
|
-
<p>
|
334
|
-
You can customize further browser side call logic by passing in JavaScript
|
335
|
-
code snippets via some optional parameters. In their order of use these
|
336
|
-
are:
|
337
|
-
</p>
|
338
|
-
<table>
|
339
|
-
<tr><td valign="top"><tt>:confirm</tt>:</td><td>Adds confirmation dialog.
|
340
|
-
|
341
|
-
</td></tr>
|
342
|
-
<tr><td valign="top"><tt>:condition</tt>:</td><td>Perform remote request conditionally by this expression. Use this to
|
343
|
-
describe browser-side conditions when request should not be initiated.
|
344
|
-
|
345
|
-
</td></tr>
|
346
|
-
<tr><td valign="top"><tt>:before</tt>:</td><td>Called before request is initiated.
|
347
|
-
|
348
|
-
</td></tr>
|
349
|
-
<tr><td valign="top"><tt>:after</tt>:</td><td>Called immediately after request was initiated and before
|
350
|
-
<tt>:loading</tt>.
|
351
|
-
|
352
|
-
</td></tr>
|
353
|
-
<tr><td valign="top"><tt>:submit</tt>:</td><td>Specifies the DOM element ID that‘s used as the parent of the form
|
354
|
-
elements. By default this is the current form, but it could just as well be
|
355
|
-
the ID of a table row or any other DOM element.
|
356
|
-
|
357
|
-
</td></tr>
|
358
|
-
</table>
|
359
|
-
|
360
|
-
<div class="sourcecode">
|
361
|
-
<p class="source-link">[ <a href="javascript:toggleSource('M000034_source')" id="l_M000034_source">show source</a> ]</p>
|
362
|
-
<div id="M000034_source" class="dyn-source">
|
363
|
-
<pre>
|
364
|
-
<span class="ruby-comment cmt"># File lib/bivouac/helpers/view/goh/javascript.rb, line 371</span>
|
365
|
-
371: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">link_to_remote</span>(<span class="ruby-identifier">name</span>, <span class="ruby-identifier">options</span> = {}, <span class="ruby-identifier">html_options</span> = {})
|
366
|
-
372: <span class="ruby-identifier">link_to_function</span>(<span class="ruby-identifier">name</span>, <span class="ruby-identifier">remote_function</span>(<span class="ruby-identifier">options</span>), <span class="ruby-identifier">html_options</span>)
|
367
|
-
373: <span class="ruby-keyword kw">end</span>
|
368
|
-
</pre>
|
369
|
-
</div>
|
370
|
-
</div>
|
371
|
-
<h4 class="ruled">Public Instance method:
|
372
|
-
<strong><a name="M000036">observe_field(field_id, options = {})</a></strong> <a href="#M000036"><img src="../../permalink.gif" border="0" title="Permalink to Public Instance method: observe_field" /></a></h4>
|
373
|
-
|
374
|
-
<p>
|
375
|
-
Observes the field with the DOM ID specified by <tt>field_id</tt> and makes
|
376
|
-
an Ajax call when its contents have changed.
|
377
|
-
</p>
|
378
|
-
<p>
|
379
|
-
Required <tt>options</tt> are either of:
|
380
|
-
</p>
|
381
|
-
<table>
|
382
|
-
<tr><td valign="top"><tt>:url</tt>:</td><td><tt>url_for</tt>-style options for the action to call when the field has
|
383
|
-
changed.
|
384
|
-
|
385
|
-
</td></tr>
|
386
|
-
<tr><td valign="top"><tt>:function</tt>:</td><td>Instead of making a remote call to a URL, you can specify a function to be
|
387
|
-
called instead.
|
388
|
-
|
389
|
-
</td></tr>
|
390
|
-
</table>
|
391
|
-
<p>
|
392
|
-
Additional options are:
|
393
|
-
</p>
|
394
|
-
<table>
|
395
|
-
<tr><td valign="top"><tt>:frequency</tt>:</td><td>The frequency (in seconds) at which changes to this field will be detected.
|
396
|
-
Not setting this option at all or to a value equal to or less than zero
|
397
|
-
will use event based observation instead of time based observation.
|
398
|
-
|
399
|
-
</td></tr>
|
400
|
-
<tr><td valign="top"><tt>:update</tt>:</td><td>Specifies the DOM ID of the element whose innerHTML should be updated with
|
401
|
-
the XMLHttpRequest response text.
|
402
|
-
|
403
|
-
</td></tr>
|
404
|
-
<tr><td valign="top"><tt>:with</tt>:</td><td>A JavaScript expression specifying the parameters for the XMLHttpRequest.
|
405
|
-
This defaults to ‘value’, which in the evaluated context refers
|
406
|
-
to the new field value. If you specify a string without a "=",
|
407
|
-
it‘ll be extended to mean the form key that the value should be
|
408
|
-
assigned to. So :with => "term" gives
|
409
|
-
"’term’=value". If a "=" is present, no
|
410
|
-
extension will happen.
|
411
|
-
|
412
|
-
</td></tr>
|
413
|
-
<tr><td valign="top"><tt>:on</tt>:</td><td>Specifies which event handler to observe. By default, it‘s set to
|
414
|
-
"changed" for text fields and areas and "click" for
|
415
|
-
radio buttons and checkboxes. With this, you can specify it instead to be
|
416
|
-
"blur" or "focus" or any other event.
|
417
|
-
|
418
|
-
</td></tr>
|
419
|
-
</table>
|
420
|
-
<p>
|
421
|
-
Additionally, you may specify any of the options documented in <a
|
422
|
-
href="JavaScriptView.html#M000034">link_to_remote</a>.
|
423
|
-
</p>
|
424
|
-
|
425
|
-
<div class="sourcecode">
|
426
|
-
<p class="source-link">[ <a href="javascript:toggleSource('M000036_source')" id="l_M000036_source">show source</a> ]</p>
|
427
|
-
<div id="M000036_source" class="dyn-source">
|
428
|
-
<pre>
|
429
|
-
<span class="ruby-comment cmt"># File lib/bivouac/helpers/view/goh/javascript.rb, line 420</span>
|
430
|
-
420: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">observe_field</span>(<span class="ruby-identifier">field_id</span>, <span class="ruby-identifier">options</span> = {})
|
431
|
-
421: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:frequency</span>] <span class="ruby-operator">&&</span> <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:frequency</span>] <span class="ruby-operator">></span> <span class="ruby-value">0</span>
|
432
|
-
422: <span class="ruby-identifier">build_observer</span>(<span class="ruby-value str">'Form.Element.Observer'</span>, <span class="ruby-identifier">field_id</span>, <span class="ruby-identifier">options</span>)
|
433
|
-
423: <span class="ruby-keyword kw">else</span>
|
434
|
-
424: <span class="ruby-identifier">build_observer</span>(<span class="ruby-value str">'Form.Element.EventObserver'</span>, <span class="ruby-identifier">field_id</span>, <span class="ruby-identifier">options</span>)
|
435
|
-
425: <span class="ruby-keyword kw">end</span>
|
436
|
-
426: <span class="ruby-keyword kw">end</span>
|
437
|
-
</pre>
|
438
|
-
</div>
|
439
|
-
</div>
|
440
|
-
<h4 class="ruled">Public Instance method:
|
441
|
-
<strong><a name="M000035">periodically_call_remote(options = {})</a></strong> <a href="#M000035"><img src="../../permalink.gif" border="0" title="Permalink to Public Instance method: periodically_call_remote" /></a></h4>
|
442
|
-
|
443
|
-
<p>
|
444
|
-
Periodically calls the specified url (<tt>options[:url]</tt>) every
|
445
|
-
<tt>options[:frequency]</tt> seconds (default is 10). Usually used to
|
446
|
-
update a specified div (<tt>options[:update]</tt>) with the results of the
|
447
|
-
remote call. The options for specifying the target with :url and defining
|
448
|
-
callbacks is the same as <a
|
449
|
-
href="JavaScriptView.html#M000034">link_to_remote</a>.
|
450
|
-
</p>
|
451
|
-
|
452
|
-
<div class="sourcecode">
|
453
|
-
<p class="source-link">[ <a href="javascript:toggleSource('M000035_source')" id="l_M000035_source">show source</a> ]</p>
|
454
|
-
<div id="M000035_source" class="dyn-source">
|
455
|
-
<pre>
|
456
|
-
<span class="ruby-comment cmt"># File lib/bivouac/helpers/view/goh/javascript.rb, line 380</span>
|
457
|
-
380: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">periodically_call_remote</span>(<span class="ruby-identifier">options</span> = {})
|
458
|
-
381: <span class="ruby-identifier">frequency</span> = <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:frequency</span>] <span class="ruby-operator">||</span> <span class="ruby-value">10</span> <span class="ruby-comment cmt"># every ten seconds by default</span>
|
459
|
-
382: <span class="ruby-identifier">code</span> = <span class="ruby-node">"new PeriodicalExecuter(function() {#{remote_function(options)}}, #{frequency})"</span>
|
460
|
-
383: <span class="ruby-identifier">javascript_tag</span>(<span class="ruby-identifier">code</span>)
|
461
|
-
384: <span class="ruby-keyword kw">end</span>
|
462
|
-
</pre>
|
463
|
-
</div>
|
464
|
-
</div>
|
465
|
-
<h4 class="ruled">Public Instance method:
|
466
|
-
<strong><a name="M000037">remote_function(options)</a></strong> <a href="#M000037"><img src="../../permalink.gif" border="0" title="Permalink to Public Instance method: remote_function" /></a></h4>
|
467
|
-
|
468
|
-
<p>
|
469
|
-
Returns the JavaScript needed for a remote function. Takes the same
|
470
|
-
arguments as <a href="JavaScriptView.html#M000034">link_to_remote</a>.
|
471
|
-
</p>
|
472
|
-
<p>
|
473
|
-
Example:
|
474
|
-
</p>
|
475
|
-
<pre>
|
476
|
-
select( :id => "options",
|
477
|
-
:onChange => remote_function(
|
478
|
-
:update => "options",
|
479
|
-
:url => R(Update),
|
480
|
-
:onSuccess => visual_effect( :highlight, 'my_element' )
|
481
|
-
)
|
482
|
-
) do
|
483
|
-
option( "Hello", :value => 0 )
|
484
|
-
option( "World", :value => 1 )
|
485
|
-
end
|
486
|
-
</pre>
|
487
|
-
|
488
|
-
<div class="sourcecode">
|
489
|
-
<p class="source-link">[ <a href="javascript:toggleSource('M000037_source')" id="l_M000037_source">show source</a> ]</p>
|
490
|
-
<div id="M000037_source" class="dyn-source">
|
491
|
-
<pre>
|
492
|
-
<span class="ruby-comment cmt"># File lib/bivouac/helpers/view/goh/javascript.rb, line 442</span>
|
493
|
-
442: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">remote_function</span>(<span class="ruby-identifier">options</span>)
|
494
|
-
443: <span class="ruby-identifier">javascript_options</span> = <span class="ruby-identifier">options_for_ajax</span>(<span class="ruby-identifier">options</span>)
|
495
|
-
444:
|
496
|
-
445: <span class="ruby-identifier">update</span> = <span class="ruby-value str">''</span>
|
497
|
-
446: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:update</span>] <span class="ruby-operator">&&</span> <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:update</span>].<span class="ruby-identifier">is_a?</span>(<span class="ruby-constant">Hash</span>)
|
498
|
-
447: <span class="ruby-identifier">update</span> = []
|
499
|
-
448: <span class="ruby-identifier">update</span> <span class="ruby-operator"><<</span> <span class="ruby-node">"success:'#{options[:update][:success]}'"</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:update</span>][<span class="ruby-identifier">:success</span>]
|
500
|
-
449: <span class="ruby-identifier">update</span> <span class="ruby-operator"><<</span> <span class="ruby-node">"failure:'#{options[:update][:failure]}'"</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:update</span>][<span class="ruby-identifier">:failure</span>]
|
501
|
-
450: <span class="ruby-identifier">update</span> = <span class="ruby-value str">'{'</span> <span class="ruby-operator">+</span> <span class="ruby-identifier">update</span>.<span class="ruby-identifier">join</span>(<span class="ruby-value str">','</span>) <span class="ruby-operator">+</span> <span class="ruby-value str">'}'</span>
|
502
|
-
451: <span class="ruby-keyword kw">elsif</span> <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:update</span>]
|
503
|
-
452: <span class="ruby-identifier">update</span> <span class="ruby-operator"><<</span> <span class="ruby-node">"'#{options[:update]}'"</span>
|
504
|
-
453: <span class="ruby-keyword kw">end</span>
|
505
|
-
454:
|
506
|
-
455: <span class="ruby-identifier">function</span> = <span class="ruby-identifier">update</span>.<span class="ruby-identifier">empty?</span> <span class="ruby-value">? </span>
|
507
|
-
456: <span class="ruby-value str">"new Ajax.Request("</span> <span class="ruby-operator">:</span>
|
508
|
-
457: <span class="ruby-node">"new Ajax.Updater(#{update}, "</span>
|
509
|
-
458:
|
510
|
-
459: <span class="ruby-identifier">function</span> <span class="ruby-operator"><<</span> <span class="ruby-node">"'#{options[:url]}'"</span>
|
511
|
-
460: <span class="ruby-identifier">function</span> <span class="ruby-operator"><<</span> <span class="ruby-node">", #{javascript_options})"</span>
|
512
|
-
461:
|
513
|
-
462: <span class="ruby-identifier">function</span> = <span class="ruby-node">"#{options[:before]}; #{function}"</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:before</span>]
|
514
|
-
463: <span class="ruby-identifier">function</span> = <span class="ruby-node">"#{function}; #{options[:after]}"</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:after</span>]
|
515
|
-
464: <span class="ruby-identifier">function</span> = <span class="ruby-node">"if (#{options[:condition]}) { #{function}; }"</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:condition</span>]
|
516
|
-
465: <span class="ruby-identifier">function</span> = <span class="ruby-node">"if (confirm('#{escape_javascript(options[:confirm])}')) { #{function}; }"</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">options</span>[<span class="ruby-identifier">:confirm</span>]
|
517
|
-
466:
|
518
|
-
467: <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">function</span>
|
519
|
-
468: <span class="ruby-keyword kw">end</span>
|
520
|
-
</pre>
|
521
|
-
</div>
|
522
|
-
</div>
|
523
|
-
<h4 class="ruled">Public Instance method:
|
524
|
-
<strong><a name="M000031">update_page( &block )</a></strong> <a href="#M000031"><img src="../../permalink.gif" border="0" title="Permalink to Public Instance method: update_page" /></a></h4>
|
525
|
-
|
526
|
-
<p>
|
527
|
-
Yields a <a href="../JavaScriptGenerator.html">JavaScriptGenerator</a> and
|
528
|
-
returns the generated JavaScript code. Use this to update multiple elements
|
529
|
-
on a page in an Ajax response. See <a
|
530
|
-
href="../JavaScriptGenerator.html">JavaScriptGenerator</a> for more
|
531
|
-
information.
|
532
|
-
</p>
|
533
|
-
|
534
|
-
<div class="sourcecode">
|
535
|
-
<p class="source-link">[ <a href="javascript:toggleSource('M000031_source')" id="l_M000031_source">show source</a> ]</p>
|
536
|
-
<div id="M000031_source" class="dyn-source">
|
537
|
-
<pre>
|
538
|
-
<span class="ruby-comment cmt"># File lib/bivouac/helpers/view/goh/javascript.rb, line 228</span>
|
539
|
-
228: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">update_page</span>( <span class="ruby-operator">&</span><span class="ruby-identifier">block</span> )
|
540
|
-
229: <span class="ruby-constant">JavaScriptGenerator</span>.<span class="ruby-identifier">new</span>( <span class="ruby-keyword kw">self</span>, <span class="ruby-operator">&</span><span class="ruby-identifier">block</span> ).<span class="ruby-identifier">to_s</span>
|
541
|
-
230: <span class="ruby-keyword kw">end</span>
|
542
|
-
</pre>
|
543
|
-
</div>
|
544
|
-
</div>
|
545
|
-
<h4 class="ruled">Public Instance method:
|
546
|
-
<strong><a name="M000032">update_page_tag( options = {}, &block )</a></strong> <a href="#M000032"><img src="../../permalink.gif" border="0" title="Permalink to Public Instance method: update_page_tag" /></a></h4>
|
547
|
-
|
548
|
-
<p>
|
549
|
-
Works like <a href="JavaScriptView.html#M000031">update_page</a> but wraps
|
550
|
-
the generated JavaScript in a <script> tag. See <a
|
551
|
-
href="../JavaScriptGenerator.html">JavaScriptGenerator</a> for more
|
552
|
-
information.
|
553
|
-
</p>
|
554
|
-
|
555
|
-
<div class="sourcecode">
|
556
|
-
<p class="source-link">[ <a href="javascript:toggleSource('M000032_source')" id="l_M000032_source">show source</a> ]</p>
|
557
|
-
<div id="M000032_source" class="dyn-source">
|
558
|
-
<pre>
|
559
|
-
<span class="ruby-comment cmt"># File lib/bivouac/helpers/view/goh/javascript.rb, line 234</span>
|
560
|
-
234: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">update_page_tag</span>( <span class="ruby-identifier">options</span> = {}, <span class="ruby-operator">&</span><span class="ruby-identifier">block</span> )
|
561
|
-
235: <span class="ruby-identifier">javascript_tag</span> <span class="ruby-identifier">update_page</span>( <span class="ruby-operator">&</span><span class="ruby-identifier">block</span> ), <span class="ruby-identifier">options</span>
|
562
|
-
236: <span class="ruby-keyword kw">end</span>
|
563
|
-
</pre>
|
564
|
-
</div>
|
565
|
-
</div>
|
566
|
-
|
567
|
-
</div>
|
568
|
-
</div>
|
569
|
-
|
570
|
-
|
571
|
-
</div>
|
572
|
-
</body>
|
573
|
-
</html>
|