属性:
属性 | 描述 | 类型 | 默认值 |
show | 是否显示验证码弹框 | Boolean | false |
canvasWidth | 主图区域的宽度 | Number | 310 |
canvasHeight | 主图区域的高度 | Number | 160 |
imgs | 自定义图片 | Array | null |
successText | 验证成功时的提示文字 | String | 验证通过! |
failText | 验证失败时的提示文字 | String | 验证失败,请重试 |
sliderText | 下方滑动条里的文字 | String | 拖动滑块完成拼图 |
事件:
事件名 | 描述 | 返回值 |
success | 验证通过时会触发 | 偏差值px,移动的距离px(需修改源码) |
fail | 主图区域的宽度 | 偏差值px |
close | 用户点击遮罩层的回调 | null |
reset(需修改源码) | 用户点击刷新按钮和失败后重新刷新的回调 | 偏差值px |
1、安装vue-puzzle-vcode
npm i -S vue-puzzle-vcode
2、实现代码
登录
效果:
前端和后端一起结合调取接口的时候,框架原本的success和fail和close已经不满足我们使用,所以我们要修改框架的源码我们加一个reset事件和成功之后多返回一个移动的距离px~
修改后的源码main.js:
!function(t, e) { true ? module.exports = e() : undefined }(this, (function() { return function() { "use strict"; var t = { 358: function(t, e, n) { var i = n(81) , s = n.n(i) , a = n(645) , o = n.n(a)()(s()); o.push([t.id, ".vue-puzzle-vcode {\n position: fixed;\n top: 0;\n left: 0;\n bottom: 0;\n right: 0;\n background-color: rgba(0, 0, 0, 0.3);\n z-index: 999;\n opacity: 0;\n pointer-events: none;\n -webkit-transition: opacity 200ms;\n transition: opacity 200ms;\n}\n.vue-puzzle-vcode.show_ {\n opacity: 1;\n pointer-events: auto;\n}\n.vue-auth-box_ {\n position: absolute;\n top: 40%;\n left: 50%;\n -webkit-transform: translate(-50%, -50%);\n transform: translate(-50%, -50%);\n padding: 20px;\n background: #fff;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n border-radius: 3px;\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);\n}\n.vue-auth-box_ .auth-body_ {\n position: relative;\n overflow: hidden;\n border-radius: 3px;\n}\n.vue-auth-box_ .auth-body_ .loading-box_ {\n position: absolute;\n top: 0;\n left: 0;\n bottom: 0;\n right: 0;\n background-color: rgba(0, 0, 0, 0.8);\n z-index: 20;\n opacity: 1;\n -webkit-transition: opacity 200ms;\n transition: opacity 200ms;\n display: -webkit-box;\n display: -webkit-flex;\n display: flex;\n -webkit-box-align: center;\n -webkit-align-items: center;\n align-items: center;\n -webkit-box-pack: center;\n -webkit-justify-content: center;\n justify-content: center;\n}\n.vue-auth-box_ .auth-body_ .loading-box_.hide_ {\n opacity: 0;\n pointer-events: none;\n}\n.vue-auth-box_ .auth-body_ .loading-box_.hide_ .loading-gif_ span {\n -webkit-animation-play-state: paused;\n animation-play-state: paused;\n}\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ {\n -webkit-box-flex: 0;\n -webkit-flex: none;\n flex: none;\n height: 5px;\n line-height: 0;\n}\n@-webkit-keyframes load {\n0% {\n opacity: 1;\n -webkit-transform: scale(1.3);\n transform: scale(1.3);\n}\n100% {\n opacity: 0.2;\n -webkit-transform: scale(0.3);\n transform: scale(0.3);\n}\n}\n@keyframes load {\n0% {\n opacity: 1;\n -webkit-transform: scale(1.3);\n transform: scale(1.3);\n}\n100% {\n opacity: 0.2;\n -webkit-transform: scale(0.3);\n transform: scale(0.3);\n}\n}\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ span {\n display: inline-block;\n width: 5px;\n height: 100%;\n margin-left: 2px;\n border-radius: 50%;\n background-color: #888;\n -webkit-animation: load 1.04s ease infinite;\n animation: load 1.04s ease infinite;\n}\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ span:nth-child(1) {\n margin-left: 0;\n}\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ span:nth-child(2) {\n -webkit-animation-delay: 0.13s;\n animation-delay: 0.13s;\n}\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ span:nth-child(3) {\n -webkit-animation-delay: 0.26s;\n animation-delay: 0.26s;\n}\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ span:nth-child(4) {\n -webkit-animation-delay: 0.39s;\n animation-delay: 0.39s;\n}\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ span:nth-child(5) {\n -webkit-animation-delay: 0.52s;\n animation-delay: 0.52s;\n}\n.vue-auth-box_ .auth-body_ .info-box_ {\n position: absolute;\n bottom: 0;\n left: 0;\n width: 100%;\n height: 24px;\n line-height: 24px;\n text-align: center;\n overflow: hidden;\n font-size: 13px;\n background-color: #83ce3f;\n opacity: 0;\n -webkit-transform: translateY(24px);\n transform: translateY(24px);\n -webkit-transition: all 200ms;\n transition: all 200ms;\n color: #fff;\n z-index: 10;\n}\n.vue-auth-box_ .auth-body_ .info-box_.show {\n opacity: 0.95;\n -webkit-transform: translateY(0);\n transform: translateY(0);\n}\n.vue-auth-box_ .auth-body_ .info-box_.fail {\n background-color: #ce594b;\n}\n.vue-auth-box_ .auth-body_ .auth-canvas2_ {\n position: absolute;\n top: 0;\n left: 0;\n width: 60px;\n height: 100%;\n z-index: 2;\n}\n.vue-auth-box_ .auth-body_ .auth-canvas3_ {\n position: absolute;\n top: 0;\n left: 0;\n opacity: 0;\n -webkit-transition: opacity 600ms;\n transition: opacity 600ms;\n z-index: 3;\n}\n.vue-auth-box_ .auth-body_ .auth-canvas3_.show {\n opacity: 1;\n}\n.vue-auth-box_ .auth-body_ .flash_ {\n position: absolute;\n top: 0;\n left: 0;\n width: 30px;\n height: 100%;\n background-color: rgba(255, 255, 255, 0.1);\n z-index: 3;\n}\n.vue-auth-box_ .auth-body_ .flash_.show {\n -webkit-transition: -webkit-transform 600ms;\n transition: -webkit-transform 600ms;\n transition: transform 600ms;\n transition: transform 600ms, -webkit-transform 600ms;\n}\n.vue-auth-box_ .auth-body_ .reset_ {\n position: absolute;\n top: 2px;\n right: 2px;\n width: 35px;\n height: auto;\n z-index: 12;\n cursor: pointer;\n -webkit-transition: -webkit-transform 200ms;\n transition: -webkit-transform 200ms;\n transition: transform 200ms;\n transition: transform 200ms, -webkit-transform 200ms;\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg);\n}\n.vue-auth-box_ .auth-body_ .reset_:hover {\n -webkit-transform: rotate(-90deg);\n transform: rotate(-90deg);\n}\n.vue-auth-box_ .auth-control_ .range-box {\n position: relative;\n width: 100%;\n background-color: #eef1f8;\n margin-top: 20px;\n border-radius: 3px;\n box-shadow: 0 0 8px rgba(240, 240, 240, 0.6) inset;\n}\n.vue-auth-box_ .auth-control_ .range-box .range-text {\n position: absolute;\n top: 50%;\n left: 50%;\n -webkit-transform: translate(-50%, -50%);\n transform: translate(-50%, -50%);\n font-size: 14px;\n color: #b7bcd1;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n text-align: center;\n width: 100%;\n}\n.vue-auth-box_ .auth-control_ .range-box .range-slider {\n position: absolute;\n height: 100%;\n width: 50px;\n background-color: rgba(106, 160, 255, 0.8);\n border-radius: 3px;\n}\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn {\n position: absolute;\n display: -webkit-box;\n display: -webkit-flex;\n display: flex;\n -webkit-box-align: center;\n -webkit-align-items: center;\n align-items: center;\n -webkit-box-pack: center;\n -webkit-justify-content: center;\n justify-content: center;\n right: 0;\n width: 50px;\n height: 100%;\n background-color: #fff;\n border-radius: 3px;\n box-shadow: 0 0 4px #ccc;\n cursor: pointer;\n}\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn > div {\n width: 0;\n height: 40%;\n -webkit-transition: all 200ms;\n transition: all 200ms;\n border: solid 1px #6aa0ff;\n}\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn > div:nth-child(2) {\n margin: 0 4px;\n}\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn:hover > div:first-child,\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn.isDown > div:first-child {\n border: solid 4px transparent;\n height: 0;\n border-right-color: #6aa0ff;\n}\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn:hover > div:nth-child(2),\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn.isDown > div:nth-child(2) {\n border-width: 3px;\n height: 0;\n border-radius: 3px;\n margin: 0 6px;\n border-right-color: #6aa0ff;\n}\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn:hover > div:nth-child(3),\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn.isDown > div:nth-child(3) {\n border: solid 4px transparent;\n height: 0;\n border-left-color: #6aa0ff;\n}\n.vue-puzzle-overflow {\n overflow: hidden !important;\n}\n", ""]), e.Z = o }, 645: function(t) { t.exports = function(t) { var e = []; return e.toString = function() { return this.map((function(e) { var n = "" , i = void 0 !== e[5]; return e[4] && (n += "@supports (".concat(e[4], ") {")), e[2] && (n += "@media ".concat(e[2], " {")), i && (n += "@layer".concat(e[5].length > 0 ? " ".concat(e[5]) : "", " {")), n += t(e), i && (n += "}"), e[2] && (n += "}"), e[4] && (n += "}"), n } )).join("") } , e.i = function(t, n, i, s, a) { "string" == typeof t && (t = [[null, t, void 0]]); var o = {}; if (i) for (var r = 0; r < this.length; r++) { var h = this[r][0]; null != h && (o[h] = !0) } for (var l = 0; l < t.length; l++) { var c = [].concat(t[l]); i && o[c[0]] || (void 0 !== a && (void 0 === c[5] || (c[1] = "@layer".concat(c[5].length > 0 ? " ".concat(c[5]) : "", " {").concat(c[1], "}")), c[5] = a), n && (c[2] ? (c[1] = "@media ".concat(c[2], " {").concat(c[1], "}"), c[2] = n) : c[2] = n), s && (c[4] ? (c[1] = "@supports (".concat(c[4], ") {").concat(c[1], "}"), c[4] = s) : c[4] = "".concat(s)), e.push(c)) } } , e } }, 81: function(t) { t.exports = function(t) { return t[1] } }, 379: function(t) { var e = []; function n(t) { for (var n = -1, i = 0; i < e.length; i++) if (e[i].identifier === t) { n = i; break } return n } function i(t, i) { for (var a = {}, o = [], r = 0; r < t.length; r++) { var h = t[r] , l = i.base ? h[0] + i.base : h[0] , c = a[l] || 0 , d = "".concat(l, " ").concat(c); a[l] = c + 1; var u = n(d) , p = { css: h[1], media: h[2], sourceMap: h[3], supports: h[4], layer: h[5] }; if (-1 !== u) e[u].references++, e[u].updater(p); else { var f = s(p, i); i.byIndex = r, e.splice(r, 0, { identifier: d, updater: f, references: 1 }) } o.push(d) } return o } function s(t, e) { var n = e.domAPI(e); return n.update(t), function(e) { if (e) { if (e.css === t.css && e.media === t.media && e.sourceMap === t.sourceMap && e.supports === t.supports && e.layer === t.layer) return; n.update(t = e) } else n.remove() } } t.exports = function(t, s) { var a = i(t = t || [], s = s || {}); return function(t) { t = t || []; for (var o = 0; o < a.length; o++) { var r = n(a[o]); e[r].references-- } for (var h = i(t, s), l = 0; l < a.length; l++) { var c = n(a[l]); 0 === e[c].references && (e[c].updater(), e.splice(c, 1)) } a = h } } }, 569: function(t) { var e = {}; t.exports = function(t, n) { var i = function(t) { if (void 0 === e[t]) { var n = document.querySelector(t); if (window.HTMLIFrameElement && n instanceof window.HTMLIFrameElement) try { n = n.contentDocument.head } catch (t) { n = null } e[t] = n } return e[t] }(t); if (!i) throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid."); i.appendChild(n) } }, 216: function(t) { t.exports = function(t) { var e = document.createElement("style"); return t.setAttributes(e, t.attributes), t.insert(e, t.options), e } }, 565: function(t, e, n) { t.exports = function(t) { var e = n.nc; e && t.setAttribute("nonce", e) } }, 795: function(t) { t.exports = function(t) { var e = t.insertStyleElement(t); return { update: function(n) { !function(t, e, n) { var i = ""; n.supports && (i += "@supports (".concat(n.supports, ") {")), n.media && (i += "@media ".concat(n.media, " {")); var s = void 0 !== n.layer; s && (i += "@layer".concat(n.layer.length > 0 ? " ".concat(n.layer) : "", " {")), i += n.css, s && (i += "}"), n.media && (i += "}"), n.supports && (i += "}"); var a = n.sourceMap; a && "undefined" != typeof btoa && (i += "\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(a)))), " */")), e.styleTagTransform(i, t, e.options) }(e, t, n) }, remove: function() { !function(t) { if (null === t.parentNode) return !1; t.parentNode.removeChild(t) }(e) } } } }, 589: function(t) { t.exports = function(t, e) { if (e.styleSheet) e.styleSheet.cssText = t; else { for (; e.firstChild; ) e.removeChild(e.firstChild); e.appendChild(document.createTextNode(t)) } } } } , e = {}; function n(i) { var s = e[i]; if (void 0 !== s) return s.exports; var a = e[i] = { id: i, exports: {} }; return t[i](a, a.exports, n), a.exports } n.n = function(t) { var e = t && t.__esModule ? function() { return t.default } : function() { return t } ; return n.d(e, { a: e }), e } , n.d = function(t, e) { for (var i in e) n.o(e, i) && !n.o(t, i) && Object.defineProperty(t, i, { enumerable: !0, get: e[i] }) } , n.o = function(t, e) { return Object.prototype.hasOwnProperty.call(t, e) } , n.r = function(t) { "undefined" != typeof Symbol && Symbol.toStringTag && Object.defineProperty(t, Symbol.toStringTag, { value: "Module" }), Object.defineProperty(t, "__esModule", { value: !0 }) } ; var i = {}; return function() { n.r(i), n.d(i, { default: function() { return x } }); var t = function() { var t = this , e = t.$createElement , n = t._self._c || e; return n("div", { class: ["vue-puzzle-vcode", { show_: t.show }], on: { mousedown: t.onCloseMouseDown, mouseup: t.onCloseMouseUp, touchstart: t.onCloseMouseDown, touchend: t.onCloseMouseUp } }, [n("div", { staticClass: "vue-auth-box_", on: { mousedown: function(t) { t.stopPropagation() }, touchstart: function(t) { t.stopPropagation() } } }, [n("div", { staticClass: "auth-body_", style: "height: " + t.canvasHeight + "px" }, [n("canvas", { ref: "canvas1", style: "width:" + t.canvasWidth + "px;height:" + t.canvasHeight + "px", attrs: { width: t.canvasWidth, height: t.canvasHeight } }), t._v(" "), n("canvas", { ref: "canvas3", class: ["auth-canvas3_", { show: t.isSuccess }], style: "width:" + t.canvasWidth + "px;height:" + t.canvasHeight + "px", attrs: { width: t.canvasWidth, height: t.canvasHeight } }), t._v(" "), n("canvas", { ref: "canvas2", staticClass: "auth-canvas2_", style: "width:" + t.puzzleBaseSize + "px;height:" + t.canvasHeight + "px;transform:translateX(" + (t.styleWidth - t.sliderBaseSize - (t.puzzleBaseSize - t.sliderBaseSize) * ((t.styleWidth - t.sliderBaseSize) / (t.canvasWidth - t.sliderBaseSize))) + "px)", attrs: { width: t.puzzleBaseSize, height: t.canvasHeight } }), t._v(" "), n("div", { class: ["loading-box_", { hide_: !t.loading }] }, [t._m(0)]), t._v(" "), n("div", { class: ["info-box_", { show: t.infoBoxShow }, { fail: t.infoBoxFail }] }, [t._v("\n " + t._s(t.infoText) + "\n ")]), t._v(" "), n("div", { class: ["flash_", { show: t.isSuccess }], style: "transform: translateX(" + (t.isSuccess ? t.canvasWidth + .578 * t.canvasHeight + "px" : "-" + .578 * t.canvasHeight + "px") + ") skew(-30deg, 0);" }), t._v(" "), n("img", { staticClass: "reset_", attrs: { src: t.resetSvg }, on: { click: t.reset } })]), t._v(" "), n("div", { staticClass: "auth-control_" }, [n("div", { staticClass: "range-box", style: "height:" + t.sliderBaseSize + "px" }, [n("div", { staticClass: "range-text" }, [t._v(t._s(t.sliderText))]), t._v(" "), n("div", { ref: "range-slider", staticClass: "range-slider", style: "width:" + t.styleWidth + "px" }, [n("div", { class: ["range-btn", { isDown: t.mouseDown }], style: "width:" + t.sliderBaseSize + "px", on: { mousedown: function(e) { return t.onRangeMouseDown(e) }, touchstart: function(e) { return t.onRangeMouseDown(e) } } }, [n("div"), t._v(" "), n("div"), t._v(" "), n("div")])])])])])]) }; t._withStripped = !0; var e = { props: { canvasWidth: { type: Number, default: 310 }, canvasHeight: { type: Number, default: 160 }, show: { type: Boolean, default: !1 }, puzzleScale: { type: Number, default: 1 }, sliderSize: { type: Number, default: 50 }, range: { type: Number, default: 10 }, imgs: { type: Array }, successText: { type: String, default: "验证通过!" }, failText: { type: String, default: "验证失败,请重试" }, sliderText: { type: String, default: "拖动滑块完成拼图" } }, data: ()=>({ mouseDown: !1, startWidth: 50, startX: 0, newX: 0, pinX: 0, pinY: 0, loading: !1, isCanSlide: !1, error: !1, infoBoxShow: !1, infoText: "", infoBoxFail: !1, timer1: null, closeDown: !1, isSuccess: !1, imgIndex: -1, isSubmting: !1, resetSvg: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACgAAAAoCAYAAACM/rhtAAAELklEQVRYR+2YW2wUZRTH//9vtlCoF9IoIklT3PqgPGi326hoetuaGEhIr9SgCYkkgt2WGOQVCca+GavWdr0GjD4YhG3RB3hply1LQA1tEQIxEXapGI2pEkys9LIzx2ylYWfY6e5sF0oi+7hzzvl+3/9855xvhrjNf7zN+XAHcL4Z+n8o6JWTeYt++W25S596AIZy6TB+n3yo+Nchlk8vmIIVowdXU9c3Q1gDSilBlQwjgBAYFGDvdF58/4milqvZwDpOcXWsb5Uh8hmBqkwXFMhlCN8aX5LXNbRy/T+Z+iXsHAFWRXs3QGQPyLucLDJrK5DgUXdTsxPfjAEro8E3Ce50EtxsKxPTwCPH3U2jTmJkBJgWTnAMxDeGMEoa0xQ+LJQnCD4HYFkCyAC3RdwN3U7gMkpxRTTYrMD91sCJIgCxV5R6O1Jcfy7VwonqLoj9/CqB2kF341qncGkBvRe+ureAWpRgoalCBecMFzcdK24YymZRJz5zprgq1tsJwXYL3CVZGvdGHmwZc7JQtra2gE+f712ep2QUYP714DJhaJrXLqXZQszlZwtYdSHoB9ljVk/ePVrSZFL0ZkAlxzQBVseCT8WhZhRThtFB8plk9Zi/qCi8cv0fNxvKFrDy4oF11NXXIFy2EII4iBcG3Y03VLZT8OqRd5aFPduvOEpxRayvXolxAKB2g6NgEhobBlc1HHYKY7WvHf5wtVAPgegIlbbZ9seUZ7AyFnwewi9pGoUyDmhrB931kfnC1ZwOeKlLP8GZJi6QLSFP2yep4toXSbT3ZQAfX3O6omt8Nhd9r/aHQAUMOQywYBZo5uZD2ThQ2rbPCjlnH6yI9rUryE5DU75ctJaake46Be4DuDjF8dFBNA94/AdtiySVxIlpMlTS8td801o70vMigM9huTda2lhcKHVHPO2HZv/P6LIwX7hk/+qzPSvUJGMkrg8AQYTkroRdXMlE+HH/twsG6BsOdJHYZlaO/lBZ6weOiiSXqs3Gqj0TeAxx+T75DIpgwjC0onD51pQD4JaluPrkR/cpFT9DcoVp84LOgTL/DjtBbglgou+puHwB8lEznPxJw1XSX77VtgizBvQNBw4RMqB7xt4Lc3c8lQKJaQHoO4R8ydz0/7MWoCXk8c85MrMC9J3qaafw/WtQlwXST+F3BnAeYB4obgJ1BJIuG+YtiKAjVOZ/Pd1ZdwzoG+4uBtSPpjaRbhXLcwF3hzytb2TilgVgT5BkYybBrTYC+Rvg5nRpdTRJrIs8+VPXPQXj2i4ItxC4O2NQQUQnN4U9rRcz9nH64p4ceM2lziX5Y4s3KHCdUHwE77ecMkMEp6BwhIa2Z6DslZRvfulgHafYLuCas58WLp2aLCFUga70qxOFU6dPFL2W1feYeaU43Y5z/TxnCuYabMEuC043ckdBp4pZ7f8FE5psOI1g6fwAAAAASUVORK5CYII=" }), mounted() { document.body.appendChild(this.$el), document.addEventListener("mousemove", this.onRangeMouseMove, !1), document.addEventListener("mouseup", this.onRangeMouseUp, !1), document.addEventListener("touchmove", this.onRangeMouseMove, { passive: !1 }), document.addEventListener("touchend", this.onRangeMouseUp, !1), this.show && (document.body.classList.add("vue-puzzle-overflow"), this.reset()) }, beforeDestroy() { clearTimeout(this.timer1), document.body.removeChild(this.$el), document.removeEventListener("mousemove", this.onRangeMouseMove, !1), document.removeEventListener("mouseup", this.onRangeMouseUp, !1), document.removeEventListener("touchmove", this.onRangeMouseMove, { passive: !1 }), document.removeEventListener("touchend", this.onRangeMouseUp, !1) }, watch: { show(t) { t ? (document.body.classList.add("vue-puzzle-overflow"), this.reset()) : (this.isSubmting = !1, this.isSuccess = !1, this.infoBoxShow = !1, document.body.classList.remove("vue-puzzle-overflow")) } }, computed: { styleWidth() { const t = this.startWidth + this.newX - this.startX; return t < this.sliderBaseSize ? this.sliderBaseSize : t > this.canvasWidth ? this.canvasWidth : t }, puzzleBaseSize() { return Math.round(52.5 * Math.max(Math.min(this.puzzleScale, 2), .2) + 6) }, sliderBaseSize() { return Math.max(Math.min(Math.round(this.sliderSize), Math.round(.5 * this.canvasWidth)), 10) } }, methods: { onClose() { this.mouseDown || this.isSubmting || (clearTimeout(this.timer1), this.$emit("close")) }, onCloseMouseDown() { this.closeDown = !0 }, onCloseMouseUp() { this.closeDown && this.onClose(), this.closeDown = !1 }, onRangeMouseDown(t) { this.isCanSlide && (this.mouseDown = !0, this.startWidth = this.$refs["range-slider"].clientWidth, this.newX = t.clientX || t.changedTouches[0].clientX, this.startX = t.clientX || t.changedTouches[0].clientX) }, onRangeMouseMove(t) { this.mouseDown && (t.preventDefault(), this.newX = t.clientX || t.changedTouches[0].clientX) }, onRangeMouseUp() { this.mouseDown && (this.mouseDown = !1, this.submit()) }, init(t) { if (this.loading && !t) return; this.loading = !0, this.isCanSlide = !1; const e = this.$refs.canvas1 , n = this.$refs.canvas2 , i = this.$refs.canvas3 , s = e.getContext("2d") , a = n.getContext("2d") , o = i.getContext("2d") , r = navigator.userAgent.indexOf("Firefox") >= 0 && navigator.userAgent.indexOf("Windows") >= 0 , h = document.createElement("img"); if (s.fillStyle = "rgba(255,255,255,1)", o.fillStyle = "rgba(255,255,255,1)", s.clearRect(0, 0, this.canvasWidth, this.canvasHeight), a.clearRect(0, 0, this.canvasWidth, this.canvasHeight), this.pinX = this.getRandom(this.puzzleBaseSize, this.canvasWidth - this.puzzleBaseSize - 20), this.pinY = this.getRandom(20, this.canvasHeight - this.puzzleBaseSize - 20), h.crossOrigin = "anonymous", h.onload = ()=>{ const [t,e,n,i] = this.makeImgSize(h); s.save(), this.paintBrick(s), s.closePath(), r ? (s.clip(), s.save(), s.shadowOffsetX = 0, s.shadowOffsetY = 0, s.shadowColor = "#000", s.shadowBlur = 3, s.fill(), s.restore()) : (s.shadowOffsetX = 0, s.shadowOffsetY = 0, s.shadowColor = "#000", s.shadowBlur = 3, s.fill(), s.clip()), s.drawImage(h, t, e, n, i), o.fillRect(0, 0, this.canvasWidth, this.canvasHeight), o.drawImage(h, t, e, n, i), s.globalCompositeOperation = "source-atop", this.paintBrick(s), s.arc(this.pinX + Math.ceil(this.puzzleBaseSize / 2), this.pinY + Math.ceil(this.puzzleBaseSize / 2), 1.2 * this.puzzleBaseSize, 0, 2 * Math.PI, !0), s.closePath(), s.shadowColor = "rgba(255, 255, 255, .8)", s.shadowOffsetX = -1, s.shadowOffsetY = -1, s.shadowBlur = Math.min(Math.ceil(8 * this.puzzleScale), 12), s.fillStyle = "#ffffaa", s.fill(); const l = s.getImageData(this.pinX - 3, this.pinY - 20, this.pinX + this.puzzleBaseSize + 5, this.pinY + this.puzzleBaseSize + 5); a.putImageData(l, 0, this.pinY - 20), s.restore(), s.clearRect(0, 0, this.canvasWidth, this.canvasHeight), s.save(), this.paintBrick(s), s.globalAlpha = .8, s.fillStyle = "#ffffff", s.fill(), s.restore(), s.save(), s.globalCompositeOperation = "source-atop", this.paintBrick(s), s.arc(this.pinX + Math.ceil(this.puzzleBaseSize / 2), this.pinY + Math.ceil(this.puzzleBaseSize / 2), 1.2 * this.puzzleBaseSize, 0, 2 * Math.PI, !0), s.shadowColor = "#000", s.shadowOffsetX = 2, s.shadowOffsetY = 2, s.shadowBlur = 16, s.fill(), s.restore(), s.save(), s.globalCompositeOperation = "destination-over", s.drawImage(h, t, e, n, i), s.restore(), this.loading = !1, this.isCanSlide = !0 } , h.onerror = ()=>{ this.init(!0) } , !t && this.imgs && this.imgs.length) { let t = this.getRandom(0, this.imgs.length - 1); t === this.imgIndex && (t === this.imgs.length - 1 ? t = 0 : t++), this.imgIndex = t, h.src = this.imgs[t] } else h.src = this.makeImgWithCanvas() }, getRandom: (t,e)=>Math.ceil(Math.random() * (e - t) + t), makeImgSize(t) { const e = t.width / t.height; let n = 0 , i = 0 , s = 0 , a = 0; return e > this.canvasWidth / this.canvasHeight ? (a = this.canvasHeight, s = e * a, i = 0, n = (this.canvasWidth - s) / 2) : (s = this.canvasWidth, a = s / e, n = 0, i = (this.canvasHeight - a) / 2), [n, i, s, a] }, paintBrick(t) { const e = Math.ceil(15 * this.puzzleScale); t.beginPath(), t.moveTo(this.pinX, this.pinY), t.lineTo(this.pinX + e, this.pinY), t.arcTo(this.pinX + e, this.pinY - e / 2, this.pinX + e + e / 2, this.pinY - e / 2, e / 2), t.arcTo(this.pinX + e + e, this.pinY - e / 2, this.pinX + e + e, this.pinY, e / 2), t.lineTo(this.pinX + e + e + e, this.pinY), t.lineTo(this.pinX + e + e + e, this.pinY + e), t.arcTo(this.pinX + e + e + e + e / 2, this.pinY + e, this.pinX + e + e + e + e / 2, this.pinY + e + e / 2, e / 2), t.arcTo(this.pinX + e + e + e + e / 2, this.pinY + e + e, this.pinX + e + e + e, this.pinY + e + e, e / 2), t.lineTo(this.pinX + e + e + e, this.pinY + e + e + e), t.lineTo(this.pinX, this.pinY + e + e + e), t.lineTo(this.pinX, this.pinY + e + e), t.arcTo(this.pinX + e / 2, this.pinY + e + e, this.pinX + e / 2, this.pinY + e + e / 2, e / 2), t.arcTo(this.pinX + e / 2, this.pinY + e, this.pinX, this.pinY + e, e / 2), t.lineTo(this.pinX, this.pinY) }, makeImgWithCanvas() { const t = document.createElement("canvas") , e = t.getContext("2d"); t.width = this.canvasWidth, t.height = this.canvasHeight, e.fillStyle = `rgb(${this.getRandom(100, 255)},${this.getRandom(100, 255)},${this.getRandom(100, 255)})`, e.fillRect(0, 0, this.canvasWidth, this.canvasHeight); for (let n = 0; n < 12; n++) if (e.fillStyle = `rgb(${this.getRandom(100, 255)},${this.getRandom(100, 255)},${this.getRandom(100, 255)})`, e.strokeStyle = `rgb(${this.getRandom(100, 255)},${this.getRandom(100, 255)},${this.getRandom(100, 255)})`, this.getRandom(0, 2) > 1) e.save(), e.rotate(this.getRandom(-90, 90) * Math.PI / 180), e.fillRect(this.getRandom(-20, t.width - 20), this.getRandom(-20, t.height - 20), this.getRandom(10, t.width / 2 + 10), this.getRandom(10, t.height / 2 + 10)), e.restore(); else { e.beginPath(); const n = this.getRandom(-Math.PI, Math.PI); e.arc(this.getRandom(0, t.width), this.getRandom(0, t.height), this.getRandom(10, t.height / 2 + 10), n, n + 1.5 * Math.PI), e.closePath(), e.fill() } return t.toDataURL("image/png") }, submit() { this.isSubmting = !0; const t = Math.abs(this.pinX - (this.styleWidth - this.sliderBaseSize) + (this.puzzleBaseSize - this.sliderBaseSize) * ((this.styleWidth - this.sliderBaseSize) / (this.canvasWidth - this.sliderBaseSize)) - 3); t < this.range ? (this.infoText = this.successText, this.infoBoxFail = !1, this.infoBoxShow = !0, this.isCanSlide = !1, this.isSuccess = !0, clearTimeout(this.timer1), this.timer1 = setTimeout((()=>{ this.isSubmting = !1, this.$emit("success", t, this.pinX) } ), 800)) : (this.infoText = this.failText, this.infoBoxFail = !0, this.infoBoxShow = !0, this.isCanSlide = !1, this.$emit("fail", t), clearTimeout(this.timer1), this.timer1 = setTimeout((()=>{ this.isSubmting = !1, this.reset() } ), 800)) }, resetState() { this.infoBoxFail = !1, this.infoBoxShow = !1, this.isCanSlide = !1, this.isSuccess = !1, this.startWidth = this.sliderBaseSize, this.startX = 0, this.newX = 0 }, reset() { this.$emit("reset", t), this.isSubmting || (this.resetState(), this.init()) } } } , s = n(379) , a = n.n(s) , o = n(795) , r = n.n(o) , h = n(569) , l = n.n(h) , c = n(565) , d = n.n(c) , u = n(216) , p = n.n(u) , f = n(589) , g = n.n(f) , v = n(358) , b = {}; b.styleTagTransform = g(), b.setAttributes = d(), b.insert = l().bind(null, "head"), b.domAPI = r(), b.insertStyleElement = p(), a()(v.Z, b), v.Z && v.Z.locals && v.Z.locals; var m = function(t, e, n, i, s, a, o, r) { var h, l = "function" == typeof t ? t.options : t; if (e && (l.render = e, l.staticRenderFns = [function() { var t = this , e = t.$createElement , n = t._self._c || e; return n("div", { staticClass: "loading-gif_" }, [n("span"), t._v(" "), n("span"), t._v(" "), n("span"), t._v(" "), n("span"), t._v(" "), n("span")]) } ], l._compiled = !0), h) if (l.functional) { l._injectStyles = h; var c = l.render; l.render = function(t, e) { return h.call(e), c(t, e) } } else { var d = l.beforeCreate; l.beforeCreate = d ? [].concat(d, h) : [h] } return { exports: t, options: l } }(e, t); m.options.__file = "src/app.vue"; var x = m.exports }(), i }() } )); //# sourceURL=[module] //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/vue-puzzle-vcode/dist/main.js.js","sources":["webpack:///./node_modules/vue-puzzle-vcode/dist/main.js?1069"],"sourcesContent":["!function(t,e){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=e():\"function\"==typeof define&&define.amd?define([],e):\"object\"==typeof exports?exports[\"vue-puzzle-vcode\"]=e():t[\"vue-puzzle-vcode\"]=e()}(this,(function(){return function(){\"use strict\";var t={358:function(t,e,n){var i=n(81),s=n.n(i),a=n(645),o=n.n(a)()(s());o.push([t.id,\".vue-puzzle-vcode {\\n  position: fixed;\\n  top: 0;\\n  left: 0;\\n  bottom: 0;\\n  right: 0;\\n  background-color: rgba(0, 0, 0, 0.3);\\n  z-index: 999;\\n  opacity: 0;\\n  pointer-events: none;\\n  -webkit-transition: opacity 200ms;\\n  transition: opacity 200ms;\\n}\\n.vue-puzzle-vcode.show_ {\\n  opacity: 1;\\n  pointer-events: auto;\\n}\\n.vue-auth-box_ {\\n  position: absolute;\\n  top: 40%;\\n  left: 50%;\\n  -webkit-transform: translate(-50%, -50%);\\n          transform: translate(-50%, -50%);\\n  padding: 20px;\\n  background: #fff;\\n  -webkit-user-select: none;\\n     -moz-user-select: none;\\n      -ms-user-select: none;\\n          user-select: none;\\n  border-radius: 3px;\\n  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);\\n}\\n.vue-auth-box_ .auth-body_ {\\n  position: relative;\\n  overflow: hidden;\\n  border-radius: 3px;\\n}\\n.vue-auth-box_ .auth-body_ .loading-box_ {\\n  position: absolute;\\n  top: 0;\\n  left: 0;\\n  bottom: 0;\\n  right: 0;\\n  background-color: rgba(0, 0, 0, 0.8);\\n  z-index: 20;\\n  opacity: 1;\\n  -webkit-transition: opacity 200ms;\\n  transition: opacity 200ms;\\n  display: -webkit-box;\\n  display: -webkit-flex;\\n  display: flex;\\n  -webkit-box-align: center;\\n  -webkit-align-items: center;\\n          align-items: center;\\n  -webkit-box-pack: center;\\n  -webkit-justify-content: center;\\n          justify-content: center;\\n}\\n.vue-auth-box_ .auth-body_ .loading-box_.hide_ {\\n  opacity: 0;\\n  pointer-events: none;\\n}\\n.vue-auth-box_ .auth-body_ .loading-box_.hide_ .loading-gif_ span {\\n  -webkit-animation-play-state: paused;\\n          animation-play-state: paused;\\n}\\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ {\\n  -webkit-box-flex: 0;\\n  -webkit-flex: none;\\n          flex: none;\\n  height: 5px;\\n  line-height: 0;\\n}\\n@-webkit-keyframes load {\\n0% {\\n    opacity: 1;\\n    -webkit-transform: scale(1.3);\\n            transform: scale(1.3);\\n}\\n100% {\\n    opacity: 0.2;\\n    -webkit-transform: scale(0.3);\\n            transform: scale(0.3);\\n}\\n}\\n@keyframes load {\\n0% {\\n    opacity: 1;\\n    -webkit-transform: scale(1.3);\\n            transform: scale(1.3);\\n}\\n100% {\\n    opacity: 0.2;\\n    -webkit-transform: scale(0.3);\\n            transform: scale(0.3);\\n}\\n}\\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ span {\\n  display: inline-block;\\n  width: 5px;\\n  height: 100%;\\n  margin-left: 2px;\\n  border-radius: 50%;\\n  background-color: #888;\\n  -webkit-animation: load 1.04s ease infinite;\\n          animation: load 1.04s ease infinite;\\n}\\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ span:nth-child(1) {\\n  margin-left: 0;\\n}\\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ span:nth-child(2) {\\n  -webkit-animation-delay: 0.13s;\\n          animation-delay: 0.13s;\\n}\\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ span:nth-child(3) {\\n  -webkit-animation-delay: 0.26s;\\n          animation-delay: 0.26s;\\n}\\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ span:nth-child(4) {\\n  -webkit-animation-delay: 0.39s;\\n          animation-delay: 0.39s;\\n}\\n.vue-auth-box_ .auth-body_ .loading-box_ .loading-gif_ span:nth-child(5) {\\n  -webkit-animation-delay: 0.52s;\\n          animation-delay: 0.52s;\\n}\\n.vue-auth-box_ .auth-body_ .info-box_ {\\n  position: absolute;\\n  bottom: 0;\\n  left: 0;\\n  width: 100%;\\n  height: 24px;\\n  line-height: 24px;\\n  text-align: center;\\n  overflow: hidden;\\n  font-size: 13px;\\n  background-color: #83ce3f;\\n  opacity: 0;\\n  -webkit-transform: translateY(24px);\\n          transform: translateY(24px);\\n  -webkit-transition: all 200ms;\\n  transition: all 200ms;\\n  color: #fff;\\n  z-index: 10;\\n}\\n.vue-auth-box_ .auth-body_ .info-box_.show {\\n  opacity: 0.95;\\n  -webkit-transform: translateY(0);\\n          transform: translateY(0);\\n}\\n.vue-auth-box_ .auth-body_ .info-box_.fail {\\n  background-color: #ce594b;\\n}\\n.vue-auth-box_ .auth-body_ .auth-canvas2_ {\\n  position: absolute;\\n  top: 0;\\n  left: 0;\\n  width: 60px;\\n  height: 100%;\\n  z-index: 2;\\n}\\n.vue-auth-box_ .auth-body_ .auth-canvas3_ {\\n  position: absolute;\\n  top: 0;\\n  left: 0;\\n  opacity: 0;\\n  -webkit-transition: opacity 600ms;\\n  transition: opacity 600ms;\\n  z-index: 3;\\n}\\n.vue-auth-box_ .auth-body_ .auth-canvas3_.show {\\n  opacity: 1;\\n}\\n.vue-auth-box_ .auth-body_ .flash_ {\\n  position: absolute;\\n  top: 0;\\n  left: 0;\\n  width: 30px;\\n  height: 100%;\\n  background-color: rgba(255, 255, 255, 0.1);\\n  z-index: 3;\\n}\\n.vue-auth-box_ .auth-body_ .flash_.show {\\n  -webkit-transition: -webkit-transform 600ms;\\n  transition: -webkit-transform 600ms;\\n  transition: transform 600ms;\\n  transition: transform 600ms, -webkit-transform 600ms;\\n}\\n.vue-auth-box_ .auth-body_ .reset_ {\\n  position: absolute;\\n  top: 2px;\\n  right: 2px;\\n  width: 35px;\\n  height: auto;\\n  z-index: 12;\\n  cursor: pointer;\\n  -webkit-transition: -webkit-transform 200ms;\\n  transition: -webkit-transform 200ms;\\n  transition: transform 200ms;\\n  transition: transform 200ms, -webkit-transform 200ms;\\n  -webkit-transform: rotate(0deg);\\n          transform: rotate(0deg);\\n}\\n.vue-auth-box_ .auth-body_ .reset_:hover {\\n  -webkit-transform: rotate(-90deg);\\n          transform: rotate(-90deg);\\n}\\n.vue-auth-box_ .auth-control_ .range-box {\\n  position: relative;\\n  width: 100%;\\n  background-color: #eef1f8;\\n  margin-top: 20px;\\n  border-radius: 3px;\\n  box-shadow: 0 0 8px rgba(240, 240, 240, 0.6) inset;\\n}\\n.vue-auth-box_ .auth-control_ .range-box .range-text {\\n  position: absolute;\\n  top: 50%;\\n  left: 50%;\\n  -webkit-transform: translate(-50%, -50%);\\n          transform: translate(-50%, -50%);\\n  font-size: 14px;\\n  color: #b7bcd1;\\n  white-space: nowrap;\\n  overflow: hidden;\\n  text-overflow: ellipsis;\\n  text-align: center;\\n  width: 100%;\\n}\\n.vue-auth-box_ .auth-control_ .range-box .range-slider {\\n  position: absolute;\\n  height: 100%;\\n  width: 50px;\\n  background-color: rgba(106, 160, 255, 0.8);\\n  border-radius: 3px;\\n}\\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn {\\n  position: absolute;\\n  display: -webkit-box;\\n  display: -webkit-flex;\\n  display: flex;\\n  -webkit-box-align: center;\\n  -webkit-align-items: center;\\n          align-items: center;\\n  -webkit-box-pack: center;\\n  -webkit-justify-content: center;\\n          justify-content: center;\\n  right: 0;\\n  width: 50px;\\n  height: 100%;\\n  background-color: #fff;\\n  border-radius: 3px;\\n  box-shadow: 0 0 4px #ccc;\\n  cursor: pointer;\\n}\\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn > div {\\n  width: 0;\\n  height: 40%;\\n  -webkit-transition: all 200ms;\\n  transition: all 200ms;\\n  border: solid 1px #6aa0ff;\\n}\\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn > div:nth-child(2) {\\n  margin: 0 4px;\\n}\\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn:hover > div:first-child,\\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn.isDown > div:first-child {\\n  border: solid 4px transparent;\\n  height: 0;\\n  border-right-color: #6aa0ff;\\n}\\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn:hover > div:nth-child(2),\\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn.isDown > div:nth-child(2) {\\n  border-width: 3px;\\n  height: 0;\\n  border-radius: 3px;\\n  margin: 0 6px;\\n  border-right-color: #6aa0ff;\\n}\\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn:hover > div:nth-child(3),\\n.vue-auth-box_ .auth-control_ .range-box .range-slider .range-btn.isDown > div:nth-child(3) {\\n  border: solid 4px transparent;\\n  height: 0;\\n  border-left-color: #6aa0ff;\\n}\\n.vue-puzzle-overflow {\\n  overflow: hidden !important;\\n}\\n\",\"\"]),e.Z=o},645:function(t){t.exports=function(t){var e=[];return e.toString=function(){return this.map((function(e){var n=\"\",i=void 0!==e[5];return e[4]&&(n+=\"@supports (\".concat(e[4],\") {\")),e[2]&&(n+=\"@media \".concat(e[2],\" {\")),i&&(n+=\"@layer\".concat(e[5].length>0?\" \".concat(e[5]):\"\",\" {\")),n+=t(e),i&&(n+=\"}\"),e[2]&&(n+=\"}\"),e[4]&&(n+=\"}\"),n})).join(\"\")},e.i=function(t,n,i,s,a){\"string\"==typeof t&&(t=[[null,t,void 0]]);var o={};if(i)for(var r=0;r<this.length;r++){var h=this[r][0];null!=h&&(o[h]=!0)}for(var l=0;l<t.length;l++){var c=[].concat(t[l]);i&&o[c[0]]||(void 0!==a&&(void 0===c[5]||(c[1]=\"@layer\".concat(c[5].length>0?\" \".concat(c[5]):\"\",\" {\").concat(c[1],\"}\")),c[5]=a),n&&(c[2]?(c[1]=\"@media \".concat(c[2],\" {\").concat(c[1],\"}\"),c[2]=n):c[2]=n),s&&(c[4]?(c[1]=\"@supports (\".concat(c[4],\") {\").concat(c[1],\"}\"),c[4]=s):c[4]=\"\".concat(s)),e.push(c))}},e}},81:function(t){t.exports=function(t){return t[1]}},379:function(t){var e=[];function n(t){for(var n=-1,i=0;i<e.length;i++)if(e[i].identifier===t){n=i;break}return n}function i(t,i){for(var a={},o=[],r=0;r<t.length;r++){var h=t[r],l=i.base?h[0]+i.base:h[0],c=a[l]||0,d=\"\".concat(l,\" \").concat(c);a[l]=c+1;var u=n(d),p={css:h[1],media:h[2],sourceMap:h[3],supports:h[4],layer:h[5]};if(-1!==u)e[u].references++,e[u].updater(p);else{var f=s(p,i);i.byIndex=r,e.splice(r,0,{identifier:d,updater:f,references:1})}o.push(d)}return o}function s(t,e){var n=e.domAPI(e);return n.update(t),function(e){if(e){if(e.css===t.css&&e.media===t.media&&e.sourceMap===t.sourceMap&&e.supports===t.supports&&e.layer===t.layer)return;n.update(t=e)}else n.remove()}}t.exports=function(t,s){var a=i(t=t||[],s=s||{});return function(t){t=t||[];for(var o=0;o<a.length;o++){var r=n(a[o]);e[r].references--}for(var h=i(t,s),l=0;l<a.length;l++){var c=n(a[l]);0===e[c].references&&(e[c].updater(),e.splice(c,1))}a=h}}},569:function(t){var e={};t.exports=function(t,n){var i=function(t){if(void 0===e[t]){var n=document.querySelector(t);if(window.HTMLIFrameElement&&n instanceof window.HTMLIFrameElement)try{n=n.contentDocument.head}catch(t){n=null}e[t]=n}return e[t]}(t);if(!i)throw new Error(\"Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.\");i.appendChild(n)}},216:function(t){t.exports=function(t){var e=document.createElement(\"style\");return t.setAttributes(e,t.attributes),t.insert(e,t.options),e}},565:function(t,e,n){t.exports=function(t){var e=n.nc;e&&t.setAttribute(\"nonce\",e)}},795:function(t){t.exports=function(t){var e=t.insertStyleElement(t);return{update:function(n){!function(t,e,n){var i=\"\";n.supports&&(i+=\"@supports (\".concat(n.supports,\") {\")),n.media&&(i+=\"@media \".concat(n.media,\" {\"));var s=void 0!==n.layer;s&&(i+=\"@layer\".concat(n.layer.length>0?\" \".concat(n.layer):\"\",\" {\")),i+=n.css,s&&(i+=\"}\"),n.media&&(i+=\"}\"),n.supports&&(i+=\"}\");var a=n.sourceMap;a&&\"undefined\"!=typeof btoa&&(i+=\"\\n/*# sourceMappingURL=data:application/json;base64,\".concat(btoa(unescape(encodeURIComponent(JSON.stringify(a)))),\" */\")),e.styleTagTransform(i,t,e.options)}(e,t,n)},remove:function(){!function(t){if(null===t.parentNode)return!1;t.parentNode.removeChild(t)}(e)}}}},589:function(t){t.exports=function(t,e){if(e.styleSheet)e.styleSheet.cssText=t;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(t))}}}},e={};function n(i){var s=e[i];if(void 0!==s)return s.exports;var a=e[i]={id:i,exports:{}};return t[i](a,a.exports,n),a.exports}n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,{a:e}),e},n.d=function(t,e){for(var i in e)n.o(e,i)&&!n.o(t,i)&&Object.defineProperty(t,i,{enumerable:!0,get:e[i]})},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.r=function(t){\"undefined\"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:\"Module\"}),Object.defineProperty(t,\"__esModule\",{value:!0})};var i={};return function(){n.r(i),n.d(i,{default:function(){return x}});var t=function(){var t=this,e=t.$createElement,n=t._self._c||e;return n(\"div\",{class:[\"vue-puzzle-vcode\",{show_:t.show}],on:{mousedown:t.onCloseMouseDown,mouseup:t.onCloseMouseUp,touchstart:t.onCloseMouseDown,touchend:t.onCloseMouseUp}},[n(\"div\",{staticClass:\"vue-auth-box_\",on:{mousedown:function(t){t.stopPropagation()},touchstart:function(t){t.stopPropagation()}}},[n(\"div\",{staticClass:\"auth-body_\",style:\"height: \"+t.canvasHeight+\"px\"},[n(\"canvas\",{ref:\"canvas1\",style:\"width:\"+t.canvasWidth+\"px;height:\"+t.canvasHeight+\"px\",attrs:{width:t.canvasWidth,height:t.canvasHeight}}),t._v(\" \"),n(\"canvas\",{ref:\"canvas3\",class:[\"auth-canvas3_\",{show:t.isSuccess}],style:\"width:\"+t.canvasWidth+\"px;height:\"+t.canvasHeight+\"px\",attrs:{width:t.canvasWidth,height:t.canvasHeight}}),t._v(\" \"),n(\"canvas\",{ref:\"canvas2\",staticClass:\"auth-canvas2_\",style:\"width:\"+t.puzzleBaseSize+\"px;height:\"+t.canvasHeight+\"px;transform:translateX(\"+(t.styleWidth-t.sliderBaseSize-(t.puzzleBaseSize-t.sliderBaseSize)*((t.styleWidth-t.sliderBaseSize)/(t.canvasWidth-t.sliderBaseSize)))+\"px)\",attrs:{width:t.puzzleBaseSize,height:t.canvasHeight}}),t._v(\" \"),n(\"div\",{class:[\"loading-box_\",{hide_:!t.loading}]},[t._m(0)]),t._v(\" \"),n(\"div\",{class:[\"info-box_\",{show:t.infoBoxShow},{fail:t.infoBoxFail}]},[t._v(\"\\n        \"+t._s(t.infoText)+\"\\n      \")]),t._v(\" \"),n(\"div\",{class:[\"flash_\",{show:t.isSuccess}],style:\"transform: translateX(\"+(t.isSuccess?t.canvasWidth+.578*t.canvasHeight+\"px\":\"-\"+.578*t.canvasHeight+\"px\")+\") skew(-30deg, 0);\"}),t._v(\" \"),n(\"img\",{staticClass:\"reset_\",attrs:{src:t.resetSvg},on:{click:t.reset}})]),t._v(\" \"),n(\"div\",{staticClass:\"auth-control_\"},[n(\"div\",{staticClass:\"range-box\",style:\"height:\"+t.sliderBaseSize+\"px\"},[n(\"div\",{staticClass:\"range-text\"},[t._v(t._s(t.sliderText))]),t._v(\" \"),n(\"div\",{ref:\"range-slider\",staticClass:\"range-slider\",style:\"width:\"+t.styleWidth+\"px\"},[n(\"div\",{class:[\"range-btn\",{isDown:t.mouseDown}],style:\"width:\"+t.sliderBaseSize+\"px\",on:{mousedown:function(e){return t.onRangeMouseDown(e)},touchstart:function(e){return t.onRangeMouseDown(e)}}},[n(\"div\"),t._v(\" \"),n(\"div\"),t._v(\" \"),n(\"div\")])])])])])])};t._withStripped=!0;var e={props:{canvasWidth:{type:Number,default:310},canvasHeight:{type:Number,default:160},show:{type:Boolean,default:!1},puzzleScale:{type:Number,default:1},sliderSize:{type:Number,default:50},range:{type:Number,default:10},imgs:{type:Array},successText:{type:String,default:\"验证通过！\"},failText:{type:String,default:\"验证失败，请重试\"},sliderText:{type:String,default:\"拖动滑块完成拼图\"}},data:()=>({mouseDown:!1,startWidth:50,startX:0,newX:0,pinX:0,pinY:0,loading:!1,isCanSlide:!1,error:!1,infoBoxShow:!1,infoText:\"\",infoBoxFail:!1,timer1:null,closeDown:!1,isSuccess:!1,imgIndex:-1,isSubmting:!1,resetSvg:\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACgAAAAoCAYAAACM/rhtAAAELklEQVRYR+2YW2wUZRTH//9vtlCoF9IoIklT3PqgPGi326hoetuaGEhIr9SgCYkkgt2WGOQVCca+GavWdr0GjD4YhG3RB3hply1LQA1tEQIxEXapGI2pEkys9LIzx2ylYWfY6e5sF0oi+7hzzvl+3/9855xvhrjNf7zN+XAHcL4Z+n8o6JWTeYt++W25S596AIZy6TB+n3yo+Nchlk8vmIIVowdXU9c3Q1gDSilBlQwjgBAYFGDvdF58/4milqvZwDpOcXWsb5Uh8hmBqkwXFMhlCN8aX5LXNbRy/T+Z+iXsHAFWRXs3QGQPyLucLDJrK5DgUXdTsxPfjAEro8E3Ce50EtxsKxPTwCPH3U2jTmJkBJgWTnAMxDeGMEoa0xQ+LJQnCD4HYFkCyAC3RdwN3U7gMkpxRTTYrMD91sCJIgCxV5R6O1Jcfy7VwonqLoj9/CqB2kF341qncGkBvRe+ureAWpRgoalCBecMFzcdK24YymZRJz5zprgq1tsJwXYL3CVZGvdGHmwZc7JQtra2gE+f712ep2QUYP714DJhaJrXLqXZQszlZwtYdSHoB9ljVk/ePVrSZFL0ZkAlxzQBVseCT8WhZhRThtFB8plk9Zi/qCi8cv0fNxvKFrDy4oF11NXXIFy2EII4iBcG3Y03VLZT8OqRd5aFPduvOEpxRayvXolxAKB2g6NgEhobBlc1HHYKY7WvHf5wtVAPgegIlbbZ9seUZ7AyFnwewi9pGoUyDmhrB931kfnC1ZwOeKlLP8GZJi6QLSFP2yep4toXSbT3ZQAfX3O6omt8Nhd9r/aHQAUMOQywYBZo5uZD2ThQ2rbPCjlnH6yI9rUryE5DU75ctJaake46Be4DuDjF8dFBNA94/AdtiySVxIlpMlTS8td801o70vMigM9huTda2lhcKHVHPO2HZv/P6LIwX7hk/+qzPSvUJGMkrg8AQYTkroRdXMlE+HH/twsG6BsOdJHYZlaO/lBZ6weOiiSXqs3Gqj0TeAxx+T75DIpgwjC0onD51pQD4JaluPrkR/cpFT9DcoVp84LOgTL/DjtBbglgou+puHwB8lEznPxJw1XSX77VtgizBvQNBw4RMqB7xt4Lc3c8lQKJaQHoO4R8ydz0/7MWoCXk8c85MrMC9J3qaafw/WtQlwXST+F3BnAeYB4obgJ1BJIuG+YtiKAjVOZ/Pd1ZdwzoG+4uBtSPpjaRbhXLcwF3hzytb2TilgVgT5BkYybBrTYC+Rvg5nRpdTRJrIs8+VPXPQXj2i4ItxC4O2NQQUQnN4U9rRcz9nH64p4ceM2lziX5Y4s3KHCdUHwE77ecMkMEp6BwhIa2Z6DslZRvfulgHafYLuCas58WLp2aLCFUga70qxOFU6dPFL2W1feYeaU43Y5z/TxnCuYabMEuC043ckdBp4pZ7f8FE5psOI1g6fwAAAAASUVORK5CYII=\"}),mounted(){document.body.appendChild(this.$el),document.addEventListener(\"mousemove\",this.onRangeMouseMove,!1),document.addEventListener(\"mouseup\",this.onRangeMouseUp,!1),document.addEventListener(\"touchmove\",this.onRangeMouseMove,{passive:!1}),document.addEventListener(\"touchend\",this.onRangeMouseUp,!1),this.show&&(document.body.classList.add(\"vue-puzzle-overflow\"),this.reset())},beforeDestroy(){clearTimeout(this.timer1),document.body.removeChild(this.$el),document.removeEventListener(\"mousemove\",this.onRangeMouseMove,!1),document.removeEventListener(\"mouseup\",this.onRangeMouseUp,!1),document.removeEventListener(\"touchmove\",this.onRangeMouseMove,{passive:!1}),document.removeEventListener(\"touchend\",this.onRangeMouseUp,!1)},watch:{show(t){t?(document.body.classList.add(\"vue-puzzle-overflow\"),this.reset()):(this.isSubmting=!1,this.isSuccess=!1,this.infoBoxShow=!1,document.body.classList.remove(\"vue-puzzle-overflow\"))}},computed:{styleWidth(){const t=this.startWidth+this.newX-this.startX;return t<this.sliderBaseSize?this.sliderBaseSize:t>this.canvasWidth?this.canvasWidth:t},puzzleBaseSize(){return Math.round(52.5*Math.max(Math.min(this.puzzleScale,2),.2)+6)},sliderBaseSize(){return Math.max(Math.min(Math.round(this.sliderSize),Math.round(.5*this.canvasWidth)),10)}},methods:{onClose(){this.mouseDown||this.isSubmting||(clearTimeout(this.timer1),this.$emit(\"close\"))},onCloseMouseDown(){this.closeDown=!0},onCloseMouseUp(){this.closeDown&&this.onClose(),this.closeDown=!1},onRangeMouseDown(t){this.isCanSlide&&(this.mouseDown=!0,this.startWidth=this.$refs[\"range-slider\"].clientWidth,this.newX=t.clientX||t.changedTouches[0].clientX,this.startX=t.clientX||t.changedTouches[0].clientX)},onRangeMouseMove(t){this.mouseDown&&(t.preventDefault(),this.newX=t.clientX||t.changedTouches[0].clientX)},onRangeMouseUp(){this.mouseDown&&(this.mouseDown=!1,this.submit())},init(t){if(this.loading&&!t)return;this.loading=!0,this.isCanSlide=!1;const e=this.$refs.canvas1,n=this.$refs.canvas2,i=this.$refs.canvas3,s=e.getContext(\"2d\"),a=n.getContext(\"2d\"),o=i.getContext(\"2d\"),r=navigator.userAgent.indexOf(\"Firefox\")>=0&&navigator.userAgent.indexOf(\"Windows\")>=0,h=document.createElement(\"img\");if(s.fillStyle=\"rgba(255,255,255,1)\",o.fillStyle=\"rgba(255,255,255,1)\",s.clearRect(0,0,this.canvasWidth,this.canvasHeight),a.clearRect(0,0,this.canvasWidth,this.canvasHeight),this.pinX=this.getRandom(this.puzzleBaseSize,this.canvasWidth-this.puzzleBaseSize-20),this.pinY=this.getRandom(20,this.canvasHeight-this.puzzleBaseSize-20),h.crossOrigin=\"anonymous\",h.onload=()=>{const[t,e,n,i]=this.makeImgSize(h);s.save(),this.paintBrick(s),s.closePath(),r?(s.clip(),s.save(),s.shadowOffsetX=0,s.shadowOffsetY=0,s.shadowColor=\"#000\",s.shadowBlur=3,s.fill(),s.restore()):(s.shadowOffsetX=0,s.shadowOffsetY=0,s.shadowColor=\"#000\",s.shadowBlur=3,s.fill(),s.clip()),s.drawImage(h,t,e,n,i),o.fillRect(0,0,this.canvasWidth,this.canvasHeight),o.drawImage(h,t,e,n,i),s.globalCompositeOperation=\"source-atop\",this.paintBrick(s),s.arc(this.pinX+Math.ceil(this.puzzleBaseSize/2),this.pinY+Math.ceil(this.puzzleBaseSize/2),1.2*this.puzzleBaseSize,0,2*Math.PI,!0),s.closePath(),s.shadowColor=\"rgba(255, 255, 255, .8)\",s.shadowOffsetX=-1,s.shadowOffsetY=-1,s.shadowBlur=Math.min(Math.ceil(8*this.puzzleScale),12),s.fillStyle=\"#ffffaa\",s.fill();const l=s.getImageData(this.pinX-3,this.pinY-20,this.pinX+this.puzzleBaseSize+5,this.pinY+this.puzzleBaseSize+5);a.putImageData(l,0,this.pinY-20),s.restore(),s.clearRect(0,0,this.canvasWidth,this.canvasHeight),s.save(),this.paintBrick(s),s.globalAlpha=.8,s.fillStyle=\"#ffffff\",s.fill(),s.restore(),s.save(),s.globalCompositeOperation=\"source-atop\",this.paintBrick(s),s.arc(this.pinX+Math.ceil(this.puzzleBaseSize/2),this.pinY+Math.ceil(this.puzzleBaseSize/2),1.2*this.puzzleBaseSize,0,2*Math.PI,!0),s.shadowColor=\"#000\",s.shadowOffsetX=2,s.shadowOffsetY=2,s.shadowBlur=16,s.fill(),s.restore(),s.save(),s.globalCompositeOperation=\"destination-over\",s.drawImage(h,t,e,n,i),s.restore(),this.loading=!1,this.isCanSlide=!0},h.onerror=()=>{this.init(!0)},!t&&this.imgs&&this.imgs.length){let t=this.getRandom(0,this.imgs.length-1);t===this.imgIndex&&(t===this.imgs.length-1?t=0:t++),this.imgIndex=t,h.src=this.imgs[t]}else h.src=this.makeImgWithCanvas()},getRandom:(t,e)=>Math.ceil(Math.random()*(e-t)+t),makeImgSize(t){const e=t.width/t.height;let n=0,i=0,s=0,a=0;return e>this.canvasWidth/this.canvasHeight?(a=this.canvasHeight,s=e*a,i=0,n=(this.canvasWidth-s)/2):(s=this.canvasWidth,a=s/e,n=0,i=(this.canvasHeight-a)/2),[n,i,s,a]},paintBrick(t){const e=Math.ceil(15*this.puzzleScale);t.beginPath(),t.moveTo(this.pinX,this.pinY),t.lineTo(this.pinX+e,this.pinY),t.arcTo(this.pinX+e,this.pinY-e/2,this.pinX+e+e/2,this.pinY-e/2,e/2),t.arcTo(this.pinX+e+e,this.pinY-e/2,this.pinX+e+e,this.pinY,e/2),t.lineTo(this.pinX+e+e+e,this.pinY),t.lineTo(this.pinX+e+e+e,this.pinY+e),t.arcTo(this.pinX+e+e+e+e/2,this.pinY+e,this.pinX+e+e+e+e/2,this.pinY+e+e/2,e/2),t.arcTo(this.pinX+e+e+e+e/2,this.pinY+e+e,this.pinX+e+e+e,this.pinY+e+e,e/2),t.lineTo(this.pinX+e+e+e,this.pinY+e+e+e),t.lineTo(this.pinX,this.pinY+e+e+e),t.lineTo(this.pinX,this.pinY+e+e),t.arcTo(this.pinX+e/2,this.pinY+e+e,this.pinX+e/2,this.pinY+e+e/2,e/2),t.arcTo(this.pinX+e/2,this.pinY+e,this.pinX,this.pinY+e,e/2),t.lineTo(this.pinX,this.pinY)},makeImgWithCanvas(){const t=document.createElement(\"canvas\"),e=t.getContext(\"2d\");t.width=this.canvasWidth,t.height=this.canvasHeight,e.fillStyle=`rgb(${this.getRandom(100,255)},${this.getRandom(100,255)},${this.getRandom(100,255)})`,e.fillRect(0,0,this.canvasWidth,this.canvasHeight);for(let n=0;n<12;n++)if(e.fillStyle=`rgb(${this.getRandom(100,255)},${this.getRandom(100,255)},${this.getRandom(100,255)})`,e.strokeStyle=`rgb(${this.getRandom(100,255)},${this.getRandom(100,255)},${this.getRandom(100,255)})`,this.getRandom(0,2)>1)e.save(),e.rotate(this.getRandom(-90,90)*Math.PI/180),e.fillRect(this.getRandom(-20,t.width-20),this.getRandom(-20,t.height-20),this.getRandom(10,t.width/2+10),this.getRandom(10,t.height/2+10)),e.restore();else{e.beginPath();const n=this.getRandom(-Math.PI,Math.PI);e.arc(this.getRandom(0,t.width),this.getRandom(0,t.height),this.getRandom(10,t.height/2+10),n,n+1.5*Math.PI),e.closePath(),e.fill()}return t.toDataURL(\"image/png\")},submit(){this.isSubmting=!0;const t=Math.abs(this.pinX-(this.styleWidth-this.sliderBaseSize)+(this.puzzleBaseSize-this.sliderBaseSize)*((this.styleWidth-this.sliderBaseSize)/(this.canvasWidth-this.sliderBaseSize))-3);t<this.range?(this.infoText=this.successText,this.infoBoxFail=!1,this.infoBoxShow=!0,this.isCanSlide=!1,this.isSuccess=!0,clearTimeout(this.timer1),this.timer1=setTimeout((()=>{this.isSubmting=!1,this.$emit(\"success\",t)}),800)):(this.infoText=this.failText,this.infoBoxFail=!0,this.infoBoxShow=!0,this.isCanSlide=!1,this.$emit(\"fail\",t),clearTimeout(this.timer1),this.timer1=setTimeout((()=>{this.isSubmting=!1,this.reset()}),800))},resetState(){this.infoBoxFail=!1,this.infoBoxShow=!1,this.isCanSlide=!1,this.isSuccess=!1,this.startWidth=this.sliderBaseSize,this.startX=0,this.newX=0},reset(){this.isSubmting||(this.resetState(),this.init())}}},s=n(379),a=n.n(s),o=n(795),r=n.n(o),h=n(569),l=n.n(h),c=n(565),d=n.n(c),u=n(216),p=n.n(u),f=n(589),g=n.n(f),v=n(358),b={};b.styleTagTransform=g(),b.setAttributes=d(),b.insert=l().bind(null,\"head\"),b.domAPI=r(),b.insertStyleElement=p(),a()(v.Z,b),v.Z&&v.Z.locals&&v.Z.locals;var m=function(t,e,n,i,s,a,o,r){var h,l=\"function\"==typeof t?t.options:t;if(e&&(l.render=e,l.staticRenderFns=[function(){var t=this,e=t.$createElement,n=t._self._c||e;return n(\"div\",{staticClass:\"loading-gif_\"},[n(\"span\"),t._v(\" \"),n(\"span\"),t._v(\" \"),n(\"span\"),t._v(\" \"),n(\"span\"),t._v(\" \"),n(\"span\")])}],l._compiled=!0),h)if(l.functional){l._injectStyles=h;var c=l.render;l.render=function(t,e){return h.call(e),c(t,e)}}else{var d=l.beforeCreate;l.beforeCreate=d?[].concat(d,h):[h]}return{exports:t,options:l}}(e,t);m.options.__file=\"src/app.vue\";var x=m.exports}(),i}()}));"],"mappings":"AAAA","sourceRoot":""} //# sourceURL=webpack-internal:///./node_modules/vue-puzzle-vcode/dist/main.js
还没有评论,来说两句吧...