<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
  
  

  
<link rel="stylesheet" type="text/css" href="http://static.jquery.com/ui/css/trac.css" />
<link rel="stylesheet" href="http://static.jquery.com/ui/css/base2.css" type="text/css" media="screen" />


  

  <head>
    <title>
      Attachment –
      jQuery UI Development – Trac
    </title>
        <link rel="search" href="/search" />
        <link rel="help" href="/wiki/TracGuide" />
        <link rel="alternate" href="/raw-attachment/ticket/4324/ui.effects.core-1.7-doublerebel.js" type="text/x-javascript; charset=utf-8" title="Original Format" />
        <link rel="up" href="/ticket/4324" title="Ticket #4324" />
        <link rel="start" href="/wiki" />
        <link rel="stylesheet" href="/chrome/common/css/trac.css" type="text/css" /><link rel="stylesheet" href="/chrome/common/css/code.css" type="text/css" />
        <link rel="shortcut icon" href="http://ui.jquery.com/images/favicon.ico" type="image/x-icon" />
        <link rel="icon" href="http://ui.jquery.com/images/favicon.ico" type="image/x-icon" />
      <link type="application/opensearchdescription+xml" rel="search" href="/search/opensearch" title="Search jQuery UI Development" />
    <script type="text/javascript" src="/chrome/common/js/jquery.js"></script><script type="text/javascript" src="/chrome/common/js/trac.js"></script><script type="text/javascript" src="/chrome/common/js/search.js"></script>
    <!--[if lt IE 7]>
    <script type="text/javascript" src="/chrome/common/js/ie_pre7_hacks.js"></script>
    <![endif]-->
</head>
  <body id="trac">
   <div id="wrapper">
	<div id="banner">
		<h1 class="logo">
			<a href="http://ui.jquery.com/home" title="jQuery UI"><span>jQuery UI</span></a>
		</h1>
		<div id="dock">
			<div class="left"></div>
			<ul>
				<li>
					<a href="http://jquery.com">jQuery</a>
				</li>
				<li style="padding-right: 12px;">
					<a href="http://plugins.jquery.com/">Plugins</a>
				</li>
				<li class="selected" style="padding-right: 12px;">
					<a href="http://jqueryui.com/home">UI</a>
				</li>
				<li style="padding-left: 12px;">
					<div style="background: #555; width: 1px; height: 24px; position: absolute; left: 0px;"></div>
					<a href="http://blog.jqueryui.com/">Blog</a>
				</li>
				<li>
					<a href="http://jqueryui.com/about">About</a>
				</li>
				<li>
					<a href="http://docs.jquery.com/Donate">Donate</a>
				</li>
			</ul>
			<div class="right"></div>
		</div>
		<div id="navigation">
			<div class="left"></div>
			<ul>
				<li>
					<a href="http://jqueryui.com/download">Download</a>
				</li>
				<li>
					<a href="http://jqueryui.com/demos">Demos &amp; Documentation</a>
				</li>
				<li>
					<a href="http://jqueryui.com/themeroller">Themes</a>
				</li>
				<li class="selected">
					<a href="http://jqueryui.com/development">Development</a>
				</li>
				<li class="last">
					<a href="http://jqueryui.com/support">Support</a>
				</li>
			</ul>
			<div class="right"></div>
		</div>
	</div>
	<div id="content-wrapper">
		<div id="content">
    <div id="banner">
      <div id="header">
        <h1><a href="">jQuery UI Development</a></h1>
      </div>
      <form id="search" action="/search" method="get">
        <div>
          <label for="proj-search">Search:</label>
          <input type="text" id="proj-search" name="q" size="18" value="" />
          <input type="submit" value="Search" />
        </div>
      </form>
      <div id="metanav" class="nav">
    <ul>
      <li class="first"><a href="/login">Login</a></li><li><a href="/prefs">Preferences</a></li><li><a href="/wiki/TracGuide">Help/Guide</a></li><li><a href="/about">About Trac</a></li><li class="last"><a href="/register">Register</a></li>
    </ul>
  </div>
    </div>
    <div id="mainnav" class="nav">
    <ul>
      <li class="first"><a href="/wiki">Wiki</a></li><li><a href="/timeline">Timeline</a></li><li><a href="/roadmap">Roadmap</a></li><li><a href="/browser">Browse Source</a></li><li><a href="/report">View Tickets</a></li><li class="last"><a href="/search">Search</a></li>
    </ul>
  </div>
    <div id="main">
      <div id="ctxtnav" class="nav">
        <h2>Context Navigation</h2>
          <ul>
            <li class="first last"><a href="/ticket/4324">Back to Ticket #4324</a></li>
          </ul>
        <hr />
      </div>
    <div id="content" class="attachment">
        <h1><a href="/ticket/4324">Ticket #4324</a>: ui.effects.core-1.7-doublerebel.js</h1>
        <table id="info" summary="Description">
          <tbody>
            <tr>
              <th scope="col">
                File ui.effects.core-1.7-doublerebel.js, <span title="22266 bytes">21.7 kB</span>
                (added by doublerebel,  <a class="timeline" href="/timeline?from=2009-03-28T21%3A05%3A36Z-0700&amp;precision=second" title="2009-03-28T21:05:36Z-0700 in Timeline">3 months</a> ago)
              </th>
            </tr>
            <tr>
              <td class="message searchable">
                <p>
