%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /www/varak.net/awstats.varak.net/js/
Upload File :
Create Path :
Current File : /www/varak.net/awstats.varak.net/js/jquery.flot.navigate.js

/*
 Flot plugin for adding panning and zooming capabilities to a plot.

 The default behaviour is double click and scrollwheel up/down to zoom
 in, drag to pan. The plugin defines plot.zoom({ center }),
 plot.zoomOut() and plot.pan(offset) so you easily can add custom
 controls. It also fires a "plotpan" and "plotzoom" event when
 something happens, useful for synchronizing plots.

 Example usage:

 plot = $.plot(...);

 // zoom default amount in on the pixel (100, 200)
 plot.zoom({ center: { left: 10, top: 20 } });

 // zoom out again
 plot.zoomOut();

 // pan 100 pixels to the left and 20 down
 plot.pan({ left: -100, top: 20 })


 Options:

 zoom: {
 interactive: false
 trigger: "dblclick" // or "click" for single click
 amount: 1.5         // 2 = 200% (zoom in), 0.5 = 50% (zoom out)
 }

 pan: {
 interactive: false
 }

 xaxis, yaxis, x2axis, y2axis: {
 zoomRange: null  // or [number, number] (min range, max range)
 panRange: null   // or [number, number] (min, max)
 }

 "interactive" enables the built-in drag/click behaviour. "amount" is
 the amount to zoom the viewport relative to the current range, so 1 is
 100% (i.e. no change), 1.5 is 150% (zoom in), 0.7 is 70% (zoom out).

 "zoomRange" is the interval in which zooming can happen, e.g. with
 zoomRange: [1, 100] the zoom will never scale the axis so that the
 difference between min and max is smaller than 1 or larger than 100.
 You can set either of them to null to ignore.

 "panRange" confines the panning to stay within a range, e.g. with
 panRange: [-10, 20] panning stops at -10 in one end and at 20 in the
 other. Either can be null.
 */


// First two dependencies, jquery.event.drag.js and
// jquery.mousewheel.js, we put them inline here to save people the
// effort of downloading them.

/*
 jquery.event.drag.js ~ v1.5 ~ Copyright (c) 2008, Three Dub Media (http://threedubmedia.com)
 Licensed under the MIT License ~ http://threedubmedia.googlecode.com/files/MIT-LICENSE.txt
 */
(function(E) {
    E.fn.drag = function(L, K, J) {
        if (K) {
            this.bind("dragstart", L)
        }
        if (J) {
            this.bind("dragend", J)
        }
        return !L ? this.trigger("drag") : this.bind("drag", K ? K : L)
    };
    var A = E.event, B = A.special, F = B.drag = {not: ":input", distance: 0, which: 1, dragging: false, setup: function(J) {
            J = E.extend({distance: F.distance, which: F.which, not: F.not}, J || {});
            J.distance = I(J.distance);
            A.add(this, "mousedown", H, J);
            if (this.attachEvent) {
                this.attachEvent("ondragstart", D)
            }
        }, teardown: function() {
            A.remove(this, "mousedown", H);
            if (this === F.dragging) {
                F.dragging = F.proxy = false
            }
            G(this, true);
            if (this.detachEvent) {
                this.detachEvent("ondragstart", D)
            }
        }};
    B.dragstart = B.dragend = {setup: function() {
        }, teardown: function() {
        }};
    function H(L) {
        var K = this, J, M = L.data || {};
        if (M.elem) {
            K = L.dragTarget = M.elem;
            L.dragProxy = F.proxy || K;
            L.cursorOffsetX = M.pageX - M.left;
            L.cursorOffsetY = M.pageY - M.top;
            L.offsetX = L.pageX - L.cursorOffsetX;
            L.offsetY = L.pageY - L.cursorOffsetY
        } else {
            if (F.dragging || (M.which > 0 && L.which != M.which) || E(L.target).is(M.not)) {
                return
            }
        }
        switch (L.type) {
            case"mousedown":
                E.extend(M, E(K).offset(), {elem: K, target: L.target, pageX: L.pageX, pageY: L.pageY});
                A.add(document, "mousemove mouseup", H, M);
                G(K, false);
                F.dragging = null;
                return false;
            case !F.dragging && "mousemove":
                if (I(L.pageX - M.pageX) + I(L.pageY - M.pageY) < M.distance) {
                    break
                }
                L.target = M.target;
                J = C(L, "dragstart", K);
                if (J !== false) {
                    F.dragging = K;
                    F.proxy = L.dragProxy = E(J || K)[0]
                }
            case"mousemove":
                if (F.dragging) {
                    J = C(L, "drag", K);
                    if (B.drop) {
                        B.drop.allowed = (J !== false);
                        B.drop.handler(L)
                    }
                    if (J !== false) {
                        break
                    }
                    L.type = "mouseup"
                }
            case"mouseup":
                A.remove(document, "mousemove mouseup", H);
                if (F.dragging) {
                    if (B.drop) {
                        B.drop.handler(L)
                    }
                    C(L, "dragend", K)
                }
                G(K, true);
                F.dragging = F.proxy = M.elem = false;
                break
        }
        return true
    }
    function C(M, K, L) {
        M.type = K;
        var J = E.event.handle.call(L, M);
        return J === false ? false : J || M.result
    }
    function I(J) {
        return Math.pow(J, 2)
    }
    function D() {
        return(F.dragging === false)
    }
    function G(K, J) {
        if (!K) {
            return
        }
        K.unselectable = J ? "off" : "on";
        K.onselectstart = function() {
            return J
        };
        if (K.style) {
            K.style.MozUserSelect = J ? "" : "none"
        }
    }}
)(jQuery);


