diff options
Diffstat (limited to 'docs/index.js')
-rw-r--r-- | docs/index.js | 212 |
1 files changed, 211 insertions, 1 deletions
diff --git a/docs/index.js b/docs/index.js index 5b0517223..23773e1bd 100644 --- a/docs/index.js +++ b/docs/index.js @@ -1,5 +1,42 @@ var isMac = false +;(function(){ +"use strict"; + + +// anim.min.js +var anim=function(h){h=function(a,e,f,b){var g,d,c=[],j=function(a){ +if(a=c.shift())a[1]?h.apply(this,a).anim(j):0<a[0]?setTimeout(j,1E3*a[0]):(a[0](),j())}; +a.charAt&&(a=document.getElementById(a));if(0<a||!a)e={},f=0,j(c=[[a||0]]); +q(e,{padding:0,margin:0,border:"Width"},[l,m,n,p]);q(e,{borderRadius:"Radius"},[l+p,l+m,n+m,n+p]);++r; +for(g in e)d=e[g],!d.to&&0!==d.to&&(d=e[g]={to:d}),h.defs(d,a,g,b);h.iter(e,1E3*f,j); +return{anim:function(){c.push([].slice.call(arguments));return this}}}; +var l="Top", m="Right",n="Bottom",p="Left",r=1,q=function(a,e,f,b,g,d,c){for(b in a)if(b in e){c=a[b]; +for(g=0;d=f[g];g++)a[b.replace(e[b],"")+d+(e[b]||"")]={to:0===c.to?c.to:c.to||c,fr:c.fr,e:c.e}; +delete a[b]}},s=function(w,a){return w["r"+a]||w["webkitR"+a]||w["mozR"+a]||w["msR"+a]||w["oR"+a]}( +window,"equestAnimationFrame");h.defs=function(a,e,f,b,g){g=e.style;a.a=f;a.n=e;a.s=f in g?g:e; +a.e=a.e||b;a.fr=a.fr||(0===a.fr?0:a.s==e?e[f]:(window.getComputedStyle?getComputedStyle(e, null) +:e.currentStyle)[f]);a.u=(/\d(\D+)$/.exec(a.to)||/\d(\D+)$/.exec(a.fr)||[0,0])[1];a.fn=/color/i.test(f)? +h.fx.color:h.fx[f]||h.fx._;a.mx="anim_"+f;e[a.mx]=a.mxv=r;e[a.mx]!=a.mxv&&(a.mxv=null)};h.iter=function(a,e,f){ +var b,g,d,c,h,k=+new Date+e;b=function(){g=k-(new Date).getTime();if(50>g){ +for(d in a)d=a[d],d.p=1,d.fn(d,d.n,d.to,d.fr,d.a,d.e);f&&f()}else{g/=e;for(d in a){d=a[d]; +if(d.n[d.mx]!=d.mxv)return;h=d.e;c=g;"lin"==h?c=1-c:"ease"==h?(c=2*(0.5-c),c=1-(c*c*c-3*c+2)/4): +"ease-in"==h?(c= 1-c,c*=c*c):c=1-c*c*c;d.p=c;d.fn(d,d.n,d.to,d.fr,d.a,d.e)}s?s(b):setTimeout(b,20)}}; +b()};h.fx={_:function(a,e,f,b,g){b=parseFloat(b)||0;f=parseFloat(f)||0;a.s[g]=(1<=a.p?f:a.p*(f-b)+b)+a.u}, +width:function(a,e,f,b,g,d){0<=a._fr||(a._fr=!isNaN(b=parseFloat(b))?b:"width"==g?e.clientWidth:e.clientHeight); +h.fx._(a,e,f,a._fr,g,d)},opacity:function(a,e,f,b,g){if(isNaN(b=b||a._fr))b=e.style,b.zoom=1, +b=a._fr=(/alpha\(opacity=(\d+)\b/i.exec(b.filter)||{})[1]/100||1;b*=1;f=a.p*(f-b)+b;e=e.style;g in e?e[g]= f: +e.filter=1<=f?"":"alpha("+g+"="+Math.round(100*f)+")"},color:function(a,e,f,b,g,d,c,j){ +a.ok||(f=a.to=h.toRGBA(f),b=a.fr=h.toRGBA(b),0==f[3]&&(f=[].concat(b),f[3]=0),0==b[3]&& +(b=[].concat(f),b[3]=0),a.ok=1);j=[0,0,0,a.p*(f[3]-b[3])+1*b[3]];for(c=2;0<=c;c--)j[c]=Math.round( +a.p*(f[c]-b[c])+1*b[c]);(1<=j[3]||h.rgbaIE)&&j.pop();try{a.s[g]=(3<j.length?"rgba(":"rgb(")+j.join(",")+")" +}catch(k){h.rgbaIE=1}}};h.fx.height=h.fx.width; +h.RGBA=/#(.)(.)(.)\b|#(..)(..)(..)\b|(\d+)%,(\d+)%,(\d+)%(?:,([\d\.]+))?|(\d+),(\d+),(\d+)(?:,([\d\.]+))?\b/; +h.toRGBA=function(a,e){e=[0,0,0,0];a.replace(/\s/g,"").replace(h.RGBA,function(a,b,g,d,c,h,k,l,m,n,p,q,r,s,t){ +k=[b+b||c,g+g||h,d+d||k];b=[l,m,n];for(a=0;3>a;a++)k[a]=parseInt(k[a],16),b[a]=Math.round(2.55*b[a]); +e=[k[0]||b[0]||q||0,k[1]||b[1]||r||0,k[2]||b[2]||s||0,p||t||1]});return e};return h}(); + + if (!window.MSStream && /mac|ipad|iphone|ipod/i.test(navigator.userAgent)) { @@ -10,9 +47,182 @@ if (!window.MSStream && } } -(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ + +// timeNow() :float +var timeNow = ( + window.performance !== undefined && window.performance.now ? function() { + return window.performance.now() + } : Date.now ? function() { + return Date.now() + } : function() { + return (new Date()).getTime() + } +) + + +// Carousel +var carousel = document.querySelector('.carousel') +if (carousel) { + var itemsContainer = carousel.querySelector('.items') + var dotsContainer = carousel.querySelector('.dots') + var singleStepAnimDuration = 0.25 + + var currentCenterItem = itemsContainer.children[0] + var currentDot = null + var lastScrollResponseTimestamp = 0 + + itemsContainer.addEventListener('click', scrollToNext) + + Array.prototype.slice.call(itemsContainer.children).forEach(function(item, index) { + item.dataset.index = index + + if (!item.complete) { + var hasLoaded = false + var loadTimer = setTimeout(function(){ + if (!hasLoaded) { + item.classList.add('loading') + } + }, 10) + item.addEventListener('load', function() { + hasLoaded = true + clearTimeout(loadTimer) + item.classList.remove('loading') + }) + } + + if (index+1 == itemsContainer.children.length) { + item.style.cursor = 'w-resize'; + } + + if (dotsContainer) { + var dot = document.createElement('div') + dot.className = 'dot' + + var graphic = document.createElement('div') + graphic.className = 'graphic' + dot.appendChild(graphic) + + dot.addEventListener('click', function(ev) { + lastScrollResponseTimestamp = ev.timeStamp + var stepDistance = Math.abs(currentCenterItem.dataset.index - index) + selectItem(item, singleStepAnimDuration * stepDistance * 0.7) + }, {capture:false, passive:true}) + dotsContainer.appendChild(dot) + } + }) + + + function updateDot() { + if (currentDot) { + currentDot.classList.remove('active') + } + if (currentCenterItem) { + currentDot = dotsContainer.children[currentCenterItem.dataset.index] + currentDot.classList.add('active') + } + } + + + updateDot() + + + function selectItem(item, animDuration) { + currentCenterItem = item + var scrollLeftTarget = currentCenterItem.offsetLeft - itemsContainer.offsetLeft + // updateDot() + anim(itemsContainer, {scrollLeft: scrollLeftTarget}, animDuration, "ease-out") + } + + + // TODO: cursor on left side to go in "previous" direction + + + function scrollToNext(ev) { + if (!currentCenterItem) { + return + } + + var animDuration = singleStepAnimDuration + var nextItem = currentCenterItem.nextElementSibling + if (!nextItem) { + nextItem = itemsContainer.children[0] + animDuration *= 2 + } + + lastScrollResponseTimestamp = ev.timeStamp + selectItem(nextItem, animDuration) + } + + + var scrollUpdateCenterItemTimer = null + + + function updateCenterItem() { + var scrollCenterX = itemsContainer.scrollLeft + (itemsContainer.clientWidth / 2) + var offsX = itemsContainer.offsetLeft + var i, e, itemOffsX, scrollLeftTarget = 0 + + for (i = 0; i < itemsContainer.children.length; ++i) { + e = itemsContainer.children[i] + itemOffsX = e.offsetLeft - offsX + if (scrollCenterX < itemOffsX + e.clientWidth) { + // pick this element + break + } + } + + if (!e) { + return + } + + currentCenterItem = e + updateDot() + } + + + function updateCarouselFocus() { + updateCenterItem() + var scrollLeftTarget = currentCenterItem.offsetLeft - itemsContainer.offsetLeft + anim(itemsContainer, {scrollLeft: scrollLeftTarget}, 0.25, "ease") + } + + + var scrollUpdateTimer = null + + itemsContainer.addEventListener('scroll', function(ev) { + clearTimeout(scrollUpdateTimer) + + if (ev.timeStamp - lastScrollResponseTimestamp < 100) { + // ignore scroll event caused by reacting to scroll events + return + } + + updateCenterItem() + + var timeStamp = ev.timeStamp + 90 + scrollUpdateTimer = setTimeout(function(){ + lastScrollResponseTimestamp = timeStamp + updateCarouselFocus() + }, 90) + }, {capture:false, passive:true}) + + window.addEventListener('resize', function(ev) { + clearTimeout(scrollUpdateTimer) + lastScrollResponseTimestamp = ev.timeStamp + updateCenterItem() + var scrollLeftTarget = currentCenterItem.offsetLeft - itemsContainer.offsetLeft + itemsContainer.scrollLeft = scrollLeftTarget + }, {capture:false, passive:true}) + +} + + +// Google Analytics +;(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o), m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m) })(window,document,'script','https://www.google-analytics.com/analytics.js','ga'); ga('create', 'UA-105091131-2', 'auto'); ga('send', 'pageview'); + +})(); |