kute.js/dist/kute.min.js

3 lines
34 KiB
JavaScript
Raw Normal View History

2020-06-20 11:23:25 +02:00
// KUTE.js Standard v2.0.6 | thednp © 2020 | MIT-License
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t=t||self).KUTE=e()}(this,(function(){"use strict";var t={},e=[],n="undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{};function r(t,e,n){return(t=+t)+(e-=t)*n}var i={numbers:r,units:function(t,e,n,r){return(t=+t)+(e-=t)*r+n},arrays:function(t,e,n){for(var r=[],i=0,a=e.length;i<a;i++)r[i]=(1e3*(t[i]+(e[i]-t[i])*n)>>0)/1e3;return r}},a={},s={};"undefined"==typeof self&&"undefined"!=typeof process&&process.hrtime?s.now=function(){var t=process.hrtime();return 1e3*t[0]+t[1]/1e6}:"undefined"!=typeof self&&void 0!==self.performance&&void 0!==self.performance.now&&(s.now=self.performance.now.bind(self.performance));var o=0,u=function(t){for(var n=0;n<e.length;)e[n].update(t)?n++:e.splice(n,1);o=requestAnimationFrame(u)};function l(){setTimeout((function(){if(!e.length&&o){for(var n in cancelAnimationFrame(o),o=null,a)if("function"==typeof a[n])t[n]&&delete t[n];else for(var r in a[n])t[r]&&delete t[r];for(var s in i)t[s]&&delete t[s]}}),64)}var c={Tick:o,Ticker:u,Tweens:e,Time:s};for(var p in c)t[p]||(t[p]="Time"===p?s.now:c[p]);n._KUTE=t;var h={},f={},d={duration:700,delay:0,easing:"linear"},v={},g={},m={},y={},w={},b={supportedProperties:h,defaultValues:f,defaultOptions:d,prepareProperty:v,prepareStart:g,crossCheck:m,onStart:a,onComplete:y,linkProperty:w},_={},x={};function S(t){return e.push(t)}function T(t){var n=e.indexOf(t);-1!==n&&e.splice(n,1)}function E(){var e=this,n=function(n){var r=w[n],i=h[n];for(var a in r)if("function"==typeof r[a]&&Object.keys(e.valuesEnd).some((function(t){return i&&i.includes(t)||"attr"===t&&Object.keys(e.valuesEnd[t]).some((function(t){return i&&i.includes(t)}))})))!t[a]&&(t[a]=r[a]);else for(var s in e.valuesEnd)for(var o in e.valuesEnd[s])if("function"==typeof r[o])!t[o]&&(t[o]=r[o]);else for(var u in r[a])r[o]&&"function"==typeof r[o][u]&&!t[u]&&(t[u]=r[o][u])};for(var r in w)n(r)}var C={add:S,remove:T,getAll:function(){return e},removeAll:function(){e.length=0},stop:l,linkInterpolation:E};function I(t){if(t.style){var e=t.style.cssText.replace(/\s/g,"").split(";"),n={},r=["translate3d","translate","scale3d","skew"];return e.map((function(t){/transform/i.test(t)&&t.split(":")[1].split(")").map((function(t){var e=t.split("("),i=e[0],a=e[1];/matrix/.test(i)||(n[i]=r.includes(i)?a.split(","):a)}))})),n}}function A(t,e){var n=t.style,r=getComputedStyle(t)||t.currentStyle,i=n[e]&&!/auto|initial|none|unset/.test(n[e])?n[e]:r[e];if("transform"!==e&&(e in r||e in n))return i||f[e]}function M(t,e){var n="start"===e?this.valuesStart:this.valuesEnd;for(var r in v){var i=v[r],a=h[r];for(var s in i){var o={};for(var u in t)f[u]&&i[u]?n[u]=i[u].call(this,u,t[u]):!f[s]&&"transform"===s&&a.includes(u)?o[u]=t[u]:!f[s]&&a&&a.includes(u)&&(n[u]=i[s].call(this,u,t[u]));Object.keys&&Object.keys(o).length&&(n[s]=i[s].call(this,s,o))}}}function k(){var t={},e=I(this.element);for(var n in this.valuesStart)for(var r in g){var i=g[r];for(var a in i)(a===n&&i[n]||h[r]&&h[r].includes(n))&&(t[n]=i[a].call(this,n,this.valuesStart[n]))}for(var s in e)s in this.valuesStart||(t[s]=e[s]||f[s]);this.valuesStart={},M.call(this,t,"start")}var O={getInlineStyle:I,getStyleForProperty:A,getStartValues:k,prepareObject:M},L=function(t,e,n,r,i){var a=this;this.cx=3*t,this.bx=3*(n-t)-this.cx,this.ax=1-this.cx-this.bx,this.cy=3*e,this.by=3*(r-e)-this.cy,this.ay=1-this.cy-this.by;var s=function(t){return a.sampleCurveY(a.solveCurveX(t))};return Object.defineProperty(s,"name",{writable:!0}),s.name=i||"cubic-bezier("+[t,e,n,r]+")",s};L.prototype.sampleCurveX=function(t){return((this.ax*t+this.bx)*t+this.cx)*t},L.prototype.sampleCurveY=function(t){return((this.ay*t+this.by)*t+this.cy)*t},L.prototype.sampleCurveDerivativeX=function(t){return(3*this.ax*t+2*this.bx)*t+this.cx},L.prototype.solveCurveX=function(t){var e,n,r,i,a,s;for(r=t,s=0;s<32;s++){if(i=this.sampleCurveX(r)-t,Math.abs(i)<1e-5)return r;if(a=this.sampleCurveDerivativeX(r),Math.abs(a)<1e-5)br