/* jquery.mousewheel.min.js
 * Copyright (c) 2009 Brandon Aaron (http://brandonaaron.net)
 * Dual licensed under the MIT (http://www.opensource.org/licenses/mit-license.php)
 * and GPL (http://www.opensource.org/licenses/gpl-license.php) licenses.
 * Thanks to: http://adomas.org/javascript-mouse-wheel/ for some pointers.
 * Thanks to: Mathias Bank(http://www.mathias-bank.de) for a scope bug fix.
 *
 * Version: 3.0.2
 *
 * Requires: 1.2.2+
 */
(function(c) {
    var a = ["DOMMouseScroll", "mousewheel"];
    c.event.special.mousewheel = {setup: function() {
            if (this.addEventListener) {
                for (var d = a.length; d; ) {
                    this.addEventListener(a[--d], b, false)
                }
            } else {
                this.onmousewheel = b
            }
        }, teardown: function() {
            if (this.removeEventListener) {
                for (var d = a.length; d; ) {
                    this.removeEventListener(a[--d], b, false)
                }
            } else {
                this.onmousewheel = null
            }
        }};
    c.fn.extend({mousewheel: function(d) {
            return d ? this.bind("mousewheel", d) : this.trigger("mousewheel")
        }, unmousewheel: function(d) {
            return this.unbind("mousewheel", d)
        }});
    function b(f) {
        var d = [].slice.call(arguments, 1), g = 0, e = true;
        f = c.event.fix(f || window.event);
        f.type = "mousewheel";
        if (f.wheelDelta) {
            g = f.wheelDelta / 120
        }
        if (f.detail) {
            g = -f.detail / 3
        }
        d.unshift(f, g);
        return c.event.handle.apply(this, d)
    }}
)(jQuery);




