<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>SciWerks.com &#187; AJAX</title>
	<atom:link href="http://www.sciwerks.com/blog/category/ajax/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.sciwerks.com/blog</link>
	<description>Software for scientists, by scientists</description>
	<lastBuildDate>Fri, 24 Oct 2008 01:02:08 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.8.4</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>How to use an auto_complete to validate passwords</title>
		<link>http://www.sciwerks.com/blog/2007/01/31/how-to-use-an-auto_complete-to-validate-passwords/</link>
		<comments>http://www.sciwerks.com/blog/2007/01/31/how-to-use-an-auto_complete-to-validate-passwords/#comments</comments>
		<pubDate>Thu, 01 Feb 2007 02:04:20 +0000</pubDate>
		<dc:creator>Kevin Olbrich</dc:creator>
				<category><![CDATA[AJAX]]></category>
		<category><![CDATA[Forms]]></category>
		<category><![CDATA[Ruby on Rails]]></category>
		<category><![CDATA[User Interface]]></category>
		<category><![CDATA[auto_complete]]></category>

		<guid isPermaLink="false">http://www.sciwerks.com/blog/2007/01/31/how-to-use-an-auto_complete-to-validate-passwords/</guid>
		<description><![CDATA[As a follow up to my previous article about using auto_completes to ensure unique filenames, I&#8217;ve put together a bit of code that does essentially the same thing except that it checks a password field to ensure that it meets certain criteria.




# view file


&#60;%= text_field_with_auto_complete :user, :password %&#62;&#60;div id=login_error&#62;&#60;/div&#62;


&#160;


# model file


&#160;


def User &#60; ActiveRecord::Base


&#160; validates_length_of [...]]]></description>
			<content:encoded><![CDATA[<p>As a follow up to my previous article about using auto_completes to ensure unique filenames, I&#8217;ve put together a bit of code that does essentially the same thing except that it checks a password field to ensure that it meets certain criteria.</p>
<div class="codesnip-container" >
<div class="codesnip" style="font-family: monospace;">
<ol>
<li class="li1">
<div class="de1"><span class="co1"># view file</span></div>
</li>
<li class="li1">
<div class="de1">&lt;%= text_field_with_auto_complete :user, :password %&gt;&lt;div id=login_error&gt;&lt;/div&gt;</div>
</li>
<li class="li1">
<div class="de1">&nbsp;</div>
</li>
<li class="li1">
<div class="de1"><span class="co1"># model file</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp;</div>
</li>
<li class="li1">
<div class="de1"><span class="kw1">def</span> User &lt; ActiveRecord::Base</div>
</li>
<li class="li1">
<div class="de1">&nbsp; validates_length_of :password, :<span class="kw1">in</span>=&gt;<span class="nu0">3</span>..<span class="nu0">20</span></div>
</li>
<li class="li1">
<div class="de1"><span class="kw1">end</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp;</div>
</li>
<li class="li1">
<div class="de1"><span class="co1"># controller file</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp;</div>
</li>
<li class="li1">
<div class="de1"><span class="kw1">def</span> auto_complete_for_user_password</div>
</li>
<li class="li1">
<div class="de1">&nbsp; @user = User.<span class="me1">new</span><span class="br0">&#40;</span>params<span class="br0">&#91;</span>:user<span class="br0">&#93;</span><span class="br0">&#41;</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp; @user.<span class="me1">valid</span>?&nbsp; <span class="co1"># ensures the errors array is populated</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp; password_errors = @user.<span class="me1">errors</span>.<span class="me1">on</span><span class="br0">&#40;</span>&#8216;password&#8217;<span class="br0">&#41;</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp; render :update <span class="kw1">do</span> |page|</div>
</li>
<li class="li1">
<div class="de1">&nbsp; &nbsp; &nbsp;page.<span class="me1">replace_html</span> &#8216;login_error&#8217;, <span class="br0">&#40;</span>password_errors.<span class="me1">empty</span>? ? <span class="st0">&quot;&quot;</span> : password_errors<span class="br0">&#41;</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp; &nbsp;<span class="kw1">end</span></div>
</li>
<li class="li1">
<div class="de1"><span class="kw1">end</span> </div>
</li>
</ol>
</div>
</div>
<p>This will indicate when a password does not meet the validation criteria defined in the model.  You can add custom validations to check the strength of the password itself.<br />
<script type="text/javascript"><!--
google_ad_client = "pub-1072568092760209";
google_ad_width = 468;
google_ad_height = 60;
google_ad_format = "468x60_as";
google_ad_type = "text_image";
google_ad_channel = "";
//--></script>
<script type="text/javascript"
  src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
</script></p>
]]></content:encoded>
			<wfw:commentRss>http://www.sciwerks.com/blog/2007/01/31/how-to-use-an-auto_complete-to-validate-passwords/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Passing extra data with an auto_complete</title>
		<link>http://www.sciwerks.com/blog/2006/11/21/passing-extra-data-with-an-auto_complete/</link>
		<comments>http://www.sciwerks.com/blog/2006/11/21/passing-extra-data-with-an-auto_complete/#comments</comments>
		<pubDate>Tue, 21 Nov 2006 19:23:43 +0000</pubDate>
		<dc:creator>Kevin Olbrich</dc:creator>
				<category><![CDATA[AJAX]]></category>
		<category><![CDATA[Forms]]></category>
		<category><![CDATA[Ruby on Rails]]></category>
		<category><![CDATA[User Interface]]></category>
		<category><![CDATA[auto_complete]]></category>

		<guid isPermaLink="false">http://www.sciwerks.com/blog/2006/11/21/passing-extra-data-with-an-auto_complete/</guid>
		<description><![CDATA[A quick and easy method to pass additional data to an auto_complete_for method.]]></description>
			<content:encoded><![CDATA[<p>I recently found myself trying to use an auto_complete field to allow the user to select an object from a list of possible objects.  That&#8217;s all fine and dandy, but I wanted to exclude certain values depending on which object I was editing.  There are at least two ways to do this, the first is to stuff the extra data into the session and then read that value from the auto_complete_for method and act appropriately.</p>
<p>I don&#8217;t really like this approach because I don&#8217;t want to clutter up the session with various form parameters.  Thankfully, there is a simple way to do this by once again abusing the built in text_field_with_auto_complete function&#8230;</p>
<div class="codesnip-container" >
<div class="codesnip" style="font-family: monospace;">
<ol>
<li class="li1">
<div class="de1"><span class="co1"># View</span></div>
</li>
<li class="li1">
<div class="de1">&lt;%= text_field_with_auto_complete &#8216;new_object&#8217;, &#8216;name&#8217;, <span class="br0">&#123;</span> :tabindex=&gt;<span class="nu0">1</span> <span class="br0">&#125;</span>, <span class="br0">&#123;</span>:url=&gt;<span class="br0">&#123;</span>:action=&gt;&#8217;auto_complete_for_object_name&#8217;, :extra=&gt;@object.<span class="me1">extra</span><span class="br0">&#125;</span> %&gt; </div>
</li>
</ol>
</div>
</div>
<p>[In my case, I used the :extra data to exclude certain objects from the auto_complete_for response]</p>
<p>By passing the :url option, you rewrite the URL that the AJAX actions call, enabling you to add extra parameters that can be acted on by the method.  Also note that you can change the name of the action called (in fact, you need to specify it or it will default to the name of the action for the current view&#8230; probably not what you want).  This is handy because it lets you assign the response to a variable with a different name without writing a separate auto_complete_for handler.  In this case, the submitted form will have a &#8216;new_object[name]&#8216; in the params, even though the action called was &#8216;auto_complete_for_object_name&#8217;.</p>
<p>Needless to say, you need to write a custom &#8216;auto_complete_for&#8217; method to handle the extra data.  Note that you could also use this method to handle multiple auto_complete fields. </p>
<p><script type="text/javascript"><!--
google_ad_client = "pub-1072568092760209";
google_ad_width = 468;
google_ad_height = 60;
google_ad_format = "468x60_as";
google_ad_type = "text_image";
google_ad_channel = "";
//--></script>
<script type="text/javascript"
  src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
</script></p>
]]></content:encoded>
			<wfw:commentRss>http://www.sciwerks.com/blog/2006/11/21/passing-extra-data-with-an-auto_complete/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Using an auto_complete to ensure uniqueness</title>
		<link>http://www.sciwerks.com/blog/2006/10/09/using-an-auto_complete-to-ensure-uniqueness/</link>
		<comments>http://www.sciwerks.com/blog/2006/10/09/using-an-auto_complete-to-ensure-uniqueness/#comments</comments>
		<pubDate>Mon, 09 Oct 2006 16:33:52 +0000</pubDate>
		<dc:creator>Kevin Olbrich</dc:creator>
				<category><![CDATA[AJAX]]></category>
		<category><![CDATA[Ruby on Rails]]></category>
		<category><![CDATA[User Interface]]></category>
		<category><![CDATA[auto_complete]]></category>

		<guid isPermaLink="false">http://www.sciwerks.com/blog/2006/10/09/using-an-auto_complete-to-ensure-uniqueness/</guid>
		<description><![CDATA[A quick and easy way to indicate if a text field is unique by subverting auto_complete fields for your own <s>nefarious</s> purposes.]]></description>
			<content:encoded><![CDATA[<h2>The Problem</h2>
<p>Occasionally there is a need to have a user enter a unique string.  For example, if you want to ensure that a new user&#8217;s login id is not used by someone else.  The traditional rails way of doing this is to set up a &#8216;validates_uniqueness_of&#8217; validation on the model and then catch the error when you try to save the record.  </p>
<p>From the user&#8217;s point of view, this can be a horrendously painful experience that can be akin to trying to outsmart the Sphinx.</p>
<div class="codesnip-container" >Form: &#8220;please enter a unique login id&#8217;<br />
User: &#8220;john smith&#8221;<br />
Form: &#8220;Wrong, guess again!&#8221;<br />
User: &#8220;jsmith&#8221;<br />
Form: &#8220;Nope, getting warmer&#8221;<br />
User: &#8220;jsmith1&#8243;<br />
Form: &#8220;You wish! Keep trying!&#8221;<br />
User: &#8220;as;ldfkjasd;flkajsdf;lakjsd&#8221;<br />
Form: &#8220;Ha! your id must be only numbers and letters!&#8221;<br />
User: &#8220;!@!$!@!#!@#!@#!@#%*(#^($!!!!!!!&#8221;<br />
Form: &#8220;Sorry, wrong again!&#8221;<br />
* user navigates to youtube *</div>
<p>The biggest problem here is that there is no feedback to the user if the value they selected is valid until they submit.  Some forms will also force you to retype your new password everytime this fails as well.  Double ouch!</p>
<h2>Solutions</h2>
<ol>
<li>offer suggestions for valid responses when it fails the first time.  Not exactly the best, you might as well autogenerate their id for them and hope they don&#8217;t forget it.</li>
<li>
provide feedback with AJAX to let them know if the value is ok.</li>
</ol>
<p>As you might have guessed from the title of the article, I&#8217;m going to show you how to do this with a standard rails auto_complete text field.</p>
<div class="codesnip-container" >
<div class="codesnip" style="font-family: monospace;">
<ol>
<li class="li1">
<div class="de1"><span class="co1"># view file</span></div>
</li>
<li class="li1">
<div class="de1">&lt;%= text_field_with_auto_complete :user, :login_id %&gt;&lt;div id=login_error&gt;&lt;/div&gt;</div>
</li>
<li class="li1">
<div class="de1">&nbsp;</div>
</li>
<li class="li1">
<div class="de1"><span class="co1"># controller file</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp;</div>
</li>
<li class="li1">
<div class="de1"><span class="kw1">def</span> auto_complete_for_user_user_name</div>
</li>
<li class="li1">
<div class="de1">&nbsp; @user = User.<span class="me1">find_by_user_name</span><span class="br0">&#40;</span>params<span class="br0">&#91;</span>:user<span class="br0">&#93;</span><span class="br0">&#91;</span>:user_name<span class="br0">&#93;</span><span class="br0">&#41;</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp; &nbsp;render :update <span class="kw1">do</span> |page|</div>
</li>
<li class="li1">
<div class="de1">&nbsp; &nbsp; &nbsp;page.<span class="me1">replace_html</span> &#8216;login_error&#8217;, <span class="br0">&#40;</span>@user ? <span class="st0">&quot;Login id already in use&quot;</span> : <span class="st0">&quot;&quot;</span><span class="br0">&#41;</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp; &nbsp;<span class="kw1">end</span></div>
</li>
<li class="li1">
<div class="de1"><span class="kw1">end</span> </div>
</li>
</ol>
</div>
</div>
<p>That&#8217;s it.  Anytime the auto_complete matches a record, it will change the &#8216;login_error&#8217; div to indicate there&#8217;s a problem.</p>
<p>Net result&#8230;. a much better user interface experience and much happier users.<span id="more-21"></span></p>
]]></content:encoded>
			<wfw:commentRss>http://www.sciwerks.com/blog/2006/10/09/using-an-auto_complete-to-ensure-uniqueness/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
		</item>
		<item>
		<title>Auto disabling the submit button with KRJS</title>
		<link>http://www.sciwerks.com/blog/2006/10/04/auto-disabling-the-submit-button-with-krjs/</link>
		<comments>http://www.sciwerks.com/blog/2006/10/04/auto-disabling-the-submit-button-with-krjs/#comments</comments>
		<pubDate>Thu, 05 Oct 2006 00:52:49 +0000</pubDate>
		<dc:creator>Kevin Olbrich</dc:creator>
				<category><![CDATA[AJAX]]></category>
		<category><![CDATA[Ruby on Rails]]></category>
		<category><![CDATA[User Interface]]></category>
		<category><![CDATA[plugins]]></category>

		<guid isPermaLink="false">http://www.sciwerks.com/blog/2006/10/04/auto-disabling-the-submit-button-with-krjs/</guid>
		<description><![CDATA[Benjamin over at RubyOnRailsBlog   was recently wondering about how to painlessly disable a submit button to prevent the user from hitting it multiple times.
This requires some sort of javascript hackery to achieve, but the easiest way I&#8217;ve found to do this is with my trusty old KRJS pocketknife.




# in application controller


&#160;


def on_commit_click


&#160; render [...]]]></description>
			<content:encoded><![CDATA[<p>Benjamin over at <a href="http://www.rubyonrailsblog.com/articles/2006/10/03/disable-submit-button-after-its-pressed">RubyOnRailsBlog</a>   was recently wondering about how to painlessly disable a submit button to prevent the user from hitting it multiple times.</p>
<p>This requires some sort of javascript hackery to achieve, but the easiest way I&#8217;ve found to do this is with my trusty old KRJS pocketknife.</p>
<div class="codesnip-container" >
<div class="codesnip" style="font-family: monospace;">
<ol>
<li class="li1">
<div class="de1"><span class="co1"># in application controller</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp;</div>
</li>
<li class="li1">
<div class="de1"><span class="kw1">def</span> on_commit_click</div>
</li>
<li class="li1">
<div class="de1">&nbsp; render :update |page| <span class="kw1">do</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp; &nbsp;page<span class="br0">&#91;</span>&#8216;commit&#8217;<span class="br0">&#93;</span>.<span class="me1">disabled</span> = <span class="kw2">true</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp; &nbsp;page &lt;&lt; <span class="st0">&quot;$(&#8217;commit&#8217;).form.submit();&quot;</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp; <span class="kw1">end</span></div>
</li>
<li class="li1">
<div class="de1"><span class="kw1">end</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp;</div>
</li>
<li class="li1">
<div class="de1"><span class="co1"># in the form</span></div>
</li>
<li class="li1">
<div class="de1">&nbsp;</div>
</li>
<li class="li1">
<div class="de1">&lt;%= submit_tag &#8216;Submit&#8217;, :id=&gt;&#8217;commit&#8217; %&gt; </div>
</li>
</ol>
</div>
</div>
<p>This will add this behavior for all submit buttons with the &#8216;commit&#8217; id.  The hardest part here is remembering to add the &#8216;commit&#8217; id.</p>
<p>Requires: <a href="http://www.agilewebdevelopment.com/plugins/krjs">KRJS Plugin </a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.sciwerks.com/blog/2006/10/04/auto-disabling-the-submit-button-with-krjs/feed/</wfw:commentRss>
		<slash:comments>4</slash:comments>
		</item>
	</channel>
</rss>
