src/cm/media/js/lib/yui/yui_3.0.0b1/api/Widget-PositionExt.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: widget-position-ext   Widget-PositionExt.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>widget-position-ext&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_widget-position-ext.html" title="widget-position-ext">widget-position-ext</a>
       
    22                 
       
    23                  &gt; Widget-PositionExt.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"> * Provides extended/advanced XY positioning support for Widgets, through an extension.</span>
       
    52 <span class="c"> *</span>
       
    53 <span class="c"> * It builds on top of the widget-position module, to provide alignmentment and centering support.</span>
       
    54 <span class="c"> * Future releases aim to add constrained and fixed positioning support.</span>
       
    55 <span class="c"> *</span>
       
    56 <span class="c"> * @module widget-position-ext</span>
       
    57 <span class="c"> */</span>
       
    58         <span class="k">var</span> <span class="nx">L</span> <span class="o">=</span> <span class="nx">Y</span><span class="o">.</span><span class="nx">Lang</span><span class="o">,</span>
       
    59             <span class="nx">ALIGN</span> <span class="o">=</span> <span class="s2">&quot;align&quot;</span><span class="o">,</span>
       
    60 
       
    61             <span class="nx">BINDUI</span> <span class="o">=</span> <span class="s2">&quot;bindUI&quot;</span><span class="o">,</span>
       
    62             <span class="nx">SYNCUI</span> <span class="o">=</span> <span class="s2">&quot;syncUI&quot;</span><span class="o">,</span>
       
    63 
       
    64             <span class="nx">OFFSET_WIDTH</span> <span class="o">=</span> <span class="s2">&quot;offsetWidth&quot;</span><span class="o">,</span>
       
    65             <span class="nx">OFFSET_HEIGHT</span> <span class="o">=</span> <span class="s2">&quot;offsetHeight&quot;</span><span class="o">,</span>
       
    66             <span class="nx">VIEWPORT_REGION</span> <span class="o">=</span> <span class="s2">&quot;viewportRegion&quot;</span><span class="o">,</span>
       
    67             <span class="nx">REGION</span> <span class="o">=</span> <span class="s2">&quot;region&quot;</span><span class="o">,</span>
       
    68 
       
    69             <span class="nx">AlignChange</span> <span class="o">=</span> <span class="s2">&quot;alignChange&quot;</span><span class="o">;</span>
       
    70 
       
    71         <span class="c">/**</span>
       
    72 <span class="c">         * Widget extension, which can be used to add extended XY positioning support to the base Widget class,</span>
       
    73 <span class="c">         * through the &lt;a href=&quot;Base.html#method_build&quot;&gt;Base.build&lt;/a&gt; method. This extension requires that </span>
       
    74 <span class="c">         * the WidgetPosition extension be added to the Widget (before WidgetPositionExt, if part of the same </span>
       
    75 <span class="c">         * extension list passed to Base.build).</span>
       
    76 <span class="c">         *</span>
       
    77 <span class="c">         * @class WidgetPositionExt</span>
       
    78 <span class="c">         * @param {Object} User configuration object</span>
       
    79 <span class="c">         */</span>
       
    80         <span class="k">function</span> <span class="nx">PositionExt</span><span class="o">(</span><span class="nx">config</span><span class="o">)</span> <span class="o">{</span>
       
    81             <span class="k">if</span> <span class="o">(!</span><span class="k">this</span><span class="o">.</span><span class="nx">hasImpl</span><span class="o">(</span><span class="nx">Y</span><span class="o">.</span><span class="nx">WidgetPosition</span><span class="o">)</span> <span class="o">||</span> <span class="o">!</span><span class="k">this</span><span class="o">.</span><span class="nx">_posNode</span><span class="o">)</span> <span class="o">{</span>
       
    82                 <span class="nx">Y</span><span class="o">.</span><span class="nx">error</span><span class="o">(</span><span class="s2">&quot;WidgetPosition needs to be added to the Widget, before WidgetPositionExt is added&quot;</span><span class="o">);</span> 
       
    83             <span class="o">}</span>
       
    84             <span class="nx">Y</span><span class="o">.</span><span class="nx">after</span><span class="o">(</span><span class="k">this</span><span class="o">.</span><span class="nx">_syncUIPosExtras</span><span class="o">,</span> <span class="k">this</span><span class="o">,</span> <span class="nx">SYNCUI</span><span class="o">);</span>
       
    85             <span class="nx">Y</span><span class="o">.</span><span class="nx">after</span><span class="o">(</span><span class="k">this</span><span class="o">.</span><span class="nx">_bindUIPosExtras</span><span class="o">,</span> <span class="k">this</span><span class="o">,</span> <span class="nx">BINDUI</span><span class="o">);</span>
       
    86         <span class="o">}</span>
       
    87 
       
    88         <span class="c">/**</span>
       
    89 <span class="c">         * Static property used to define the default attribute </span>
       
    90 <span class="c">         * configuration introduced by WidgetPositionExt.</span>
       
    91 <span class="c">         * </span>
       
    92 <span class="c">         * @property WidgetPositionExt.ATTRS</span>
       
    93 <span class="c">         * @type Object</span>
       
    94 <span class="c">         * @static</span>
       
    95 <span class="c">         */</span>
       
    96         <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">ATTRS</span> <span class="o">=</span> <span class="o">{</span>
       
    97 
       
    98             <span class="c">/**</span>
       
    99 <span class="c">             * @attribute align</span>
       
   100 <span class="c">             * @type Object</span>
       
   101 <span class="c">             * @default null</span>
       
   102 <span class="c">             * @desciption The align attribute is used to align a reference point on the widget, with the refernce point on another node, or the viewport. </span>
       
   103 <span class="c">             * The object which align expects has the following properties:</span>
       
   104 <span class="c">             * &lt;dl&gt;</span>
       
   105 <span class="c">             *       &lt;dt&gt;node&lt;/dt&gt;</span>
       
   106 <span class="c">             *       &lt;dd&gt;</span>
       
   107 <span class="c">             *         The node to which the Widget is to be aligned. If set to null, or not provided, the Widget is aligned to the viewport</span>
       
   108 <span class="c">             *       &lt;/dd&gt;</span>
       
   109 <span class="c">             *       &lt;dt&gt;points&lt;/dt&gt;</span>
       
   110 <span class="c">             *       &lt;dd&gt;</span>
       
   111 <span class="c">             *         &lt;p&gt;</span>
       
   112 <span class="c">             *         A two element array, defining the two points on the Widget and node/viewport which are to be aligned. The first element is the point on the Widget, and the second element is the point on the node/viewport.</span>
       
   113 <span class="c">             *         Supported alignment points are defined as static properties on &lt;code&gt;WidgetPositionExt&lt;/code&gt;.</span>
       
   114 <span class="c">             *         &lt;/p&gt;</span>
       
   115 <span class="c">             *         &lt;p&gt;</span>
       
   116 <span class="c">             *         e.g. &lt;code&gt;[WidgetPositionExt.TR, WidgetPositionExt.TL]&lt;/code&gt; aligns the Top-Right corner of the Widget with the</span>
       
   117 <span class="c">             *         Top-Left corner of the node/viewport, and &lt;code&gt;[WidgetPositionExt.CC, WidgetPositionExt.TC]&lt;/code&gt; aligns the Center of the </span>
       
   118 <span class="c">             *         Widget with the Top-Center edge of the node/viewport.</span>
       
   119 <span class="c">             *         &lt;/p&gt;</span>
       
   120 <span class="c">             *       &lt;/dd&gt;</span>
       
   121 <span class="c">             *   &lt;/dl&gt;</span>
       
   122 <span class="c">             */</span>
       
   123             <span class="nx">align</span><span class="o">:</span> <span class="o">{</span>
       
   124                 <span class="nx">value</span><span class="o">:</span><span class="kc">null</span>
       
   125             <span class="o">},</span>
       
   126 
       
   127             <span class="c">/**</span>
       
   128 <span class="c">             * @attribute centered</span>
       
   129 <span class="c">             * @type {boolean | node} </span>
       
   130 <span class="c">             * @default false</span>
       
   131 <span class="c">             * @description A convenience attribute, which can be used as a shortcut for the align attribute.</span>
       
   132 <span class="c">             * If set to true, the Widget is centered in the viewport. If set to a node reference or valid selector string,</span>
       
   133 <span class="c">             * the Widget will be centered within the node. If set the false, no center positioning is applied.</span>
       
   134 <span class="c">             */</span>
       
   135             <span class="nx">centered</span><span class="o">:</span> <span class="o">{</span>
       
   136                 <span class="nx">setter</span><span class="o">:</span> <span class="k">function</span><span class="o">(</span><span class="nx">val</span><span class="o">)</span> <span class="o">{</span>
       
   137                     <span class="k">return</span> <span class="k">this</span><span class="o">.</span><span class="nx">_setAlignCenter</span><span class="o">(</span><span class="nx">val</span><span class="o">);</span>
       
   138                 <span class="o">},</span>
       
   139                 <span class="nx">value</span><span class="o">:</span><span class="kc">false</span>
       
   140             <span class="o">}</span>
       
   141         <span class="o">};</span>
       
   142 
       
   143         <span class="c">/**</span>
       
   144 <span class="c">         * Constant used to specify the top-left corner for alignment</span>
       
   145 <span class="c">         * </span>
       
   146 <span class="c">         * @property WidgetPositionExt.TL</span>
       
   147 <span class="c">         * @type String</span>
       
   148 <span class="c">         * @static</span>
       
   149 <span class="c">         * @value &quot;tl&quot;</span>
       
   150 <span class="c">         */</span>
       
   151         <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">TL</span> <span class="o">=</span> <span class="s2">&quot;tl&quot;</span><span class="o">;</span>
       
   152         <span class="c">/**</span>
       
   153 <span class="c">         * Constant used to specify the top-right corner for alignment</span>
       
   154 <span class="c">         * </span>
       
   155 <span class="c">         * @property WidgetPositionExt.TR</span>
       
   156 <span class="c">         * @type String</span>
       
   157 <span class="c">         * @static</span>
       
   158 <span class="c">         * @value &quot;tr&quot;</span>
       
   159 <span class="c">         */</span>
       
   160         <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">TR</span> <span class="o">=</span> <span class="s2">&quot;tr&quot;</span><span class="o">;</span>
       
   161         <span class="c">/**</span>
       
   162 <span class="c">         * Constant used to specify the bottom-left corner for alignment</span>
       
   163 <span class="c">         * </span>
       
   164 <span class="c">         * @property WidgetPositionExt.BL</span>
       
   165 <span class="c">         * @type String</span>
       
   166 <span class="c">         * @static</span>
       
   167 <span class="c">         * @value &quot;bl&quot;</span>
       
   168 <span class="c">         */</span>
       
   169         <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">BL</span> <span class="o">=</span> <span class="s2">&quot;bl&quot;</span><span class="o">;</span>
       
   170         <span class="c">/**</span>
       
   171 <span class="c">         * Constant used to specify the bottom-right corner for alignment</span>
       
   172 <span class="c">         * </span>
       
   173 <span class="c">         * @property WidgetPositionExt.BR</span>
       
   174 <span class="c">         * @type String</span>
       
   175 <span class="c">         * @static</span>
       
   176 <span class="c">         * @value &quot;br&quot;</span>
       
   177 <span class="c">         */</span>
       
   178         <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">BR</span> <span class="o">=</span> <span class="s2">&quot;br&quot;</span><span class="o">;</span>
       
   179         <span class="c">/**</span>
       
   180 <span class="c">         * Constant used to specify the top edge-center point for alignment</span>
       
   181 <span class="c">         * </span>
       
   182 <span class="c">         * @property WidgetPositionExt.TC</span>
       
   183 <span class="c">         * @type String</span>
       
   184 <span class="c">         * @static</span>
       
   185 <span class="c">         * @value &quot;tc&quot;</span>
       
   186 <span class="c">         */</span>
       
   187         <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">TC</span> <span class="o">=</span> <span class="s2">&quot;tc&quot;</span><span class="o">;</span>
       
   188         <span class="c">/**</span>
       
   189 <span class="c">         * Constant used to specify the right edge, center point for alignment</span>
       
   190 <span class="c">         * </span>
       
   191 <span class="c">         * @property WidgetPositionExt.RC</span>
       
   192 <span class="c">         * @type String</span>
       
   193 <span class="c">         * @static</span>
       
   194 <span class="c">         * @value &quot;rc&quot;</span>
       
   195 <span class="c">         */</span>
       
   196         <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">RC</span> <span class="o">=</span> <span class="s2">&quot;rc&quot;</span><span class="o">;</span>
       
   197         <span class="c">/**</span>
       
   198 <span class="c">         * Constant used to specify the bottom edge, center point for alignment</span>
       
   199 <span class="c">         * </span>
       
   200 <span class="c">         * @property WidgetPositionExt.BC</span>
       
   201 <span class="c">         * @type String</span>
       
   202 <span class="c">         * @static</span>
       
   203 <span class="c">         * @value &quot;bc&quot;</span>
       
   204 <span class="c">         */</span>
       
   205         <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">BC</span> <span class="o">=</span> <span class="s2">&quot;bc&quot;</span><span class="o">;</span>
       
   206         <span class="c">/**</span>
       
   207 <span class="c">         * Constant used to specify the left edge, center point for alignment</span>
       
   208 <span class="c">         * </span>
       
   209 <span class="c">         * @property WidgetPositionExt.LC</span>
       
   210 <span class="c">         * @type String</span>
       
   211 <span class="c">         * @static</span>
       
   212 <span class="c">         * @value &quot;lc&quot;</span>
       
   213 <span class="c">         */</span>
       
   214         <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">LC</span> <span class="o">=</span> <span class="s2">&quot;lc&quot;</span><span class="o">;</span>
       
   215         <span class="c">/**</span>
       
   216 <span class="c">         * Constant used to specify the center of widget/node/viewport for alignment</span>
       
   217 <span class="c">         * </span>
       
   218 <span class="c">         * @property WidgetPositionExt.CC</span>
       
   219 <span class="c">         * @type String</span>
       
   220 <span class="c">         * @static</span>
       
   221 <span class="c">         * @value &quot;cc&quot;</span>
       
   222 <span class="c">         */</span>
       
   223         <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">CC</span> <span class="o">=</span> <span class="s2">&quot;cc&quot;</span><span class="o">;</span>
       
   224 
       
   225         <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">prototype</span> <span class="o">=</span> <span class="o">{</span>
       
   226 
       
   227             <span class="c">/**</span>
       
   228 <span class="c">             * Synchronizes the UI to match the Widgets extended positioning state.</span>
       
   229 <span class="c">             * This method in invoked after syncUI is invoked for the Widget class</span>
       
   230 <span class="c">             * using YUI&#39;s aop infrastructure.</span>
       
   231 <span class="c">             *</span>
       
   232 <span class="c">             * @method _syncUIPosExtras</span>
       
   233 <span class="c">             * @protected</span>
       
   234 <span class="c">             */</span>
       
   235             <span class="nx">_syncUIPosExtras</span> <span class="o">:</span> <span class="k">function</span><span class="o">()</span> <span class="o">{</span>
       
   236                 <span class="k">var</span> <span class="nx">align</span> <span class="o">=</span> <span class="k">this</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">ALIGN</span><span class="o">);</span>
       
   237                 <span class="k">if</span> <span class="o">(</span><span class="nx">align</span><span class="o">)</span> <span class="o">{</span>
       
   238                     <span class="k">this</span><span class="o">.</span><span class="nx">_uiSetAlign</span><span class="o">(</span><span class="nx">align</span><span class="o">.</span><span class="nx">node</span><span class="o">,</span> <span class="nx">align</span><span class="o">.</span><span class="nx">points</span><span class="o">);</span>
       
   239                 <span class="o">}</span>
       
   240             <span class="o">},</span>
       
   241 
       
   242             <span class="c">/**</span>
       
   243 <span class="c">             * Binds event listeners responsible for updating the UI state in response to </span>
       
   244 <span class="c">             * Widget extended positioning related state changes.</span>
       
   245 <span class="c">             * &lt;p&gt;</span>
       
   246 <span class="c">             * This method is invoked after bindUI is invoked for the Widget class</span>
       
   247 <span class="c">             * using YUI&#39;s aop infrastructure.</span>
       
   248 <span class="c">             * &lt;/p&gt;</span>
       
   249 <span class="c">             * @method _bindUIStack</span>
       
   250 <span class="c">             * @protected</span>
       
   251 <span class="c">             */</span>
       
   252             <span class="nx">_bindUIPosExtras</span> <span class="o">:</span> <span class="k">function</span><span class="o">()</span> <span class="o">{</span>
       
   253                 <span class="k">this</span><span class="o">.</span><span class="nx">after</span><span class="o">(</span><span class="nx">AlignChange</span><span class="o">,</span> <span class="k">this</span><span class="o">.</span><span class="nx">_afterAlignChange</span><span class="o">);</span>
       
   254             <span class="o">},</span>
       
   255 
       
   256             <span class="c">/**</span>
       
   257 <span class="c">             * Default setter for center attribute changes. Sets up the appropriate value, and passes </span>
       
   258 <span class="c">             * it through the to the align attribute.</span>
       
   259 <span class="c">             *</span>
       
   260 <span class="c">             * @method _setAlignCenter</span>
       
   261 <span class="c">             * @protected</span>
       
   262 <span class="c">             * @param {boolean | node} The attribute value being set. </span>
       
   263 <span class="c">             * @return {Number} The attribute value being set.</span>
       
   264 <span class="c">             */</span>
       
   265             <span class="nx">_setAlignCenter</span> <span class="o">:</span> <span class="k">function</span><span class="o">(</span><span class="nx">val</span><span class="o">)</span> <span class="o">{</span>
       
   266                 <span class="k">if</span> <span class="o">(</span><span class="nx">val</span><span class="o">)</span> <span class="o">{</span>
       
   267                     <span class="k">this</span><span class="o">.</span><span class="nx">set</span><span class="o">(</span><span class="nx">ALIGN</span><span class="o">,</span> <span class="o">{</span>
       
   268                         <span class="nx">node</span><span class="o">:</span> <span class="nx">val</span> <span class="o">===</span> <span class="kc">true</span> <span class="o">?</span> <span class="kc">null</span> <span class="o">:</span> <span class="nx">val</span><span class="o">,</span>
       
   269                         <span class="nx">points</span><span class="o">:</span> <span class="o">[</span><span class="nx">PositionExt</span><span class="o">.</span><span class="nx">CC</span><span class="o">,</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">CC</span><span class="o">]</span>
       
   270                     <span class="o">});</span>
       
   271                 <span class="o">}</span>
       
   272                 <span class="k">return</span> <span class="nx">val</span><span class="o">;</span>
       
   273             <span class="o">},</span>
       
   274 
       
   275             <span class="c">/**</span>
       
   276 <span class="c">             * Default attribute change listener for the align attribute, responsible</span>
       
   277 <span class="c">             * for updating the UI, in response to attribute changes.</span>
       
   278 <span class="c">             * </span>
       
   279 <span class="c">             * @method _afterAlignChange</span>
       
   280 <span class="c">             * @protected</span>
       
   281 <span class="c">             * @param {EventFacade} e The event facade for the attribute change</span>
       
   282 <span class="c">             */</span>
       
   283             <span class="nx">_afterAlignChange</span> <span class="o">:</span> <span class="k">function</span><span class="o">(</span><span class="nx">e</span><span class="o">)</span> <span class="o">{</span>
       
   284                 <span class="k">if</span> <span class="o">(</span><span class="nx">e</span><span class="o">.</span><span class="nx">newVal</span><span class="o">)</span> <span class="o">{</span>
       
   285                     <span class="k">this</span><span class="o">.</span><span class="nx">_uiSetAlign</span><span class="o">(</span><span class="nx">e</span><span class="o">.</span><span class="nx">newVal</span><span class="o">.</span><span class="nx">node</span><span class="o">,</span> <span class="nx">e</span><span class="o">.</span><span class="nx">newVal</span><span class="o">.</span><span class="nx">points</span><span class="o">);</span>
       
   286                 <span class="o">}</span>
       
   287             <span class="o">},</span>
       
   288 
       
   289             <span class="c">/**</span>
       
   290 <span class="c">             * Updates the UI to reflect the align value passed in (see the align attribute documentation, for the object stucture expected)</span>
       
   291 <span class="c">             * @method _uiSetAlign</span>
       
   292 <span class="c">             * @protected</span>
       
   293 <span class="c">             * @param {Node | null} The node to align to, or null to indicate the viewport</span>
       
   294 <span class="c">             */</span>
       
   295             <span class="nx">_uiSetAlign</span><span class="o">:</span> <span class="k">function</span> <span class="o">(</span><span class="nx">node</span><span class="o">,</span> <span class="nx">points</span><span class="o">)</span> <span class="o">{</span>
       
   296 
       
   297                 <span class="k">if</span> <span class="o">(!</span><span class="nx">L</span><span class="o">.</span><span class="nx">isArray</span><span class="o">(</span><span class="nx">points</span><span class="o">)</span> <span class="o">||</span> <span class="nx">points</span><span class="o">.</span><span class="nx">length</span> <span class="o">!=</span> <span class="m">2</span><span class="o">)</span> <span class="o">{</span>
       
   298                     <span class="nx">Y</span><span class="o">.</span><span class="nx">error</span><span class="o">(</span><span class="s2">&quot;align: Invalid Points Arguments&quot;</span><span class="o">);</span>
       
   299                     <span class="k">return</span><span class="o">;</span>
       
   300                 <span class="o">}</span>
       
   301 
       
   302                 <span class="k">var</span> <span class="nx">nodeRegion</span><span class="o">,</span> <span class="nx">widgetPoint</span><span class="o">,</span> <span class="nx">nodePoint</span><span class="o">,</span> <span class="nx">xy</span><span class="o">;</span>
       
   303 
       
   304                 <span class="k">if</span> <span class="o">(!</span><span class="nx">node</span><span class="o">)</span> <span class="o">{</span>
       
   305                     <span class="nx">nodeRegion</span> <span class="o">=</span> <span class="k">this</span><span class="o">.</span><span class="nx">_posNode</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">VIEWPORT_REGION</span><span class="o">);</span>
       
   306                 <span class="o">}</span> <span class="k">else</span> <span class="o">{</span>
       
   307                     <span class="nx">node</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">get</span><span class="o">(</span><span class="nx">node</span><span class="o">);</span>
       
   308                     <span class="k">if</span> <span class="o">(</span><span class="nx">node</span><span class="o">)</span> <span class="o">{</span>
       
   309                         <span class="nx">nodeRegion</span> <span class="o">=</span> <span class="nx">node</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">REGION</span><span class="o">);</span>
       
   310                     <span class="o">}</span>
       
   311                 <span class="o">}</span>
       
   312 
       
   313                 <span class="k">if</span> <span class="o">(</span><span class="nx">nodeRegion</span><span class="o">)</span> <span class="o">{</span>
       
   314 
       
   315                     <span class="c">// TODO: ViewportRegion doesn&#39;t have width/height - Workaround until normalized in Node/Dom</span>
       
   316 <span class="c"></span>                    <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">width</span> <span class="o">=</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">width</span> <span class="o">||</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">right</span> <span class="o">-</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">left</span><span class="o">;</span>
       
   317                     <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">height</span> <span class="o">=</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">height</span> <span class="o">||</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">bottom</span> <span class="o">-</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">top</span><span class="o">;</span>
       
   318 
       
   319                     <span class="nx">widgetPoint</span> <span class="o">=</span> <span class="nx">points</span><span class="o">[</span><span class="m">0</span><span class="o">];</span>
       
   320                     <span class="nx">nodePoint</span> <span class="o">=</span> <span class="nx">points</span><span class="o">[</span><span class="m">1</span><span class="o">];</span>
       
   321 
       
   322                     <span class="c">// TODO: Optimize KWeight - Would lookup table help?</span>
       
   323 <span class="c"></span>                    <span class="nx">switch</span> <span class="o">(</span><span class="nx">nodePoint</span><span class="o">)</span> <span class="o">{</span>
       
   324                         <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">TL</span><span class="o">:</span>
       
   325                             <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">left</span><span class="o">,</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">top</span><span class="o">];</span>
       
   326                             <span class="k">break</span><span class="o">;</span>
       
   327                         <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">TR</span><span class="o">:</span>
       
   328                             <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">right</span><span class="o">,</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">top</span><span class="o">];</span>
       
   329                             <span class="k">break</span><span class="o">;</span>
       
   330                         <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">BL</span><span class="o">:</span>
       
   331                             <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">left</span><span class="o">,</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">bottom</span><span class="o">];</span>
       
   332                             <span class="k">break</span><span class="o">;</span>
       
   333                         <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">BR</span><span class="o">:</span>
       
   334                             <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">right</span><span class="o">,</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">bottom</span><span class="o">];</span>
       
   335                             <span class="k">break</span><span class="o">;</span>
       
   336                         <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">TC</span><span class="o">:</span>
       
   337                             <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">left</span> <span class="o">+</span> <span class="nb">Math</span><span class="o">.</span><span class="nx">floor</span><span class="o">(</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">width</span><span class="o">/</span><span class="m">2</span><span class="o">),</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">top</span><span class="o">];</span>
       
   338                             <span class="k">break</span><span class="o">;</span>
       
   339                         <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">BC</span><span class="o">:</span>
       
   340                             <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">left</span> <span class="o">+</span> <span class="nb">Math</span><span class="o">.</span><span class="nx">floor</span><span class="o">(</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">width</span><span class="o">/</span><span class="m">2</span><span class="o">),</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">bottom</span><span class="o">];</span>
       
   341                             <span class="k">break</span><span class="o">;</span>
       
   342                         <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">LC</span><span class="o">:</span>
       
   343                             <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">left</span><span class="o">,</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">top</span> <span class="o">+</span> <span class="nb">Math</span><span class="o">.</span><span class="nx">floor</span><span class="o">(</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">height</span><span class="o">/</span><span class="m">2</span><span class="o">)];</span>
       
   344                             <span class="k">break</span><span class="o">;</span>
       
   345                         <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">RC</span><span class="o">:</span>
       
   346                             <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">right</span><span class="o">,</span> <span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">top</span> <span class="o">+</span> <span class="nb">Math</span><span class="o">.</span><span class="nx">floor</span><span class="o">(</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">height</span><span class="o">/</span><span class="m">2</span><span class="o">),</span> <span class="nx">widgetPoint</span><span class="o">];</span>
       
   347                             <span class="k">break</span><span class="o">;</span>
       
   348                         <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">CC</span><span class="o">:</span>
       
   349                             <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">left</span> <span class="o">+</span> <span class="nb">Math</span><span class="o">.</span><span class="nx">floor</span><span class="o">(</span><span class="nx">nodeRegion</span><span class="o">.</span><span class="nx">width</span><span class="sr">/2), nodeRegion.top + Math.floor(nodeRegion.height/</span><span class="m">2</span><span class="o">),</span> <span class="nx">widgetPoint</span><span class="o">];</span>
       
   350                             <span class="k">break</span><span class="o">;</span>
       
   351                         <span class="nx">default</span><span class="o">:</span>
       
   352                             <span class="nx">Y</span><span class="o">.</span><span class="nx">log</span><span class="o">(</span><span class="s2">&quot;align: Invalid Points Arguments&quot;</span><span class="o">,</span> <span class="s2">&quot;info&quot;</span><span class="o">,</span> <span class="s2">&quot;widget-position-extras&quot;</span><span class="o">);</span>
       
   353                             <span class="k">break</span><span class="o">;</span>
       
   354                     <span class="o">}</span>
       
   355 
       
   356                     <span class="k">if</span> <span class="o">(</span><span class="nx">xy</span><span class="o">)</span> <span class="o">{</span>
       
   357                         <span class="k">this</span><span class="o">.</span><span class="nx">_doAlign</span><span class="o">(</span><span class="nx">widgetPoint</span><span class="o">,</span> <span class="nx">xy</span><span class="o">[</span><span class="m">0</span><span class="o">],</span> <span class="nx">xy</span><span class="o">[</span><span class="m">1</span><span class="o">]);</span>
       
   358                     <span class="o">}</span>
       
   359                 <span class="o">}</span>
       
   360             <span class="o">},</span>
       
   361 
       
   362             <span class="c">/**</span>
       
   363 <span class="c">             * Helper method, used to align the given point on the widget, with the XY page co-ordinates provided.</span>
       
   364 <span class="c">             *</span>
       
   365 <span class="c">             * @method _doAlign</span>
       
   366 <span class="c">             * @private</span>
       
   367 <span class="c">             * @param {String} widgetPoint Supported point constant (e.g. WidgetPositionExt.TL)</span>
       
   368 <span class="c">             * @param {Number} x X page co-ordinate to align to</span>
       
   369 <span class="c">             * @param {Number} y Y page co-ordinate to align to</span>
       
   370 <span class="c">             */</span>
       
   371             <span class="nx">_doAlign</span> <span class="o">:</span> <span class="k">function</span><span class="o">(</span><span class="nx">widgetPoint</span><span class="o">,</span> <span class="nx">x</span><span class="o">,</span> <span class="nx">y</span><span class="o">)</span> <span class="o">{</span>
       
   372                 <span class="k">var</span> <span class="nx">widgetNode</span> <span class="o">=</span> <span class="k">this</span><span class="o">.</span><span class="nx">_posNode</span><span class="o">,</span>
       
   373                     <span class="nx">xy</span><span class="o">;</span>
       
   374 
       
   375                 <span class="nx">switch</span> <span class="o">(</span><span class="nx">widgetPoint</span><span class="o">)</span> <span class="o">{</span>
       
   376                     <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">TL</span><span class="o">:</span>
       
   377                         <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">x</span><span class="o">,</span> <span class="nx">y</span><span class="o">];</span>
       
   378                         <span class="k">break</span><span class="o">;</span>
       
   379                     <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">TR</span><span class="o">:</span>
       
   380                         <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">x</span> <span class="o">-</span> <span class="nx">widgetNode</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">OFFSET_WIDTH</span><span class="o">),</span> <span class="nx">y</span><span class="o">];</span>
       
   381                         <span class="k">break</span><span class="o">;</span>
       
   382                     <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">BL</span><span class="o">:</span>
       
   383                         <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">x</span><span class="o">,</span> <span class="nx">y</span> <span class="o">-</span> <span class="nx">widgetNode</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">OFFSET_HEIGHT</span><span class="o">)];</span>
       
   384                         <span class="k">break</span><span class="o">;</span>
       
   385                     <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">BR</span><span class="o">:</span>
       
   386                         <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">x</span> <span class="o">-</span> <span class="nx">widgetNode</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">OFFSET_WIDTH</span><span class="o">),</span> <span class="nx">y</span> <span class="o">-</span> <span class="nx">widgetNode</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">OFFSET_HEIGHT</span><span class="o">)];</span>
       
   387                         <span class="k">break</span><span class="o">;</span>
       
   388                     <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">TC</span><span class="o">:</span>
       
   389                         <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">x</span> <span class="o">-</span> <span class="o">(</span><span class="nx">widgetNode</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">OFFSET_WIDTH</span><span class="o">)/</span><span class="m">2</span><span class="o">),</span> <span class="nx">y</span><span class="o">];</span>
       
   390                         <span class="k">break</span><span class="o">;</span>
       
   391                     <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">BC</span><span class="o">:</span>
       
   392                         <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">x</span> <span class="o">-</span> <span class="o">(</span><span class="nx">widgetNode</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">OFFSET_WIDTH</span><span class="o">)/</span><span class="m">2</span><span class="o">),</span> <span class="nx">y</span> <span class="o">-</span> <span class="nx">widgetNode</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">OFFSET_HEIGHT</span><span class="o">)];</span>
       
   393                         <span class="k">break</span><span class="o">;</span>
       
   394                     <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">LC</span><span class="o">:</span>
       
   395                         <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">x</span><span class="o">,</span> <span class="nx">y</span> <span class="o">-</span> <span class="o">(</span><span class="nx">widgetNode</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">OFFSET_HEIGHT</span><span class="o">)/</span><span class="m">2</span><span class="o">)];</span>
       
   396                         <span class="k">break</span><span class="o">;</span>
       
   397                     <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">RC</span><span class="o">:</span>
       
   398                         <span class="nx">xy</span> <span class="o">=</span> <span class="o">[(</span><span class="nx">x</span> <span class="o">-</span> <span class="nx">widgetNode</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">OFFSET_WIDTH</span><span class="o">)),</span> <span class="nx">y</span> <span class="o">-</span> <span class="o">(</span><span class="nx">widgetNode</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">OFFSET_HEIGHT</span><span class="o">)/</span><span class="m">2</span><span class="o">)];</span>
       
   399                         <span class="k">break</span><span class="o">;</span>
       
   400                     <span class="nx">case</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">CC</span><span class="o">:</span>
       
   401                         <span class="nx">xy</span> <span class="o">=</span> <span class="o">[</span><span class="nx">x</span> <span class="o">-</span> <span class="o">(</span><span class="nx">widgetNode</span><span class="o">.</span><span class="nx">get</span><span class="o">(</span><span class="nx">OFFSET_WIDTH</span><span class="o">)</span><span class="sr">/2), y - (widgetNode.get(OFFSET_HEIGHT)/</span><span class="m">2</span><span class="o">)];</span>
       
   402                         <span class="k">break</span><span class="o">;</span>
       
   403                     <span class="nx">default</span><span class="o">:</span>
       
   404                         <span class="nx">Y</span><span class="o">.</span><span class="nx">log</span><span class="o">(</span><span class="s2">&quot;align: Invalid Points Argument&quot;</span><span class="o">,</span> <span class="s2">&quot;info&quot;</span><span class="o">,</span> <span class="s2">&quot;widget-position-extras&quot;</span><span class="o">);</span>
       
   405                         <span class="k">break</span><span class="o">;</span>
       
   406                 <span class="o">}</span>
       
   407 
       
   408                 <span class="k">if</span> <span class="o">(</span><span class="nx">xy</span><span class="o">)</span> <span class="o">{</span>
       
   409                     <span class="k">this</span><span class="o">.</span><span class="nx">move</span><span class="o">(</span><span class="nx">xy</span><span class="o">);</span>
       
   410                 <span class="o">}</span>
       
   411             <span class="o">},</span>
       
   412 
       
   413             <span class="c">/**</span>
       
   414 <span class="c">             * Aligns the Widget to the provided node (or viewport) using the provided</span>
       
   415 <span class="c">             * points. The method can be invoked directly, however it will result in </span>
       
   416 <span class="c">             * the align attribute being out of sync with current position of the of Widget.</span>
       
   417 <span class="c">             * </span>
       
   418 <span class="c">             * @method align</span>
       
   419 <span class="c">             * @param {Node | String | null} node A reference (or selector string) for the Node which with the Widget is to be aligned.</span>
       
   420 <span class="c">             * If null is passed in, the Widget will be aligned with the viewport.</span>
       
   421 <span class="c">             * @param {Array[2]} points A two element array, specifying the points on the Widget and node/viewport which need to be aligned. </span>
       
   422 <span class="c">             * The first entry is the point on the Widget, and the second entry is the point on the node/viewport which need to align.</span>
       
   423 <span class="c">             * Valid point references are defined as static constants on the WidgetPositionExt class. </span>
       
   424 <span class="c">             * </span>
       
   425 <span class="c">             * e.g. [WidgetPositionExt.TL, WidgetPositionExt.TR] will align the top-left corner of the Widget with the top-right corner of the node/viewport.</span>
       
   426 <span class="c">             */</span>
       
   427             <span class="nx">align</span><span class="o">:</span> <span class="k">function</span> <span class="o">(</span><span class="nx">node</span><span class="o">,</span> <span class="nx">points</span><span class="o">)</span> <span class="o">{</span>
       
   428                 <span class="k">this</span><span class="o">.</span><span class="nx">set</span><span class="o">(</span><span class="nx">ALIGN</span><span class="o">,</span> <span class="o">{</span><span class="nx">node</span><span class="o">:</span> <span class="nx">node</span><span class="o">,</span> <span class="nx">points</span><span class="o">:</span><span class="nx">points</span><span class="o">});</span>
       
   429             <span class="o">},</span>
       
   430 
       
   431             <span class="c">/**</span>
       
   432 <span class="c">             * Centers the container in the viewport, or if a node is passed in,</span>
       
   433 <span class="c">             * the node.</span>
       
   434 <span class="c">             *</span>
       
   435 <span class="c">             * @method centered</span>
       
   436 <span class="c">             * @param {Node | String} node Optional. A node reference or selector string defining the node </span>
       
   437 <span class="c">             * inside which the Widget is to be centered. If not passed in, the Widget will be centered in the </span>
       
   438 <span class="c">             * viewport.</span>
       
   439 <span class="c">             */</span>
       
   440             <span class="nx">centered</span><span class="o">:</span> <span class="k">function</span> <span class="o">(</span><span class="nx">node</span><span class="o">)</span> <span class="o">{</span>
       
   441                 <span class="k">this</span><span class="o">.</span><span class="nx">align</span><span class="o">(</span><span class="nx">node</span><span class="o">,</span> <span class="o">[</span><span class="nx">PositionExt</span><span class="o">.</span><span class="nx">CC</span><span class="o">,</span> <span class="nx">PositionExt</span><span class="o">.</span><span class="nx">CC</span><span class="o">]);</span>
       
   442             <span class="o">}</span>
       
   443         <span class="o">};</span>
       
   444 
       
   445         <span class="nx">Y</span><span class="o">.</span><span class="nx">WidgetPositionExt</span> <span class="o">=</span> <span class="nx">PositionExt</span><span class="o">;</span>
       
   446 </pre></div>
       
   447                     </div>
       
   448 			</div>
       
   449 		</div>
       
   450 		<div class="yui-b">
       
   451             <div class="nav">
       
   452 
       
   453                     <div id="moduleList" class="module">
       
   454                         <h4>Modules</h4>
       
   455                         <ul class="content">
       
   456                                 <li class=""><a href="module_anim.html" title="anim">anim</a></li>
       
   457                                 <li class=""><a href="module_attribute.html" title="attribute">attribute</a></li>
       
   458                                 <li class=""><a href="module_base.html" title="base">base</a></li>
       
   459                                 <li class=""><a href="module_cache.html" title="cache">cache</a></li>
       
   460                                 <li class=""><a href="module_classnamemanager.html" title="classnamemanager">classnamemanager</a></li>
       
   461                                 <li class=""><a href="module_collection.html" title="collection">collection</a></li>
       
   462                                 <li class=""><a href="module_console.html" title="console">console</a></li>
       
   463                                 <li class=""><a href="module_console-filters.html" title="console-filters">console-filters</a></li>
       
   464                                 <li class=""><a href="module_cookie.html" title="cookie">cookie</a></li>
       
   465                                 <li class=""><a href="module_dataschema.html" title="dataschema">dataschema</a></li>
       
   466                                 <li class=""><a href="module_datasource.html" title="datasource">datasource</a></li>
       
   467                                 <li class=""><a href="module_datatype.html" title="datatype">datatype</a></li>
       
   468                                 <li class=""><a href="module_dd.html" title="dd">dd</a></li>
       
   469                                 <li class=""><a href="module_dom.html" title="dom">dom</a></li>
       
   470                                 <li class=""><a href="module_dump.html" title="dump">dump</a></li>
       
   471                                 <li class=""><a href="module_event.html" title="event">event</a></li>
       
   472                                 <li class=""><a href="module_event-custom.html" title="event-custom">event-custom</a></li>
       
   473                                 <li class=""><a href="module_event-simulate.html" title="event-simulate">event-simulate</a></li>
       
   474                                 <li class=""><a href="module_history.html" title="history">history</a></li>
       
   475                                 <li class=""><a href="module_imageloader.html" title="imageloader">imageloader</a></li>
       
   476                                 <li class=""><a href="module_io.html" title="io">io</a></li>
       
   477                                 <li class=""><a href="module_json.html" title="json">json</a></li>
       
   478                                 <li class=""><a href="module_node.html" title="node">node</a></li>
       
   479                                 <li class=""><a href="module_node-focusmanager.html" title="node-focusmanager">node-focusmanager</a></li>
       
   480                                 <li class=""><a href="module_node-menunav.html" title="node-menunav">node-menunav</a></li>
       
   481                                 <li class=""><a href="module_oop.html" title="oop">oop</a></li>
       
   482                                 <li class=""><a href="module_overlay.html" title="overlay">overlay</a></li>
       
   483                                 <li class=""><a href="module_plugin.html" title="plugin">plugin</a></li>
       
   484                                 <li class=""><a href="module_profiler.html" title="profiler">profiler</a></li>
       
   485                                 <li class=""><a href="module_queue.html" title="queue">queue</a></li>
       
   486                                 <li class=""><a href="module_slider.html" title="slider">slider</a></li>
       
   487                                 <li class=""><a href="module_stylesheet.html" title="stylesheet">stylesheet</a></li>
       
   488                                 <li class=""><a href="module_substitute.html" title="substitute">substitute</a></li>
       
   489                                 <li class=""><a href="module_test.html" title="test">test</a></li>
       
   490                                 <li class=""><a href="module_widget.html" title="widget">widget</a></li>
       
   491                                 <li class=""><a href="module_widget-position.html" title="widget-position">widget-position</a></li>
       
   492                                 <li class="selected"><a href="module_widget-position-ext.html" title="widget-position-ext">widget-position-ext</a></li>
       
   493                                 <li class=""><a href="module_widget-stack.html" title="widget-stack">widget-stack</a></li>
       
   494                                 <li class=""><a href="module_widget-stdmod.html" title="widget-stdmod">widget-stdmod</a></li>
       
   495                                 <li class=""><a href="module_yui.html" title="yui">yui</a></li>
       
   496                         </ul>
       
   497                     </div>
       
   498 
       
   499                     <div id="classList" class="module">
       
   500                         <h4>Classes</h4>
       
   501                         <ul class="content">
       
   502                                 <li class=""><a href="WidgetPositionExt.html" title="WidgetPositionExt">WidgetPositionExt</a></li>
       
   503                         </ul>
       
   504                     </div>
       
   505 
       
   506                     <div id="fileList" class="module">
       
   507                         <h4>Files</h4>
       
   508                         <ul class="content">        
       
   509                                 <li class="selected"><a href="Widget-PositionExt.js.html" title="Widget-PositionExt.js">Widget-PositionExt.js</a></li>
       
   510                         </ul>
       
   511                     </div>
       
   512 
       
   513 
       
   514 
       
   515 
       
   516 
       
   517             </div>
       
   518 		</div>
       
   519 	</div>
       
   520 	<div id="ft">
       
   521         <hr />
       
   522         Copyright &copy; 2009 Yahoo! Inc. All rights reserved.
       
   523 	</div>
       
   524 </div>
       
   525 <script type="text/javascript">
       
   526     ALL_YUI_PROPS = [{"access": "protected", "host": "WidgetPositionExt", "name": "_afterAlignChange", "url": "WidgetPositionExt.html#method__afterAlignChange", "type": "method"}, {"access": "", "host": "WidgetPositionExt", "name": "align", "url": "WidgetPositionExt.html#method_align", "type": "method"}, {"access": "", "host": "WidgetPositionExt", "name": "align", "url": "WidgetPositionExt.html#config_align", "type": "config"}, {"access": "", "host": "WidgetPositionExt", "name": "alignChange", "url": "WidgetPositionExt.html#event_alignChange", "type": "event"}, {"access": "protected", "host": "WidgetPositionExt", "name": "_bindUIStack", "url": "WidgetPositionExt.html#method__bindUIStack", "type": "method"}, {"access": "", "host": "WidgetPositionExt", "name": "centered", "url": "WidgetPositionExt.html#method_centered", "type": "method"}, {"access": "", "host": "WidgetPositionExt", "name": "centered", "url": "WidgetPositionExt.html#config_centered", "type": "config"}, {"access": "", "host": "WidgetPositionExt", "name": "centeredChange", "url": "WidgetPositionExt.html#event_centeredChange", "type": "event"}, {"access": "private", "host": "WidgetPositionExt", "name": "_doAlign", "url": "WidgetPositionExt.html#method__doAlign", "type": "method"}, {"access": "protected", "host": "WidgetPositionExt", "name": "_setAlignCenter", "url": "WidgetPositionExt.html#method__setAlignCenter", "type": "method"}, {"access": "protected", "host": "WidgetPositionExt", "name": "_syncUIPosExtras", "url": "WidgetPositionExt.html#method__syncUIPosExtras", "type": "method"}, {"access": "protected", "host": "WidgetPositionExt", "name": "_uiSetAlign", "url": "WidgetPositionExt.html#method__uiSetAlign", "type": "method"}, {"access": "", "host": "WidgetPositionExt", "name": "WidgetPositionExt.ATTRS", "url": "WidgetPositionExt.html#property_WidgetPositionExt.ATTRS", "type": "property"}, {"access": "", "host": "WidgetPositionExt", "name": "WidgetPositionExt.BC", "url": "WidgetPositionExt.html#property_WidgetPositionExt.BC", "type": "property"}, {"access": "", "host": "WidgetPositionExt", "name": "WidgetPositionExt.BL", "url": "WidgetPositionExt.html#property_WidgetPositionExt.BL", "type": "property"}, {"access": "", "host": "WidgetPositionExt", "name": "WidgetPositionExt.BR", "url": "WidgetPositionExt.html#property_WidgetPositionExt.BR", "type": "property"}, {"access": "", "host": "WidgetPositionExt", "name": "WidgetPositionExt.CC", "url": "WidgetPositionExt.html#property_WidgetPositionExt.CC", "type": "property"}, {"access": "", "host": "WidgetPositionExt", "name": "WidgetPositionExt.LC", "url": "WidgetPositionExt.html#property_WidgetPositionExt.LC", "type": "property"}, {"access": "", "host": "WidgetPositionExt", "name": "WidgetPositionExt.RC", "url": "WidgetPositionExt.html#property_WidgetPositionExt.RC", "type": "property"}, {"access": "", "host": "WidgetPositionExt", "name": "WidgetPositionExt.TC", "url": "WidgetPositionExt.html#property_WidgetPositionExt.TC", "type": "property"}, {"access": "", "host": "WidgetPositionExt", "name": "WidgetPositionExt.TL", "url": "WidgetPositionExt.html#property_WidgetPositionExt.TL", "type": "property"}, {"access": "", "host": "WidgetPositionExt", "name": "WidgetPositionExt.TR", "url": "WidgetPositionExt.html#property_WidgetPositionExt.TR", "type": "property"}];
       
   527 </script>
       
   528 </body>
       
   529 </html>