(function($) {
    var options = {
        xaxis: {
            zoomRange: null, // or [number, number] (min range, max range)
            panRange: null // or [number, number] (min, max)
        },
        zoom: {
            interactive: false,
            trigger: "dblclick", // or "click" for single click
            amount: 1.5 // how much to zoom relative to current position, 2 = 200% (zoom in), 0.5 = 50% (zoom out)
        },
        pan: {
            interactive: false
        }
    };

    function init(plot) {
        var prevPoint = null;

        function bindEvents(plot, eventHolder) {
            var o = plot.getOptions();
            if (o.zoom.interactive) {
                function clickHandler(e) {
                    prevPoint = plot.offset();
                    prevPoint.left = e.pageX - prevPoint.left;
                    prevPoint.top = e.pageY - prevPoint.top;
                    plot.zoom({center: prevPoint});
                }

                eventHolder[o.zoom.trigger](clickHandler);

                eventHolder.mousewheel(function(e, delta) {
                    if (delta > 0)
                        clickHandler(e);
                    else
                        plot.zoomOut();
                });
            }
            if (o.pan.interactive) {
                var prevCursor = 'default', pageX = 0, pageY = 0;

                eventHolder.bind("dragstart", {distance: 10}, function(e) {
                    if (e.which != 1)  // only accept left-click
                        return false;
                    eventHolderCursor = eventHolder.css('cursor');
                    eventHolder.css('cursor', 'move');
                    pageX = e.pageX;
                    pageY = e.pageY;
                });
                eventHolder.bind("drag", function(e) {
                    // unused at the moment, but we need it here to
                    // trigger the dragstart/dragend events
                });
                eventHolder.bind("dragend", function(e) {
                    eventHolder.css('cursor', prevCursor);
                    plot.pan({left: pageX - e.pageX,
                        top: pageY - e.pageY});
                });
            }
        }

        plot.zoomOut = function() {
            plot.zoom({amount: 1 / plot.getOptions().zoom.amount});
            prevPoint = null;
        }

        plot.zoom = function(args) {
            var axes = plot.getAxes(),
                    options = plot.getOptions(),
                    c = args.center ? args.center : prevPoint,
                    amount = args.amount ? args.amount : options.zoom.amount,
                    w = plot.width(), h = plot.height();

            if (!c)
                c = {left: w / 2, top: h / 2};

            var xf = c.left / w,
                    x1 = c.left - xf * w / amount,
                    x2 = c.left + (1 - xf) * w / amount,
                    yf = c.top / h,
                    y1 = c.top - yf * h / amount,
                    y2 = c.top + (1 - yf) * h / amount;

            function scaleAxis(min, max, name) {
                var axis = axes[name],
                        axisOptions = options[name];

                if (!axis.used)
                    return;

                min = axis.c2p(min);
                max = axis.c2p(max);
                if (max < min) { // make sure min < max
                    var tmp = min
                    min = max;
                    max = tmp;
                }

                var range = max - min, zr = axisOptions.zoomRange;
                if (zr &&
                        ((zr[0] != null && range < zr[0]) ||
                                (zr[1] != null && range > zr[1])))
                    return;

                axisOptions.min = min;
                axisOptions.max = max;
            }

            scaleAxis(x1, x2, 'xaxis');
            scaleAxis(x1, x2, 'x2axis');
            scaleAxis(y1, y2, 'yaxis');
            scaleAxis(y1, y2, 'y2axis');

            plot.setupGrid();
            plot.draw();

            if (!args.preventEvent)
                plot.getPlaceholder().trigger("plotzoom", [plot]);
        }

        plot.pan = function(args) {
            var l = +args.left, t = +args.top,
                    axes = plot.getAxes(), options = plot.getOptions();

            if (isNaN(l))
                l = 0;
            if (isNaN(t))
                t = 0;

            function panAxis(delta, name) {
                var axis = axes[name],
                        axisOptions = options[name],
                        min, max;

                if (!axis.used)
                    return;

                min = axis.c2p(axis.p2c(axis.min) + delta),
                        max = axis.c2p(axis.p2c(axis.max) + delta);

                var pr = axisOptions.panRange;
                if (pr) {
                    // check whether we hit the wall
                    if (pr[0] != null && pr[0] > min) {
                        delta = pr[0] - min;
                        min += delta;
                        max += delta;
                    }

                    if (pr[1] != null && pr[1] < max) {
                        delta = pr[1] - max;
                        min += delta;
                        max += delta;
                    }
                }

                axisOptions.min = min;
                axisOptions.max = max;
            }

            panAxis(l, 'xaxis');
            panAxis(l, 'x2axis');
            panAxis(t, 'yaxis');
            panAxis(t, 'y2axis');

            plot.setupGrid();
            plot.draw();

            if (!args.preventEvent)
                plot.getPlaceholder().trigger("plotpan", [plot]);
        }

        plot.hooks.bindEvents.push(bindEvents);
    }

    $.plot.plugins.push({
        init: init,
        options: options,
        name: 'navigate',
        version: '1.0'
    });
})(jQuery);

Zerion Mini Shell 1.0