Contains <a class="missing wiki" href="/wiki/WebKit" rel="nofollow">WebKit?</a> style object fixes as well as IE color animation &amp; edge case fixes
</p>

              </td>
            </tr>
          </tbody>
        </table>
        <div id="preview" class="searchable">
    <table class="code"><thead><tr><th class="lineno" title="Line numbers">Line</th><th class="content"> </th></tr></thead><tbody><tr><th id="L1"><a href="#L1">1</a></th><td>/*</td></tr><tr><th id="L2"><a href="#L2">2</a></th><td> * jQuery UI Effects 1.7</td></tr><tr><th id="L3"><a href="#L3">3</a></th><td> *</td></tr><tr><th id="L4"><a href="#L4">4</a></th><td> * Copyright (c) 2009 AUTHORS.txt (http://jqueryui.com/about)</td></tr><tr><th id="L5"><a href="#L5">5</a></th><td> * Dual licensed under the MIT (MIT-LICENSE.txt)</td></tr><tr><th id="L6"><a href="#L6">6</a></th><td> * and GPL (GPL-LICENSE.txt) licenses.</td></tr><tr><th id="L7"><a href="#L7">7</a></th><td> *</td></tr><tr><th id="L8"><a href="#L8">8</a></th><td> * http://docs.jquery.com/UI/Effects/</td></tr><tr><th id="L9"><a href="#L9">9</a></th><td> */</td></tr><tr><th id="L10"><a href="#L10">10</a></th><td>;jQuery.effects || (function($) {</td></tr><tr><th id="L11"><a href="#L11">11</a></th><td></td></tr><tr><th id="L12"><a href="#L12">12</a></th><td>$.effects = {</td></tr><tr><th id="L13"><a href="#L13">13</a></th><td>        version: "1.7",</td></tr><tr><th id="L14"><a href="#L14">14</a></th><td></td></tr><tr><th id="L15"><a href="#L15">15</a></th><td>        // Saves a set of properties in a data storage</td></tr><tr><th id="L16"><a href="#L16">16</a></th><td>        save: function(element, set) {</td></tr><tr><th id="L17"><a href="#L17">17</a></th><td>                for(var i=0; i &lt; set.length; i++) {</td></tr><tr><th id="L18"><a href="#L18">18</a></th><td>                        if(set[i] !== null) element.data("ec.storage."+set[i], element[0].style[set[i]]);</td></tr><tr><th id="L19"><a href="#L19">19</a></th><td>                }</td></tr><tr><th id="L20"><a href="#L20">20</a></th><td>        },</td></tr><tr><th id="L21"><a href="#L21">21</a></th><td></td></tr><tr><th id="L22"><a href="#L22">22</a></th><td>        // Restores a set of previously saved properties from a data storage</td></tr><tr><th id="L23"><a href="#L23">23</a></th><td>        restore: function(element, set) {</td></tr><tr><th id="L24"><a href="#L24">24</a></th><td>                for(var i=0; i &lt; set.length; i++) {</td></tr><tr><th id="L25"><a href="#L25">25</a></th><td>                        if(set[i] !== null) element.css(set[i], element.data("ec.storage."+set[i]));</td></tr><tr><th id="L26"><a href="#L26">26</a></th><td>                }</td></tr><tr><th id="L27"><a href="#L27">27</a></th><td>        },</td></tr><tr><th id="L28"><a href="#L28">28</a></th><td></td></tr><tr><th id="L29"><a href="#L29">29</a></th><td>        setMode: function(el, mode) {</td></tr><tr><th id="L30"><a href="#L30">30</a></th><td>                if (mode == 'toggle') mode = el.is(':hidden') ? 'show' : 'hide'; // Set for toggle</td></tr><tr><th id="L31"><a href="#L31">31</a></th><td>                return mode;</td></tr><tr><th id="L32"><a href="#L32">32</a></th><td>        },</td></tr><tr><th id="L33"><a href="#L33">33</a></th><td></td></tr><tr><th id="L34"><a href="#L34">34</a></th><td>        getBaseline: function(origin, original) { // Translates a [top,left] array into a baseline value</td></tr><tr><th id="L35"><a href="#L35">35</a></th><td>                // this should be a little more flexible in the future to handle a string &amp; hash</td></tr><tr><th id="L36"><a href="#L36">36</a></th><td>                var y, x;</td></tr><tr><th id="L37"><a href="#L37">37</a></th><td>                switch (origin[0]) {</td></tr><tr><th id="L38"><a href="#L38">38</a></th><td>                        case 'top': y = 0; break;</td></tr><tr><th id="L39"><a href="#L39">39</a></th><td>                        case 'middle': y = 0.5; break;</td></tr><tr><th id="L40"><a href="#L40">40</a></th><td>                        case 'bottom': y = 1; break;</td></tr><tr><th id="L41"><a href="#L41">41</a></th><td>                        default: y = origin[0] / original.height;</td></tr><tr><th id="L42"><a href="#L42">42</a></th><td>                };</td></tr><tr><th id="L43"><a href="#L43">43</a></th><td>                switch (origin[1]) {</td></tr><tr><th id="L44"><a href="#L44">44</a></th><td>                        case 'left': x = 0; break;</td></tr><tr><th id="L45"><a href="#L45">45</a></th><td>                        case 'center': x = 0.5; break;</td></tr><tr><th id="L46"><a href="#L46">46</a></th><td>                        case 'right': x = 1; break;</td></tr><tr><th id="L47"><a href="#L47">47</a></th><td>                        default: x = origin[1] / original.width;</td></tr><tr><th id="L48"><a href="#L48">48</a></th><td>                };</td></tr><tr><th id="L49"><a href="#L49">49</a></th><td>                return {x: x, y: y};</td></tr><tr><th id="L50"><a href="#L50">50</a></th><td>        },</td></tr><tr><th id="L51"><a href="#L51">51</a></th><td></td></tr><tr><th id="L52"><a href="#L52">52</a></th><td>        // Wraps the element around a wrapper that copies position properties</td></tr><tr><th id="L53"><a href="#L53">53</a></th><td>        createWrapper: function(element) {</td></tr><tr><th id="L54"><a href="#L54">54</a></th><td></td></tr><tr><th id="L55"><a href="#L55">55</a></th><td>                //if the element is already wrapped, return it</td></tr><tr><th id="L56"><a href="#L56">56</a></th><td>                if (element.parent().is('.ui-effects-wrapper'))</td></tr><tr><th id="L57"><a href="#L57">57</a></th><td>                        return element.parent();</td></tr><tr><th id="L58"><a href="#L58">58</a></th><td></td></tr><tr><th id="L59"><a href="#L59">59</a></th><td>                //Cache width,height and float properties of the element, and create a wrapper around it</td></tr><tr><th id="L60"><a href="#L60">60</a></th><td>                var props = { width: element.outerWidth(true), height: element.outerHeight(true), 'float': element.css('float') };</td></tr><tr><th id="L61"><a href="#L61">61</a></th><td>                element.wrap('&lt;div class="ui-effects-wrapper" style="font-size:100%;background:transparent;border:none;margin:0;padding:0"&gt;&lt;/div&gt;');</td></tr><tr><th id="L62"><a href="#L62">62</a></th><td>                var wrapper = element.parent();</td></tr><tr><th id="L63"><a href="#L63">63</a></th><td></td></tr><tr><th id="L64"><a href="#L64">64</a></th><td>                //Transfer the positioning of the element to the wrapper</td></tr><tr><th id="L65"><a href="#L65">65</a></th><td>                if (element.css('position') == 'static') {</td></tr><tr><th id="L66"><a href="#L66">66</a></th><td>                        wrapper.css({ position: 'relative' });</td></tr><tr><th id="L67"><a href="#L67">67</a></th><td>                        element.css({ position: 'relative'} );</td></tr><tr><th id="L68"><a href="#L68">68</a></th><td>                } else {</td></tr><tr><th id="L69"><a href="#L69">69</a></th><td>                        var top = element.css('top'); if(isNaN(parseInt(top,10))) top = 'auto';</td></tr><tr><th id="L70"><a href="#L70">70</a></th><td>                        var left = element.css('left'); if(isNaN(parseInt(left,10))) left = 'auto';</td></tr><tr><th id="L71"><a href="#L71">71</a></th><td>                        wrapper.css({ position: element.css('position'), top: top, left: left, zIndex: element.css('z-index') }).show();</td></tr><tr><th id="L72"><a href="#L72">72</a></th><td>                        element.css({position: 'relative', top: 0, left: 0 });</td></tr><tr><th id="L73"><a href="#L73">73</a></th><td>                }</td></tr><tr><th id="L74"><a href="#L74">74</a></th><td></td></tr><tr><th id="L75"><a href="#L75">75</a></th><td>                wrapper.css(props);</td></tr><tr><th id="L76"><a href="#L76">76</a></th><td>                return wrapper;</td></tr><tr><th id="L77"><a href="#L77">77</a></th><td>        },</td></tr><tr><th id="L78"><a href="#L78">78</a></th><td></td></tr><tr><th id="L79"><a href="#L79">79</a></th><td>        removeWrapper: function(element) {</td></tr><tr><th id="L80"><a href="#L80">80</a></th><td>                if (element.parent().is('.ui-effects-wrapper'))</td></tr><tr><th id="L81"><a href="#L81">81</a></th><td>                        return element.parent().replaceWith(element);</td></tr><tr><th id="L82"><a href="#L82">82</a></th><td>                return element;</td></tr><tr><th id="L83"><a href="#L83">83</a></th><td>        },</td></tr><tr><th id="L84"><a href="#L84">84</a></th><td></td></tr><tr><th id="L85"><a href="#L85">85</a></th><td>        setTransition: function(element, list, factor, value) {</td></tr><tr><th id="L86"><a href="#L86">86</a></th><td>                value = value || {};</td></tr><tr><th id="L87"><a href="#L87">87</a></th><td>                $.each(list, function(i, x){</td></tr><tr><th id="L88"><a href="#L88">88</a></th><td>                        unit = element.cssUnit(x);</td></tr><tr><th id="L89"><a href="#L89">89</a></th><td>                        if (unit[0] &gt; 0) value[x] = unit[0] * factor + unit[1];</td></tr><tr><th id="L90"><a href="#L90">90</a></th><td>                });</td></tr><tr><th id="L91"><a href="#L91">91</a></th><td>                return value;</td></tr><tr><th id="L92"><a href="#L92">92</a></th><td>        },</td></tr><tr><th id="L93"><a href="#L93">93</a></th><td></td></tr><tr><th id="L94"><a href="#L94">94</a></th><td>        //Base function to animate from one class to another in a seamless transition</td></tr><tr><th id="L95"><a href="#L95">95</a></th><td>        animateClass: function(value, duration, easing, callback) {</td></tr><tr><th id="L96"><a href="#L96">96</a></th><td></td></tr><tr><th id="L97"><a href="#L97">97</a></th><td>                var cb = (typeof easing == "function" ? easing : (callback ? callback : null));</td></tr><tr><th id="L98"><a href="#L98">98</a></th><td>                var ea = (typeof easing == "string" ? easing : null);</td></tr><tr><th id="L99"><a href="#L99">99</a></th><td></td></tr><tr><th id="L100"><a href="#L100">100</a></th><td>                return this.each(function() {</td></tr><tr><th id="L101"><a href="#L101">101</a></th><td></td></tr><tr><th id="L102"><a href="#L102">102</a></th><td>                        var offset = {}; var that = $(this); var oldStyleAttr = that.attr("style") || '';</td></tr><tr><th id="L103"><a href="#L103">103</a></th><td>                        if(typeof oldStyleAttr == 'object') oldStyleAttr = oldStyleAttr["cssText"]; /* Stupidly in IE, style is a object.. */</td></tr><tr><th id="L104"><a href="#L104">104</a></th><td>                        if(value.toggle) { that.hasClass(value.toggle) ? value.remove = value.toggle : value.add = value.toggle; }</td></tr><tr><th id="L105"><a href="#L105">105</a></th><td></td></tr><tr><th id="L106"><a href="#L106">106</a></th><td>                        //Let's get a style offset</td></tr><tr><th id="L107"><a href="#L107">107</a></th><td>                        var oldStyle = $.extend({}, (document.defaultView ? document.defaultView.getComputedStyle(this,null) : this.currentStyle));</td></tr><tr><th id="L108"><a href="#L108">108</a></th><td>                        if (0 in oldStyle) { //performance check for integer indices in WebKit browsers [charles@doublerebel.com]</td></tr><tr><th id="L109"><a href="#L109">109</a></th><td>                                for (var val in oldStyle) { //WebKit fix</td></tr><tr><th id="L110"><a href="#L110">110</a></th><td>                                        if (parseInt(val, 10) == val)  { //if the extend created indexes, as in when copying WebKit's broken getComputedStyle 'object', fix these properties</td></tr><tr><th id="L111"><a href="#L111">111</a></th><td>                                                oldStyle[oldStyle[val]] = document.defaultView.getComputedStyle(this,null)[oldStyle[val]];</td></tr><tr><th id="L112"><a href="#L112">112</a></th><td>                                                delete oldStyle[val]; //remove old undefined incorrect properties</td></tr><tr><th id="L113"><a href="#L113">113</a></th><td>                                        }</td></tr><tr><th id="L114"><a href="#L114">114</a></th><td>                                }</td></tr><tr><th id="L115"><a href="#L115">115</a></th><td>                        }</td></tr><tr><th id="L116"><a href="#L116">116</a></th><td>                        if(value.add) that.addClass(value.add); if(value.remove) that.removeClass(value.remove);</td></tr><tr><th id="L117"><a href="#L117">117</a></th><td>                        var newStyle = $.extend({}, (document.defaultView ? document.defaultView.getComputedStyle(this,null) : this.currentStyle));</td></tr><tr><th id="L118"><a href="#L118">118</a></th><td>                        if (0 in newStyle) { //performance check for integer indices in WebKit browsers [charles@doublerebel.com]</td></tr><tr><th id="L119"><a href="#L119">119</a></th><td>                                for (var val in newStyle) { //WebKit fix</td></tr><tr><th id="L120"><a href="#L120">120</a></th><td>                                        if (parseInt(val, 10) == val)  { //if the extend created indexes, as in when copying WebKit's broken getComputedStyle 'object', fix these properties</td></tr><tr><th id="L121"><a href="#L121">121</a></th><td>                                                newStyle[newStyle[val]] = document.defaultView.getComputedStyle(this,null)[newStyle[val]];</td></tr><tr><th id="L122"><a href="#L122">122</a></th><td>                                                delete newStyle[val]; //remove old undefined incorrect properties</td></tr><tr><th id="L123"><a href="#L123">123</a></th><td>                                        }</td></tr><tr><th id="L124"><a href="#L124">124</a></th><td>                                }</td></tr><tr><th id="L125"><a href="#L125">125</a></th><td>                        }</td></tr><tr><th id="L126"><a href="#L126">126</a></th><td>                        if(value.add) that.removeClass(value.add); if(value.remove) that.addClass(value.remove);</td></tr><tr><th id="L127"><a href="#L127">127</a></th><td></td></tr><tr><th id="L128"><a href="#L128">128</a></th><td>                        // The main function to form the object for animation</td></tr><tr><th id="L129"><a href="#L129">129</a></th><td>                        for(var n in newStyle) {</td></tr><tr><th id="L130"><a href="#L130">130</a></th><td>                                if( typeof newStyle[n] != "function" &amp;&amp; newStyle[n] /* No functions and null properties */</td></tr><tr><th id="L131"><a href="#L131">131</a></th><td>                                &amp;&amp; n.indexOf("Moz") == -1 &amp;&amp; n.indexOf("length") == -1 /* No mozilla spezific render properties. */</td></tr><tr><th id="L132"><a href="#L132">132</a></th><td>                                &amp;&amp; n.indexOf("webk") == -1 /* No WebKit-specific ones either */</td></tr><tr><th id="L133"><a href="#L133">133</a></th><td>                                &amp;&amp; n.indexOf("scrollbarBase") == -1 &amp;&amp; n != "margin" /* No IE bug ridiculousness [scrollbarBaseColor returns NaN; the margin property throws an error in the Dean Edwards styleLeft fix in curCSS()] */</td></tr><tr><th id="L134"><a href="#L134">134</a></th><td>                                &amp;&amp; newStyle[n] != oldStyle[n] /* Only values that have changed are used for the animation */</td></tr><tr><th id="L135"><a href="#L135">135</a></th><td>                                &amp;&amp; (n.match(/color/i) || (!n.match(/color/i) &amp;&amp; !isNaN(parseInt(newStyle[n],10)))) /* Only things that can be parsed to integers or colors */</td></tr><tr><th id="L136"><a href="#L136">136</a></th><td>                                &amp;&amp; (oldStyle.position != "static" || (oldStyle.position == "static" &amp;&amp; !n.match(/left|top|bottom|right/))) /* No need for positions when dealing with static positions */</td></tr><tr><th id="L137"><a href="#L137">137</a></th><td>                                ) offset[n] = newStyle[n];</td></tr><tr><th id="L138"><a href="#L138">138</a></th><td>                        }</td></tr><tr><th id="L139"><a href="#L139">139</a></th><td>                        </td></tr><tr><th id="L140"><a href="#L140">140</a></th><td>                        that.animate(offset, duration, ea, function() { // Animate the newly constructed offset object</td></tr><tr><th id="L141"><a href="#L141">141</a></th><td>                                // Change style attribute back to original. For stupid IE, we need to clear the damn object.</td></tr><tr><th id="L142"><a href="#L142">142</a></th><td>                                if(typeof $(this).attr("style") == 'object') { $(this).attr("style")["cssText"] = ""; $(this).attr("style")["cssText"] = oldStyleAttr; } else $(this).attr("style", oldStyleAttr);</td></tr><tr><th id="L143"><a href="#L143">143</a></th><td>                                if(value.add) $(this).addClass(value.add); if(value.remove) $(this).removeClass(value.remove);</td></tr><tr><th id="L144"><a href="#L144">144</a></th><td>                                if(cb) cb.apply(this, arguments);</td></tr><tr><th id="L145"><a href="#L145">145</a></th><td>                        });</td></tr><tr><th id="L146"><a href="#L146">146</a></th><td></td></tr><tr><th id="L147"><a href="#L147">147</a></th><td>                });</td></tr><tr><th id="L148"><a href="#L148">148</a></th><td>        }</td></tr><tr><th id="L149"><a href="#L149">149</a></th><td>};</td></tr><tr><th id="L150"><a href="#L150">150</a></th><td></td></tr><tr><th id="L151"><a href="#L151">151</a></th><td></td></tr><tr><th id="L152"><a href="#L152">152</a></th><td>function _normalizeArguments(a, m) {</td></tr><tr><th id="L153"><a href="#L153">153</a></th><td></td></tr><tr><th id="L154"><a href="#L154">154</a></th><td>        var o = a[1] &amp;&amp; a[1].constructor == Object ? a[1] : {}; if(m) o.mode = m;</td></tr><tr><th id="L155"><a href="#L155">155</a></th><td>        var speed = a[1] &amp;&amp; a[1].constructor != Object ? a[1] : (o.duration ? o.duration : a[2]); //either comes from options.duration or the secon/third argument</td></tr><tr><th id="L156"><a href="#L156">156</a></th><td>                speed = $.fx.off ? 0 : typeof speed === "number" ? speed : $.fx.speeds[speed] || $.fx.speeds._default;</td></tr><tr><th id="L157"><a href="#L157">157</a></th><td>        var callback = o.callback || ( $.isFunction(a[1]) &amp;&amp; a[1] ) || ( $.isFunction(a[2]) &amp;&amp; a[2] ) || ( $.isFunction(a[3]) &amp;&amp; a[3] );</td></tr><tr><th id="L158"><a href="#L158">158</a></th><td></td></tr><tr><th id="L159"><a href="#L159">159</a></th><td>        return [a[0], o, speed, callback];</td></tr><tr><th id="L160"><a href="#L160">160</a></th><td>        </td></tr><tr><th id="L161"><a href="#L161">161</a></th><td>}</td></tr><tr><th id="L162"><a href="#L162">162</a></th><td></td></tr><tr><th id="L163"><a href="#L163">163</a></th><td>//Extend the methods of jQuery</td></tr><tr><th id="L164"><a href="#L164">164</a></th><td>$.fn.extend({</td></tr><tr><th id="L165"><a href="#L165">165</a></th><td></td></tr><tr><th id="L166"><a href="#L166">166</a></th><td>        //Save old methods</td></tr><tr><th id="L167"><a href="#L167">167</a></th><td>        _show: $.fn.show,</td></tr><tr><th id="L168"><a href="#L168">168</a></th><td>        _hide: $.fn.hide,</td></tr><tr><th id="L169"><a href="#L169">169</a></th><td>        __toggle: $.fn.toggle,</td></tr><tr><th id="L170"><a href="#L170">170</a></th><td>        _addClass: $.fn.addClass,</td></tr><tr><th id="L171"><a href="#L171">171</a></th><td>        _removeClass: $.fn.removeClass,</td></tr><tr><th id="L172"><a href="#L172">172</a></th><td>        _toggleClass: $.fn.toggleClass,</td></tr><tr><th id="L173"><a href="#L173">173</a></th><td></td></tr><tr><th id="L174"><a href="#L174">174</a></th><td>        // New effect methods</td></tr><tr><th id="L175"><a href="#L175">175</a></th><td>        effect: function(fx, options, speed, callback) {</td></tr><tr><th id="L176"><a href="#L176">176</a></th><td>                return $.effects[fx] ? $.effects[fx].call(this, {method: fx, options: options || {}, duration: speed, callback: callback }) : null;</td></tr><tr><th id="L177"><a href="#L177">177</a></th><td>        },</td></tr><tr><th id="L178"><a href="#L178">178</a></th><td></td></tr><tr><th id="L179"><a href="#L179">179</a></th><td>        show: function() {</td></tr><tr><th id="L180"><a href="#L180">180</a></th><td>                if(!arguments[0] || (arguments[0].constructor == Number || (/(slow|normal|fast)/).test(arguments[0])))</td></tr><tr><th id="L181"><a href="#L181">181</a></th><td>                        return this._show.apply(this, arguments);</td></tr><tr><th id="L182"><a href="#L182">182</a></th><td>                else {</td></tr><tr><th id="L183"><a href="#L183">183</a></th><td>                        return this.effect.apply(this, _normalizeArguments(arguments, 'show'));</td></tr><tr><th id="L184"><a href="#L184">184</a></th><td>                }</td></tr><tr><th id="L185"><a href="#L185">185</a></th><td>        },</td></tr><tr><th id="L186"><a href="#L186">186</a></th><td></td></tr><tr><th id="L187"><a href="#L187">187</a></th><td>        hide: function() {</td></tr><tr><th id="L188"><a href="#L188">188</a></th><td>                if(!arguments[0] || (arguments[0].constructor == Number || (/(slow|normal|fast)/).test(arguments[0])))</td></tr><tr><th id="L189"><a href="#L189">189</a></th><td>                        return this._hide.apply(this, arguments);</td></tr><tr><th id="L190"><a href="#L190">190</a></th><td>                else {</td></tr><tr><th id="L191"><a href="#L191">191</a></th><td>                        return this.effect.apply(this, _normalizeArguments(arguments, 'hide'));</td></tr><tr><th id="L192"><a href="#L192">192</a></th><td>                }</td></tr><tr><th id="L193"><a href="#L193">193</a></th><td>        },</td></tr><tr><th id="L194"><a href="#L194">194</a></th><td></td></tr><tr><th id="L195"><a href="#L195">195</a></th><td>        toggle: function(){</td></tr><tr><th id="L196"><a href="#L196">196</a></th><td>                if(!arguments[0] || (arguments[0].constructor == Number || (/(slow|normal|fast)/).test(arguments[0])) || (arguments[0].constructor == Function))</td></tr><tr><th id="L197"><a href="#L197">197</a></th><td>                        return this.__toggle.apply(this, arguments);</td></tr><tr><th id="L198"><a href="#L198">198</a></th><td>                else {</td></tr><tr><th id="L199"><a href="#L199">199</a></th><td>                        return this.effect.apply(this, _normalizeArguments(arguments, 'toggle'));</td></tr><tr><th id="L200"><a href="#L200">200</a></th><td>                }</td></tr><tr><th id="L201"><a href="#L201">201</a></th><td>        },</td></tr><tr><th id="L202"><a href="#L202">202</a></th><td></td></tr><tr><th id="L203"><a href="#L203">203</a></th><td>        addClass: function(classNames, speed, easing, callback) {</td></tr><tr><th id="L204"><a href="#L204">204</a></th><td>                return speed ? $.effects.animateClass.apply(this, [{ add: classNames },speed,easing,callback]) : this._addClass(classNames);</td></tr><tr><th id="L205"><a href="#L205">205</a></th><td>        },</td></tr><tr><th id="L206"><a href="#L206">206</a></th><td>        removeClass: function(classNames,speed,easing,callback) {</td></tr><tr><th id="L207"><a href="#L207">207</a></th><td>                return speed ? $.effects.animateClass.apply(this, [{ remove: classNames },speed,easing,callback]) : this._removeClass(classNames);</td></tr><tr><th id="L208"><a href="#L208">208</a></th><td>        },</td></tr><tr><th id="L209"><a href="#L209">209</a></th><td>        toggleClass: function(classNames,speed,easing,callback) {</td></tr><tr><th id="L210"><a href="#L210">210</a></th><td>                return ( (typeof speed !== "boolean") &amp;&amp; speed ) ? $.effects.animateClass.apply(this, [{ toggle: classNames },speed,easing,callback]) : this._toggleClass(classNames, speed);</td></tr><tr><th id="L211"><a href="#L211">211</a></th><td>        },</td></tr><tr><th id="L212"><a href="#L212">212</a></th><td>        morph: function(remove,add,speed,easing,callback) {</td></tr><tr><th id="L213"><a href="#L213">213</a></th><td>                return $.effects.animateClass.apply(this, [{ add: add, remove: remove },speed,easing,callback]);</td></tr><tr><th id="L214"><a href="#L214">214</a></th><td>        },</td></tr><tr><th id="L215"><a href="#L215">215</a></th><td>        switchClass: function() {</td></tr><tr><th id="L216"><a href="#L216">216</a></th><td>                return this.morph.apply(this, arguments);</td></tr><tr><th id="L217"><a href="#L217">217</a></th><td>        },</td></tr><tr><th id="L218"><a href="#L218">218</a></th><td></td></tr><tr><th id="L219"><a href="#L219">219</a></th><td>        // helper functions</td></tr><tr><th id="L220"><a href="#L220">220</a></th><td>        cssUnit: function(key) {</td></tr><tr><th id="L221"><a href="#L221">221</a></th><td>                var style = this.css(key), val = [];</td></tr><tr><th id="L222"><a href="#L222">222</a></th><td>                $.each( ['em','px','%','pt'], function(i, unit){</td></tr><tr><th id="L223"><a href="#L223">223</a></th><td>                        if(style.indexOf(unit) &gt; 0)</td></tr><tr><th id="L224"><a href="#L224">224</a></th><td>                                val = [parseFloat(style), unit];</td></tr><tr><th id="L225"><a href="#L225">225</a></th><td>                });</td></tr><tr><th id="L226"><a href="#L226">226</a></th><td>                return val;</td></tr><tr><th id="L227"><a href="#L227">227</a></th><td>        }</td></tr><tr><th id="L228"><a href="#L228">228</a></th><td>});</td></tr><tr><th id="L229"><a href="#L229">229</a></th><td></td></tr><tr><th id="L230"><a href="#L230">230</a></th><td>/*</td></tr><tr><th id="L231"><a href="#L231">231</a></th><td> * jQuery Color Animations</td></tr><tr><th id="L232"><a href="#L232">232</a></th><td> * Copyright 2007 John Resig</td></tr><tr><th id="L233"><a href="#L233">233</a></th><td> * Released under the MIT and GPL licenses.</td></tr><tr><th id="L234"><a href="#L234">234</a></th><td> */</td></tr><tr><th id="L235"><a href="#L235">235</a></th><td></td></tr><tr><th id="L236"><a href="#L236">236</a></th><td>/* Still throws errors in IE7 on Vista</td></tr><tr><th id="L237"><a href="#L237">237</a></th><td>// We override the animation for all of these color styles</td></tr><tr><th id="L238"><a href="#L238">238</a></th><td>$.each(['backgroundColor', 'borderBottomColor', 'borderLeftColor', 'borderRightColor', 'borderTopColor', 'color', 'outlineColor'], function(i,attr){</td></tr><tr><th id="L239"><a href="#L239">239</a></th><td>                $.fx.step[attr] = function(fx) {</td></tr><tr><th id="L240"><a href="#L240">240</a></th><td>                                if ( fx.state == 0 ) {</td></tr><tr><th id="L241"><a href="#L241">241</a></th><td>                                                fx.start = getColor( fx.elem, attr );</td></tr><tr><th id="L242"><a href="#L242">242</a></th><td>                                                fx.end = getRGB( fx.end );</td></tr><tr><th id="L243"><a href="#L243">243</a></th><td>                                }</td></tr><tr><th id="L244"><a href="#L244">244</a></th><td></td></tr><tr><th id="L245"><a href="#L245">245</a></th><td>                                fx.elem.style[attr] = "rgb(" + [</td></tr><tr><th id="L246"><a href="#L246">246</a></th><td>                                                Math.max(Math.min( parseInt((fx.pos * (fx.end[0] - fx.start[0])) + fx.start[0],10), 255), 0),</td></tr><tr><th id="L247"><a href="#L247">247</a></th><td>                                                Math.max(Math.min( parseInt((fx.pos * (fx.end[1] - fx.start[1])) + fx.start[1],10), 255), 0),</td></tr><tr><th id="L248"><a href="#L248">248</a></th><td>                                                Math.max(Math.min( parseInt((fx.pos * (fx.end[2] - fx.start[2])) + fx.start[2],10), 255), 0)</td></tr><tr><th id="L249"><a href="#L249">249</a></th><td>                                ].join(",") + ")";</td></tr><tr><th id="L250"><a href="#L250">250</a></th><td>                        };</td></tr><tr><th id="L251"><a href="#L251">251</a></th><td>}); // */</td></tr><tr><th id="L252"><a href="#L252">252</a></th><td></td></tr><tr><th id="L253"><a href="#L253">253</a></th><td>// We override the animation for all of these color styles</td></tr><tr><th id="L254"><a href="#L254">254</a></th><td>$.each(['backgroundColor', 'borderBottomColor', 'borderLeftColor', 'borderRightColor', 'borderTopColor', 'color', 'outlineColor'], function(i,attr){</td></tr><tr><th id="L255"><a href="#L255">255</a></th><td>                $.fx.step[attr] = function(fx) {</td></tr><tr><th id="L256"><a href="#L256">256</a></th><td>                                if ( fx.state == 0 ) {</td></tr><tr><th id="L257"><a href="#L257">257</a></th><td>                                                fx.start = getColor( fx.elem, attr );</td></tr><tr><th id="L258"><a href="#L258">258</a></th><td>                                                fx.end = getRGB( fx.end );</td></tr><tr><th id="L259"><a href="#L259">259</a></th><td>                                }</td></tr><tr><th id="L260"><a href="#L260">260</a></th><td>                                var rgb = "rgb(" + [</td></tr><tr><th id="L261"><a href="#L261">261</a></th><td>                                                Math.max(Math.min( parseInt((fx.pos * (fx.end[0] - fx.start[0])) + fx.start[0],10), 255), 0),</td></tr><tr><th id="L262"><a href="#L262">262</a></th><td>                                                Math.max(Math.min( parseInt((fx.pos * (fx.end[1] - fx.start[1])) + fx.start[1],10), 255), 0),</td></tr><tr><th id="L263"><a href="#L263">263</a></th><td>                                                Math.max(Math.min( parseInt((fx.pos * (fx.end[2] - fx.start[2])) + fx.start[2],10), 255), 0)</td></tr><tr><th id="L264"><a href="#L264">264</a></th><td>                                ].join(",") + ")";</td></tr><tr><th id="L265"><a href="#L265">265</a></th><td>                                if ( (typeof fx.elem.style[attr] !== undefined) &amp;&amp; !(/N/.test(rgb)) ) { fx.elem.style[attr] = rgb; } //Prevent Firefox &amp; IE from hitting edge-case undefined errors [charles@doublerebel.com]</td></tr><tr><th id="L266"><a href="#L266">266</a></th><td>                        };</td></tr><tr><th id="L267"><a href="#L267">267</a></th><td>});</td></tr><tr><th id="L268"><a href="#L268">268</a></th><td></td></tr><tr><th id="L269"><a href="#L269">269</a></th><td></td></tr><tr><th id="L270"><a href="#L270">270</a></th><td>// Color Conversion functions from highlightFade</td></tr><tr><th id="L271"><a href="#L271">271</a></th><td>// By Blair Mitchelmore</td></tr><tr><th id="L272"><a href="#L272">272</a></th><td>// http://jquery.offput.ca/highlightFade/</td></tr><tr><th id="L273"><a href="#L273">273</a></th><td></td></tr><tr><th id="L274"><a href="#L274">274</a></th><td>// Parse strings looking for color tuples [255,255,255]</td></tr><tr><th id="L275"><a href="#L275">275</a></th><td>function getRGB(color) {</td></tr><tr><th id="L276"><a href="#L276">276</a></th><td>                var result;</td></tr><tr><th id="L277"><a href="#L277">277</a></th><td></td></tr><tr><th id="L278"><a href="#L278">278</a></th><td>                // Check if we're already dealing with an array of colors</td></tr><tr><th id="L279"><a href="#L279">279</a></th><td>                if ( color &amp;&amp; color.constructor == Array &amp;&amp; color.length == 3 )</td></tr><tr><th id="L280"><a href="#L280">280</a></th><td>                                return color;</td></tr><tr><th id="L281"><a href="#L281">281</a></th><td></td></tr><tr><th id="L282"><a href="#L282">282</a></th><td>                // Look for rgb(num,num,num)</td></tr><tr><th id="L283"><a href="#L283">283</a></th><td>                if (result = /rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec(color))</td></tr><tr><th id="L284"><a href="#L284">284</a></th><td>                                return [parseInt(result[1],10), parseInt(result[2],10), parseInt(result[3],10)];</td></tr><tr><th id="L285"><a href="#L285">285</a></th><td></td></tr><tr><th id="L286"><a href="#L286">286</a></th><td>                // Look for rgb(num%,num%,num%)</td></tr><tr><th id="L287"><a href="#L287">287</a></th><td>                if (result = /rgb\(\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*\)/.exec(color))</td></tr><tr><th id="L288"><a href="#L288">288</a></th><td>                                return [parseFloat(result[1])*2.55, parseFloat(result[2])*2.55, parseFloat(result[3])*2.55];</td></tr><tr><th id="L289"><a href="#L289">289</a></th><td></td></tr><tr><th id="L290"><a href="#L290">290</a></th><td>                // Look for #a0b1c2</td></tr><tr><th id="L291"><a href="#L291">291</a></th><td>                if (result = /#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(color))</td></tr><tr><th id="L292"><a href="#L292">292</a></th><td>                                return [parseInt(result[1],16), parseInt(result[2],16), parseInt(result[3],16)];</td></tr><tr><th id="L293"><a href="#L293">293</a></th><td></td></tr><tr><th id="L294"><a href="#L294">294</a></th><td>                // Look for #fff</td></tr><tr><th id="L295"><a href="#L295">295</a></th><td>                if (result = /#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec(color))</td></tr><tr><th id="L296"><a href="#L296">296</a></th><td>                                return [parseInt(result[1]+result[1],16), parseInt(result[2]+result[2],16), parseInt(result[3]+result[3],16)];</td></tr><tr><th id="L297"><a href="#L297">297</a></th><td></td></tr><tr><th id="L298"><a href="#L298">298</a></th><td>                // Look for rgba(0, 0, 0, 0) == transparent in Safari 3</td></tr><tr><th id="L299"><a href="#L299">299</a></th><td>                if (result = /rgba\(0, 0, 0, 0\)/.exec(color))</td></tr><tr><th id="L300"><a href="#L300">300</a></th><td>                                return colors['transparent'];</td></tr><tr><th id="L301"><a href="#L301">301</a></th><td></td></tr><tr><th id="L302"><a href="#L302">302</a></th><td>                // Otherwise, we're most likely dealing with a named color</td></tr><tr><th id="L303"><a href="#L303">303</a></th><td>                return colors[$.trim(color).toLowerCase()];</td></tr><tr><th id="L304"><a href="#L304">304</a></th><td>}</td></tr><tr><th id="L305"><a href="#L305">305</a></th><td></td></tr><tr><th id="L306"><a href="#L306">306</a></th><td>function getColor(elem, attr) {</td></tr><tr><th id="L307"><a href="#L307">307</a></th><td>                var color;</td></tr><tr><th id="L308"><a href="#L308">308</a></th><td></td></tr><tr><th id="L309"><a href="#L309">309</a></th><td>                do {</td></tr><tr><th id="L310"><a href="#L310">310</a></th><td>                                color = $.curCSS(elem, attr);</td></tr><tr><th id="L311"><a href="#L311">311</a></th><td></td></tr><tr><th id="L312"><a href="#L312">312</a></th><td>                                // Keep going until we find an element that has color, or we hit the body</td></tr><tr><th id="L313"><a href="#L313">313</a></th><td>                                if ( color != '' &amp;&amp; color != 'transparent' || $.nodeName(elem, "body") )</td></tr><tr><th id="L314"><a href="#L314">314</a></th><td>                                                break;</td></tr><tr><th id="L315"><a href="#L315">315</a></th><td></td></tr><tr><th id="L316"><a href="#L316">316</a></th><td>                                attr = "backgroundColor";</td></tr><tr><th id="L317"><a href="#L317">317</a></th><td>                } while ( elem = elem.parentNode );</td></tr><tr><th id="L318"><a href="#L318">318</a></th><td></td></tr><tr><th id="L319"><a href="#L319">319</a></th><td>                return getRGB(color);</td></tr><tr><th id="L320"><a href="#L320">320</a></th><td>};</td></tr><tr><th id="L321"><a href="#L321">321</a></th><td></td></tr><tr><th id="L322"><a href="#L322">322</a></th><td>// Some named colors to work with</td></tr><tr><th id="L323"><a href="#L323">323</a></th><td>// From Interface by Stefan Petre</td></tr><tr><th id="L324"><a href="#L324">324</a></th><td>// http://interface.eyecon.ro/</td></tr><tr><th id="L325"><a href="#L325">325</a></th><td></td></tr><tr><th id="L326"><a href="#L326">326</a></th><td>var colors = {</td></tr><tr><th id="L327"><a href="#L327">327</a></th><td>        aqua:[0,255,255],</td></tr><tr><th id="L328"><a href="#L328">328</a></th><td>        azure:[240,255,255],</td></tr><tr><th id="L329"><a href="#L329">329</a></th><td>        beige:[245,245,220],</td></tr><tr><th id="L330"><a href="#L330">330</a></th><td>        black:[0,0,0],</td></tr><tr><th id="L331"><a href="#L331">331</a></th><td>        blue:[0,0,255],</td></tr><tr><th id="L332"><a href="#L332">332</a></th><td>        brown:[165,42,42],</td></tr><tr><th id="L333"><a href="#L333">333</a></th><td>        cyan:[0,255,255],</td></tr><tr><th id="L334"><a href="#L334">334</a></th><td>        darkblue:[0,0,139],</td></tr><tr><th id="L335"><a href="#L335">335</a></th><td>        darkcyan:[0,139,139],</td></tr><tr><th id="L336"><a href="#L336">336</a></th><td>        darkgrey:[169,169,169],</td></tr><tr><th id="L337"><a href="#L337">337</a></th><td>        darkgreen:[0,100,0],</td></tr><tr><th id="L338"><a href="#L338">338</a></th><td>        darkkhaki:[189,183,107],</td></tr><tr><th id="L339"><a href="#L339">339</a></th><td>        darkmagenta:[139,0,139],</td></tr><tr><th id="L340"><a href="#L340">340</a></th><td>        darkolivegreen:[85,107,47],</td></tr><tr><th id="L341"><a href="#L341">341</a></th><td>        darkorange:[255,140,0],</td></tr><tr><th id="L342"><a href="#L342">342</a></th><td>        darkorchid:[153,50,204],</td></tr><tr><th id="L343"><a href="#L343">343</a></th><td>        darkred:[139,0,0],</td></tr><tr><th id="L344"><a href="#L344">344</a></th><td>        darksalmon:[233,150,122],</td></tr><tr><th id="L345"><a href="#L345">345</a></th><td>        darkviolet:[148,0,211],</td></tr><tr><th id="L346"><a href="#L346">346</a></th><td>        fuchsia:[255,0,255],</td></tr><tr><th id="L347"><a href="#L347">347</a></th><td>        gold:[255,215,0],</td></tr><tr><th id="L348"><a href="#L348">348</a></th><td>        green:[0,128,0],</td></tr><tr><th id="L349"><a href="#L349">349</a></th><td>        indigo:[75,0,130],</td></tr><tr><th id="L350"><a href="#L350">350</a></th><td>        khaki:[240,230,140],</td></tr><tr><th id="L351"><a href="#L351">351</a></th><td>        lightblue:[173,216,230],</td></tr><tr><th id="L352"><a href="#L352">352</a></th><td>        lightcyan:[224,255,255],</td></tr><tr><th id="L353"><a href="#L353">353</a></th><td>        lightgreen:[144,238,144],</td></tr><tr><th id="L354"><a href="#L354">354</a></th><td>        lightgrey:[211,211,211],</td></tr><tr><th id="L355"><a href="#L355">355</a></th><td>        lightpink:[255,182,193],</td></tr><tr><th id="L356"><a href="#L356">356</a></th><td>        lightyellow:[255,255,224],</td></tr><tr><th id="L357"><a href="#L357">357</a></th><td>        lime:[0,255,0],</td></tr><tr><th id="L358"><a href="#L358">358</a></th><td>        magenta:[255,0,255],</td></tr><tr><th id="L359"><a href="#L359">359</a></th><td>        maroon:[128,0,0],</td></tr><tr><th id="L360"><a href="#L360">360</a></th><td>        navy:[0,0,128],</td></tr><tr><th id="L361"><a href="#L361">361</a></th><td>        olive:[128,128,0],</td></tr><tr><th id="L362"><a href="#L362">362</a></th><td>        orange:[255,165,0],</td></tr><tr><th id="L363"><a href="#L363">363</a></th><td>        pink:[255,192,203],</td></tr><tr><th id="L364"><a href="#L364">364</a></th><td>        purple:[128,0,128],</td></tr><tr><th id="L365"><a href="#L365">365</a></th><td>        violet:[128,0,128],</td></tr><tr><th id="L366"><a href="#L366">366</a></th><td>        red:[255,0,0],</td></tr><tr><th id="L367"><a href="#L367">367</a></th><td>        silver:[192,192,192],</td></tr><tr><th id="L368"><a href="#L368">368</a></th><td>        white:[255,255,255],</td></tr><tr><th id="L369"><a href="#L369">369</a></th><td>        yellow:[255,255,0],</td></tr><tr><th id="L370"><a href="#L370">370</a></th><td>        transparent: [255,255,255]</td></tr><tr><th id="L371"><a href="#L371">371</a></th><td>};</td></tr><tr><th id="L372"><a href="#L372">372</a></th><td></td></tr><tr><th id="L373"><a href="#L373">373</a></th><td>/*</td></tr><tr><th id="L374"><a href="#L374">374</a></th><td> * jQuery Easing v1.3 - http://gsgd.co.uk/sandbox/jquery/easing/</td></tr><tr><th id="L375"><a href="#L375">375</a></th><td> *</td></tr><tr><th id="L376"><a href="#L376">376</a></th><td> * Uses the built in easing capabilities added In jQuery 1.1</td></tr><tr><th id="L377"><a href="#L377">377</a></th><td> * to offer multiple easing options</td></tr><tr><th id="L378"><a href="#L378">378</a></th><td> *</td></tr><tr><th id="L379"><a href="#L379">379</a></th><td> * TERMS OF USE - jQuery Easing</td></tr><tr><th id="L380"><a href="#L380">380</a></th><td> *</td></tr><tr><th id="L381"><a href="#L381">381</a></th><td> * Open source under the BSD License.</td></tr><tr><th id="L382"><a href="#L382">382</a></th><td> *</td></tr><tr><th id="L383"><a href="#L383">383</a></th><td> * Copyright 2008 George McGinley Smith</td></tr><tr><th id="L384"><a href="#L384">384</a></th><td> * All rights reserved.</td></tr><tr><th id="L385"><a href="#L385">385</a></th><td> *</td></tr><tr><th id="L386"><a href="#L386">386</a></th><td> * Redistribution and use in source and binary forms, with or without modification,</td></tr><tr><th id="L387"><a href="#L387">387</a></th><td> * are permitted provided that the following conditions are met:</td></tr><tr><th id="L388"><a href="#L388">388</a></th><td> *</td></tr><tr><th id="L389"><a href="#L389">389</a></th><td> * Redistributions of source code must retain the above copyright notice, this list of</td></tr><tr><th id="L390"><a href="#L390">390</a></th><td> * conditions and the following disclaimer.</td></tr><tr><th id="L391"><a href="#L391">391</a></th><td> * Redistributions in binary form must reproduce the above copyright notice, this list</td></tr><tr><th id="L392"><a href="#L392">392</a></th><td> * of conditions and the following disclaimer in the documentation and/or other materials</td></tr><tr><th id="L393"><a href="#L393">393</a></th><td> * provided with the distribution.</td></tr><tr><th id="L394"><a href="#L394">394</a></th><td> *</td></tr><tr><th id="L395"><a href="#L395">395</a></th><td> * Neither the name of the author nor the names of contributors may be used to endorse</td></tr><tr><th id="L396"><a href="#L396">396</a></th><td> * or promote products derived from this software without specific prior written permission.</td></tr><tr><th id="L397"><a href="#L397">397</a></th><td> *</td></tr><tr><th id="L398"><a href="#L398">398</a></th><td> * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY</td></tr><tr><th id="L399"><a href="#L399">399</a></th><td> * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF</td></tr><tr><th id="L400"><a href="#L400">400</a></th><td> * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE</td></tr><tr><th id="L401"><a href="#L401">401</a></th><td> * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,</td></tr><tr><th id="L402"><a href="#L402">402</a></th><td> * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE</td></tr><tr><th id="L403"><a href="#L403">403</a></th><td> * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED</td></tr><tr><th id="L404"><a href="#L404">404</a></th><td> * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING</td></tr><tr><th id="L405"><a href="#L405">405</a></th><td> * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED</td></tr><tr><th id="L406"><a href="#L406">406</a></th><td> * OF THE POSSIBILITY OF SUCH DAMAGE.</td></tr><tr><th id="L407"><a href="#L407">407</a></th><td> *</td></tr><tr><th id="L408"><a href="#L408">408</a></th><td>*/</td></tr><tr><th id="L409"><a href="#L409">409</a></th><td></td></tr><tr><th id="L410"><a href="#L410">410</a></th><td>// t: current time, b: begInnIng value, c: change In value, d: duration</td></tr><tr><th id="L411"><a href="#L411">411</a></th><td>$.easing.jswing = $.easing.swing;</td></tr><tr><th id="L412"><a href="#L412">412</a></th><td></td></tr><tr><th id="L413"><a href="#L413">413</a></th><td>$.extend($.easing,</td></tr><tr><th id="L414"><a href="#L414">414</a></th><td>{</td></tr><tr><th id="L415"><a href="#L415">415</a></th><td>        def: 'easeOutQuad',</td></tr><tr><th id="L416"><a href="#L416">416</a></th><td>        swing: function (x, t, b, c, d) {</td></tr><tr><th id="L417"><a href="#L417">417</a></th><td>                //alert($.easing.default);</td></tr><tr><th id="L418"><a href="#L418">418</a></th><td>                return $.easing[$.easing.def](x, t, b, c, d);</td></tr><tr><th id="L419"><a href="#L419">419</a></th><td>        },</td></tr><tr><th id="L420"><a href="#L420">420</a></th><td>        easeInQuad: function (x, t, b, c, d) {</td></tr><tr><th id="L421"><a href="#L421">421</a></th><td>                return c*(t/=d)*t + b;</td></tr><tr><th id="L422"><a href="#L422">422</a></th><td>        },</td></tr><tr><th id="L423"><a href="#L423">423</a></th><td>        easeOutQuad: function (x, t, b, c, d) {</td></tr><tr><th id="L424"><a href="#L424">424</a></th><td>                return -c *(t/=d)*(t-2) + b;</td></tr><tr><th id="L425"><a href="#L425">425</a></th><td>        },</td></tr><tr><th id="L426"><a href="#L426">426</a></th><td>        easeInOutQuad: function (x, t, b, c, d) {</td></tr><tr><th id="L427"><a href="#L427">427</a></th><td>                if ((t/=d/2) &lt; 1) return c/2*t*t + b;</td></tr><tr><th id="L428"><a href="#L428">428</a></th><td>                return -c/2 * ((--t)*(t-2) - 1) + b;</td></tr><tr><th id="L429"><a href="#L429">429</a></th><td>        },</td></tr><tr><th id="L430"><a href="#L430">430</a></th><td>        easeInCubic: function (x, t, b, c, d) {</td></tr><tr><th id="L431"><a href="#L431">431</a></th><td>                return c*(t/=d)*t*t + b;</td></tr><tr><th id="L432"><a href="#L432">432</a></th><td>        },</td></tr><tr><th id="L433"><a href="#L433">433</a></th><td>        easeOutCubic: function (x, t, b, c, d) {</td></tr><tr><th id="L434"><a href="#L434">434</a></th><td>                return c*((t=t/d-1)*t*t + 1) + b;</td></tr><tr><th id="L435"><a href="#L435">435</a></th><td>        },</td></tr><tr><th id="L436"><a href="#L436">436</a></th><td>        easeInOutCubic: function (x, t, b, c, d) {</td></tr><tr><th id="L437"><a href="#L437">437</a></th><td>                if ((t/=d/2) &lt; 1) return c/2*t*t*t + b;</td></tr><tr><th id="L438"><a href="#L438">438</a></th><td>                return c/2*((t-=2)*t*t + 2) + b;</td></tr><tr><th id="L439"><a href="#L439">439</a></th><td>        },</td></tr><tr><th id="L440"><a href="#L440">440</a></th><td>        easeInQuart: function (x, t, b, c, d) {</td></tr><tr><th id="L441"><a href="#L441">441</a></th><td>                return c*(t/=d)*t*t*t + b;</td></tr><tr><th id="L442"><a href="#L442">442</a></th><td>        },</td></tr><tr><th id="L443"><a href="#L443">443</a></th><td>        easeOutQuart: function (x, t, b, c, d) {</td></tr><tr><th id="L444"><a href="#L444">444</a></th><td>                return -c * ((t=t/d-1)*t*t*t - 1) + b;</td></tr><tr><th id="L445"><a href="#L445">445</a></th><td>        },</td></tr><tr><th id="L446"><a href="#L446">446</a></th><td>        easeInOutQuart: function (x, t, b, c, d) {</td></tr><tr><th id="L447"><a href="#L447">447</a></th><td>                if ((t/=d/2) &lt; 1) return c/2*t*t*t*t + b;</td></tr><tr><th id="L448"><a href="#L448">448</a></th><td>                return -c/2 * ((t-=2)*t*t*t - 2) + b;</td></tr><tr><th id="L449"><a href="#L449">449</a></th><td>        },</td></tr><tr><th id="L450"><a href="#L450">450</a></th><td>        easeInQuint: function (x, t, b, c, d) {</td></tr><tr><th id="L451"><a href="#L451">451</a></th><td>                return c*(t/=d)*t*t*t*t + b;</td></tr><tr><th id="L452"><a href="#L452">452</a></th><td>        },</td></tr><tr><th id="L453"><a href="#L453">453</a></th><td>        easeOutQuint: function (x, t, b, c, d) {</td></tr><tr><th id="L454"><a href="#L454">454</a></th><td>                return c*((t=t/d-1)*t*t*t*t + 1) + b;</td></tr><tr><th id="L455"><a href="#L455">455</a></th><td>        },</td></tr><tr><th id="L456"><a href="#L456">456</a></th><td>        easeInOutQuint: function (x, t, b, c, d) {</td></tr><tr><th id="L457"><a href="#L457">457</a></th><td>                if ((t/=d/2) &lt; 1) return c/2*t*t*t*t*t + b;</td></tr><tr><th id="L458"><a href="#L458">458</a></th><td>                return c/2*((t-=2)*t*t*t*t + 2) + b;</td></tr><tr><th id="L459"><a href="#L459">459</a></th><td>        },</td></tr><tr><th id="L460"><a href="#L460">460</a></th><td>        easeInSine: function (x, t, b, c, d) {</td></tr><tr><th id="L461"><a href="#L461">461</a></th><td>                return -c * Math.cos(t/d * (Math.PI/2)) + c + b;</td></tr><tr><th id="L462"><a href="#L462">462</a></th><td>        },</td></tr><tr><th id="L463"><a href="#L463">463</a></th><td>        easeOutSine: function (x, t, b, c, d) {</td></tr><tr><th id="L464"><a href="#L464">464</a></th><td>                return c * Math.sin(t/d * (Math.PI/2)) + b;</td></tr><tr><th id="L465"><a href="#L465">465</a></th><td>        },</td></tr><tr><th id="L466"><a href="#L466">466</a></th><td>        easeInOutSine: function (x, t, b, c, d) {</td></tr><tr><th id="L467"><a href="#L467">467</a></th><td>                return -c/2 * (Math.cos(Math.PI*t/d) - 1) + b;</td></tr><tr><th id="L468"><a href="#L468">468</a></th><td>        },</td></tr><tr><th id="L469"><a href="#L469">469</a></th><td>        easeInExpo: function (x, t, b, c, d) {</td></tr><tr><th id="L470"><a href="#L470">470</a></th><td>                return (t==0) ? b : c * Math.pow(2, 10 * (t/d - 1)) + b;</td></tr><tr><th id="L471"><a href="#L471">471</a></th><td>        },</td></tr><tr><th id="L472"><a href="#L472">472</a></th><td>        easeOutExpo: function (x, t, b, c, d) {</td></tr><tr><th id="L473"><a href="#L473">473</a></th><td>                return (t==d) ? b+c : c * (-Math.pow(2, -10 * t/d) + 1) + b;</td></tr><tr><th id="L474"><a href="#L474">474</a></th><td>        },</td></tr><tr><th id="L475"><a href="#L475">475</a></th><td>        easeInOutExpo: function (x, t, b, c, d) {</td></tr><tr><th id="L476"><a href="#L476">476</a></th><td>                if (t==0) return b;</td></tr><tr><th id="L477"><a href="#L477">477</a></th><td>                if (t==d) return b+c;</td></tr><tr><th id="L478"><a href="#L478">478</a></th><td>                if ((t/=d/2) &lt; 1) return c/2 * Math.pow(2, 10 * (t - 1)) + b;</td></tr><tr><th id="L479"><a href="#L479">479</a></th><td>                return c/2 * (-Math.pow(2, -10 * --t) + 2) + b;</td></tr><tr><th id="L480"><a href="#L480">480</a></th><td>        },</td></tr><tr><th id="L481"><a href="#L481">481</a></th><td>        easeInCirc: function (x, t, b, c, d) {</td></tr><tr><th id="L482"><a href="#L482">482</a></th><td>                return -c * (Math.sqrt(1 - (t/=d)*t) - 1) + b;</td></tr><tr><th id="L483"><a href="#L483">483</a></th><td>        },</td></tr><tr><th id="L484"><a href="#L484">484</a></th><td>        easeOutCirc: function (x, t, b, c, d) {</td></tr><tr><th id="L485"><a href="#L485">485</a></th><td>                return c * Math.sqrt(1 - (t=t/d-1)*t) + b;</td></tr><tr><th id="L486"><a href="#L486">486</a></th><td>        },</td></tr><tr><th id="L487"><a href="#L487">487</a></th><td>        easeInOutCirc: function (x, t, b, c, d) {</td></tr><tr><th id="L488"><a href="#L488">488</a></th><td>                if ((t/=d/2) &lt; 1) return -c/2 * (Math.sqrt(1 - t*t) - 1) + b;</td></tr><tr><th id="L489"><a href="#L489">489</a></th><td>                return c/2 * (Math.sqrt(1 - (t-=2)*t) + 1) + b;</td></tr><tr><th id="L490"><a href="#L490">490</a></th><td>        },</td></tr><tr><th id="L491"><a href="#L491">491</a></th><td>        easeInElastic: function (x, t, b, c, d) {</td></tr><tr><th id="L492"><a href="#L492">492</a></th><td>                var s=1.70158;var p=0;var a=c;</td></tr><tr><th id="L493"><a href="#L493">493</a></th><td>                if (t==0) return b;  if ((t/=d)==1) return b+c;  if (!p) p=d*.3;</td></tr><tr><th id="L494"><a href="#L494">494</a></th><td>                if (a &lt; Math.abs(c)) { a=c; var s=p/4; }</td></tr><tr><th id="L495"><a href="#L495">495</a></th><td>                else var s = p/(2*Math.PI) * Math.asin (c/a);</td></tr><tr><th id="L496"><a href="#L496">496</a></th><td>                return -(a*Math.pow(2,10*(t-=1)) * Math.sin( (t*d-s)*(2*Math.PI)/p )) + b;</td></tr><tr><th id="L497"><a href="#L497">497</a></th><td>        },</td></tr><tr><th id="L498"><a href="#L498">498</a></th><td>        easeOutElastic: function (x, t, b, c, d) {</td></tr><tr><th id="L499"><a href="#L499">499</a></th><td>                var s=1.70158;var p=0;var a=c;</td></tr><tr><th id="L500"><a href="#L500">500</a></th><td>                if (t==0) return b;  if ((t/=d)==1) return b+c;  if (!p) p=d*.3;</td></tr><tr><th id="L501"><a href="#L501">501</a></th><td>                if (a &lt; Math.abs(c)) { a=c; var s=p/4; }</td></tr><tr><th id="L502"><a href="#L502">502</a></th><td>                else var s = p/(2*Math.PI) * Math.asin (c/a);</td></tr><tr><th id="L503"><a href="#L503">503</a></th><td>                return a*Math.pow(2,-10*t) * Math.sin( (t*d-s)*(2*Math.PI)/p ) + c + b;</td></tr><tr><th id="L504"><a href="#L504">504</a></th><td>        },</td></tr><tr><th id="L505"><a href="#L505">505</a></th><td>        easeInOutElastic: function (x, t, b, c, d) {</td></tr><tr><th id="L506"><a href="#L506">506</a></th><td>                var s=1.70158;var p=0;var a=c;</td></tr><tr><th id="L507"><a href="#L507">507</a></th><td>                if (t==0) return b;  if ((t/=d/2)==2) return b+c;  if (!p) p=d*(.3*1.5);</td></tr><tr><th id="L508"><a href="#L508">508</a></th><td>                if (a &lt; Math.abs(c)) { a=c; var s=p/4; }</td></tr><tr><th id="L509"><a href="#L509">509</a></th><td>                else var s = p/(2*Math.PI) * Math.asin (c/a);</td></tr><tr><th id="L510"><a href="#L510">510</a></th><td>                if (t &lt; 1) return -.5*(a*Math.pow(2,10*(t-=1)) * Math.sin( (t*d-s)*(2*Math.PI)/p )) + b;</td></tr><tr><th id="L511"><a href="#L511">511</a></th><td>                return a*Math.pow(2,-10*(t-=1)) * Math.sin( (t*d-s)*(2*Math.PI)/p )*.5 + c + b;</td></tr><tr><th id="L512"><a href="#L512">512</a></th><td>        },</td></tr><tr><th id="L513"><a href="#L513">513</a></th><td>        easeInBack: function (x, t, b, c, d, s) {</td></tr><tr><th id="L514"><a href="#L514">514</a></th><td>                if (s == undefined) s = 1.70158;</td></tr><tr><th id="L515"><a href="#L515">515</a></th><td>                return c*(t/=d)*t*((s+1)*t - s) + b;</td></tr><tr><th id="L516"><a href="#L516">516</a></th><td>        },</td></tr><tr><th id="L517"><a href="#L517">517</a></th><td>        easeOutBack: function (x, t, b, c, d, s) {</td></tr><tr><th id="L518"><a href="#L518">518</a></th><td>                if (s == undefined) s = 1.70158;</td></tr><tr><th id="L519"><a href="#L519">519</a></th><td>                return c*((t=t/d-1)*t*((s+1)*t + s) + 1) + b;</td></tr><tr><th id="L520"><a href="#L520">520</a></th><td>        },</td></tr><tr><th id="L521"><a href="#L521">521</a></th><td>        easeInOutBack: function (x, t, b, c, d, s) {</td></tr><tr><th id="L522"><a href="#L522">522</a></th><td>                if (s == undefined) s = 1.70158;</td></tr><tr><th id="L523"><a href="#L523">523</a></th><td>                if ((t/=d/2) &lt; 1) return c/2*(t*t*(((s*=(1.525))+1)*t - s)) + b;</td></tr><tr><th id="L524"><a href="#L524">524</a></th><td>                return c/2*((t-=2)*t*(((s*=(1.525))+1)*t + s) + 2) + b;</td></tr><tr><th id="L525"><a href="#L525">525</a></th><td>        },</td></tr><tr><th id="L526"><a href="#L526">526</a></th><td>        easeInBounce: function (x, t, b, c, d) {</td></tr><tr><th id="L527"><a href="#L527">527</a></th><td>                return c - $.easing.easeOutBounce (x, d-t, 0, c, d) + b;</td></tr><tr><th id="L528"><a href="#L528">528</a></th><td>        },</td></tr><tr><th id="L529"><a href="#L529">529</a></th><td>        easeOutBounce: function (x, t, b, c, d) {</td></tr><tr><th id="L530"><a href="#L530">530</a></th><td>                if ((t/=d) &lt; (1/2.75)) {</td></tr><tr><th id="L531"><a href="#L531">531</a></th><td>                        return c*(7.5625*t*t) + b;</td></tr><tr><th id="L532"><a href="#L532">532</a></th><td>                } else if (t &lt; (2/2.75)) {</td></tr><tr><th id="L533"><a href="#L533">533</a></th><td>                        return c*(7.5625*(t-=(1.5/2.75))*t + .75) + b;</td></tr><tr><th id="L534"><a href="#L534">534</a></th><td>                } else if (t &lt; (2.5/2.75)) {</td></tr><tr><th id="L535"><a href="#L535">535</a></th><td>                        return c*(7.5625*(t-=(2.25/2.75))*t + .9375) + b;</td></tr><tr><th id="L536"><a href="#L536">536</a></th><td>                } else {</td></tr><tr><th id="L537"><a href="#L537">537</a></th><td>                        return c*(7.5625*(t-=(2.625/2.75))*t + .984375) + b;</td></tr><tr><th id="L538"><a href="#L538">538</a></th><td>                }</td></tr><tr><th id="L539"><a href="#L539">539</a></th><td>        },</td></tr><tr><th id="L540"><a href="#L540">540</a></th><td>        easeInOutBounce: function (x, t, b, c, d) {</td></tr><tr><th id="L541"><a href="#L541">541</a></th><td>                if (t &lt; d/2) return $.easing.easeInBounce (x, t*2, 0, c, d) * .5 + b;</td></tr><tr><th id="L542"><a href="#L542">542</a></th><td>                return $.easing.easeOutBounce (x, t*2-d, 0, c, d) * .5 + c*.5 + b;</td></tr><tr><th id="L543"><a href="#L543">543</a></th><td>        }</td></tr><tr><th id="L544"><a href="#L544">544</a></th><td>});</td></tr><tr><th id="L545"><a href="#L545">545</a></th><td></td></tr><tr><th id="L546"><a href="#L546">546</a></th><td>/*</td></tr><tr><th id="L547"><a href="#L547">547</a></th><td> *</td></tr><tr><th id="L548"><a href="#L548">548</a></th><td> * TERMS OF USE - EASING EQUATIONS</td></tr><tr><th id="L549"><a href="#L549">549</a></th><td> *</td></tr><tr><th id="L550"><a href="#L550">550</a></th><td> * Open source under the BSD License.</td></tr><tr><th id="L551"><a href="#L551">551</a></th><td> *</td></tr><tr><th id="L552"><a href="#L552">552</a></th><td> * Copyright 2001 Robert Penner</td></tr><tr><th id="L553"><a href="#L553">553</a></th><td> * All rights reserved.</td></tr><tr><th id="L554"><a href="#L554">554</a></th><td> *</td></tr><tr><th id="L555"><a href="#L555">555</a></th><td> * Redistribution and use in source and binary forms, with or without modification,</td></tr><tr><th id="L556"><a href="#L556">556</a></th><td> * are permitted provided that the following conditions are met:</td></tr><tr><th id="L557"><a href="#L557">557</a></th><td> *</td></tr><tr><th id="L558"><a href="#L558">558</a></th><td> * Redistributions of source code must retain the above copyright notice, this list of</td></tr><tr><th id="L559"><a href="#L559">559</a></th><td> * conditions and the following disclaimer.</td></tr><tr><th id="L560"><a href="#L560">560</a></th><td> * Redistributions in binary form must reproduce the above copyright notice, this list</td></tr><tr><th id="L561"><a href="#L561">561</a></th><td> * of conditions and the following disclaimer in the documentation and/or other materials</td></tr><tr><th id="L562"><a href="#L562">562</a></th><td> * provided with the distribution.</td></tr><tr><th id="L563"><a href="#L563">563</a></th><td> *</td></tr><tr><th id="L564"><a href="#L564">564</a></th><td> * Neither the name of the author nor the names of contributors may be used to endorse</td></tr><tr><th id="L565"><a href="#L565">565</a></th><td> * or promote products derived from this software without specific prior written permission.</td></tr><tr><th id="L566"><a href="#L566">566</a></th><td> *</td></tr><tr><th id="L567"><a href="#L567">567</a></th><td> * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY</td></tr><tr><th id="L568"><a href="#L568">568</a></th><td> * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF</td></tr><tr><th id="L569"><a href="#L569">569</a></th><td> * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE</td></tr><tr><th id="L570"><a href="#L570">570</a></th><td> * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,</td></tr><tr><th id="L571"><a href="#L571">571</a></th><td> * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE</td></tr><tr><th id="L572"><a href="#L572">572</a></th><td> * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED</td></tr><tr><th id="L573"><a href="#L573">573</a></th><td> * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING</td></tr><tr><th id="L574"><a href="#L574">574</a></th><td> * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED</td></tr><tr><th id="L575"><a href="#L575">575</a></th><td> * OF THE POSSIBILITY OF SUCH DAMAGE.</td></tr><tr><th id="L576"><a href="#L576">576</a></th><td> *</td></tr><tr><th id="L577"><a href="#L577">577</a></th><td> */</td></tr><tr><th id="L578"><a href="#L578">578</a></th><td></td></tr><tr><th id="L579"><a href="#L579">579</a></th><td>})(jQuery);</td></tr></tbody></table>
        </div>
    </div>
    <div id="altlinks">
      <h3>Download in other formats:</h3>
      <ul>
        <li class="last first">
          <a rel="nofollow" href="/raw-attachment/ticket/4324/ui.effects.core-1.7-doublerebel.js">Original Format</a>
        </li>
      </ul>
    </div>
    </div>
    <div id="footer" lang="en" xml:lang="en"><hr />
      <a id="tracpowered" href="http://trac.edgewall.org/"><img src="/chrome/common/trac_logo_mini.png" height="30" width="107" alt="Trac Powered" /></a>
      <p class="left">
        Powered by <a href="/about"><strong>Trac 0.11.1</strong></a><br />
        By <a href="http://www.edgewall.org/">Edgewall Software</a>.
      </p>
      <p class="right"></p>
    </div>
		</div>
	</div>
	<div id="footer">
		<div class="bg"></div>
		<div class="inner">
			<p>
				<span class="first">Sponsored by: </span>
				<a href="http://www.filamentgroup.com" class="block filamentgroup"><span>Filamentgroup</span></a>
				<span style="float: right; padding-right: 12px;" class="first">© 2009 Paul Bakaus and the <a href="/about">jQuery UI Team</a>.</span>
			</p>
		</div>
	</div>
	</div>
</body>
</html>
