/*
* jQuery Tools 1.2.1 - The missing UI library for the Web
*
* [scrollable, scrollable.autoscroll, scrollable.navigator, overlay]
*
* NO COPYRIGHTS OR LICENSES. DO WHAT YOU LIKE.
*
* http://flowplayer.org/tools/
*
* File generated: Fri May 14 18:17:25 GMT 2010
*/
(function (e) {
    function n(f, c) {
        var a = e(c);
        return a.length < 2 ? a : f.parent().find(c)
    }
    function t(f, c) {
        var a = this,
            k = f.add(a),
            g = f.children(),
            l = 0,
            m = c.vertical;
        j || (j = a);
        if (g.length > 1) g = e(c.items, f);
        e.extend(a, {
            getConf: function () {
                return c
            },
            getIndex: function () {
                return l
            },
            getSize: function () {
                return a.getItems().size()
            },
            getNaviButtons: function () {
                return o.add(p)
            },
            getRoot: function () {
                return f
            },
            getItemWrap: function () {
                return g
            },
            getItems: function () {
                return g.children(c.item).not("." + c.clonedClass)
            },
            move: function (b, d) {
                return a.seekTo(l + b, d)
            },
            next: function (b) {
                return a.move(1, b)
            },
            prev: function (b) {
                return a.move(-1, b)
            },
            begin: function (b) {
                return a.seekTo(0, b)
            },
            end: function (b) {
                return a.seekTo(a.getSize() - 1, b)
            },
            focus: function () {
                return j = a
            },
            addItem: function (b) {
                b = e(b);
                if (c.circular) {
                    e(".cloned:last").before(b);
                    e(".cloned:first").replaceWith(b.clone().addClass(c.clonedClass))
                } else g.append(b);
                k.trigger("onAddItem", [b]);
                return a
            },
            seekTo: function (b, d, h) {
                if (!c.circular && b < 0 || b > a.getSize()) return a;
                var i = b;
                if (b.jquery) b = a.getItems().index(b);
                else i = a.getItems().eq(b);
                var q = e.Event("onBeforeSeek");
                if (!h) {
                    k.trigger(q, [b, d]);
                    if (q.isDefaultPrevented() || !i.length) return a
                }
                i = m ? {
                    top: -i.position().top
                } : {
                    left: -i.position().left
                };
                l = b;
                j = a;
                g.animate(i, d, c.easing, h ||
                function () {
                    k.trigger("onSeek", [b])
                });
                return a
            }
        });
        e.each(["onBeforeSeek", "onSeek", "onAddItem"], function (b, d) {
            e.isFunction(c[d]) && e(a).bind(d, c[d]);
            a[d] = function (h) {
                e(a).bind(d, h);
                return a
            }
        });
        if (c.circular) {
            var r = a.getItems().slice(-1).clone().prependTo(g),
                s = a.getItems().eq(1).clone().appendTo(g);
            r.add(s).addClass(c.clonedClass);
            a.onBeforeSeek(function (b, d, h) {
                if (!b.isDefaultPrevented()) if (d == -1) {
                    a.seekTo(r, h, function () {
                        a.end(0)
                    });
                    return b.preventDefault()
                } else d == a.getSize() && a.seekTo(s, h, function () {
                    a.begin(0)
                })
            });
            a.seekTo(0, 0)
        }
        var o = n(f, c.prev).click(function () {
            a.prev()
        }),
            p = n(f, c.next).click(function () {
                a.next()
            });
        !c.circular && a.getSize() > 1 && a.onBeforeSeek(function (b, d) {
            o.toggleClass(c.disabledClass, d <= 0);
            p.toggleClass(c.disabledClass, d >= a.getSize() - 1)
        });
        c.mousewheel && e.fn.mousewheel && f.mousewheel(function (b, d) {
            if (c.mousewheel) {
                a.move(d < 0 ? 1 : -1, c.wheelSpeed || 50);
                return false
            }
        });
        c.keyboard && e(document).bind("keydown.scrollable", function (b) {
            if (!(!c.keyboard || b.altKey || b.ctrlKey || e(b.target).is(":input"))) if (!(c.keyboard != "static" && j != a)) {
                var d = b.keyCode;
                if (m && (d == 38 || d == 40)) {
                    a.move(d == 38 ? -1 : 1);
                    return b.preventDefault()
                }
                if (!m && (d == 37 || d == 39)) {
                    a.move(d == 37 ? -1 : 1);
                    return b.preventDefault()
                }
            }
        });
        e(a).trigger("onBeforeSeek", [c.initialIndex])
    }
    e.tools = e.tools || {
        version: "1.2.1"
    };
    e.tools.scrollable = {
        conf: {
            activeClass: "active",
            circular: false,
            clonedClass: "cloned",
            disabledClass: "disabled",
            easing: "swing",
            initialIndex: 0,
            item: null,
            items: ".items",
            keyboard: true,
            mousewheel: false,
            next: ".next",
            prev: ".prev",
            speed: 400,
            vertical: false,
            wheelSpeed: 0
        }
    };
    var j;
    e.fn.scrollable = function (f) {
        var c = this.data("scrollable");
        if (c) return c;
        f = e.extend({}, e.tools.scrollable.conf, f);
        this.each(function () {
            c = new t(e(this), f);
            e(this).data("scrollable", c)
        });
        return f.api ? c : this
    }
})(jQuery);
(function (c) {
    var g = c.tools.scrollable;
    g.autoscroll = {
        conf: {
            autoplay: true,
            interval: 3E3,
            autopause: true
        }
    };
    c.fn.autoscroll = function (d) {
        if (typeof d == "number") d = {
            interval: d
        };
        var b = c.extend({}, g.autoscroll.conf, d),
            h;
        this.each(function () {
            var a = c(this).data("scrollable");
            if (a) h = a;
            var e, i, f = true;
            a.play = function () {
                if (!e) {
                    f = false;
                    e = setInterval(function () {
                        a.next()
                    }, b.interval);
                    a.next()
                }
            };
            a.pause = function () {
                e = clearInterval(e)
            };
            a.stop = function () {
                a.pause();
                f = true
            };
            b.autopause && a.getRoot().add(a.getNaviButtons()).hover(function () {
                a.pause();
                clearInterval(i)
            }, function () {
                f || (i = setTimeout(a.play, b.interval))
            });
            b.autoplay && setTimeout(a.play, b.interval)
        });
        return b.api ? h : this
    }
})(jQuery);
(function (d) {
    function p(c, g) {
        var h = d(g);
        return h.length < 2 ? h : c.parent().find(g)
    }
    var m = d.tools.scrollable;
    m.navigator = {
        conf: {
            navi: ".navi",
            naviItem: null,
            activeClass: "active",
            indexed: false,
            idPrefix: null,
            history: false
        }
    };
    d.fn.navigator = function (c) {
        if (typeof c == "string") c = {
            navi: c
        };
        c = d.extend({}, m.navigator.conf, c);
        var g;
        this.each(function () {
            function h(a, b, i) {
                e.seekTo(b);
                if (j) {
                    if (location.hash) location.hash = a.attr("href").replace("#", "")
                } else return i.preventDefault()
            }
            function f() {
                return k.find(c.naviItem || "> *")
            }
            function n(a) {
                var b = d("<" + (c.naviItem || "a") + "/>").click(function (i) {
                    h(d(this), a, i)
                }).attr("href", "#" + a);
                a === 0 && b.addClass(l);
                c.indexed && b.text(a + 1);
                c.idPrefix && b.attr("id", c.idPrefix + a);
                return b.appendTo(k)
            }
            function o(a, b) {
                a = f().eq(b.replace("#", ""));
                a.length || (a = f().filter("[href=" + b + "]"));
                a.click()
            }
            var e = d(this).data("scrollable"),
                k = p(e.getRoot(), c.navi),
                q = e.getNaviButtons(),
                l = c.activeClass,
                j = c.history && d.fn.history;
            if (e) g = e;
            e.getNaviButtons = function () {
                return q.add(k)
            };
            f().length ? f().each(function (a) {
                d(this).click(function (b) {
                    h(d(this), a, b)
                })
            }) : d.each(e.getItems(), function (a) {
                n(a)
            });
            e.onBeforeSeek(function (a, b) {
                var i = f().eq(b);
                !a.isDefaultPrevented() && i.length && f().removeClass(l).eq(b).addClass(l)
            });
            e.onAddItem(function (a, b) {
                b = n(e.getItems().index(b));
                j && b.history(o)
            });
            j && f().history(o)
        });
        return c.api ? g : this
    }
})(jQuery);
(function (a) {
    function t(d, b) {
        var c = this,
            i = d.add(c),
            o = a(window),
            k, f, m, g = a.tools.expose && (b.mask || b.expose),
            n = Math.random().toString().slice(10);
        if (g) {
            if (typeof g == "string") g = {
                color: g
            };
            g.closeOnClick = g.closeOnEsc = false
        }
        var p = b.target || d.attr("rel");
        f = p ? a(p) : d;
        if (!f.length) throw "Could not find Overlay: " + p;
        d && d.index(f) == -1 && d.click(function (e) {
            c.load(e);
            return e.preventDefault()
        });
        a.extend(c, {
            load: function (e) {
                if (c.isOpened()) return c;
                var h = q[b.effect];
                if (!h) throw 'Overlay: cannot find effect : "' + b.effect + '"';
                b.oneInstance && a.each(s, function () {
                    this.close(e)
                });
                e = e || a.Event();
                e.type = "onBeforeLoad";
                i.trigger(e);
                if (e.isDefaultPrevented()) return c;
                m = true;
                g && a(f).expose(g);
                var j = b.top,
                    r = b.left,
                    u = f.outerWidth({
                        margin: true
                    }),
                    v = f.outerHeight({
                        margin: true
                    });
                if (typeof j == "string") j = j == "center" ? Math.max((o.height() - v) / 2, 0) : parseInt(j, 10) / 100 * o.height();
                if (r == "center") r = Math.max((o.width() - u) / 2, 0);
                h[0].call(c, {
                    top: j,
                    left: r
                }, function () {
                    if (m) {
                        e.type = "onLoad";
                        i.trigger(e)
                    }
                });
                g && b.closeOnClick && a.mask.getMask().one("click", c.close);
                b.closeOnClick && a(document).bind("click." + n, function (l) {
                    a(l.target).parents(f).length || c.close(l)
                });
                b.closeOnEsc && a(document).bind("keydown." + n, function (l) {
                    l.keyCode == 27 && c.close(l)
                });
                return c
            },
            close: function (e) {
                if (!c.isOpened()) return c;
                e = e || a.Event();
                e.type = "onBeforeClose";
                i.trigger(e);
                if (!e.isDefaultPrevented()) {
                    m = false;
                    q[b.effect][1].call(c, function () {
                        e.type = "onClose";
                        i.trigger(e)
                    });
                    a(document).unbind("click." + n).unbind("keydown." + n);
                    g && a.mask.close();
                    return c
                }
            },
            getOverlay: function () {
                return f
            },
            getTrigger: function () {
                return d
            },
            getClosers: function () {
                return k
            },
            isOpened: function () {
                return m
            },
            getConf: function () {
                return b
            }
        });
        a.each("onBeforeLoad,onStart,onLoad,onBeforeClose,onClose".split(","), function (e, h) {
            a.isFunction(b[h]) && a(c).bind(h, b[h]);
            c[h] = function (j) {
                a(c).bind(h, j);
                return c
            }
        });
        k = f.find(b.close || ".close");
        if (!k.length && !b.close) {
            k = a('<div class="close"></div>');
            f.prepend(k)
        }
        k.click(function (e) {
            c.close(e)
        });
        b.load && c.load()
    }
    a.tools = a.tools || {
        version: "1.2.1"
    };
    a.tools.overlay = {
        addEffect: function (d, b, c) {
            q[d] = [b, c]
        },
        conf: {
            close: null,
            closeOnClick: true,
            closeOnEsc: true,
            closeSpeed: "fast",
            effect: "default",
            fixed: !a.browser.msie || a.browser.version > 6,
            left: "center",
            load: false,
            mask: null,
            oneInstance: true,
            speed: "normal",
            target: null,
            top: "10%"
        }
    };
    var s = [],
        q = {};
    a.tools.overlay.addEffect("default", function (d, b) {
        var c = this.getConf(),
            i = a(window);
        if (!c.fixed) {
            d.top += i.scrollTop();
            d.left += i.scrollLeft()
        }
        d.position = c.fixed ? "fixed" : "absolute";
        this.getOverlay().css(d).fadeIn(c.speed, b)
    }, function (d) {
        this.getOverlay().fadeOut(this.getConf().closeSpeed, d)
    });
    a.fn.overlay = function (d) {
        var b = this.data("overlay");
        if (b) return b;
        if (a.isFunction(d)) d = {
            onBeforeLoad: d
        };
        d = a.extend(true, {}, a.tools.overlay.conf, d);
        this.each(function () {
            b = new t(a(this), d);
            s.push(b);
            a(this).data("overlay", b)
        });
        return d.api ? b : this
    }
})(jQuery);
