﻿(function ($) {

    /**
     * 并行加载指定的脚本
     * 并行加载[同步]同时加载，不管上个是否加载完成，直接加载全部
     * 全部加载完成后执行回调
     * @param {Array|String} scripts 指定要加载的脚本
     * @param {Function} callback 成功后回调的函数
     */
    var parallelLoadScripts = function parallelLoadScripts(scripts, callback) {
        if (typeof (scripts) !== 'object') {
            scripts = [{ "url": scripts, "id": randomWord(true, 5, 8) }];
        }
        var HEAD = document.getElementsByTagName('head')[0] || document.documentElement;
        var s = [];
        var loaded = 0;
        for (var i = 0; i < scripts.length; i++) {
            if (document.getElementById(scripts[i].name)) {
                loaded++;
                if (loaded === scripts.length && typeof (callback) === 'function') callback();
                continue;
            }

            s[i] = document.createElement('script');
            s[i].setAttribute('type', 'text/javascript');
            s[i].setAttribute('id', scripts[i].name);
            // 同步
            s[i].setAttribute('src', scripts[i].url);
            HEAD.appendChild(s[i]);

            // 异步
            s[i].onload = s[i].onreadystatechange = function () {
                if (! /*@cc_on!@*/ 0 || this.readyState === 'loaded' || this.readyState === 'complete') {
                    loaded++;
                    if (loaded === scripts.length && typeof (callback) === 'function') callback();
                }
            };

        }
    };

    //加载css样式
    var loadCssContent = function loadCssContent(renderTo, id, cssContent) {

        if (cssContent && cssContent !== '' && $(id).length === 0) {
            renderTo = (typeof renderTo == 'string') ? $(renderTo) : renderTo;
            var css = " <style id=\"" + id + "\" type=\"text/css\">";
            css += cssContent;
            css += "</style>";
            renderTo.append(css);
        }

    };

    //Js模拟休息
    var sleep = function sleep(numberMillis) {
        var now = new Date();
        var exitTime = now.getTime() + numberMillis;
        while (true) {
            now = new Date();
            if (now.getTime() > exitTime)
                return;
        }
    };

    //查找对象在数组中的位置 jquery.inArray不能查找对象
    //没有返回-1，如果有返回第一次匹配到数组位置
    var objectInArray = function objectInArray(anObject, objectArr) {

        if ($.isArray(objectArr)) {
            for (var i = 0; i < objectArr.length; i++) {
                var isEquals = true;
                $.each(anObject, function (name, value) {
                    if (objectArr[i][name] != value) {
                        isEquals = false;
                        return;
                    }
                });

                if (isEquals) {
                    return i;
                }
            }
        }
        return -1;
    };

        /*
    ** randomWord 产生任意长度随机字母数字组合
    ** randomFlag-是否任意长度 min-任意长度最小位[固定位数] max-任意长度最大位
    */
    var randomWord = function randomWord(randomFlag, min, max) {
        var str = "",
            range = min,
            arr = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'];
        // 随机产生
        if (randomFlag) {
            range = Math.round(Math.random() * (max - min)) + min;
        }
        for (var i = 0; i < range; i++) {
            pos = Math.round(Math.random() * (arr.length - 1));
            str += arr[pos];
        }
        return str;
    };

    //默认参数
    var defaluts = {
        renderTo: null, //追加的位置
        id: null, /* 在页面中的唯一id，如果为null则自动生成随机id,一个id只会显示一个 */
        top: "200px", /* 窗口离顶部的距离,可以是百分比或像素(如 '100px')  0标识居中显示 */
        opacity: 0.5, /* 窗口隔离层的透明度,如果设置为0,则不显示隔离层 */
        //showType: 'fade', /* 窗口显示的类型,可选值有:show、fade、slide、fly */
        //showSpeed: 1000, /* 窗口显示的速度,可选值有:'slow'、'fast'、表示毫秒的整数 */
        showClose: true, /* 是否显示窗口右上角的关闭按钮 */
        draggable: false, /* 是否可以拖动窗口 */
        data: {
            id: "",
            url: 'http://h5.deiyoudian.com/jycccc'
        }, /*数据*/
        showPage: false, //是否展示分页
        pageData: [], //翻页数据
        width: 800, /* 窗口的宽度，值为'auto'或表示像素的整数 */
        height: 710, /* 窗口的高度，值为'auto'或表示像素的整数 */
        buttons: [{
            text: "复制链接",
            className: "primary", //系统默认样式
            style: "", //自定义样式
            autoClose: false,
            initFunc: function (self) { //初始化事件
                if (self) {
                    self.attr("id", randomWord(true,5,8)); //设置名称
                    self.attr("data-clipboard-text", "hello preview!");

                    parallelLoadScripts([{ "name": "clipboard", "url": "https://cdn.bootcss.com/clipboard.js/2.0.1/clipboard.js" }], function () {
                        var clipboard = new ClipboardJS("#" + self.attr("id"), { //先实例化
                            // 点击copy按钮，直接通过text直接返回复印的内容
                            text: function () {
                                sleep(300);
                                return self.attr("data-clipboard-text");

                            }
                        });

                        clipboard.on('success', function (e) {
                            alert('复制成功');　　//复制成功区间
                        });

                        clipboard.on('error', function (e) {

                        });
                    });
                }
            },
            clickFunc: function (self, data) { //点击事件

                if (data.url && self) {
                    self.attr("data-clipboard-text", data.url);
                }
            }
        }], /* 窗口的按钮 */
        closed: function (data) { } /* 窗口关闭后执行的函数 */
    };

    $.extend($, {
        preview: function (setting) {
            var ps = $.extend(defaluts, setting);

            if (ps.data === null || ps.data.url === null || ps.data.url === undefined) {
                alert('data参数错误，无法预览');
            }

            var css = ".preview-modal-mask{position:fixed;top:0;bottom:0;left:0;right:0;background-color:rgba(55,55,55);height:100%;z-index:1000;display:none;}.preview-modal-wrap{position:fixed;overflow:auto;top:0;right:0;bottom:0;left:0;z-index:1000;-webkit-overflow-scrolling:touch;outline:0}.preview-modal-wrap *{box-sizing:border-box;-webkit-tap-highlight-color:transparent}.page-maskingLayer .close::after,.page-maskingLayer .close::before{content:'';position:absolute;height:2px;width:100%;top:50%;left:0;margin-top:-1px;background:#000}.page-maskingLayer .close.rounded::after,.page-maskingLayer .close.rounded::before{border-radius:5px}.page-maskingLayer .close::before{-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);-o-transform:rotate(45deg);transform:rotate(45deg)}.page-maskingLayer .close::after{-webkit-transform:rotate(-45deg);-moz-transform:rotate(-45deg);-ms-transform:rotate(-45deg);-o-transform:rotate(-45deg);transform:rotate(-45deg)}.preview-modal{width:auto;margin:0 auto;position:relative;outline:0;top:100px}.preview-modal-content{position:relative;background-color:#fff;border:0;border-radius:6px;background-clip:padding-box;height:100%;box-shadow:0 4px 12px rgba(0,0,0,.15)}.preview-modal-close{z-index:1;font-size:12px;position:absolute;right:20px;top:15px;overflow:hidden;cursor:pointer;width: 20px;height: 20px;display:none;}.page-maskingLayer .preview-modal-body{padding:0;height:100%}.preview-modal-body{padding:16px;font-size:12px;line-height:1.5}.page-maskingLayer .maskingLayer_div .lf{background:#f4f4f4;position:relative;width:50%;height:100%;float:left}.page-maskingLayer .maskingLayer_div .lf .arrow{position:absolute;top:50%;width:2rem;height:2rem;border-top:.3rem solid #dcdcdc;border-right:.3rem solid #dcdcdc;box-shadow:0 0 0 #d3d3d3;-webkit-transition:all .2s ease;transition:all .2s ease;display:none}.page-maskingLayer .maskingLayer_div .lf .arrow.left{left:25px;-webkit-transform:translate3d(0,-50%,0) rotate(-135deg);transform:translate3d(0,-50%,0) rotate(-135deg)}.page-maskingLayer .maskingLayer_div .lf .arrow.right{right:25px;-webkit-transform:translate3d(0,-50%,0) rotate(45deg);transform:translate3d(0,-50%,0) rotate(45deg)}.page-maskingLayer .maskingLayer_div .lf .arrow:hover{border-top: 0.3rem solid #bfbfbf; border-right: 0.3rem solid #bfbfbf;}.page-maskingLayer .maskingLayer_div .lf .wechat-head{width:350px;height:60px;background:url('');background-position:50%;background-size:100%;border-bottom:1px solid #e5e5e5;position:absolute;left:50px;top:20px}.page-maskingLayer .maskingLayer_iframe{width:350px;height:606px;position:absolute;left:50px;top:80px;z-index:2;border-radius:5px;z-index:1001}.page-maskingLayer .maskingLayer_div{height:100%;}.page-maskingLayer .maskingLayer_div .lr{width:50%;height:100%;background:#fff;float:left}.page-maskingLayer.has-pageing .maskingLayer_div .lf{width:60%}.page-maskingLayer.has-pageing .maskingLayer_div .lr{width:40%}.page-maskingLayer .maskingLayer_div .lr .con{width:80%;position:relative;top:40%;margin:auto;-webkit-transform:translateY(-40%);transform:translateY(-40%)}.page-maskingLayer .maskingLayer_div .lr .link-qrcode{width:210px;height:210px;margin:auto;}.page-maskingLayer .maskingLayer_div .lr .link-qrcode .qrcode{width:100%;height:100%}.page-maskingLayer .maskingLayer_div .lr .con .btns{text-align:center}.page-maskingLayer .maskingLayer_div .lr .con .btns button{margin:5px}.page-maskingLayer .maskingLayer_div .lr .con .link-txt{background-color:#f5f7f9;min-width:210px;margin: 25px auto 10px;text-align:center;min-height:28px;line-height:28px;padding-left:8px;padding-right:8px;overflow:hidden;text-overflow:ellipsis;font-family:MicrosoftYaHei;font-weight:400;word-break:break-all}.preview-btn.primary{color:#fff;background-color:#2d8cf0;border-color:#2d8cf0}.preview-btn{display:inline-block;margin-bottom:0;font-weight:400;text-align:center;touch-action:manipulation;cursor:pointer;background-image:none;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;padding:5px 15px 6px;font-size:12px;border-radius:4px;transition:color .2s linear,background-color .2s linear,border .2s linear,box-shadow .2s linear;color:#515a6e;background-color:#fff;border:1px solid #dcdee2}.text-center{text-align:center;}";

            if (ps.renderTo) {  //追加位置
                ps.renderTo = (typeof ps.renderTo == 'string' ? $(ps.renderTo) : ps.renderTo);
            }
            else {
                ps.renderTo = $(document.body);
            }

            //加载css样式
            loadCssContent(ps.renderTo, "h5-preview", css);

            ps.id = ps.id == null ? randomWord(true, 5, 8) : ps.id;
            var $preview_window = $("" + ps.id + "");
            if ($preview_window.length < 1) {
                $preview_window = $("<div id='" + ps.id + "' class='page-maskingLayer v-transfer-dom " + (ps.showPage == true ? "has-pageing" : "") + "'><div class='preview-modal-mask'></div><div class='preview-modal-wrap'><div class='preview-modal'><div class='preview-modal-content'><a class='preview-modal-close'><i class='close rounded'></i></a><div class='preview-modal-body'><div class='maskingLayer_div clearfix'><div class='lf'><a href='javascript:void(0)' title='上一个' class='arrow left'></a><a href='javascript:void(0)' title='下一个' class='arrow right'></a><div class='wechat-head'></div><div class='maskingLayer_iframe'></div></div><div class='lr'><div class='con'><div class='link-qrcode'><div class='qrcode-preview' style='width:210px;height:210px;'></div><div class='text-center'>请使用手机扫码查看</div></div><div class='link-txt'></div><div class='btns text-center'></div></div></div></div></div></div></div></div></div>").appendTo(ps.renderTo);
            }

            var $preview_window_modal = $preview_window.find(".preview-modal");

            if (ps.opacity > 0) { //遮罩层
                $preview_window.find(".preview-modal-mask").css("opacity", ps.opacity).show();
            }

            if (ps.showClose) { //关闭按钮
                $preview_window.find(".preview-modal-close").show();
                $preview_window.find(".preview-modal-close").on("click", function () {

                    closeWindow();
                    if (typeof (ps.closed) === 'function') {
                        ps.closed(ps.data);
                    }
                });
            }

            if (ps.width > 0) { //宽度
                $preview_window_modal.css("width", ps.width + "px");
            }

            if (ps.height > 0) { //高度
                $preview_window_modal.css("height", ps.height + "px");
            }

            if (ps.top == "") //居中
            {
                ps.top = (document.documentElement.clientHeight - ps.height) / 2 + $(document).scrollTop() + "px";
            }
            $preview_window.css({ "left": (($(document).width() - ps.width) / 2) + "px", "top": ps.top + "px" });

            //显示网址和二维码
            if (ps.data) {
                previewUrlAndQrcode();
            }

            if (ps.buttons.length > 0) { //要显示的button

                //输出按钮
                $.each(ps.buttons, function () {
                    var $this = $(this);
                    var $btn = $("<button type='button' class='preview-btn " + printText($this.attr("className")) + "' style='" + printText($this.attr("style")) + "'><span>" + printText($this.attr("text")) + "</span></button>").appendTo($preview_window.find(".lr .con .btns"));

                    if (typeof ($this.attr("initFunc")) == 'function') {
                        $this.attr("initFunc")($btn);
                    }

                    $btn.click(function () {
                        if (typeof ($this.attr("autoClose")) != 'undefined' && $this.attr("autoClose") == true) {
                            closeWindow();
                        }

                        if (typeof ($this.attr("clickFunc")) == 'function') {
                            $this.attr("clickFunc")($btn, ps.data);
                        }
                    });
                });
            }

            //计算左侧预览区域位置
            var left = (($preview_window_modal.find(".lf").width() - $preview_window_modal.find(".wechat-head").width())) / 2 + "px";
            $preview_window_modal.find(".wechat-head").css("left", left);
            $preview_window_modal.find(".maskingLayer_iframe").css("left", left);
            $preview_window_modal.find(".maskingLayer_iframe").css("height", ($preview_window_modal.find(".lf").height() - 104) + "px");

            //显示上一条/下一条
            if (ps.showPage) {
                var i = objectInArray(ps.data, ps.pageData);
                $preview_window_modal.find(".lf .arrow").fadeIn(2000);

                //注册事件
                $preview_window_modal.find(".lf .arrow.left").click(function () {
                    if (i === -1) {
                        ps.pageData.push(ps.data);
                        i = ps.pageData.length - 1;
                    }
                    else {
                        i--;
                    }

                    if (i < 0) {
                        i = ps.pageData.length - 1;
                    }
                    ps.data = ps.pageData[i];
                    previewUrlAndQrcode();
                });

                $preview_window_modal.find(".lf .arrow.right").click(function () {
                    if (i === -1) {
                        ps.pageData.push(ps.data);
                        i = 0;
                    }
                    else {
                        i++;
                    }

                    if (i >= ps.pageData.length) {
                        i = 0;
                    }

                    ps.data = ps.pageData[i];
                    previewUrlAndQrcode();
                });
            }

            //自由拖动
            if (ps.draggable) {
                var bDrag = false;
                var disX = disY = 0;
                var oH2 = $preview_window_modal[0]; //将JQ抓换成Dom对象
                var oWin = $preview_window_modal[0];
                oH2.style.cursor = "move";
                oH2.onmousedown = function (event) {
                    var event = event || window.event;
                    bDrag = true;
                    disX = event.clientX - oWin.offsetLeft;
                    disY = event.clientY - oWin.offsetTop;
                    this.setCapture && this.setCapture();
                    return false
                };
                document.onmousemove = function (event) {
                    if (!bDrag) return;
                    var event = event || window.event;
                    var iL = event.clientX - disX;
                    var iT = event.clientY - disY;
                    var maxL = document.documentElement.clientWidth - oWin.offsetWidth;
                    var maxT = document.documentElement.clientHeight - oWin.offsetHeight;
                    iL = iL < 0 ? 0 : iL;
                    iL = iL > maxL ? maxL : iL;
                    iT = iT < 0 ? 0 : iT;
                    iT = iT > maxT ? maxT : iT;

                    oWin.style.marginTop = oWin.style.marginLeft = 0;
                    oWin.style.left = iL + "px";
                    oWin.style.top = iT + "px";
                    return false
                };
                document.onmouseup = window.onblur = oH2.onlosecapture = function () {
                    bDrag = false;
                    oH2.releaseCapture && oH2.releaseCapture();
                };
            }

            $preview_window.fadeIn(ps.showSpeed);

            return ps.id;

            //预览地址和qrcode
            function previewUrlAndQrcode() {
                $preview_window_modal.find(".maskingLayer_iframe").empty().html("<iframe src='" + ps.data.url + "' frameborder='0' width='100%' height='100%'></iframe>");

                $preview_window_modal.find(".link-txt").text(ps.data.url);
                parallelLoadScripts([{ "name": "jquery-qrcode", "url": "https://cdn.bootcss.com/jquery.qrcode/1.0/jquery.qrcode.min.js" }], function () {
                    $preview_window.find('.link-qrcode .qrcode-preview').empty().qrcode({
                        render: "canvas", //table方式
                        width: 210, //宽度
                        height: 200, //高度
                        text: ps.data.url
                    });
                });

            }

            //关闭窗口
            function closeWindow() {
                $preview_window.hide();

                $preview_window.find(".preview-modal-mask").hide();
                $preview_window_modal.find(".lf .arrow").hide().unbind("click");
                $preview_window.find(".lr .con .btns").empty();
                $preview_window.find(".preview-modal-close").hide().unbind("click");
                $preview_window_modal.find(".maskingLayer_iframe").empty();
            }

            function printText(text) {
                if (text != undefined) {
                    return text;
                }
                return "";
            }
        }

    });
})(jQuery);