1 line
13 KiB
JavaScript

!function(t,n){"object"==typeof exports&&"object"==typeof module?module.exports=n():"function"==typeof define&&define.amd?define([],n):"object"==typeof exports?exports["vue-flip-down"]=n():t["vue-flip-down"]=n()}(window,(function(){return function(t){var n={};function e(i){if(n[i])return n[i].exports;var o=n[i]={i:i,l:!1,exports:{}};return t[i].call(o.exports,o,o.exports,e),o.l=!0,o.exports}return e.m=t,e.c=n,e.d=function(t,n,i){e.o(t,n)||Object.defineProperty(t,n,{enumerable:!0,get:i})},e.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},e.t=function(t,n){if(1&n&&(t=e(t)),8&n)return t;if(4&n&&"object"==typeof t&&t&&t.__esModule)return t;var i=Object.create(null);if(e.r(i),Object.defineProperty(i,"default",{enumerable:!0,value:t}),2&n&&"string"!=typeof t)for(var o in t)e.d(i,o,function(n){return t[n]}.bind(null,o));return i},e.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(n,"a",n),n},e.o=function(t,n){return Object.prototype.hasOwnProperty.call(t,n)},e.p="",e(e.s=1)}([function(t,n,e){var i=e(3),o=e(4);"string"==typeof(o=o.__esModule?o.default:o)&&(o=[[t.i,o,""]]);var r={insert:"head",singleton:!1},a=(i(t.i,o,r),o.locals?o.locals:{});t.exports=a},function(t,n,e){t.exports=e(6)},function(t,n,e){"use strict";var i=e(0);e.n(i).a},function(t,n,e){"use strict";var i,o=function(){return void 0===i&&(i=Boolean(window&&document&&document.all&&!window.atob)),i},r=function(){var t={};return function(n){if(void 0===t[n]){var e=document.querySelector(n);if(window.HTMLIFrameElement&&e instanceof window.HTMLIFrameElement)try{e=e.contentDocument.head}catch(t){e=null}t[n]=e}return t[n]}}(),a={};function s(t,n,e){for(var i=0;i<n.length;i++){var o={css:n[i][1],media:n[i][2],sourceMap:n[i][3]};a[t][i]?a[t][i](o):a[t].push(h(o,e))}}function c(t){var n=document.createElement("style"),i=t.attributes||{};if(void 0===i.nonce){var o=e.nc;o&&(i.nonce=o)}if(Object.keys(i).forEach((function(t){n.setAttribute(t,i[t])})),"function"==typeof t.insert)t.insert(n);else{var a=r(t.insert||"head");if(!a)throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");a.appendChild(n)}return n}var u,p=(u=[],function(t,n){return u[t]=n,u.filter(Boolean).join("\n")});function l(t,n,e,i){var o=e?"":i.css;if(t.styleSheet)t.styleSheet.cssText=p(n,o);else{var r=document.createTextNode(o),a=t.childNodes;a[n]&&t.removeChild(a[n]),a.length?t.insertBefore(r,a[n]):t.appendChild(r)}}function d(t,n,e){var i=e.css,o=e.media,r=e.sourceMap;if(o?t.setAttribute("media",o):t.removeAttribute("media"),r&&btoa&&(i+="\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(r))))," */")),t.styleSheet)t.styleSheet.cssText=i;else{for(;t.firstChild;)t.removeChild(t.firstChild);t.appendChild(document.createTextNode(i))}}var f=null,m=0;function h(t,n){var e,i,o;if(n.singleton){var r=m++;e=f||(f=c(n)),i=l.bind(null,e,r,!1),o=l.bind(null,e,r,!0)}else e=c(n),i=d.bind(null,e,n),o=function(){!function(t){if(null===t.parentNode)return!1;t.parentNode.removeChild(t)}(e)};return i(t),function(n){if(n){if(n.css===t.css&&n.media===t.media&&n.sourceMap===t.sourceMap)return;i(t=n)}else o()}}t.exports=function(t,n,e){return(e=e||{}).singleton||"boolean"==typeof e.singleton||(e.singleton=o()),t=e.base?t+e.base:t,n=n||[],a[t]||(a[t]=[]),s(t,n,e),function(n){if(n=n||[],"[object Array]"===Object.prototype.toString.call(n)){a[t]||(a[t]=[]),s(t,n,e);for(var i=n.length;i<a[t].length;i++)a[t][i]();a[t].length=n.length,0===a[t].length&&delete a[t]}}}},function(t,n,e){(n=e(5)(!1)).push([t.i,'.vue-countdown-component {\n display: -webkit-box;\n display: -webkit-flex;\n display: flex;\n}\n@-webkit-keyframes animate-filp-face {\n0% {\n -webkit-transform: rotateX(-0.01deg);\n transform: rotateX(-0.01deg);\n opacity: 1;\n}\n50% {\n opacity: 1;\n}\n51% {\n opacity: 0;\n}\n100% {\n -webkit-transform: rotateX(-180deg);\n transform: rotateX(-180deg);\n opacity: 0;\n}\n}\n@keyframes animate-filp-face {\n0% {\n -webkit-transform: rotateX(-0.01deg);\n transform: rotateX(-0.01deg);\n opacity: 1;\n}\n50% {\n opacity: 1;\n}\n51% {\n opacity: 0;\n}\n100% {\n -webkit-transform: rotateX(-180deg);\n transform: rotateX(-180deg);\n opacity: 0;\n}\n}\n@-webkit-keyframes animate-filp-back {\n0% {\n -webkit-transform: rotateX(180deg);\n transform: rotateX(180deg);\n}\n100% {\n -webkit-transform: rotateX(-0.01deg);\n transform: rotateX(-0.01deg);\n}\n}\n@keyframes animate-filp-back {\n0% {\n -webkit-transform: rotateX(180deg);\n transform: rotateX(180deg);\n}\n100% {\n -webkit-transform: rotateX(-0.01deg);\n transform: rotateX(-0.01deg);\n}\n}\n.vue-countdown-component.ie .base .base-b {\n clip: rect(15px, auto, auto, auto);\n}\n.vue-countdown-component.ie .face {\n clip: rect(auto, auto, 15px, auto);\n}\n.vue-countdown-component.ie .back {\n clip: rect(15px, auto, auto, auto);\n}\n.vue-countdown-component.theme2 .time-box {\n min-width: 20px;\n}\n.vue-countdown-component.theme2 .time-box + .time-box {\n margin-left: 1px;\n}\n.vue-countdown-component .time-unit {\n padding: 0 4px;\n color: #222;\n font-size: 14px;\n line-height: 30px;\n white-space: nowrap;\n}\n.vue-countdown-component .time-box {\n position: relative;\n box-sizing: border-box;\n height: 30px;\n min-width: 28px;\n font-size: 14px;\n text-align: center;\n background-color: #6c96e8;\n -webkit-perspective: 60px;\n perspective: 60px;\n border-radius: 3px;\n padding: 0 2px;\n color: #fff;\n line-height: 30px;\n}\n.vue-countdown-component .time-box:before {\n content: "";\n position: absolute;\n background: #a7c7ff;\n width: 1px;\n height: 6px;\n top: 50%;\n left: -1px;\n margin-top: -3px;\n z-index: -1;\n}\n.vue-countdown-component .time-box:after {\n content: "";\n position: absolute;\n background: #a7c7ff;\n width: 1px;\n height: 6px;\n top: 50%;\n right: -1px;\n margin-top: -3px;\n z-index: -1;\n}\n.vue-countdown-component .time-box + .time-box {\n margin-left: 8px;\n}\n.vue-countdown-component .time-box > div {\n overflow: hidden;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear;\n -webkit-animation-duration: 400ms;\n animation-duration: 400ms;\n -webkit-transform: rotateX(-0.01deg);\n transform: rotateX(-0.01deg);\n border-radius: 3px;\n}\n.vue-countdown-component .time-box > div.base {\n position: relative;\n}\n.vue-countdown-component .time-box > div.base .base-b {\n position: absolute;\n left: 0;\n bottom: 0;\n border-radius: 0 0 3px 3px;\n width: 100%;\n height: 100%;\n background-color: #709bf1;\n -webkit-clip-path: polygon(0 50%, 100% 50%, 100% 100%, 0 100%);\n clip-path: polygon(0 50%, 100% 50%, 100% 100%, 0 100%);\n}\n.vue-countdown-component .time-box > div.face {\n position: absolute;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n background-color: #6c96e8;\n -webkit-backface-visibility: visible;\n backface-visibility: visible;\n -webkit-clip-path: polygon(0 0, 100% 0, 100% 50%, 0 50%);\n clip-path: polygon(0 0, 100% 0, 100% 50%, 0 50%);\n z-index: 2;\n}\n.vue-countdown-component .time-box > div.face.anime {\n -webkit-animation-name: animate-filp-face;\n animation-name: animate-filp-face;\n}\n.vue-countdown-component .time-box > div.back {\n position: absolute;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n background-color: #709bf1;\n -webkit-transform: rotateX(-180deg);\n transform: rotateX(-180deg);\n -webkit-backface-visibility: visible;\n backface-visibility: visible;\n -webkit-clip-path: polygon(0 50%, 100% 50%, 100% 100%, 0 100%);\n clip-path: polygon(0 50%, 100% 50%, 100% 100%, 0 100%);\n}\n.vue-countdown-component .time-box > div.back.anime {\n -webkit-animation-name: animate-filp-back;\n animation-name: animate-filp-back;\n}\n',""]),t.exports=n},function(t,n,e){"use strict";t.exports=function(t){var n=[];return n.toString=function(){return this.map((function(n){var e=function(t,n){var e=t[1]||"",i=t[3];if(!i)return e;if(n&&"function"==typeof btoa){var o=(a=i,s=btoa(unescape(encodeURIComponent(JSON.stringify(a)))),c="sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(s),"/*# ".concat(c," */")),r=i.sources.map((function(t){return"/*# sourceURL=".concat(i.sourceRoot).concat(t," */")}));return[e].concat(r).concat([o]).join("\n")}var a,s,c;return[e].join("\n")}(n,t);return n[2]?"@media ".concat(n[2]," {").concat(e,"}"):e})).join("")},n.i=function(t,e){"string"==typeof t&&(t=[[null,t,""]]);for(var i=0;i<t.length;i++){var o=[].concat(t[i]);e&&(o[2]?o[2]="".concat(e," and ").concat(o[2]):o[2]=e),n.push(o)}},n}},function(t,n,e){"use strict";e.r(n);var i=function(){var t=this,n=t.$createElement,e=t._self._c||n;return e("div",{class:["vue-countdown-component",{theme2:1!==t.theme},{ie:t.isIE}]},[t._l(t.timeArray,(function(n,i){return[e("div",{key:i,class:["time-box"]},[e("div",{staticClass:"base"},[t._v(t._s(n)),e("div",{staticClass:"base-b"},[t._v(t._s(t.timeArrayT[i]))])]),t._v(" "),e("div",{class:["face",{anime:t.isAnimate[i]}],on:{animationend:function(n){return t.onAnimateEnd(i)}}},[t._v(t._s(t.timeArrayT[i]))]),t._v(" "),e("div",{class:["back",{anime:t.isAnimate[i]}]},[t._v(t._s(n))])]),t._v(" "),t.isTimeUnitShow(i)?e("div",{key:"unit-"+i,staticClass:"time-unit"},[t._v("\n "+t._s(t.setTimeUnit(i))+"\n ")]):t._e()]}))],2)};i._withStripped=!0;var o={data(){return{isIE:!1,timeArray:2===this.theme?new Array(2*this.type).fill("0"):new Array(this.type).fill("00"),timeArrayT:2===this.theme?new Array(2*this.type).fill("0"):new Array(this.type).fill("00"),isAnimate:2===this.theme?new Array(2*this.type).fill(!1):new Array(this.type).fill(!1)}},props:{endDate:{type:[Date,Number,String],default:0},type:{type:[Number,String],default:4},theme:{type:[Number,String],default:1},timeUnit:{type:Array,default:()=>[]}},computed:{endTime(){return this.endDate instanceof Date?this.endDate.getTime():Number(this.endDate)>0?Number(this.endDate):0},step(){return 1===this.theme?1:2},arr(){const t=this.timeArray.length,n=this.step,e=[t-1,t-n-1,t-2*n-1,t-3*n-1];return e.length=this.type>1?this.type:1,e}},watch:{timeArray(t,n){const e=[];t.forEach((t,i)=>{t!==n[i]&&(e.push({value:t,index:i}),this.$set(this.isAnimate,i,!0))}),setTimeout(()=>{e.forEach(t=>{this.$set(this.timeArrayT,t.index,t.value)})},350)},endTime(t){t>0&&this.start()}},mounted(){(window.ActiveXObject||"ActiveXObject"in window||window.navigator.userAgent.indexOf("Edge")>-1)&&(this.isIE=!0),this.start(0)},beforeDestroy(){clearTimeout(this.timer)},methods:{start(t=1e3){clearTimeout(this.timer),this.timer=setTimeout(()=>{let t=this.endTime-(new Date).getTime();t=t<0?0:t;let n=0,e=0,i=0,o=0;const r=Number(this.type);r>=4?(n=Math.floor(t/864e5),e=Math.floor(t/36e5-24*n),i=Math.floor(t/6e4-1440*n-60*e),o=Math.floor(t/1e3-86400*n-3600*e-60*i)):r>=3?(e=Math.floor(t/36e5),i=Math.floor(t/6e4-60*e),o=Math.floor(t/1e3-3600*e-60*i)):r>=2?(i=Math.floor(t/6e4),o=Math.floor(t/1e3-60*i)):o=Math.floor(t/1e3);let a=[];1===Number(this.theme)?(r>=4&&a.push(String(n).padStart(2,"0")),r>=3&&a.push(String(e).padStart(2,"0")),r>=2&&a.push(String(i).padStart(2,"0")),a.push(String(o).padStart(2,"0"))):(r>=4&&a.push(...String(n).padStart(2,"0").split("")),r>=3&&a.push(...String(e).padStart(2,"0").split("")),r>=2&&a.push(...String(i).padStart(2,"0").split("")),a.push(...String(o).padStart(2,"0").split(""))),this.timeArray=a,t>0?this.start():this.$emit("timeUp")},t)},onAnimateEnd(t){this.$set(this.isAnimate,t,!1)},isTimeUnitShow(t){return!!this.arr.includes(t)&&!(t===this.timeArray.length-1&&!this.timeUnit[3])},setTimeUnit(t){switch(t){case this.timeArray.length-1:return this.timeUnit[3]||"";case this.timeArray.length-this.step-1:return this.timeUnit[2]||"";case this.timeArray.length-2*this.step-1:return this.timeUnit[1]||"";default:return this.timeUnit[0]||""}}}};e(2);var r=function(t,n,e,i,o,r,a,s){var c,u="function"==typeof t?t.options:t;if(n&&(u.render=n,u.staticRenderFns=e,u._compiled=!0),i&&(u.functional=!0),r&&(u._scopeId="data-v-"+r),a?(c=function(t){(t=t||this.$vnode&&this.$vnode.ssrContext||this.parent&&this.parent.$vnode&&this.parent.$vnode.ssrContext)||"undefined"==typeof __VUE_SSR_CONTEXT__||(t=__VUE_SSR_CONTEXT__),o&&o.call(this,t),t&&t._registeredComponents&&t._registeredComponents.add(a)},u._ssrRegister=c):o&&(c=s?function(){o.call(this,this.$root.$options.shadowRoot)}:o),c)if(u.functional){u._injectStyles=c;var p=u.render;u.render=function(t,n){return c.call(n),p(t,n)}}else{var l=u.beforeCreate;u.beforeCreate=l?[].concat(l,c):[c]}return{exports:t,options:u}}(o,i,[],!1,null,null,null);r.options.__file="src/app.vue";var a=r.exports;n.default=a}])}));