File "mojomagnify.js"

Full path: /var/www/vhosts/msproyectoscloud.cl/siadrecursos.msproyectoscloud.cl/RECURSOS/recursos.siadspsminsal.cl/Bipolar/M4/mojomagnify.js
File size: 20.01 KiB (20493 bytes)
MIME-type: text/plain
Charset: utf-8

Download   Open   Back

/*
 * MojoMagnify 0.1.10 - JavaScript Image Magnifier
 * Copyright (c) 2008-2010 Jacob Seidelin, cupboy@gmail.com, http://blog.nihilogic.dk/
 * Licensed under the MPL License [http://www.nihilogic.dk/licenses/mpl-license.txt]
 * Modified  by Fran MacĂ­as 2013 for exelearning.net
 */
/*
 optional css:
 .selectsizeglass{...}
 .selectzoomglass{...}
 .zoomglass{...}
 use:
 <img id="..." src="..." data-magnifysrc="..."  width="n" height="n" data-size="n"  data-zoom="n" />
 */
var MojoMagnify = (function () {
    var dfstyle = 'background:#fff;width:80px;padding:3px;border:1px solid #ccc;height:28px;margin:5px';
    var zommstl = false;

    function withStyle(name) {
        var cssstyle;
        var valor = false;
        var cssstyle;
        for (cssstyle = 0; cssstyle < document.styleSheets.length; cssstyle++) {
            var clcss = new Array();
            if (document.styleSheets[cssstyle].cssRules)
                clcss = document.styleSheets[cssstyle].cssRules
            else if (document.styleSheets[cssstyle].rules)
                clcss = document.styleSheets[cssstyle].rules
            for (var t = 0; t < clcss.length; t++) {
                if (clcss[t].selectorText === name) {
                    valor = true
                }
            }
        }
        return valor;
    };
    var $ = function (id) {
        return document.getElementById(id);
    };
    var dc = function (tag) {
        return document.createElement(tag);
    };

    function isIE8() {
        var vernav = 8;
        var resul = false;
        if (navigator.appName == 'Microsoft Internet Explorer') {
            var data = navigator.userAgent;
            var re = new RegExp("MSIE ([0-9]{1,}[\.0-9]{0,})");
            if (re.exec(data) != null)
                vernav = parseFloat(RegExp.$1);
            if (vernav > 8) resul = true;
        }
        return resul;
    }

    var isIE = !! document.all && !! window.attachEvent && !window.opera;

    var isIE9 = isIE && isIE8();

    var isIE9CompatibilityMode = isIE9 && (navigator.userAgent.indexOf("MSIE 7.0;") > -1);

    function addEvent(element, ev, handler) {
        if (element.addEventListener) {
            element.addEventListener(ev, handler, false);
        } else if (element.attachEvent) {
            element.attachEvent("on" + ev, handler);
        }
    }

    function removeEvent(element, ev, handler) {
        if (element.removeEventListener) {
            element.removeEventListener(ev, handler, false);
        } else if (element.detachEvent) {
            element.detachEvent("on" + ev, handler);
        }
    }

    function getElementPos(element) {
        var x = element.offsetLeft;
        var y = element.offsetTop;
        var parent = element.offsetParent;
        while (parent) {
            x += parent.offsetLeft;
            y += parent.offsetTop;
            parent = parent.offsetParent;
        }
        return {
            x: x,
            y: y
        }
    }

    function getEventMousePos(element, e) {
        var scrollX = document.body.scrollLeft || document.documentElement.scrollLeft;
        var scrollY = document.body.scrollTop || document.documentElement.scrollTop;
        if (e.currentTarget) {
            var pos = getElementPos(element);
            return {
                x: e.clientX - pos.x + scrollX,
                y: e.clientY - pos.y + scrollY
            }
        }
        return {
            x: e.offsetX,
            y: e.offsetY
        }
    }

    function setZoomPos(img, x, y, pos) {
        var zoomImg = img.__mojoMagnifyImage;
        if (!zoomImg) return;
        var full = img.__mojoMagnifyOptions.full;
        img.__mojoMagnifyX = x;
        img.__mojoMagnifyY = y;
        img.__mojoMagnifyPos = pos;
        var zoom = img.__mojoMagnifyZoomer;
        var maskWidth = zoom.offsetWidth;
        var maskHeight = zoom.offsetHeight;
        var imgLeft = img.offsetLeft;
        var imgTop = img.offsetTop;
        var w = img.offsetWidth ? img.offsetWidth : img.naturalWidth;
        var h = img.offsetHeight ? img.offsetHeight : img.naturalHeight;
        if (full) {
            var fx = x / w;
            var fy = y / h;
            var dw = maskWidth - w;
            var dh = maskHeight - h;
            var left = -dw * fx;
            var top = -dh * fy;
        } else {
            var left = pos.x - maskWidth / 2;
            var top = pos.y - maskHeight / 2;
            if (!isIE) {
                left -= imgLeft;
                top -= imgTop;
            }
        }
        zoom.style.left = left + "px";
        zoom.style.top = top + "px";
        var zoomWidth = zoomImg.offsetWidth ? zoomImg.offsetWidth : zoomImg.naturalWidth;
        var zoomHeight = zoomImg.offsetHeight ? zoomImg.offsetHeight : zoomImg.naturalHeight;
        if (full) {
            var zx = 0;
            var zy = 0;
        } else {
            var zoomXRatio = zoomWidth / w;
            var zoomYRatio = zoomHeight / h;
            var zoomX = Math.round(x * zoomXRatio);
            var zoomY = Math.round(y * zoomYRatio);
            var zx = -zoomX + maskWidth / 2;
            var zy = -zoomY + maskHeight / 2;
        }
        zoomImg.style.left = zx + "px";
        zoomImg.style.top = zy + "px";
    }

    function startAnimation(img) {
        var options = img.__mojoMagnifyOptions;
        if (img.__mojoMagnifyAnimTimer) clearTimeout(img.__mojoMagnifyAnimTimer);
        var step = 1;
        var zoom = img.__mojoMagnifyZoomer;
        var zoomImg = img.__mojoMagnifyImage;
        var zoomBorder = img.__mojoMagnifyBorder;
        var imgWidth = img.offsetWidth ? img.offsetWidth : img.naturalWidth;
        var imgHeight = img.offsetHeight ? img.offsetHeight : img.naturalHeight;
        var dw = img.__mojoMagnifyWidth - imgWidth;
        var dh = img.__mojoMagnifyHeight - imgHeight;
        var next = function () {
            var w = imgWidth + dw * (step / 10);
            var h = imgHeight + dh * (step / 10);
            zoomBorder.style.width = w + "px";
            zoomBorder.style.height = h + "px";
            zoom.style.width = w + "px";
            zoom.style.height = h + "px";
            zoomImg.style.width = w + "px";
            zoomImg.style.height = h + "px";
            if (img.__mojoMagnifyPos) {
                setZoomPos(img, img.__mojoMagnifyX, img.__mojoMagnifyY, img.__mojoMagnifyPos);
            }
            if (step < 10) {
                step += 1;
                img.__mojoMagnifyAnimTimer = setTimeout(next, 60);
            } else {
                img.__mojoMagnifyAnimTimer = 0;
            }
        }
        next();
    }

    function makeMagnifiable(img, zoomSrc, opt, zSize, zZoom) {
        // just set the new zoom src if this img already has the Mojo structure setup
        if (img.__mojoMagnifyImage) {
            img.__mojoMagnifyImage.src = zoomSrc;
            return;
        }
        var options = opt || {};
        var zoSize = zSize || 100;
        var zoZoom = zZoom || 1;
        if (zoZoom > 99) zoZoom = zoZoom / 100;
        if (zoSize < 6) zoSize = zoSize * 50;
        img.__mojoMagnifyOptions = options;
        // make sure the image is loaded, if not then add an onload event and return
        if (!img.complete && !img.__mojoMagnifyQueued) {
            addEvent(img, "load", function () {
                img.__mojoMagnifyQueued = true;
                setTimeout(function () {
                    img.__mojoMagnifyImage.width = "3000px";
                    img.__mojoMagnifyImage.height = "3000px";
                    makeMagnifiable(img, zoomSrc);
                }, 1);
            });
            return;
        }
        var w = img.offsetWidth ? img.offsetWidth : img.naturalWidth;
        var h = img.offsetHeight ? img.offsetHeight : img.naturalHeight;
        var oldParent = img.parentNode;

        if (oldParent.nodeName.toLowerCase() != "a") {
            var linkParent = dc("div");
            oldParent.replaceChild(linkParent, img);
            linkParent.appendChild(img);
        } else {
            var linkParent = oldParent;

        }

        linkParent.style.position = "relative";
        linkParent.style.display = "block";
        linkParent.style.width = w + "px";
        linkParent.style.height = h + "px";
        linkParent.style.marginBottom = "40px";
        var imgLeft = img.offsetLeft;
        var imgTop = img.offsetTop;
        var zoom = dc("div");
        zoom.style.position = "absolute";
        zoom.style.width = zoSize + "px";
        zoom.style.height = zoSize + "px";
        zoom.style.overflow = "hidden";
        if (withStyle('.zoomglass') == false) {
            zoom.style.cursor = "none";
            zoom.style.borderWidth = "2px";
            zoom.style.borderStyle = "solid";
            zoom.style.borderColor = "#cccccc";
            zoom.style.boxShadow = "5px 5px 10px #333333";
            zoom.style.borderRadius = (zoSize / 2) + "px"
        } else {
            zoom.className = "zoomglass";
            zommstl = true;
        }
        zoom.style.left = "-9999px";
        var parent = img.parentNode;
        var zoomImg = dc("img");
        zoomImg.style.position = "absolute";
        zoomImg.style.maxWidth = "none";
        zoomImg.style.maxHeight = "none";
        var imgW = img.offsetWidth * zoZoom;
        var imgH = img.offsetHeight * zoZoom;
        zoomImg.style.width = imgW + "px";
        zoomImg.style.height = imgH + "px";

        if (isIE) {
            var zoomLink = dc("a");
            zoomLink.setAttribute("href", linkParent.getAttribute("href"));
            zoomLink.style.position = "absolute";
            zoomLink.style.left = "0px";
            zoomLink.style.top = "0px";
            zoomLink.appendChild(zoomImg);
            zoomLink.style.cursor = 'none';
            zoomLink.onclick = function() { return false; }
            zoom.appendChild(zoomLink);
        } else {
            zoom.appendChild(zoomImg);
        }
        var ctr = dc("div");
        with(ctr.style) {
            position = "absolute";
            left = imgLeft + "px";
            top = imgTop + "px";
            width = w + "px";
            height = h + "px";
            overflow = "hidden";
            display = "block";

        }
        ctr.appendChild(zoom);
        parent.appendChild(ctr);
        var zoomBorder = dc("div");
        zoomBorder.className = "mojomagnify_border";
        zoom.appendChild(zoomBorder);
        var zoomInput = parent;
        // clear old overlay
        if (img.__mojoMagnifyOverlay) parent.removeChild(img.__mojoMagnifyOverlay);
        img.__mojoMagnifyOverlay = ctr;
        // clear old high-res image
        if (img.__mojoMagnifyImage && img.__mojoMagnifyImage.parentNode) img.__mojoMagnifyImage.parentNode.removeChild(img.__mojoMagnifyImage);
        img.__mojoMagnifyImage = zoomImg;
        img.__mojoMagnifyZoomer = zoom;
        img.__mojoMagnifyBorder = zoomBorder;
        var isInImage = false;
        var dvselect = document.createElement("div");
        dvselect.setAttribute('style', 'border:1px solid #cccccc;margin:5px 0 15px 0');
        var modzoom = document.createElement("select");
        modzoom.onclick = changezoom;
        if (withStyle('.selectzoomglass') == false) {
            modzoom.setAttribute('style', dfstyle);
        } else {
            modzoom.className = 'selectzoomglass';
        }
        var stZoom = new Array("x1", "x1.5", "x2", "x2.5", "x3", "x4", "x6");
        var valZoom = new Array(1, 1.5, 2, 2.5, 3, 4, 6);

        for (var i = 0; i < valZoom.length; ++i) {
            modzoom[modzoom.length] = new Option(stZoom[i], valZoom[i]);
        }
        if (zoZoom!='undefined') {
            modzoom[i] = new Option("x" + zoZoom, zoZoom);
            modzoom[i].setAttribute("selected", "selected");
        }
        var sizeGlass = document.createElement("select");
        sizeGlass.onclick = changeglass;
        if (withStyle('.selectsizeglass') == false) {
            sizeGlass.setAttribute('style', dfstyle);
        } else {
            sizeGlass.className = 'selectsizeglass';
        }
        var valGlass = new Array(50, 100, 150, 200, 250, 300, 400);
        var stzoSize = zoSize.toString();
        for (var i = 0; i < valGlass.length; ++i) {
            if (valGlass[i] == stzoSize) {
                sizeGlass[i] = new Option(valGlass[i], valGlass[i]);
                sizeGlass[i].setAttribute("selected", "selected");
            } else {
                sizeGlass[i] = new Option(valGlass[i], valGlass[i]);
            }
        }
        var imax = document.createElement("img");
        imax.src = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAAB3RJTUUH3QoRFDoBieBoSQAAAZ1JREFUOMuFk71qVFEUhb91zj1z70xiMhi9RIIEJJBHsBTEQhEJPoIYJNhplSalnYKtaXwEfQEbsdPGFFaKICRjHH8y6HCdSe7ZFqOJzJ2fVW7Y39l7rX3EkJY21vJ7Kzf2m6GBMV3JcKHd6+jCzCJ5bR4bizCimQGqAPK02X//q/WqHTrlMEDAYSxDnjZXz6ZzCyMnyNP5gw/d1tXUhcq7Xs5etHdO319Z2wauAST5nevux2GXU0mmM7W5ePPcRdvavNsdt3N663ImiMce3F6+srmYNX1R9rPPvYPnWztPXk8yLTgvkBMQMZLzjYUHq7NL/Dz6jZNrsff2DYwPoO6DNLADIVwiT3AJXg4v16czObbUBaEBAMCdBGMAkf3J8Wc+6G8g1TsQRPYmTxBccA6Ff0McAwZ3ceLuOM36tNwtvu/24tFHw/onAECaDshc+Pql19koYt+XFv9fwTCbDnj5aNskdSseeHnqvnbp8cOnmaSRzZ+K9jdJzyqfyQxmfGrLjXy9tLg+qllAUfbeARWAgUmS6r42eX+fFMO1P2nzhjk/kyDRAAAAAElFTkSuQmCC";
        imax.setAttribute('style', 'margin-left:4px;margin-right:-3px;');
        dvselect.appendChild(modzoom);
        dvselect.appendChild(imax);


        dvselect.appendChild(sizeGlass);
        linkParent.appendChild(dvselect);
        if (linkParent.offsetWidth < 140) {
            linkParent.style.marginBottom = "110px";
        } else if (linkParent.offsetWidth < 190) {
            linkParent.style.marginBottom = "90px";
        } else {
            linkParent.style.marginBottom = "50px";
        }

        function changezoom(e) {
            var imgW = img.offsetWidth * this.value;
            var imgH = img.offsetHeight * this.value;
            zoomImg.style.width = imgW + "px";
            zoomImg.style.height = imgH + "px";
        }

        function changeglass(e) {
            zoom.style.width = sizeGlass.value + "px";
            zoom.style.height = sizeGlass.value + "px";
            if (zommstl == false) zoom.style.borderRadius = (sizeGlass.value / 2) + "px"
        }

        function onMouseOut(e) {
            e = e || window.event;
            var target = e.target || e.srcElement;
            if (!target) return;
            if (target.nodeName != "DIV") return;
            var relTarget = e.relatedTarget || e.toElement;
            if (!relTarget) return;
            while (relTarget != target && relTarget.nodeName != "BODY" && relTarget.parentNode) {
                relTarget = relTarget.parentNode;
            }
            if (relTarget != target) {
                isInImage = false;
                ctr.style.display = "none";
            }
        };

        function onMouseMove(e) {
            e = e || window.event;
            var target = e.target || e.srcElement;
            if (isInImage && target.nodeName != 'IMG') {
                ctr.style.display = "none";
            } else {
                isInImage = true;
                ctr.style.display = "block";
                var pos = getEventMousePos(zoomInput, e);

                if (e.srcElement && isIE && (!isIE9 || isIE9CompatibilityMode)) {
                    if (e.srcElement == zoom) return;
                    if (e.srcElement != zoomInput) {
                        var zoomImgPos = getElementPos(e.srcElement);
                        var imgPos = getElementPos(img);
                        pos.x -= (imgPos.x - zoomImgPos.x);
                        pos.y -= (imgPos.y - zoomImgPos.y);
                    }
                }
                var x = e.clientX - (getElementPos(img).x - (document.body.scrollLeft || document.documentElement.scrollLeft));
                var y = e.clientY - (getElementPos(img).y - (document.body.scrollTop || document.documentElement.scrollTop));
                setZoomPos(img, x, y, pos);
            }
        }
        addEvent(zoomImg, "load", function () {
            addEvent(ctr, "mouseout", onMouseOut);
            addEvent(ctr, "mouseleave", onMouseOut);
            if (isIE) {
                addEvent(document.body, "mouseover",

                    function (e) {
                        e = e || window.event;
                        if (isInImage && e.toElement != zoomImg) {
                            ctr.style.display = "none";
                        }
                    });
            }
            // try removing the event first so we don't get multiple handlers firing
            removeEvent(zoomInput, "mousemove", onMouseMove);
            addEvent(zoomInput, "mousemove", onMouseMove);
            if (options.full) {
                var maskWidth = zoomImg.offsetWidth;
                var maskHeight = zoomImg.offsetHeight;
                img.__mojoMagnifyWidth = maskWidth;
                img.__mojoMagnifyHeight = maskHeight;
                zoomBorder.style.width = maskWidth + "px";
                zoomBorder.style.height = maskHeight + "px";
                zoom.style.width = maskWidth + "px";
                zoom.style.height = maskHeight + "px";
            }
            ctr.style.display = "none";
        });
        // I've no idea. Simply setting the src will make IE screw it self into a 100% CPU fest. In a timeout, it's ok.
        setTimeout(function () {
            zoomImg.src = zoomSrc;
        }, 1);
    }

    function setCoords(img, x, y) {
        if (!img.__mojoMagnifyOverlay) return;
        isInImage = true;
        img.__mojoMagnifyOverlay.style.display = "block";
        setZoomPos(img, x, y, {
            x: x,
            y: y
        });
    }

    function init() {
        var images = document.getElementsByTagName("img");
        var imgList = [];
        for (var i = 0; i < images.length; i++) {
            imgList.push(images[i]);
        }
        for (var i = 0; i < imgList.length; i++) {
            var img = imgList[i];
            var zoomSrc = img.getAttribute("data-magnifysrc");
            if (zoomSrc) {
                var opt = {
                    full: img.getAttribute("data-magnifyfull") === "true",
                    animate: img.getAttribute("data-magnifyanimate") === "true"
                };
                var zoomSize = img.getAttribute("data-size") || 100;
                var zoomZoom = img.getAttribute("data-zoom") || 1;
                makeMagnifiable(img, zoomSrc, opt, zoomSize, zoomZoom);
            }
        }
    }
    return {
        addEvent: addEvent,
        init: init,
        makeMagnifiable: makeMagnifiable,
        setCoords: setCoords
    };
})();
// MojoMagnify.addEvent(window, "load", MojoMagnify.init);
// Get the required HTML before init:
$(function(){
    $(".ImageMagnifierIdevice .image-thumbnail").each(function(){
        // From: <img src="" alt="" width="" height="" class="magnifier-size-x magnifier-zoom-y" />
        // To: <img id="magnifier%s" src="" data-magnifysrc="x" width="" height="" data-size="x"  data-zoom="y" />
        var img = this.getElementsByTagName("IMG");
        if (img.length==1) {
            img = img[0];
            var id = this.id.replace("image-thumbnail-","magnifier");
            var w = img.width;
            var h = img.height;
            var c = img.className.split(" ");
            if (c.length==2) {
                var size = c[0].replace("magnifier-size-","");
                var zoom = c[1].replace("magnifier-zoom-","");
            }
            var html = '<img id="'+id+'" src="'+img.src+'" data-magnifysrc="'+img.src+'" width="'+w+'" height="'+h+'" data-size="'+size+'" data-zoom="'+zoom+'" />'
            this.innerHTML = html;
        }
    });
    setTimeout(function(){
        MojoMagnify.init();
    },500);
});