src/cm/media/js/lib/yui/yui_3.0.0b1/api/io-upload-iframe.js.html
changeset 0 40c8f766c9b8
equal deleted inserted replaced
-1:000000000000 0:40c8f766c9b8
       
     1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
       
     2 <html xmlns:yui="http://yuilibrary.com/rdf/1.0/yui.rdf#">
       
     3 <head>
       
     4     <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
       
     5 	<title>API: io   io-upload-iframe.js  (YUI Library)</title>
       
     6 
       
     7 	<link rel="stylesheet" type="text/css" href="assets/reset-fonts-grids-min.css" />
       
     8 	<link rel="stylesheet" type="text/css" href="assets/api.css" />
       
     9 
       
    10     <script type="text/javascript" src="assets/api-js"></script>
       
    11     <script type="text/javascript" src="assets/ac-js"></script>
       
    12 </head>
       
    13 
       
    14 <body id="yahoo-com">
       
    15 
       
    16 <div id="doc3" class="yui-t2">
       
    17 	<div id="hd">
       
    18         <h1><a href="http://developer.yahoo.com/yui/" title="Yahoo! UI Library">Yahoo! UI Library</a></h1>
       
    19         <h3>io&nbsp; <span class="subtitle">3.0.0b1</span></h3>
       
    20         <a href="./index.html" title="Yahoo! UI Library">Yahoo! UI Library</a> 
       
    21             &gt; <a href="./module_io.html" title="io">io</a>
       
    22                 
       
    23                  &gt; io-upload-iframe.js (source view) 
       
    24         <form onsubmit="return false">
       
    25             <div id="propertysearch">
       
    26                 Search: <input autocomplete="off" id="searchinput" />
       
    27                 <div id="searchresults">
       
    28                     &nbsp;
       
    29                 </div>
       
    30             </div>
       
    31         </form>
       
    32 	</div>
       
    33 
       
    34 	<div id="bd">
       
    35 		<div id="yui-main">
       
    36 			<div class="yui-b">
       
    37             <form action="#" name="yui-classopts-form" method="get" id="yui-classopts-form">
       
    38                 <fieldset>
       
    39                     <legend>Filters</legend>
       
    40                 <span class="classopts"><input type="checkbox" name="show_private" id="show_private" /> <label for="show_private">Show Private</label></span>
       
    41                 <span class="classopts"><input type="checkbox" name="show_protected" id="show_protected" /> <label for="show_protected">Show Protected</label></span>
       
    42                 <span class="classopts"><input type="checkbox" name="show_deprecated" id="show_deprecated" /> <label for="show_deprecated">Show Deprecated</label></span>
       
    43                 </fieldset>
       
    44             </form>
       
    45 
       
    46                     <div id="srcout">
       
    47                         <style>
       
    48                             #doc3 .classopts { display:none; }
       
    49                         </style>
       
    50 <div class="highlight" ><pre>   <span class="c">/**</span>
       
    51 <span class="c">   	* Extends the IO base class to enable file uploads, with HTML forms,</span>
       
    52 <span class="c">   	* using an iframe as the transport medium.</span>
       
    53 <span class="c">	* @module io</span>
       
    54 <span class="c">	* @submodule io-upload-iframe</span>
       
    55 <span class="c">	*/</span>
       
    56 
       
    57 	<span class="k">var</span> <span class="nx">w</span> <span class="o">=</span> <span class="nx">Y</span><span class="o">.</span><span class="nx">config</span><span class="o">.</span><span class="nx">win</span><span class="o">;</span>
       
    58    <span class="c">/**</span>
       
    59 <span class="c">	* @description Parses the POST data object and creates hidden form elements</span>
       
    60 <span class="c">	* for each key-value, and appends them to the HTML form object.</span>
       
    61 <span class="c">	* @method appendData</span>
       
    62 <span class="c">	* @private</span>
       
    63 <span class="c">	* @static</span>
       
    64 <span class="c">	* @param {object} d The key-value hash map.</span>
       
    65 <span class="c">	* @return {array} e Array of created fields.</span>
       
    66 <span class="c">	*/</span>
       
    67 
       
    68 	<span class="k">function</span> <span class="nx">_addData</span><span class="o">(</span><span class="nx">f</span><span class="o">,</span> <span class="nx">d</span><span class="o">)</span> <span class="o">{</span>
       
    69 		<span class="k">var</span> <span class="nx">e</span> <span class="o">=</span> <span class="o">[],</span>
       
    70 			<span class="nx">p</span><span class="o">,</span> <span class="nx">i</span><span class="o">;</span>
       
    71 
       
    72 		<span class="k">for</span> <span class="o">(</span><span class="nx">p</span> <span class="k">in</span> <span class="nx">d</span><span class="o">)</span> <span class="o">{</span>
       
    73 			<span class="k">if</span> <span class="o">(</span><span class="nx">d</span><span class="o">.</span><span class="nx">hasOwnProperty</span><span class="o">(</span><span class="nx">d</span><span class="o">,</span> <span class="nx">p</span><span class="o">))</span> <span class="o">{</span>
       
    74 				<span class="nx">e</span><span class="o">[</span><span class="nx">i</span><span class="o">]</span> <span class="o">=</span> <span class="nb">document</span><span class="o">.</span><span class="nx">createElement</span><span class="o">(</span><span class="s1">&#39;input&#39;</span><span class="o">);</span>
       
    75 				<span class="nx">e</span><span class="o">[</span><span class="nx">i</span><span class="o">].</span><span class="nx">type</span> <span class="o">=</span> <span class="s1">&#39;hidden&#39;</span><span class="o">;</span>
       
    76 				<span class="nx">e</span><span class="o">[</span><span class="nx">i</span><span class="o">].</span><span class="nx">name</span> <span class="o">=</span> <span class="nx">p</span><span class="o">;</span>
       
    77 				<span class="nx">e</span><span class="o">[</span><span class="nx">i</span><span class="o">].</span><span class="nx">value</span> <span class="o">=</span> <span class="nx">d</span><span class="o">[</span><span class="nx">p</span><span class="o">].</span>
       
    78 				<span class="nx">f</span><span class="o">.</span><span class="nx">appendChild</span><span class="o">(</span><span class="nx">e</span><span class="o">[</span><span class="nx">i</span><span class="o">]);</span>
       
    79 			<span class="o">}</span>
       
    80 		<span class="o">}</span>
       
    81 
       
    82 		<span class="k">return</span> <span class="nx">e</span><span class="o">;</span>
       
    83 	<span class="o">}</span>
       
    84 
       
    85 	<span class="k">function</span> <span class="nx">_removeData</span><span class="o">(</span><span class="nx">f</span><span class="o">,</span> <span class="nx">e</span><span class="o">)</span> <span class="o">{</span>
       
    86 		<span class="k">var</span> <span class="nx">i</span><span class="o">,</span> <span class="nx">l</span><span class="o">;</span>
       
    87 		<span class="k">if</span> <span class="o">(</span><span class="nx">e</span> <span class="o">&amp;&amp;</span> <span class="nx">e</span><span class="o">.</span><span class="nx">length</span> <span class="o">&gt;</span> <span class="m">0</span><span class="o">)</span> <span class="o">{</span>
       
    88 			<span class="k">for</span><span class="o">(</span><span class="nx">i</span> <span class="o">=</span> <span class="m">0</span><span class="o">,</span> <span class="nx">l</span> <span class="o">=</span> <span class="nx">e</span><span class="o">.</span><span class="nx">length</span><span class="o">;</span> <span class="nx">i</span> <span class="o">&lt;</span> <span class="nx">l</span><span class="o">;</span> <span class="nx">i</span><span class="o">++){</span>
       
    89 				<span class="nx">f</span><span class="o">.</span><span class="nx">removeChild</span><span class="o">(</span><span class="nx">e</span><span class="o">[</span><span class="nx">i</span><span class="o">]);</span>
       
    90 			<span class="o">}</span>
       
    91 		<span class="o">}</span>
       
    92 	<span class="o">}</span>
       
    93 
       
    94 	<span class="k">function</span> <span class="nx">_create</span><span class="o">(</span><span class="nx">o</span><span class="o">,</span> <span class="nx">c</span><span class="o">)</span> <span class="o">{</span>
       
    95 		<span class="k">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="nx">Y</span><span class="o">.</span><span class="nx">Node</span><span class="o">.</span><span class="nx">create</span><span class="o">(</span><span class="s1">&#39;&lt;iframe id=&quot;ioupload&#39;</span> <span class="o">+</span> <span class="nx">o</span><span class="o">.</span><span class="nx">id</span> <span class="o">+</span> <span class="s1">&#39;&quot; name=&quot;ioupload&#39;</span> <span class="o">+</span> <span class="nx">o</span><span class="o">.</span><span class="nx">id</span> <span class="o">+</span> <span class="s1">&#39;&quot; /&gt;&#39;</span><span class="o">),</span>
       
    96 			<span class="nx">cfg</span> <span class="o">=</span> <span class="o">{</span>
       
    97 				<span class="nx">position</span><span class="o">:</span> <span class="s1">&#39;absolute&#39;</span><span class="o">,</span>
       
    98 				<span class="nx">top</span><span class="o">:</span> <span class="s1">&#39;-1000px&#39;</span><span class="o">,</span>
       
    99 				<span class="nx">left</span><span class="o">:</span> <span class="s1">&#39;-1000px&#39;</span>
       
   100 			<span class="o">};</span>
       
   101 
       
   102 		<span class="nx">i</span><span class="o">.</span><span class="nx">setStyles</span><span class="o">(</span><span class="nx">cfg</span><span class="o">);</span>
       
   103 		<span class="nx">Y</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="s1">&#39;body&#39;</span><span class="o">).</span><span class="nx">appendChild</span><span class="o">(</span><span class="nx">i</span><span class="o">);</span>
       
   104 		<span class="c">// Bind the onload handler to the iframe to detect the file upload response.</span>
       
   105 <span class="c"></span>		<span class="nx">Y</span><span class="o">.</span><span class="nx">on</span><span class="o">(</span><span class="s2">&quot;load&quot;</span><span class="o">,</span> <span class="k">function</span><span class="o">()</span> <span class="o">{</span> <span class="nx">_handle</span><span class="o">(</span><span class="nx">o</span><span class="o">,</span> <span class="nx">c</span><span class="o">)</span> <span class="o">},</span> <span class="s1">&#39;#ioupload&#39;</span> <span class="o">+</span> <span class="nx">o</span><span class="o">.</span><span class="nx">id</span><span class="o">);</span>
       
   106 	<span class="o">}</span>
       
   107 
       
   108 	<span class="c">// Create the upload callback handler that fires when the iframe</span>
       
   109 <span class="c"></span>	<span class="c">// receives the load event.  Subsequently, the event handler is detached</span>
       
   110 <span class="c"></span>	<span class="c">// and the iframe removed from the document.</span>
       
   111 <span class="c"></span>	<span class="k">function</span> <span class="nx">_handle</span><span class="o">(</span><span class="nx">o</span><span class="o">,</span> <span class="nx">c</span><span class="o">)</span> <span class="o">{</span>
       
   112 		<span class="k">var</span> <span class="nx">p</span><span class="o">,</span>
       
   113 		    <span class="nx">b</span> <span class="o">=</span> <span class="nx">Y</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="s1">&#39;#ioupload&#39;</span> <span class="o">+</span> <span class="nx">o</span><span class="o">.</span><span class="nx">id</span><span class="o">).</span><span class="nx">get</span><span class="o">(</span><span class="s1">&#39;contentWindow.document.body&#39;</span><span class="o">);</span>
       
   114 
       
   115 		<span class="k">if</span> <span class="o">(</span><span class="nx">c</span><span class="o">.</span><span class="nx">timeout</span><span class="o">)</span> <span class="o">{</span>
       
   116 			<span class="nx">_clearTimeout</span><span class="o">(</span><span class="nx">o</span><span class="o">.</span><span class="nx">id</span><span class="o">);</span>
       
   117 		<span class="o">}</span>
       
   118 
       
   119 		<span class="c">// When a response Content-Type of &quot;text/plain&quot; is used, Firefox and Safari</span>
       
   120 <span class="c"></span>		<span class="c">// will wrap the response string with &lt;pre&gt;&lt;/pre&gt;.</span>
       
   121 <span class="c"></span>		<span class="nx">p</span> <span class="o">=</span> <span class="nx">b</span><span class="o">.</span><span class="nx">query</span><span class="o">(</span><span class="s1">&#39;pre:first-child&#39;</span><span class="o">);</span>
       
   122 		<span class="nx">o</span><span class="o">.</span><span class="nx">c</span><span class="o">.</span><span class="nx">responseText</span> <span class="o">=</span> <span class="o">(</span><span class="nx">p</span><span class="o">)</span> <span class="o">?</span> <span class="nx">p</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="s1">&#39;innerHTML&#39;</span><span class="o">)</span> <span class="o">:</span> <span class="nx">b</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="s1">&#39;innerHTML&#39;</span><span class="o">);</span>
       
   123 		<span class="nx">Y</span><span class="o">.</span><span class="nx">io</span><span class="o">.</span><span class="nx">complete</span><span class="o">(</span><span class="nx">o</span><span class="o">,</span> <span class="nx">c</span><span class="o">);</span>
       
   124 		<span class="c">// The transaction is complete, so call _destroy to remove</span>
       
   125 <span class="c"></span>		<span class="c">// the event listener bound to the iframe transport, and then</span>
       
   126 <span class="c"></span>		<span class="c">// destroy the iframe.</span>
       
   127 <span class="c"></span>		<span class="nx">setTimeout</span><span class="o">(</span> <span class="k">function</span><span class="o">()</span> <span class="o">{</span> <span class="nx">_destroy</span><span class="o">(</span><span class="nx">o</span><span class="o">.</span><span class="nx">id</span><span class="o">);</span> <span class="o">},</span> <span class="m">0</span><span class="o">);</span>
       
   128 	<span class="o">}</span>
       
   129 
       
   130    <span class="c">/**</span>
       
   131 <span class="c">	* @description Starts timeout count if the configuration object</span>
       
   132 <span class="c">	* has a defined timeout property.</span>
       
   133 <span class="c">	*</span>
       
   134 <span class="c">	* @method _startTimeout</span>
       
   135 <span class="c">	* @private</span>
       
   136 <span class="c">	* @static</span>
       
   137 <span class="c">    * @param {object} o Transaction object generated by _create().</span>
       
   138 <span class="c">    * @param {object} c Configuration object passed to YUI.io().</span>
       
   139 <span class="c">    * @return void</span>
       
   140 <span class="c">	*/</span>
       
   141 	<span class="k">function</span> <span class="nx">_startTimeout</span><span class="o">(</span><span class="nx">o</span><span class="o">,</span> <span class="nx">c</span><span class="o">)</span> <span class="o">{</span>
       
   142 		<span class="nx">Y</span><span class="o">.</span><span class="nx">io</span><span class="o">.</span><span class="nx">_timeout</span><span class="o">[</span><span class="nx">o</span><span class="o">.</span><span class="nx">id</span><span class="o">]</span> <span class="o">=</span> <span class="nx">w</span><span class="o">.</span><span class="nx">setTimeout</span><span class="o">(</span><span class="k">function</span><span class="o">()</span> <span class="o">{</span> <span class="nx">Y</span><span class="o">.</span><span class="nx">io</span><span class="o">.</span><span class="nx">abort</span><span class="o">(</span><span class="nx">o</span><span class="o">,</span> <span class="nx">c</span><span class="o">);</span> <span class="o">},</span> <span class="nx">c</span><span class="o">.</span><span class="nx">timeout</span><span class="o">);</span>
       
   143 	<span class="o">}</span>
       
   144 
       
   145    <span class="c">/**</span>
       
   146 <span class="c">	* @description Clears the timeout interval started by _startTimeout().</span>
       
   147 <span class="c">	*</span>
       
   148 <span class="c">	* @method _clearTimeout</span>
       
   149 <span class="c">	* @private</span>
       
   150 <span class="c">	* @static</span>
       
   151 <span class="c">    * @param {number} id - Transaction id.</span>
       
   152 <span class="c">    * @return void</span>
       
   153 <span class="c">	*/</span>
       
   154 	<span class="k">function</span> <span class="nx">_clearTimeout</span><span class="o">(</span><span class="nx">id</span><span class="o">)</span> <span class="o">{</span>
       
   155 		<span class="nx">w</span><span class="o">.</span><span class="nx">clearTimeout</span><span class="o">(</span><span class="nx">Y</span><span class="o">.</span><span class="nx">io</span><span class="o">.</span><span class="nx">_timeout</span><span class="o">[</span><span class="nx">id</span><span class="o">]);</span>
       
   156 		<span class="nx">delete</span> <span class="nx">Y</span><span class="o">.</span><span class="nx">io</span><span class="o">.</span><span class="nx">_timeout</span><span class="o">[</span><span class="nx">id</span><span class="o">];</span>
       
   157 	<span class="o">}</span>
       
   158 
       
   159 	<span class="k">function</span> <span class="nx">_destroy</span><span class="o">(</span><span class="nx">id</span><span class="o">)</span> <span class="o">{</span>
       
   160 		<span class="nx">Y</span><span class="o">.</span><span class="nx">Event</span><span class="o">.</span><span class="nx">purgeElement</span><span class="o">(</span><span class="s1">&#39;#ioupload&#39;</span> <span class="o">+</span> <span class="nx">id</span><span class="o">,</span> <span class="kc">false</span><span class="o">);</span>
       
   161 		<span class="nx">Y</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="s1">&#39;body&#39;</span><span class="o">).</span><span class="nx">removeChild</span><span class="o">(</span><span class="nx">Y</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="s1">&#39;#ioupload&#39;</span> <span class="o">+</span> <span class="nx">id</span><span class="o">));</span>
       
   162         <span class="nx">Y</span><span class="o">.</span><span class="nx">log</span><span class="o">(</span><span class="s1">&#39;The iframe transport for transaction &#39;</span> <span class="o">+</span> <span class="nx">id</span> <span class="o">+</span> <span class="s1">&#39;has been destroyed.&#39;</span><span class="o">,</span> <span class="s1">&#39;info&#39;</span><span class="o">,</span> <span class="s1">&#39;io&#39;</span><span class="o">);</span>
       
   163 	<span class="o">}</span>
       
   164 
       
   165 	<span class="nx">Y</span><span class="o">.</span><span class="nx">mix</span><span class="o">(</span><span class="nx">Y</span><span class="o">.</span><span class="nx">io</span><span class="o">,</span> <span class="o">{</span>
       
   166 
       
   167 	   <span class="c">/**</span>
       
   168 <span class="c">		* @description Uploads HTML form, inclusive of files/attachments, using the</span>
       
   169 <span class="c">		* iframe created in createFrame to facilitate the transaction.</span>
       
   170 <span class="c">		* @method _upload</span>
       
   171 <span class="c">		* @private</span>
       
   172 <span class="c">		* @static</span>
       
   173 <span class="c">		* @param {o} o The transaction object</span>
       
   174 <span class="c">		* @param {object} uri Qualified path to transaction resource.</span>
       
   175 <span class="c">		* @param {object} c Configuration object for the transaction.</span>
       
   176 <span class="c">		* @return {void}</span>
       
   177 <span class="c">		*/</span>
       
   178 		<span class="nx">_upload</span><span class="o">:</span> <span class="k">function</span><span class="o">(</span><span class="nx">o</span><span class="o">,</span> <span class="nx">uri</span><span class="o">,</span> <span class="nx">c</span><span class="o">)</span> <span class="o">{</span>
       
   179 			<span class="k">var</span> <span class="nx">f</span> <span class="o">=</span> <span class="o">(</span><span class="k">typeof</span> <span class="nx">c</span><span class="o">.</span><span class="nx">form</span><span class="o">.</span><span class="nx">id</span> <span class="o">===</span> <span class="s1">&#39;string&#39;</span><span class="o">)</span> <span class="o">?</span> <span class="nb">document</span><span class="o">.</span><span class="nx">getElementById</span><span class="o">(</span><span class="nx">c</span><span class="o">.</span><span class="nx">form</span><span class="o">.</span><span class="nx">id</span><span class="o">)</span> <span class="o">:</span> <span class="nx">c</span><span class="o">.</span><span class="nx">form</span><span class="o">.</span><span class="nx">id</span><span class="o">,</span>
       
   180 				<span class="nx">e</span><span class="o">,</span> <span class="nx">fields</span><span class="o">,</span> <span class="nx">i</span><span class="o">,</span> <span class="nx">p</span><span class="o">,</span> <span class="nx">attr</span><span class="o">;</span>
       
   181 
       
   182 			<span class="nx">_create</span><span class="o">(</span><span class="nx">o</span><span class="o">,</span> <span class="nx">c</span><span class="o">);</span>
       
   183 			<span class="c">// Track original HTML form attribute values.</span>
       
   184 <span class="c"></span>			<span class="nx">attr</span> <span class="o">=</span> <span class="o">{</span>
       
   185 				<span class="nx">action</span><span class="o">:</span> <span class="nx">f</span><span class="o">.</span><span class="nx">getAttribute</span><span class="o">(</span><span class="s1">&#39;action&#39;</span><span class="o">),</span>
       
   186 				<span class="nx">target</span><span class="o">:</span> <span class="nx">f</span><span class="o">.</span><span class="nx">getAttribute</span><span class="o">(</span><span class="s1">&#39;target&#39;</span><span class="o">)</span>
       
   187 			<span class="o">};</span>
       
   188 
       
   189 			<span class="c">// Initialize the HTML form properties in case they are</span>
       
   190 <span class="c"></span>			<span class="c">// not defined in the HTML form.</span>
       
   191 <span class="c"></span>			<span class="nx">f</span><span class="o">.</span><span class="nx">setAttribute</span><span class="o">(</span><span class="s1">&#39;action&#39;</span><span class="o">,</span> <span class="nx">uri</span><span class="o">);</span>
       
   192 			<span class="nx">f</span><span class="o">.</span><span class="nx">setAttribute</span><span class="o">(</span><span class="s1">&#39;method&#39;</span><span class="o">,</span> <span class="s1">&#39;POST&#39;</span><span class="o">);</span>
       
   193 			<span class="nx">f</span><span class="o">.</span><span class="nx">setAttribute</span><span class="o">(</span><span class="s1">&#39;target&#39;</span><span class="o">,</span> <span class="s1">&#39;ioupload&#39;</span> <span class="o">+</span> <span class="nx">o</span><span class="o">.</span><span class="nx">id</span> <span class="o">);</span>
       
   194 			<span class="nx">f</span><span class="o">.</span><span class="nx">setAttribute</span><span class="o">((</span><span class="nx">Y</span><span class="o">.</span><span class="nx">UA</span><span class="o">.</span><span class="nx">ie</span> <span class="o">&amp;&amp;</span> <span class="o">!</span><span class="nb">document</span><span class="o">.</span><span class="nx">documentMode</span><span class="o">)</span> <span class="o">?</span> <span class="s1">&#39;encoding&#39;</span> <span class="o">:</span> <span class="s1">&#39;enctype&#39;</span><span class="o">,</span> <span class="s1">&#39;multipart/form-data&#39;</span><span class="o">);</span>
       
   195 
       
   196 			<span class="k">if</span> <span class="o">(</span><span class="nx">c</span><span class="o">.</span><span class="nx">data</span><span class="o">)</span> <span class="o">{</span>
       
   197 				<span class="nx">fields</span> <span class="o">=</span> <span class="nx">_addData</span><span class="o">(</span><span class="nx">f</span><span class="o">,</span> <span class="nx">c</span><span class="o">.</span><span class="nx">data</span><span class="o">);</span>
       
   198 			<span class="o">}</span>
       
   199 
       
   200 			<span class="c">// Start polling if a callback is present and the timeout</span>
       
   201 <span class="c"></span>			<span class="c">// property has been defined.</span>
       
   202 <span class="c"></span>			<span class="k">if</span> <span class="o">(</span><span class="nx">c</span><span class="o">.</span><span class="nx">timeout</span><span class="o">)</span> <span class="o">{</span>
       
   203 				<span class="nx">_startTimeout</span><span class="o">(</span><span class="nx">o</span><span class="o">,</span> <span class="nx">c</span><span class="o">);</span>
       
   204         		<span class="nx">Y</span><span class="o">.</span><span class="nx">log</span><span class="o">(</span><span class="s1">&#39;Transaction timeout started for transaction &#39;</span> <span class="o">+</span> <span class="nx">id</span> <span class="o">+</span> <span class="s1">&#39;.&#39;</span><span class="o">,</span> <span class="s1">&#39;info&#39;</span><span class="o">,</span> <span class="s1">&#39;io&#39;</span><span class="o">);</span>
       
   205 			<span class="o">}</span>
       
   206 
       
   207 			<span class="c">// Start file upload.</span>
       
   208 <span class="c"></span>			<span class="nx">f</span><span class="o">.</span><span class="nx">submit</span><span class="o">();</span>
       
   209 			<span class="nx">Y</span><span class="o">.</span><span class="nx">io</span><span class="o">.</span><span class="nx">start</span><span class="o">(</span><span class="nx">o</span><span class="o">.</span><span class="nx">id</span><span class="o">,</span> <span class="nx">c</span><span class="o">);</span>
       
   210 
       
   211 			<span class="k">if</span> <span class="o">(</span><span class="nx">c</span><span class="o">.</span><span class="nx">data</span><span class="o">)</span> <span class="o">{</span>
       
   212 				<span class="nx">_removeData</span><span class="o">(</span><span class="nx">f</span><span class="o">,</span> <span class="nx">fields</span><span class="o">);</span>
       
   213 			<span class="o">}</span>
       
   214 
       
   215 			<span class="c">// Restore HTML form attributes to their original</span>
       
   216 <span class="c"></span>			<span class="c">// values prior to file upload.</span>
       
   217 <span class="c"></span>			<span class="k">for</span> <span class="o">(</span><span class="nx">p</span> <span class="k">in</span> <span class="nx">attr</span><span class="o">)</span> <span class="o">{</span>
       
   218 				<span class="k">if</span> <span class="o">(</span><span class="nx">attr</span><span class="o">.</span><span class="nx">hasOwnProperty</span><span class="o">(</span><span class="nx">attr</span><span class="o">,</span> <span class="nx">p</span><span class="o">))</span> <span class="o">{</span>
       
   219 					<span class="k">if</span> <span class="o">(</span><span class="nx">attr</span><span class="o">[</span><span class="nx">p</span><span class="o">])</span> <span class="o">{</span>
       
   220 				  		<span class="nx">f</span><span class="o">.</span><span class="nx">setAttribute</span><span class="o">(</span><span class="nx">p</span><span class="o">,</span> <span class="nx">f</span><span class="o">[</span><span class="nx">prop</span><span class="o">]);</span>
       
   221 					<span class="o">}</span>
       
   222 					<span class="k">else</span> <span class="o">{</span>
       
   223 				  		<span class="nx">f</span><span class="o">.</span><span class="nx">removeAttribute</span><span class="o">(</span><span class="nx">p</span><span class="o">);</span>
       
   224 					<span class="o">}</span>
       
   225 			  	<span class="o">}</span>
       
   226 			<span class="o">}</span>
       
   227 		<span class="o">}</span>
       
   228 	<span class="o">});</span>
       
   229 </pre></div>
       
   230                     </div>
       
   231 			</div>
       
   232 		</div>
       
   233 		<div class="yui-b">
       
   234             <div class="nav">
       
   235 
       
   236                     <div id="moduleList" class="module">
       
   237                         <h4>Modules</h4>
       
   238                         <ul class="content">
       
   239                                 <li class=""><a href="module_anim.html" title="anim">anim</a></li>
       
   240                                 <li class=""><a href="module_attribute.html" title="attribute">attribute</a></li>
       
   241                                 <li class=""><a href="module_base.html" title="base">base</a></li>
       
   242                                 <li class=""><a href="module_cache.html" title="cache">cache</a></li>
       
   243                                 <li class=""><a href="module_classnamemanager.html" title="classnamemanager">classnamemanager</a></li>
       
   244                                 <li class=""><a href="module_collection.html" title="collection">collection</a></li>
       
   245                                 <li class=""><a href="module_console.html" title="console">console</a></li>
       
   246                                 <li class=""><a href="module_console-filters.html" title="console-filters">console-filters</a></li>
       
   247                                 <li class=""><a href="module_cookie.html" title="cookie">cookie</a></li>
       
   248                                 <li class=""><a href="module_dataschema.html" title="dataschema">dataschema</a></li>
       
   249                                 <li class=""><a href="module_datasource.html" title="datasource">datasource</a></li>
       
   250                                 <li class=""><a href="module_datatype.html" title="datatype">datatype</a></li>
       
   251                                 <li class=""><a href="module_dd.html" title="dd">dd</a></li>
       
   252                                 <li class=""><a href="module_dom.html" title="dom">dom</a></li>
       
   253                                 <li class=""><a href="module_dump.html" title="dump">dump</a></li>
       
   254                                 <li class=""><a href="module_event.html" title="event">event</a></li>
       
   255                                 <li class=""><a href="module_event-custom.html" title="event-custom">event-custom</a></li>
       
   256                                 <li class=""><a href="module_event-simulate.html" title="event-simulate">event-simulate</a></li>
       
   257                                 <li class=""><a href="module_history.html" title="history">history</a></li>
       
   258                                 <li class=""><a href="module_imageloader.html" title="imageloader">imageloader</a></li>
       
   259                                 <li class="selected"><a href="module_io.html" title="io">io</a></li>
       
   260                                 <li class=""><a href="module_json.html" title="json">json</a></li>
       
   261                                 <li class=""><a href="module_node.html" title="node">node</a></li>
       
   262                                 <li class=""><a href="module_node-focusmanager.html" title="node-focusmanager">node-focusmanager</a></li>
       
   263                                 <li class=""><a href="module_node-menunav.html" title="node-menunav">node-menunav</a></li>
       
   264                                 <li class=""><a href="module_oop.html" title="oop">oop</a></li>
       
   265                                 <li class=""><a href="module_overlay.html" title="overlay">overlay</a></li>
       
   266                                 <li class=""><a href="module_plugin.html" title="plugin">plugin</a></li>
       
   267                                 <li class=""><a href="module_profiler.html" title="profiler">profiler</a></li>
       
   268                                 <li class=""><a href="module_queue.html" title="queue">queue</a></li>
       
   269                                 <li class=""><a href="module_slider.html" title="slider">slider</a></li>
       
   270                                 <li class=""><a href="module_stylesheet.html" title="stylesheet">stylesheet</a></li>
       
   271                                 <li class=""><a href="module_substitute.html" title="substitute">substitute</a></li>
       
   272                                 <li class=""><a href="module_test.html" title="test">test</a></li>
       
   273                                 <li class=""><a href="module_widget.html" title="widget">widget</a></li>
       
   274                                 <li class=""><a href="module_widget-position.html" title="widget-position">widget-position</a></li>
       
   275                                 <li class=""><a href="module_widget-position-ext.html" title="widget-position-ext">widget-position-ext</a></li>
       
   276                                 <li class=""><a href="module_widget-stack.html" title="widget-stack">widget-stack</a></li>
       
   277                                 <li class=""><a href="module_widget-stdmod.html" title="widget-stdmod">widget-stdmod</a></li>
       
   278                                 <li class=""><a href="module_yui.html" title="yui">yui</a></li>
       
   279                         </ul>
       
   280                     </div>
       
   281 
       
   282                     <div id="classList" class="module">
       
   283                         <h4>Classes</h4>
       
   284                         <ul class="content">
       
   285                                 <li class=""><a href="io.html" title="io">io</a></li>
       
   286                         </ul>
       
   287                     </div>
       
   288 
       
   289                     <div id="fileList" class="module">
       
   290                         <h4>Files</h4>
       
   291                         <ul class="content">        
       
   292                                 <li class=""><a href="io-base.js.html" title="io-base.js">io-base.js</a></li>
       
   293                                 <li class=""><a href="io-form.js.html" title="io-form.js">io-form.js</a></li>
       
   294                                 <li class=""><a href="io-queue.js.html" title="io-queue.js">io-queue.js</a></li>
       
   295                                 <li class="selected"><a href="io-upload-iframe.js.html" title="io-upload-iframe.js">io-upload-iframe.js</a></li>
       
   296                                 <li class=""><a href="io-xdr.js.html" title="io-xdr.js">io-xdr.js</a></li>
       
   297                         </ul>
       
   298                     </div>
       
   299 
       
   300 
       
   301 
       
   302 
       
   303 
       
   304             </div>
       
   305 		</div>
       
   306 	</div>
       
   307 	<div id="ft">
       
   308         <hr />
       
   309         Copyright &copy; 2009 Yahoo! Inc. All rights reserved.
       
   310 	</div>
       
   311 </div>
       
   312 <script type="text/javascript">
       
   313     ALL_YUI_PROPS = [{"access": "private", "host": "io", "name": "appendData", "url": "io.html#method_appendData", "type": "method"}, {"access": "private", "host": "io", "name": "_async", "url": "io.html#method__async", "type": "method"}, {"access": "private", "host": "io", "name": "_clearTimeout", "url": "io.html#method__clearTimeout", "type": "method"}, {"access": "private", "host": "io", "name": "_concat", "url": "io.html#method__concat", "type": "method"}, {"access": "private", "host": "io", "name": "_create", "url": "io.html#method__create", "type": "method"}, {"access": "private", "host": "io", "name": "_e", "url": "io.html#property__e", "type": "property"}, {"access": "private", "host": "io", "name": "_fn", "url": "io.html#property__fn", "type": "property"}, {"access": "private", "host": "io", "name": "_handleResponse", "url": "io.html#method__handleResponse", "type": "method"}, {"access": "", "host": "io", "name": "header", "url": "io.html#method_header", "type": "method"}, {"access": "private", "host": "io", "name": "_headers", "url": "io.html#property__headers", "type": "property"}, {"access": "private", "host": "io", "name": "_id", "url": "io.html#method__id", "type": "method"}, {"access": "private", "host": "io", "name": "_io", "url": "io.html#method__io", "type": "method"}, {"access": "", "host": "io", "name": "io", "url": "io.html#method_io", "type": "method"}, {"access": "", "host": "io", "name": "io:complete", "url": "io.html#event_io:complete", "type": "event"}, {"access": "", "host": "io", "name": "io:end", "url": "io.html#event_io:end", "type": "event"}, {"access": "", "host": "io", "name": "io:failure", "url": "io.html#event_io:failure", "type": "event"}, {"access": "", "host": "io", "name": "io:start", "url": "io.html#event_io:start", "type": "event"}, {"access": "", "host": "io", "name": "io:success", "url": "io.html#event_io:success", "type": "event"}, {"access": "", "host": "io", "name": "io:xdrReady", "url": "io.html#event_io:xdrReady", "type": "event"}, {"access": "private", "host": "io", "name": "_ioCancel", "url": "io.html#method__ioCancel", "type": "method"}, {"access": "private", "host": "io", "name": "_ioComplete", "url": "io.html#method__ioComplete", "type": "method"}, {"access": "private", "host": "io", "name": "_ioEnd", "url": "io.html#method__ioEnd", "type": "method"}, {"access": "private", "host": "io", "name": "_ioFailure", "url": "io.html#method__ioFailure", "type": "method"}, {"access": "private", "host": "io", "name": "_ioStart", "url": "io.html#method__ioStart", "type": "method"}, {"access": "private", "host": "io", "name": "_ioSuccess", "url": "io.html#method__ioSuccess", "type": "method"}, {"access": "private", "host": "io", "name": "_isInProgress", "url": "io.html#method__isInProgress", "type": "method"}, {"access": "", "host": "io", "name": "promote", "url": "io.html#method_promote", "type": "method"}, {"access": "", "host": "io", "name": "purge", "url": "io.html#method_purge", "type": "method"}, {"access": "private", "host": "io", "name": "_qState", "url": "io.html#property__qState", "type": "property"}, {"access": "private", "host": "io", "name": "_queue", "url": "io.html#method__queue", "type": "method"}, {"access": "private", "host": "io", "name": "_readyState", "url": "io.html#method__readyState", "type": "method"}, {"access": "private", "host": "io", "name": "_remove", "url": "io.html#method__remove", "type": "method"}, {"access": "private", "host": "io", "name": "_serialize", "url": "io.html#method__serialize", "type": "method"}, {"access": "private", "host": "io", "name": "_setHeader", "url": "io.html#method__setHeader", "type": "method"}, {"access": "private", "host": "io", "name": "_setHeaders", "url": "io.html#method__setHeaders", "type": "method"}, {"access": "private", "host": "io", "name": "_shift", "url": "io.html#method__shift", "type": "method"}, {"access": "private", "host": "io", "name": "_size", "url": "io.html#method__size", "type": "method"}, {"access": "", "host": "io", "name": "size", "url": "io.html#method_size", "type": "method"}, {"access": "", "host": "io", "name": "start", "url": "io.html#method_start", "type": "method"}, {"access": "private", "host": "io", "name": "_startTimeout", "url": "io.html#method__startTimeout", "type": "method"}, {"access": "private", "host": "io", "name": "_stop", "url": "io.html#method__stop", "type": "method"}, {"access": "", "host": "io", "name": "stop", "url": "io.html#method_stop", "type": "method"}, {"access": "private", "host": "io", "name": "_swf", "url": "io.html#method__swf", "type": "method"}, {"access": "private", "host": "io", "name": "_timeOut", "url": "io.html#property__timeOut", "type": "property"}, {"access": "private", "host": "io", "name": "_tPubSub", "url": "io.html#method__tPubSub", "type": "method"}, {"access": "private", "host": "io", "name": "transactionId", "url": "io.html#property_transactionId", "type": "property"}, {"access": "private", "host": "io", "name": "_transport", "url": "io.html#property__transport", "type": "property"}, {"access": "", "host": "io", "name": "transport", "url": "io.html#method_transport", "type": "method"}, {"access": "private", "host": "io", "name": "_unshift", "url": "io.html#method__unshift", "type": "method"}, {"access": "private", "host": "io", "name": "_upload", "url": "io.html#method__upload", "type": "method"}, {"access": "private", "host": "io", "name": "_xdr", "url": "io.html#method__xdr", "type": "method"}, {"access": "private", "host": "io", "name": "xdrReady", "url": "io.html#method_xdrReady", "type": "method"}, {"access": "private", "host": "io", "name": "_xhr", "url": "io.html#method__xhr", "type": "method"}, {"access": "private", "host": "io", "name": "_yQ", "url": "io.html#property__yQ", "type": "property"}];
       
   314 </script>
       
   315 </body>
       
   316 </html>