/**
 * jQuery.ScrollTo - Easy element scrolling using jQuery.
 * Copyright (c) 2007-2008 Ariel Flesler - aflesler(at)gmail(dot)com | http://flesler.blogspot.com
 * Dual licensed under MIT and GPL.
 * Date: 9/11/2008
 * @author Ariel Flesler
 * @version 1.4
 *
 * http://flesler.blogspot.com/2007/10/jqueryscrollto.html
 */

(function(h){
    var m = h.scrollTo = function(b, c, g){
        h(window).scrollTo(b, c, g)
    };
    m.defaults = {
        axis: 'y',
        duration: 1
    };
    m.window = function(b){
        return h(window).scrollable()
    };
    h.fn.scrollable = function(){
        return this.map(function(){
            var b = this.parentWindow || this.defaultView, c = this.nodeName == '#document' ? b.frameElement || b : this, g = c.contentDocument || (c.contentWindow || c).document, i = c.setInterval;
            return c.nodeName == 'IFRAME' || i && h.browser.safari ? g.body : i ? g.documentElement : this
        })
    };
    h.fn.scrollTo = function(r, j, a){
        if (typeof j == 'object') {
            a = j;
            j = 0
        }
        if (typeof a == 'function') 
            a = {
                onAfter: a
            };
        a = h.extend({}, m.defaults, a);
        j = j || a.speed || a.duration;
        a.queue = a.queue && a.axis.length > 1;
        if (a.queue) 
            j /= 2;
        a.offset = n(a.offset);
        a.over = n(a.over);
        return this.scrollable().each(function(){
            var k = this, o = h(k), d = r, l, e = {}, p = o.is('html,body');
            switch (typeof d) {
                case 'number':
                case 'string':
                    if (/^([+-]=)?\d+(px)?$/.test(d)) {
                        d = n(d);
                        break
                    }
                    d = h(d, this);
                case 'object':
                    if (d.is || d.style) 
                        l = (d = h(d)).offset()
            }
            h.each(a.axis.split(''), function(b, c){
                var g = c == 'x' ? 'Left' : 'Top', i = g.toLowerCase(), f = 'scroll' + g, s = k[f], t = c == 'x' ? 'Width' : 'Height', v = t.toLowerCase();
                if (l) {
                    e[f] = l[i] + (p ? 0 : s - o.offset()[i]);
                    if (a.margin) {
                        e[f] -= parseInt(d.css('margin' + g)) || 0;
                        e[f] -= parseInt(d.css('border' + g + 'Width')) || 0
                    }
                    e[f] += a.offset[i] || 0;
                    if (a.over[i]) 
                        e[f] += d[v]() * a.over[i]
                }
                else 
                    e[f] = d[i];
                if (/^\d+$/.test(e[f])) 
                    e[f] = e[f] <= 0 ? 0 : Math.min(e[f], u(t));
                if (!b && a.queue) {
                    if (s != e[f]) 
                        q(a.onAfterFirst);
                    delete e[f]
                }
            });
            q(a.onAfter);
            function q(b){
                o.animate(e, j, a.easing, b &&
                function(){
                    b.call(this, r, a)
                })
            };
            function u(b){
                var c = 'scroll' + b, g = k.ownerDocument;
                return p ? Math.max(g.documentElement[c], g.body[c]) : k[c]
            }
        }).end()
    };
    function n(b){
        return typeof b == 'object' ? b : {
            top: b,
            left: b
        }
    }
})(jQuery);
