svg-scroll-draw 2.6.0 → 2.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/angular/index.cjs +3 -3
- package/dist/angular/index.d.mts +22 -0
- package/dist/angular/index.d.ts +22 -0
- package/dist/angular/index.mjs +3 -3
- package/dist/astro/index.cjs +3 -3
- package/dist/astro/index.d.mts +8 -0
- package/dist/astro/index.d.ts +8 -0
- package/dist/astro/index.mjs +3 -3
- package/dist/cdn/svg-scroll-draw.global.js +3 -3
- package/dist/devtools/index.cjs +1 -1
- package/dist/devtools/index.mjs +1 -1
- package/dist/group/index.cjs +3 -3
- package/dist/group/index.d.mts +22 -0
- package/dist/group/index.d.ts +22 -0
- package/dist/group/index.mjs +3 -3
- package/dist/horizontal/index.cjs +1 -0
- package/dist/horizontal/index.d.mts +61 -0
- package/dist/horizontal/index.d.ts +61 -0
- package/dist/horizontal/index.mjs +1 -0
- package/dist/index.cjs +4 -4
- package/dist/index.d.mts +22 -0
- package/dist/index.d.ts +22 -0
- package/dist/index.mjs +4 -4
- package/dist/lenis/index.cjs +1 -0
- package/dist/lenis/index.d.mts +51 -0
- package/dist/lenis/index.d.ts +51 -0
- package/dist/lenis/index.mjs +1 -0
- package/dist/nuxt/index.cjs +2 -2
- package/dist/nuxt/index.d.mts +22 -0
- package/dist/nuxt/index.d.ts +22 -0
- package/dist/nuxt/index.mjs +2 -2
- package/dist/pin/index.cjs +1 -0
- package/dist/pin/index.d.mts +29 -0
- package/dist/pin/index.d.ts +29 -0
- package/dist/pin/index.mjs +1 -0
- package/dist/progress/index.cjs +1 -0
- package/dist/progress/index.d.mts +59 -0
- package/dist/progress/index.d.ts +59 -0
- package/dist/progress/index.mjs +1 -0
- package/dist/react/index.cjs +3 -3
- package/dist/react/index.d.mts +22 -0
- package/dist/react/index.d.ts +22 -0
- package/dist/react/index.mjs +3 -3
- package/dist/reveal/index.cjs +1 -0
- package/dist/reveal/index.d.mts +80 -0
- package/dist/reveal/index.d.ts +80 -0
- package/dist/reveal/index.mjs +1 -0
- package/dist/snap/index.cjs +1 -0
- package/dist/snap/index.d.mts +30 -0
- package/dist/snap/index.d.ts +30 -0
- package/dist/snap/index.mjs +1 -0
- package/dist/solid/index.cjs +3 -3
- package/dist/solid/index.d.mts +22 -0
- package/dist/solid/index.d.ts +22 -0
- package/dist/solid/index.mjs +3 -3
- package/dist/svelte/index.cjs +3 -3
- package/dist/svelte/index.d.mts +22 -0
- package/dist/svelte/index.d.ts +22 -0
- package/dist/svelte/index.mjs +3 -3
- package/dist/vue/index.cjs +2 -2
- package/dist/vue/index.d.mts +22 -0
- package/dist/vue/index.d.ts +22 -0
- package/dist/vue/index.mjs +2 -2
- package/dist/web-component/index.cjs +3 -3
- package/dist/web-component/index.mjs +3 -3
- package/package.json +31 -1
package/dist/vue/index.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import {defineComponent,ref,onMounted,onUnmounted,h}from'vue';function
|
|
1
|
+
import {defineComponent,ref,onMounted,onUnmounted,h}from'vue';function Mt({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,r)),l=Math.sqrt(t),s=0,m=[];for(let h=0;h<n;h++){let P=Math.pow(l,h);m.push(P),s+=P;}let c=[0],u=0;for(let h=0;h<n;h++)u+=m[h]/s,c.push(u);return h=>{if(h<=0)return 0;if(h>=1)return 1;for(let P=0;P<n;P++)if(h<=c[P+1]){let H=(h-c[P])/(c[P+1]-c[P]);if(P===0)return H*(2-H);let S=1-Math.pow(t,P);return S+(1-S)*(2*H-1)*(2*H-1)}return 1}}function Ct({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),t=Math.max(.1,r),l=n<=1?t/4:t/(2*Math.PI)*Math.asin(1/n);return s=>s<=0?0:s>=1?1:n*Math.pow(2,-10*s)*Math.sin((s-l)*(2*Math.PI)/t)+1}var ae={linear:e=>e,"ease-in":e=>e*e,"ease-out":e=>e*(2-e),"ease-in-out":e=>e<.5?2*e*e:-1+(4-2*e)*e,spring:e=>1-Math.cos(e*Math.PI*2.5)*Math.pow(1-e,2.2),bounce:Mt(),elastic:Ct()};function le(e="top bottom"){let r=e.trim();if(/^\d+(\.\d+)?%$/.test(r))return {element:"top",viewport:r};let[n="top",t="bottom"]=r.split(/\s+/).filter(Boolean);return {element:n,viewport:t}}function lt(e,r,n,t){switch(t){case "top":return e+n;case "center":return e+n+r/2;case "bottom":return e+n+r;default:return e+n}}function ct(e,r){if(/^\d+(\.\d+)?%$/.test(e))return r*(parseFloat(e)/100);switch(e){case "top":return 0;case "center":return r/2;case "bottom":return r;default:return r}}function Ye(e){let r=e.tagName.toLowerCase();if(r==="rect"){let n=parseFloat(e.getAttribute("width")??"0"),t=parseFloat(e.getAttribute("height")??"0");return 2*(n+t)}if(r==="circle"){let n=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*n}return e.getTotalLength()}function Lt(e,r,n){return Math.min(n,Math.max(r,e))}function Q(e,r,n,t){return n===r?0:Lt((e-r)/(n-r)*t,0,1)}function ye(e,r,n,t,l){let s=lt(e.top,e.height,r,t.element)-ct(t.viewport,n),m=lt(e.top,e.height,r,l.element)-ct(l.viewport,n);return {tStart:s,tEnd:m}}function ut(e){let r=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(r)return [parseInt(r[1]+r[1],16),parseInt(r[2]+r[2],16),parseInt(r[3]+r[3],16)];let n=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(n)return [parseInt(n[1],16),parseInt(n[2],16),parseInt(n[3],16)];let t=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return t?[parseInt(t[1]),parseInt(t[2]),parseInt(t[3])]:null}function Re(e,r,n){let t=ut(e),l=ut(r);return !t||!l?e:`rgb(${Math.round(t[0]+(l[0]-t[0])*n)},${Math.round(t[1]+(l[1]-t[1])*n)},${Math.round(t[2]+(l[2]-t[2])*n)})`}var ft={sketch:{easing:"ease-in",stagger:.1,speed:.9,fade:false},reveal:{easing:"ease-out",fade:true,speed:1.2,once:true},typewriter:{easing:"linear",stagger:.05,speed:1.5},cinematic:{easing:"ease-in-out",fade:true,speed:.75},spring:{easing:"spring",speed:1.1}};function mt(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r);}var pt={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},$t=0;function Pt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Ot(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?mt("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&mt("Element has a fill \u2014 it may obscure the stroke animation.",e);}function kt(e,r,n){let t=document.createElement("div");t.setAttribute("data-svg-scroll-draw-debug",""),t.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function l(){let s=n==="x"?window.scrollX:window.scrollY,m=e-s,c=r-s,u=n==="x";t.innerHTML=`
|
|
2
2
|
<div style="position:absolute;${u?`left:${m}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${m}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
|
|
3
|
-
<div style="position:absolute;${u?`left:${c}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${c}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(t),window.addEventListener("scroll",l,{passive:true}),l(),t}function Xe(e,r,n){let t=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),l=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,s=>{let m=parseFloat(s),c=t[l++]??m;return String(+(m+(c-m)*n).toFixed(4))})}function Ye(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:n,...t}=r,l=n?{...it[n],...t}:t,s=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:m="path, polyline, line, polygon, rect, circle",speed:c=1,fade:u=false,easing:d="linear",trigger:F={},stagger:B=0,direction:S="forward",once:ne=false,debug:de=false,axis:q="y",scrollContainer:K,autoReverse:T=false,delay:R=0,strokeColor:A,strokeWidth:C,fillOpacity:$,waypoints:b,velocityScale:L=false,threshold:k=0,rootMargin:D="0px",repeat:M=0,repeatDelay:z=0,morphTo:P,clip:_,autoplay:Q=false,duration:Y=1e3,native:se=true,onProgress:p,onStart:O,onComplete:y}=l,f=_===true?"left":typeof _=="string"?_:false,I=typeof d=="function"?d:ae[d]??ae.linear,ge=le(F.start??"top bottom"),a=le(F.end??"bottom top"),g=typeof K=="string"?document.querySelector(K):K??null,re=Array.isArray(A)?A[0]:null,V=Array.isArray(A)?A[1]:typeof A=="string"?A:null,U=Array.isArray(C)?C[0]:null,oe=Array.isArray(C)?C[1]:typeof C=="number"?C:null,N=Array.isArray($)?$[0]:null,G=Array.isArray($)?$[1]:typeof $=="number"?$:null;function me(o){let i=o*100;switch(f){case "right":return `inset(0 0 0 ${100-i}%)`;case "top":return `inset(0 0 ${100-i}% 0)`;case "bottom":return `inset(${100-i}% 0 0 0)`;case "center":return `circle(${o*150}% at 50% 50%)`;default:return `inset(0 ${100-i}% 0 0)`}}let ee=f?[]:Array.from(e.querySelectorAll(m)),j=[],he=[],Te=0,Ae=0,ie=false,ye=false,te=0,Ne=false,be=-1,He=-1,ce=false,Pe=0,xe=0,Me,Be=null,Ce=new Set,ze=-1,et=performance.now();function Ie(){return g?q==="x"?g.scrollLeft:g.scrollTop:q==="x"?window.scrollX:window.scrollY}function tt(){return g?q==="x"?g.clientWidth:g.clientHeight:q==="x"?window.innerWidth:window.innerHeight}function nt(){let o=e.getBoundingClientRect(),i,v,X;if(g){let ue=g.getBoundingClientRect();i=q==="x"?o.left-ue.left+g.scrollLeft:o.top-ue.top+g.scrollTop,v=q==="x"?o.width:o.height,X=Ie();}else i=q==="x"?o.left:o.top,v=q==="x"?o.width:o.height,X=Ie();let fe=pe({top:i,height:v},X,tt(),ge,a);Te=fe.tStart,Ae=fe.tEnd,de&&process.env.NODE_ENV!=="production"&&(Be?.remove(),Be=Ct(Te,Ae,q));}function ht(o,i){if(e.style.setProperty("--scroll-draw-progress",String(o)),f){let v=i==="reverse"?1-o:o;e.style.clipPath=me(v);return}ee.forEach((v,X)=>{v.style.strokeDashoffset=i==="reverse"?`${j[X]*o}`:`${j[X]*(1-o)}`,u&&(v.style.opacity=i==="reverse"?`${1-o}`:`${o}`),re&&V?v.style.stroke=ke(re,V,o):V&&(v.style.stroke=V),U!==null&&oe!==null?v.style.strokeWidth=`${U+(oe-U)*o}`:oe!==null&&(v.style.strokeWidth=`${oe}`),N!==null&&G!==null?v.style.fillOpacity=`${N+(G-N)*o}`:G!==null&&(v.style.fillOpacity=`${G}`),P&&v.tagName.toLowerCase()==="path"&&he[X]&&v.setAttribute("d",Xe(he[X],P,o));});}function Ve(){if(e.style.setProperty("--scroll-draw-progress","0"),f){e.style.clipPath=me(0);return}ee.forEach((o,i)=>{o.style.strokeDasharray=`${j[i]}`,o.style.strokeDashoffset=S==="reverse"?"0":`${j[i]}`,u?o.style.opacity=S==="reverse"?"1":"0":o.style.opacity="",re&&(o.style.stroke=re),U!==null&&(o.style.strokeWidth=`${U}`),N!==null&&(o.style.fillOpacity=`${N}`),P&&o.tagName.toLowerCase()==="path"&&he[i]&&o.setAttribute("d",he[i]);});}if(ee.forEach(o=>{Mt(o);let i=_e(o);j.push(i),o.tagName.toLowerCase()==="path"?he.push(o.getAttribute("d")??""):he.push(""),s?(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=S==="reverse"?`${i}`:"0",u&&(o.style.opacity="1"),V&&(o.style.stroke=V),oe!==null&&(o.style.strokeWidth=`${oe}`),G!==null&&(o.style.fillOpacity=`${G}`),P&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",P)):(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=S==="reverse"?"0":`${i}`,u?o.style.opacity=S==="reverse"?"1":"0":o.style.opacity="",re&&(o.style.stroke=re),U!==null&&(o.style.strokeWidth=`${U}`),N!==null&&(o.style.fillOpacity=`${N}`));}),f){if(s)return e.style.clipPath=me(1),y?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=me(0);}else if(s)return y?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function bt(){return !(se===false||!At()||!ee.length||typeof d!="string"||!(d in lt)||f||q!=="y"||g||c!==1||B!==0||ne||T||L!==false||P||b||M||R>0||p||O||y||A!=null||C!=null||$!=null||(F.start??"top bottom").trim()!=="top bottom"||(F.end??"bottom top").trim()!=="bottom top")}function wt(){let o=`svg-scroll-draw-${++Tt}`,i=S==="reverse"?"0":"var(--ssd-len)",v=S==="reverse"?"var(--ssd-len)":"0",X=`stroke-dashoffset:${i};`,fe=`stroke-dashoffset:${v};`;u&&(X+=`opacity:${S==="reverse"?1:0};`,fe+=`opacity:${S==="reverse"?0:1};`);let ue=document.createElement("style");ue.setAttribute("data-svg-scroll-draw",""),ue.textContent=`@keyframes ${o}{from{${X}}to{${fe}}}.${o}{animation-name:${o};animation-duration:auto;animation-timing-function:${lt[d]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(ue);function w(h,x){h.style.setProperty("--ssd-len",String(j[x])),h.style.strokeDasharray=`${j[x]}`,h.style.strokeDashoffset="",h.style.opacity="",h.style.animationPlayState="",h.classList.add(o);}ee.forEach(w);let H=false,Z=-1;function E(){if(Z>=0)return Z;let h=e.getBoundingClientRect(),{tStart:x,tEnd:W}=pe({top:h.top,height:h.height},Ie(),tt(),ge,a);return I(J(Ie(),x,W,c))}return {destroy(){ee.forEach(h=>{h.classList.remove(o),h.style.removeProperty("--ssd-len"),h.style.animationPlayState="";}),ue.remove();},replay(){H=false,Z=-1,ee.forEach(w);},pause(){H=true,ee.forEach(h=>{h.style.animationPlayState="paused";});},resume(){H&&(H=false,ee.forEach(h=>{h.style.animationPlayState="running";}));},seek(h){let x=Math.min(1,Math.max(0,h));Z=x,H=true,ee.forEach((W,Oe)=>{W.classList.remove(o),W.style.strokeDashoffset=S==="reverse"?`${j[Oe]*x}`:`${j[Oe]*(1-x)}`,u&&(W.style.opacity=S==="reverse"?`${1-x}`:`${x}`);});},getProgress(){return E()}}}if(bt())return wt();function vt(){let o=Math.max(1,Y),i=0,v=0;function X(E){let h=true;if(f){let x=Math.min(1,Math.max(0,E/o)),W=I(x);Pe=W,e.style.setProperty("--scroll-draw-progress",String(W)),e.style.clipPath=me(S==="reverse"?1-W:W),p?.(W),x<1&&(h=false);}else ee.forEach((x,W)=>{let Oe=W*B*o,Fe=Math.min(1,Math.max(0,(E-Oe)/o)),we=I(Fe);x.style.strokeDashoffset=S==="reverse"?`${j[W]*we}`:`${j[W]*(1-we)}`,u&&(x.style.opacity=S==="reverse"?`${1-we}`:`${we}`),re&&V?x.style.stroke=ke(re,V,we):V&&(x.style.stroke=V),U!==null&&oe!==null?x.style.strokeWidth=`${U+(oe-U)*we}`:oe!==null&&(x.style.strokeWidth=`${oe}`),N!==null&&G!==null?x.style.fillOpacity=`${N+(G-N)*we}`:G!==null&&(x.style.fillOpacity=`${G}`),P&&x.tagName.toLowerCase()==="path"&&he[W]&&x.setAttribute("d",Xe(he[W],P,we)),W===0&&(p?.(we),e.style.setProperty("--scroll-draw-progress",String(we))),Fe<1&&(h=false);});if(b){let x=Math.min(1,Math.max(0,E/o)),W=I(x);for(let Oe in b){let Fe=parseFloat(Oe);W>=Fe&&!Ce.has(Fe)&&(Ce.add(Fe),b[Oe]?.());}}return h}function fe(E){if(ce)return;let h=E-i;ye||(ye=true,O?.());let x=X(h);if(x&&!ie){ie=true,X(o*(1+Math.max(0,ee.length-1)*B)),y?.(),xe<(M==="infinite"?1/0:M??0)&&(xe++,Me=setTimeout(()=>{i=performance.now(),ye=false,ie=false,Ce.clear(),Ve(),te=requestAnimationFrame(fe);},z));return}x||(te=requestAnimationFrame(fe));}function ue(){cancelAnimationFrame(te),clearTimeout(Me),i=performance.now(),v=0,ce=false,ye=false,ie=false,xe=0,Ce.clear(),Ve(),te=requestAnimationFrame(fe);}let w=new IntersectionObserver(E=>{E.forEach(h=>{h.isIntersecting&&!(ne&&ie)?ue():!h.isIntersecting&&!ne&&!ie&&(cancelAnimationFrame(te),clearTimeout(Me),i=null);});},{root:g??null,threshold:k,rootMargin:D}),H;function Z(){clearTimeout(H),H=setTimeout(()=>{ee.forEach((E,h)=>{j[h]=_e(E),E.style.strokeDasharray=`${j[h]}`;});},150);}return window.addEventListener("resize",Z),window.addEventListener("orientationchange",Z),R>0?setTimeout(()=>w.observe(e),R):w.observe(e),{destroy(){cancelAnimationFrame(te),clearTimeout(Me),w.disconnect(),window.removeEventListener("resize",Z),window.removeEventListener("orientationchange",Z),clearTimeout(H);},replay(){xe=0,ue();},pause(){ce||(ce=true,v=performance.now()-i,cancelAnimationFrame(te));},resume(){ce&&(ce=false,i=performance.now()-v,te=requestAnimationFrame(fe));},seek(E){let h=Math.min(1,Math.max(0,E));Pe=h,ce=true,v=h*o,i=performance.now()-v,cancelAnimationFrame(te),X(v);},getProgress(){return Pe}}}if(Q)return vt();nt();function qe(){if(!Ne||ce)return;let o=performance.now(),i=Ie(),v=c;if(L!==false){let w=o-et,H=w>0?Math.abs(i-(ze<0?i:ze))/w:0;v=c*Math.max(.2,1+H*(typeof L=="number"?L:1)*.04);}ze=i,et=o;let X=T?He===-1||i>=He?"forward":"reverse":S;He=i;let fe=Ae-Te,ue=true;if(f){let w=I(J(i,Te,Ae,v));ne&&!T&&(be=Math.max(be,w),w=be),Pe=w,e.style.setProperty("--scroll-draw-progress",String(w));let H=X==="reverse"?1-w:w;e.style.clipPath=me(H),p?.(w),!ye&&J(i,Te,Ae,v)>0&&(ye=true,O?.()),w>=1&&!ie?(ie=true,y?.(),xe<(M==="infinite"?1/0:M??0)&&(xe++,Me=setTimeout(()=>{be=-1,ye=false,ie=false,e.style.clipPath=me(0);},z))):w<1&&!ne&&(ie=false),te=requestAnimationFrame(qe);return}if(ee.forEach((w,H)=>{let Z=H*B*fe,E=I(J(i,Te+Z,Ae+Z,v));ne&&!T&&(be=Math.max(be,E),E=be),Pe=E,w.style.strokeDashoffset=X==="reverse"?`${j[H]*E}`:`${j[H]*(1-E)}`,u&&(w.style.opacity=X==="reverse"?`${1-E}`:`${E}`),re&&V?w.style.stroke=ke(re,V,E):V&&(w.style.stroke=V),U!==null&&oe!==null?w.style.strokeWidth=`${U+(oe-U)*E}`:oe!==null&&(w.style.strokeWidth=`${oe}`),N!==null&&G!==null?w.style.fillOpacity=`${N+(G-N)*E}`:G!==null&&(w.style.fillOpacity=`${G}`),P&&w.tagName.toLowerCase()==="path"&&he[H]&&w.setAttribute("d",Xe(he[H],P,E)),H===0&&(p?.(E),e.style.setProperty("--scroll-draw-progress",String(E))),E<1&&(ue=false);}),b){let w=I(J(i,Te,Ae,v));for(let H in b){let Z=parseFloat(H);w>=Z&&!Ce.has(Z)&&(Ce.add(Z),b[H]?.());}}!ye&&J(i,Te,Ae,v)>0&&(ye=true,O?.()),ue&&!ie?(ie=true,y?.(),xe<(M==="infinite"?1/0:M??0)&&(xe++,Me=setTimeout(()=>{be=-1,ye=false,ie=false,Ce.clear(),Ve();},z))):!ue&&!ne&&(ie=false),te=requestAnimationFrame(qe);}let Ge=new IntersectionObserver(o=>{o.forEach(i=>{Ne=i.isIntersecting,Ne&&!ce?te=requestAnimationFrame(qe):cancelAnimationFrame(te);});},{root:g??null,threshold:k,rootMargin:D}),je;function We(){clearTimeout(je),je=setTimeout(()=>{ee.forEach((o,i)=>{j[i]=_e(o),o.style.strokeDasharray=`${j[i]}`;}),nt();},150);}return window.addEventListener("resize",We),window.addEventListener("orientationchange",We),R>0?setTimeout(()=>Ge.observe(e),R):Ge.observe(e),{destroy(){cancelAnimationFrame(te),clearTimeout(Me),Ge.disconnect(),window.removeEventListener("resize",We),window.removeEventListener("orientationchange",We),clearTimeout(je),Be?.remove();},replay(){be=-1,He=-1,ze=-1,ye=false,ie=false,xe=0,ce=false,Ce.clear(),clearTimeout(Me),Ve();},pause(){ce=true,cancelAnimationFrame(te);},resume(){ce&&(ce=false,Ne&&(te=requestAnimationFrame(qe)));},seek(o){let i=Math.min(1,Math.max(0,o));Pe=i,be=i,ce=true,cancelAnimationFrame(te),ht(i,S);},getProgress(){return Pe}}}var ct=new Map;function $e(e,r){ct.set(e,r);}function Le(e){ct.delete(e);}function $t(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function ut(e){let r=[],n=/([\w]+)\(([^)]*)\)/g,t;for(;(t=n.exec(e))!==null;){let l=[],s=[],m=t[2].trim();if(m)for(let c of m.split(/[\s,]+/)){let u=c.match(/^([-+]?[\d.eE]+)(.*)$/);l.push(u?parseFloat(u[1]):0),s.push(u?u[2]:"");}r.push({fn:t[1],nums:l,units:s});}return r}function Lt(e,r,n){let t=ut(e),l=ut(r);return t.length===0||t.length!==l.length?n<1?e:r:t.map((s,m)=>{let c=l[m];return s.fn!==c.fn||s.nums.length!==c.nums.length?n<1?`${s.fn}(${s.nums.map((u,d)=>`${u}${s.units[d]}`).join(", ")})`:`${c.fn}(${c.nums.map((u,d)=>`${u}${c.units[d]}`).join(", ")})`:`${s.fn}(${s.nums.map((u,d)=>`${u+(c.nums[d]-u)*n}${s.units[d]}`).join(", ")})`}).join(" ")}function mt(e,r,n){if(typeof e=="number"&&typeof r=="number")return String(e+(r-e)*n);let t=String(e),l=String(r);if($t(t))return ke(t,l,n);if(t.includes("("))return Lt(t,l,n);let s=t.match(/^([-+]?[\d.]+)(.*)$/),m=l.match(/^([-+]?[\d.]+)(.*)$/);if(s&&m){let c=parseFloat(s[1]),u=parseFloat(m[1]);return `${c+(u-c)*n}${s[2]||m[2]}`}return n<1?t:l}function Pt(e){return e.replace(/([A-Z])/g,r=>`-${r.toLowerCase()}`)}var ft={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Ot=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),Ft=0;function kt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Ue(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let{props:t,trigger:l={},easing:s="ease-out",speed:m=1,once:c=false,axis:u="y",scrollContainer:d,native:F=true,onProgress:B,onComplete:S}=r,ne=window.matchMedia("(prefers-reduced-motion: reduce)").matches,de=typeof s=="function"?s:ae[s]??ae["ease-out"],q=le(l.start??"top bottom"),K=le(l.end??"bottom top"),T=typeof d=="string"?document.querySelector(d):d??null,R=Object.entries(t).map(([a,g])=>({prop:Pt(a),from:Array.isArray(g)?g[0]:"",to:Array.isArray(g)?g[1]:g}));function A(){let a=window.getComputedStyle(e);for(let g of R)g.from===""&&(g.from=a.getPropertyValue(g.prop).trim()||"0");}function C(){for(let a of R)e.style.setProperty(a.prop,String(a.to));}if(ne)return C(),S?.(),n;A();function $(){if(!F||!kt()||typeof s!="string"||!(s in ft)||u!=="y"||T||c||m!==1||B||S||(l.start??"top bottom").trim()!=="top bottom"||(l.end??"bottom top").trim()!=="bottom top")return false;for(let a of R)if(!Ot.has(a.prop))return false;return true}function b(){let a=`ssd-a-${++Ft}`,g=R.map(N=>`${N.prop}:${N.from}`).join(";"),re=R.map(N=>`${N.prop}:${N.to}`).join(";"),V=document.createElement("style");V.setAttribute("data-ssd-animate",""),V.textContent=`@keyframes ${a}{from{${g}}to{${re}}}.${a}{animation-name:${a};animation-duration:auto;animation-timing-function:${ft[s]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(V),e.classList.add(a);let U=()=>u==="x"?window.scrollX:window.scrollY,oe=()=>u==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(a),V.remove();},replay(){e.classList.remove(a),e.offsetWidth,e.classList.add(a);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(N){let G=Math.min(1,Math.max(0,N));e.classList.remove(a);for(let me of R)e.style.setProperty(me.prop,mt(me.from,me.to,G));},getProgress(){let N=e.getBoundingClientRect(),G=U(),me=oe(),{tStart:ee,tEnd:j}=pe({top:N.top,height:N.height},G,me,q,K);return de(J(G,ee,j,m))}}}if($())return b();let L=0,k=0,D=0,M=false,z=false,P=-1,_=0,Q=false,Y=()=>T?u==="x"?T.scrollLeft:T.scrollTop:u==="x"?window.scrollX:window.scrollY,se=()=>T?u==="x"?T.clientWidth:T.clientHeight:u==="x"?window.innerWidth:window.innerHeight;function p(){let a=e.getBoundingClientRect(),g,re;if(T){let U=T.getBoundingClientRect();g=u==="x"?a.left-U.left+T.scrollLeft:a.top-U.top+T.scrollTop,re=u==="x"?a.width:a.height;}else g=u==="x"?a.left:a.top,re=u==="x"?a.width:a.height;let V=pe({top:g,height:re},Y(),se(),q,K);L=V.tStart,k=V.tEnd;}function O(a){e.style.setProperty("--scroll-draw-progress",String(a));for(let g of R)e.style.setProperty(g.prop,mt(g.from,g.to,a));B?.(a);}function y(){if(!M||z)return;let a=de(J(Y(),L,k,m));c&&(P=Math.max(P,a),a=P),_=a,O(a),a>=1&&!Q?(Q=true,S?.()):a<1&&!c&&(Q=false),D=requestAnimationFrame(y);}p();{let a=de(J(Y(),L,k,m));c&&a>0&&(P=a),_=a,O(a);}let f=new IntersectionObserver(a=>{a.forEach(g=>{M=g.isIntersecting,M&&!z?D=requestAnimationFrame(y):cancelAnimationFrame(D);});},{root:T??null}),I;function ge(){clearTimeout(I),I=setTimeout(p,150);}return window.addEventListener("resize",ge),window.addEventListener("orientationchange",ge),f.observe(e),$e(e,{type:"animate",getProgress:()=>_,getTrigger:()=>({tStart:L,tEnd:k})}),{destroy(){cancelAnimationFrame(D),f.disconnect(),window.removeEventListener("resize",ge),window.removeEventListener("orientationchange",ge),clearTimeout(I),Le(e);},replay(){P=-1,Q=false,_=0,z=false,O(0);},pause(){z=true,cancelAnimationFrame(D);},resume(){z&&(z=false,M&&(D=requestAnimationFrame(y)));},seek(a){let g=Math.min(1,Math.max(0,a));_=g,P=g,z=true,cancelAnimationFrame(D),O(g);},getProgress(){return _}}}var Ze={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Je(e,r){if(typeof window>"u")return Ze;let n=typeof e=="string"?document.querySelector(e):e;if(!n)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollCounter: element not found:",e),Ze;let t=n,{from:l=0,to:s,format:m,easing:c="ease-out",trigger:u={},once:d=true,decimals:F,onComplete:B}=r,S=F!==void 0?p=>p.toFixed(F):m??(p=>String(Math.round(p))),ne=typeof c=="function"?c:ae[c]??ae["ease-out"],de=le(u.start??"top 80%"),q=le(u.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=S(s),B?.(),Ze;t.textContent=S(l);let T=0,R=0,A=0,C=false,$=false,b=-1,L=0,k=false,D=()=>window.scrollY,M=()=>window.innerHeight;function z(){let p=t.getBoundingClientRect(),O=pe({top:p.top,height:p.height},D(),M(),de,q);T=O.tStart,R=O.tEnd;}function P(p){t.textContent=S(l+(s-l)*p),t.style.setProperty("--scroll-draw-progress",String(p));}function _(){if(!C||$)return;let p=ne(J(D(),T,R,1));d&&(b=Math.max(b,p),p=b),L=p,P(p),p>=1&&!k?(k=true,B?.()):p<1&&!d&&(k=false),A=requestAnimationFrame(_);}z();{let p=ne(J(D(),T,R,1));d&&p>0&&(b=p),L=p,P(p);}let Q=new IntersectionObserver(p=>{p.forEach(O=>{C=O.isIntersecting,C&&!$?A=requestAnimationFrame(_):cancelAnimationFrame(A);});}),Y;function se(){clearTimeout(Y),Y=setTimeout(z,150);}return window.addEventListener("resize",se),window.addEventListener("orientationchange",se),Q.observe(t),$e(t,{type:"counter",getProgress:()=>L,getTrigger:()=>({tStart:T,tEnd:R})}),{destroy(){cancelAnimationFrame(A),Q.disconnect(),window.removeEventListener("resize",se),window.removeEventListener("orientationchange",se),clearTimeout(Y),Le(t);},replay(){b=-1,k=false,L=0,$=false,P(0);},pause(){$=true,cancelAnimationFrame(A);},resume(){$&&($=false,C&&(A=requestAnimationFrame(_)));},seek(p){let O=Math.min(1,Math.max(0,p));L=O,b=O,$=true,cancelAnimationFrame(A),P(O);},getProgress(){return L}}}var pt={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Ke(e,r={}){if(typeof window>"u")return pt;let n=typeof e=="string"?document.querySelector(e):e;if(!n||n.tagName.toLowerCase()!=="video")return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollVideo: <video> element not found:",e),pt;let t=n,{trigger:l={},easing:s="linear",once:m=false,axis:c="y",preload:u="auto",onReady:d,onComplete:F,onProgress:B}=r,S=window.matchMedia("(prefers-reduced-motion: reduce)").matches,ne=typeof s=="function"?s:ae[s]??ae.linear,de=le(l.start??"top top"),q=le(l.end??"bottom top");t.pause(),t.hasAttribute("preload")||(t.preload=u);let K=r.from??0,T=r.to,R=0,A=0,C=0,$=false,b=false,L=-1,k=0,D=false,M=false,z=()=>c==="x"?window.scrollX:window.scrollY,P=()=>c==="x"?window.innerWidth:window.innerHeight;function _(){let f=t.getBoundingClientRect(),I=c==="x"?f.left:f.top,ge=c==="x"?f.width:f.height,a=pe({top:I,height:ge},z(),P(),de,q);R=a.tStart,A=a.tEnd;}function Q(f){if(!M)return;let I=T??t.duration??0;t.currentTime=K+(I-K)*f,t.style.setProperty("--scroll-draw-progress",String(f)),B?.(f);}function Y(){if(!$||b||!M)return;let f=ne(J(z(),R,A,1));m&&(L=Math.max(L,f),f=L),k=f,Q(f),f>=1&&!D?(D=true,F?.()):f<1&&!m&&(D=false),C=requestAnimationFrame(Y);}function se(){if(M=true,T===void 0&&(T=t.duration),S){Q(1),d?.();return}_(),d?.(),$&&!b&&(C=requestAnimationFrame(Y));}t.readyState>=1?se():t.addEventListener("loadedmetadata",se,{once:true}),M||_();let p=new IntersectionObserver(f=>{f.forEach(I=>{$=I.isIntersecting,$&&!b&&M?C=requestAnimationFrame(Y):cancelAnimationFrame(C);});}),O;function y(){clearTimeout(O),O=setTimeout(_,150);}return window.addEventListener("resize",y),window.addEventListener("orientationchange",y),p.observe(t),$e(t,{type:"video",getProgress:()=>k,getTrigger:()=>({tStart:R,tEnd:A})}),{destroy(){cancelAnimationFrame(C),p.disconnect(),t.removeEventListener("loadedmetadata",se),window.removeEventListener("resize",y),window.removeEventListener("orientationchange",y),clearTimeout(O),Le(t);},replay(){L=-1,D=false,k=0,b=false,Q(0);},pause(){b=true,cancelAnimationFrame(C);},resume(){b&&(b=false,$&&M&&(C=requestAnimationFrame(Y)));},seek(f){let I=Math.min(1,Math.max(0,f));k=I,L=I,b=true,cancelAnimationFrame(C),Q(I);},getProgress(){return k}}}function yt(e){let r=e.textContent??"";return e.textContent="",r.split(/(\s+)/).filter(Boolean).map(n=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),/^\s+$/.test(n)?(t.textContent=n,t.style.whiteSpace="pre"):(t.textContent=n,t.style.display="inline-block"),e.appendChild(t),/^\s+$/.test(n)?null:t}).filter(n=>n!==null)}function It(e){let r=e.textContent??"";return e.textContent="",r.split("").map(n=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),t.textContent=n,n===" "?t.style.whiteSpace="pre":t.style.display="inline-block",e.appendChild(t),n===" "?null:t}).filter(n=>n!==null)}function dt(e){let r=yt(e),n=new Map;for(let s of r){let m=s.offsetTop;n.has(m)||n.set(m,[]),n.get(m).push(s);}let t=[],l=Array.from(n.keys()).sort((s,m)=>s-m);for(let s of l){let m=n.get(s),c=document.createElement("span");c.setAttribute("aria-hidden","true"),c.style.display="inline-block";for(let u of m)c.appendChild(u);t.push(c);}e.textContent="";for(let s of t)e.appendChild(s),e.appendChild(document.createTextNode(" "));return t}function Dt(e,r,n,t){if(n<=1||t===0)return e;let l=(n-1)*t,s=r*t,m=s+(1-l);return m<=s?e>=s?1:0:Math.min(1,Math.max(0,(e-s)/(m-s)))}function Rt(e,r){let n=[];if(r?.y!==void 0&&n.push(`translateY(${r.y*(1-e)}px)`),r?.x!==void 0&&n.push(`translateX(${r.x*(1-e)}px)`),r?.rotate!==void 0&&n.push(`rotate(${r.rotate*(1-e)}deg)`),r?.scale!==void 0){let t=r.scale+(1-r.scale)*e;n.push(`scale(${t})`);}return n.join(" ")||""}var gt={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Qe(e,r={}){if(typeof window>"u")return gt;let n=typeof e=="string"?document.querySelector(e):e;if(!n)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollText: element not found:",e),gt;let t=n,{split:l="words",stagger:s=.04,easing:m="ease-out",from:c={opacity:0,y:24},trigger:u={},once:d=true,onComplete:F}=r,B=window.matchMedia("(prefers-reduced-motion: reduce)").matches,S=typeof m=="function"?m:ae[m]??ae["ease-out"],ne=le(u.start??"top 85%"),de=le(u.end??"top 40%"),q=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let K;l==="chars"?K=It(t):l==="lines"?K=dt(t):K=yt(t);let T=K.length;function R(y,f){c?.opacity!==void 0&&(y.style.opacity=String(c.opacity+(1-c.opacity)*f));let I=Rt(f,c);I&&(y.style.transform=I);}function A(y){t.style.setProperty("--scroll-draw-progress",String(y)),K.forEach((f,I)=>{let ge=S(Dt(y,I,T,s));R(f,ge);});}if(B)return A(1),F?.(),{destroy(){t.innerHTML=q,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};A(0);let C=0,$=0,b=0,L=false,k=false,D=-1,M=0,z=false,P=()=>window.scrollY,_=()=>window.innerHeight;function Q(){let y=t.getBoundingClientRect(),f=pe({top:y.top,height:y.height},P(),_(),ne,de);C=f.tStart,$=f.tEnd;}function Y(){if(!L||k)return;let y=J(P(),C,$,1);d&&(D=Math.max(D,y),y=D),M=y,A(y),y>=1&&!z?(z=true,F?.()):y<1&&!d&&(z=false),b=requestAnimationFrame(Y);}Q();let se=new IntersectionObserver(y=>{y.forEach(f=>{L=f.isIntersecting,L&&!k?b=requestAnimationFrame(Y):cancelAnimationFrame(b);});}),p;function O(){clearTimeout(p),p=setTimeout(()=>{if(l==="lines"){let y=M;t.innerHTML=q,t.setAttribute("aria-label",t.textContent??""),K=dt(t),A(y);}Q();},150);}return window.addEventListener("resize",O),window.addEventListener("orientationchange",O),se.observe(t),$e(t,{type:"text",getProgress:()=>M,getTrigger:()=>({tStart:C,tEnd:$})}),{destroy(){cancelAnimationFrame(b),se.disconnect(),window.removeEventListener("resize",O),window.removeEventListener("orientationchange",O),clearTimeout(p),t.innerHTML=q,t.removeAttribute("aria-label"),Le(t);},replay(){D=-1,z=false,M=0,k=false,A(0);},pause(){k=true,cancelAnimationFrame(b);},resume(){k&&(k=false,L&&(b=requestAnimationFrame(Y)));},seek(y){let f=Math.min(1,Math.max(0,y));M=f,D=f,k=true,cancelAnimationFrame(b),A(f);},getProgress(){return M}}}function ln(e={}){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Ye(r.value,e);onUnmounted(()=>n.destroy());}),r}var cn=defineComponent({name:"ScrollDraw",props:{selector:{type:String},speed:{type:Number},fade:{type:Boolean},stagger:{type:Number},easing:{type:[String,Function]},direction:{type:String},trigger:{type:Object},onProgress:{type:Function},onStart:{type:Function},onComplete:{type:Function},once:{type:Boolean},debug:{type:Boolean}},setup(e,{slots:r}){let n=ref(null);return onMounted(()=>{if(!n.value)return;let t={};e.selector!=null&&(t.selector=e.selector),e.speed!=null&&(t.speed=e.speed),e.fade!=null&&(t.fade=e.fade),e.stagger!=null&&(t.stagger=e.stagger),e.easing!=null&&(t.easing=e.easing),e.direction!=null&&(t.direction=e.direction),e.trigger!=null&&(t.trigger=e.trigger),e.once!=null&&(t.once=e.once),e.debug!=null&&(t.debug=e.debug),e.onProgress!=null&&(t.onProgress=e.onProgress),e.onStart!=null&&(t.onStart=e.onStart),e.onComplete!=null&&(t.onComplete=e.onComplete);let l=Ye(n.value,t);onUnmounted(()=>l.destroy());}),()=>h("div",{ref:n},r.default?.())}});function un(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Ue(r.value,e);onUnmounted(()=>n.destroy());}),r}var mn=defineComponent({name:"ScrollAnimate",props:{options:{type:Object,required:true}},setup(e,{slots:r}){let n=ref(null);return onMounted(()=>{if(!n.value)return;let t=Ue(n.value,e.options);onUnmounted(()=>t.destroy());}),()=>h("div",{ref:n},r.default?.())}});function fn(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Je(r.value,e);onUnmounted(()=>n.destroy());}),r}var pn=defineComponent({name:"ScrollCounter",props:{to:{type:Number,required:true},from:{type:Number},format:{type:Function},easing:{type:[String,Function]},trigger:{type:Object},once:{type:Boolean},decimals:{type:Number},onComplete:{type:Function}},setup(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n={to:e.to};e.from!=null&&(n.from=e.from),e.format!=null&&(n.format=e.format),e.easing!=null&&(n.easing=e.easing),e.trigger!=null&&(n.trigger=e.trigger),e.once!=null&&(n.once=e.once),e.decimals!=null&&(n.decimals=e.decimals),e.onComplete!=null&&(n.onComplete=e.onComplete);let t=Je(r.value,n);onUnmounted(()=>t.destroy());}),()=>h("span",{ref:r})}});function dn(e={}){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Ke(r.value,e);onUnmounted(()=>n.destroy());}),r}var gn=defineComponent({name:"ScrollVideo",props:{src:{type:String,required:true},options:{type:Object},muted:{type:Boolean,default:true},playsInline:{type:Boolean,default:true},class:{type:String}},setup(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Ke(r.value,e.options??{});onUnmounted(()=>n.destroy());}),()=>h("video",{ref:r,src:e.src,muted:e.muted,playsinline:e.playsInline,preload:"auto",class:e.class})}});function yn(e={}){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Qe(r.value,e);onUnmounted(()=>n.destroy());}),r}var hn=defineComponent({name:"ScrollText",props:{options:{type:Object},tag:{type:String,default:"p"}},setup(e,{slots:r}){let n=ref(null);return onMounted(()=>{if(!n.value)return;let t=Qe(n.value,e.options??{});onUnmounted(()=>t.destroy());}),()=>h(e.tag,{ref:n},r.default?.())}});export{mn as ScrollAnimate,pn as ScrollCounter,cn as ScrollDraw,hn as ScrollText,gn as ScrollVideo,un as useScrollAnimate,fn as useScrollCounter,ln as useScrollDraw,yn as useScrollText,dn as useScrollVideo};
|
|
3
|
+
<div style="position:absolute;${u?`left:${c}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${c}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(t),window.addEventListener("scroll",l,{passive:true}),l(),t}function Ke(e,r,n){let t=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),l=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,s=>{let m=parseFloat(s),c=t[l++]??m;return String(+(m+(c-m)*n).toFixed(4))})}function Qe(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:n,...t}=r,l=n?{...ft[n],...t}:t,s=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:m="path, polyline, line, polygon, rect, circle",speed:c=1,fade:u=false,easing:h="linear",trigger:P={},stagger:H=0,direction:S="forward",once:Y=false,debug:he=false,axis:V="y",scrollContainer:ee,autoReverse:U=false,delay:Z=0,strokeColor:E,strokeWidth:M,fillOpacity:C,waypoints:g,velocityScale:x=false,threshold:k=0,rootMargin:G="0px",repeat:O=0,repeatDelay:se=0,morphTo:L,clip:W,autoplay:_=false,duration:j=1e3,native:z=true,onProgress:p,onStart:T,onComplete:b,onEnter:y,onLeave:q,onEnterBack:Ae,onLeaveBack:Me}=l,be=W===true?"left":typeof W=="string"?W:false,we=typeof h=="function"?h:ae[h]??ae.linear,ke=le(P.start??"top bottom"),qe=le(P.end??"bottom top"),te=typeof ee=="string"?document.querySelector(ee):ee??null,pe=Array.isArray(E)?E[0]:null,J=Array.isArray(E)?E[1]:typeof E=="string"?E:null,K=Array.isArray(M)?M[0]:null,i=Array.isArray(M)?M[1]:typeof M=="number"?M:null,d=Array.isArray(C)?C[0]:null,F=Array.isArray(C)?C[1]:typeof C=="number"?C:null;function ne(o){let a=o*100;switch(be){case "right":return `inset(0 0 0 ${100-a}%)`;case "top":return `inset(0 0 ${100-a}% 0)`;case "bottom":return `inset(${100-a}% 0 0 0)`;case "center":return `circle(${o*150}% at 50% 50%)`;default:return `inset(0 ${100-a}% 0 0)`}}let $=be?[]:Array.from(e.querySelectorAll(m)),R=[],I=[],ie=0,ce=0,re=false,de=false,oe=0,Be=false,ve=-1,We=-1,ue=false,Fe=0,Ce=0,Le,Ue=null,$e=new Set,_e=-1,st=performance.now(),Ne=NaN;function He(){return te?V==="x"?te.scrollLeft:te.scrollTop:V==="x"?window.scrollX:window.scrollY}function it(){return te?V==="x"?te.clientWidth:te.clientHeight:V==="x"?window.innerWidth:window.innerHeight}function at(){let o=e.getBoundingClientRect(),a,v,X;if(te){let me=te.getBoundingClientRect();a=V==="x"?o.left-me.left+te.scrollLeft:o.top-me.top+te.scrollTop,v=V==="x"?o.width:o.height,X=He();}else a=V==="x"?o.left:o.top,v=V==="x"?o.width:o.height,X=He();let fe=ye({top:a,height:v},X,it(),ke,qe);ie=fe.tStart,ce=fe.tEnd,he&&process.env.NODE_ENV!=="production"&&(Ue?.remove(),Ue=kt(ie,ce,V));}function Et(o,a){if(e.style.setProperty("--scroll-draw-progress",String(o)),be){let v=a==="reverse"?1-o:o;e.style.clipPath=ne(v);return}$.forEach((v,X)=>{v.style.strokeDashoffset=a==="reverse"?`${R[X]*o}`:`${R[X]*(1-o)}`,u&&(v.style.opacity=a==="reverse"?`${1-o}`:`${o}`),pe&&J?v.style.stroke=Re(pe,J,o):J&&(v.style.stroke=J),K!==null&&i!==null?v.style.strokeWidth=`${K+(i-K)*o}`:i!==null&&(v.style.strokeWidth=`${i}`),d!==null&&F!==null?v.style.fillOpacity=`${d+(F-d)*o}`:F!==null&&(v.style.fillOpacity=`${F}`),L&&v.tagName.toLowerCase()==="path"&&I[X]&&v.setAttribute("d",Ke(I[X],L,o));});}function Ge(){if(e.style.setProperty("--scroll-draw-progress","0"),be){e.style.clipPath=ne(0);return}$.forEach((o,a)=>{o.style.strokeDasharray=`${R[a]}`,o.style.strokeDashoffset=S==="reverse"?"0":`${R[a]}`,u?o.style.opacity=S==="reverse"?"1":"0":o.style.opacity="",pe&&(o.style.stroke=pe),K!==null&&(o.style.strokeWidth=`${K}`),d!==null&&(o.style.fillOpacity=`${d}`),L&&o.tagName.toLowerCase()==="path"&&I[a]&&o.setAttribute("d",I[a]);});}if($.forEach(o=>{Ot(o);let a=Ye(o);R.push(a),o.tagName.toLowerCase()==="path"?I.push(o.getAttribute("d")??""):I.push(""),s?(o.style.strokeDasharray=`${a}`,o.style.strokeDashoffset=S==="reverse"?`${a}`:"0",u&&(o.style.opacity="1"),J&&(o.style.stroke=J),i!==null&&(o.style.strokeWidth=`${i}`),F!==null&&(o.style.fillOpacity=`${F}`),L&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",L)):(o.style.strokeDasharray=`${a}`,o.style.strokeDashoffset=S==="reverse"?"0":`${a}`,u?o.style.opacity=S==="reverse"?"1":"0":o.style.opacity="",pe&&(o.style.stroke=pe),K!==null&&(o.style.strokeWidth=`${K}`),d!==null&&(o.style.fillOpacity=`${d}`));}),be){if(s)return e.style.clipPath=ne(1),b?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ne(0);}else if(s)return b?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function xt(){return !(z===false||!Pt()||!$.length||typeof h!="string"||!(h in pt)||be||V!=="y"||te||c!==1||H!==0||Y||U||x!==false||L||g||O||Z>0||p||T||b||y||q||Ae||Me||E!=null||M!=null||C!=null||(P.start??"top bottom").trim()!=="top bottom"||(P.end??"bottom top").trim()!=="bottom top")}function Tt(){let o=`svg-scroll-draw-${++$t}`,a=S==="reverse"?"0":"var(--ssd-len)",v=S==="reverse"?"var(--ssd-len)":"0",X=`stroke-dashoffset:${a};`,fe=`stroke-dashoffset:${v};`;u&&(X+=`opacity:${S==="reverse"?1:0};`,fe+=`opacity:${S==="reverse"?0:1};`);let me=document.createElement("style");me.setAttribute("data-svg-scroll-draw",""),me.textContent=`@keyframes ${o}{from{${X}}to{${fe}}}.${o}{animation-name:${o};animation-duration:auto;animation-timing-function:${pt[h]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(me);function ge(f,A){f.style.setProperty("--ssd-len",String(R[A])),f.style.strokeDasharray=`${R[A]}`,f.style.strokeDashoffset="",f.style.opacity="",f.style.animationPlayState="",f.classList.add(o);}$.forEach(ge);let w=false,N=-1;function D(){if(N>=0)return N;let f=e.getBoundingClientRect(),{tStart:A,tEnd:B}=ye({top:f.top,height:f.height},He(),it(),ke,qe);return we(Q(He(),A,B,c))}return {destroy(){$.forEach(f=>{f.classList.remove(o),f.style.removeProperty("--ssd-len"),f.style.animationPlayState="";}),me.remove();},replay(){w=false,N=-1,$.forEach(ge);},pause(){w=true,$.forEach(f=>{f.style.animationPlayState="paused";});},resume(){w&&(w=false,$.forEach(f=>{f.style.animationPlayState="running";}));},seek(f){let A=Math.min(1,Math.max(0,f));N=A,w=true,$.forEach((B,Ie)=>{B.classList.remove(o),B.style.strokeDashoffset=S==="reverse"?`${R[Ie]*A}`:`${R[Ie]*(1-A)}`,u&&(B.style.opacity=S==="reverse"?`${1-A}`:`${A}`);});},getProgress(){return D()}}}if(xt())return Tt();function At(){let o=Math.max(1,j),a=0,v=0;function X(D){let f=true;if(be){let A=Math.min(1,Math.max(0,D/o)),B=we(A);Fe=B,e.style.setProperty("--scroll-draw-progress",String(B)),e.style.clipPath=ne(S==="reverse"?1-B:B),p?.(B),A<1&&(f=false);}else $.forEach((A,B)=>{let Ie=B*H*o,De=Math.min(1,Math.max(0,(D-Ie)/o)),Se=we(De);A.style.strokeDashoffset=S==="reverse"?`${R[B]*Se}`:`${R[B]*(1-Se)}`,u&&(A.style.opacity=S==="reverse"?`${1-Se}`:`${Se}`),pe&&J?A.style.stroke=Re(pe,J,Se):J&&(A.style.stroke=J),K!==null&&i!==null?A.style.strokeWidth=`${K+(i-K)*Se}`:i!==null&&(A.style.strokeWidth=`${i}`),d!==null&&F!==null?A.style.fillOpacity=`${d+(F-d)*Se}`:F!==null&&(A.style.fillOpacity=`${F}`),L&&A.tagName.toLowerCase()==="path"&&I[B]&&A.setAttribute("d",Ke(I[B],L,Se)),B===0&&(p?.(Se),e.style.setProperty("--scroll-draw-progress",String(Se))),De<1&&(f=false);});if(g){let A=Math.min(1,Math.max(0,D/o)),B=we(A);for(let Ie in g){let De=parseFloat(Ie);B>=De&&!$e.has(De)&&($e.add(De),g[Ie]?.());}}return f}function fe(D){if(ue)return;let f=D-a;de||(de=true,T?.());let A=X(f);if(A&&!re){re=true,X(o*(1+Math.max(0,$.length-1)*H)),b?.(),Ce<(O==="infinite"?1/0:O??0)&&(Ce++,Le=setTimeout(()=>{a=performance.now(),de=false,re=false,$e.clear(),Ge(),oe=requestAnimationFrame(fe);},se));return}A||(oe=requestAnimationFrame(fe));}function me(){cancelAnimationFrame(oe),clearTimeout(Le),a=performance.now(),v=0,ue=false,de=false,re=false,Ce=0,$e.clear(),Ge(),oe=requestAnimationFrame(fe);}let ge=new IntersectionObserver(D=>{D.forEach(f=>{f.isIntersecting&&!(Y&&re)?me():!f.isIntersecting&&!Y&&!re&&(cancelAnimationFrame(oe),clearTimeout(Le),a=null);});},{root:te??null,threshold:k,rootMargin:G}),w;function N(){clearTimeout(w),w=setTimeout(()=>{$.forEach((D,f)=>{R[f]=Ye(D),D.style.strokeDasharray=`${R[f]}`;});},150);}return window.addEventListener("resize",N),window.addEventListener("orientationchange",N),Z>0?setTimeout(()=>ge.observe(e),Z):ge.observe(e),{destroy(){cancelAnimationFrame(oe),clearTimeout(Le),ge.disconnect(),window.removeEventListener("resize",N),window.removeEventListener("orientationchange",N),clearTimeout(w);},replay(){Ce=0,me();},pause(){ue||(ue=true,v=performance.now()-a,cancelAnimationFrame(oe));},resume(){ue&&(ue=false,a=performance.now()-v,oe=requestAnimationFrame(fe));},seek(D){let f=Math.min(1,Math.max(0,D));Fe=f,ue=true,v=f*o,a=performance.now()-v,cancelAnimationFrame(oe),X(v);},getProgress(){return Fe}}}if(_)return At();at();function je(){if(!Be||ue)return;let o=performance.now(),a=He(),v=c;if(x!==false){let w=o-st,N=w>0?Math.abs(a-(_e<0?a:_e))/w:0;v=c*Math.max(.2,1+N*(typeof x=="number"?x:1)*.04);}_e=a,st=o;let X=U?We===-1||a>=We?"forward":"reverse":S;We=a;let fe=ce-ie,me=true,ge=fe===0?0:(a-ie)/fe;if(isNaN(Ne)||(Ne<=0&&ge>0?y?.():Ne>0&&ge<=0&&Me?.(),Ne<1&&ge>=1?q?.():Ne>=1&&ge<1&&Ae?.()),Ne=ge,be){let w=we(Q(a,ie,ce,v));Y&&!U&&(ve=Math.max(ve,w),w=ve),Fe=w,e.style.setProperty("--scroll-draw-progress",String(w));let N=X==="reverse"?1-w:w;e.style.clipPath=ne(N),p?.(w),!de&&Q(a,ie,ce,v)>0&&(de=true,T?.()),w>=1&&!re?(re=true,b?.(),Ce<(O==="infinite"?1/0:O??0)&&(Ce++,Le=setTimeout(()=>{ve=-1,de=false,re=false,e.style.clipPath=ne(0);},se))):w<1&&!Y&&(re=false),oe=requestAnimationFrame(je);return}if($.forEach((w,N)=>{let D=N*H*fe,f=we(Q(a,ie+D,ce+D,v));Y&&!U&&(ve=Math.max(ve,f),f=ve),Fe=f,w.style.strokeDashoffset=X==="reverse"?`${R[N]*f}`:`${R[N]*(1-f)}`,u&&(w.style.opacity=X==="reverse"?`${1-f}`:`${f}`),pe&&J?w.style.stroke=Re(pe,J,f):J&&(w.style.stroke=J),K!==null&&i!==null?w.style.strokeWidth=`${K+(i-K)*f}`:i!==null&&(w.style.strokeWidth=`${i}`),d!==null&&F!==null?w.style.fillOpacity=`${d+(F-d)*f}`:F!==null&&(w.style.fillOpacity=`${F}`),L&&w.tagName.toLowerCase()==="path"&&I[N]&&w.setAttribute("d",Ke(I[N],L,f)),N===0&&(p?.(f),e.style.setProperty("--scroll-draw-progress",String(f))),f<1&&(me=false);}),g){let w=we(Q(a,ie,ce,v));for(let N in g){let D=parseFloat(N);w>=D&&!$e.has(D)&&($e.add(D),g[N]?.());}}!de&&Q(a,ie,ce,v)>0&&(de=true,T?.()),me&&!re?(re=true,b?.(),Ce<(O==="infinite"?1/0:O??0)&&(Ce++,Le=setTimeout(()=>{ve=-1,de=false,re=false,$e.clear(),Ge();},se))):!me&&!Y&&(re=false),oe=requestAnimationFrame(je);}let Ze=new IntersectionObserver(o=>{o.forEach(a=>{Be=a.isIntersecting,Be&&!ue?oe=requestAnimationFrame(je):cancelAnimationFrame(oe);});},{root:te??null,threshold:k,rootMargin:G}),Je;function Xe(){clearTimeout(Je),Je=setTimeout(()=>{$.forEach((o,a)=>{R[a]=Ye(o),o.style.strokeDasharray=`${R[a]}`;}),at();},150);}return window.addEventListener("resize",Xe),window.addEventListener("orientationchange",Xe),Z>0?setTimeout(()=>Ze.observe(e),Z):Ze.observe(e),{destroy(){cancelAnimationFrame(oe),clearTimeout(Le),Ze.disconnect(),window.removeEventListener("resize",Xe),window.removeEventListener("orientationchange",Xe),clearTimeout(Je),Ue?.remove();},replay(){ve=-1,We=-1,_e=-1,de=false,re=false,Ce=0,ue=false,$e.clear(),clearTimeout(Le),Ge();},pause(){ue=true,cancelAnimationFrame(oe);},resume(){ue&&(ue=false,Be&&(oe=requestAnimationFrame(je)));},seek(o){let a=Math.min(1,Math.max(0,o));Fe=a,ve=a,ue=true,cancelAnimationFrame(oe),Et(a,S);},getProgress(){return Fe}}}var dt=new Map;function Pe(e,r){dt.set(e,r);}function Oe(e){dt.delete(e);}function Ft(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function gt(e){let r=[],n=/([\w]+)\(([^)]*)\)/g,t;for(;(t=n.exec(e))!==null;){let l=[],s=[],m=t[2].trim();if(m)for(let c of m.split(/[\s,]+/)){let u=c.match(/^([-+]?[\d.eE]+)(.*)$/);l.push(u?parseFloat(u[1]):0),s.push(u?u[2]:"");}r.push({fn:t[1],nums:l,units:s});}return r}function It(e,r,n){let t=gt(e),l=gt(r);return t.length===0||t.length!==l.length?n<1?e:r:t.map((s,m)=>{let c=l[m];return s.fn!==c.fn||s.nums.length!==c.nums.length?n<1?`${s.fn}(${s.nums.map((u,h)=>`${u}${s.units[h]}`).join(", ")})`:`${c.fn}(${c.nums.map((u,h)=>`${u}${c.units[h]}`).join(", ")})`:`${s.fn}(${s.nums.map((u,h)=>`${u+(c.nums[h]-u)*n}${s.units[h]}`).join(", ")})`}).join(" ")}function yt(e,r,n){if(typeof e=="number"&&typeof r=="number")return String(e+(r-e)*n);let t=String(e),l=String(r);if(Ft(t))return Re(t,l,n);if(t.includes("("))return It(t,l,n);let s=t.match(/^([-+]?[\d.]+)(.*)$/),m=l.match(/^([-+]?[\d.]+)(.*)$/);if(s&&m){let c=parseFloat(s[1]),u=parseFloat(m[1]);return `${c+(u-c)*n}${s[2]||m[2]}`}return n<1?t:l}function Nt(e){return e.replace(/([A-Z])/g,r=>`-${r.toLowerCase()}`)}var ht={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Dt=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),Rt=0;function Ht(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function et(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let{props:t,trigger:l={},easing:s="ease-out",speed:m=1,once:c=false,axis:u="y",scrollContainer:h,native:P=true,velocityScale:H=false,onProgress:S,onComplete:Y,onEnter:he,onLeave:V,onEnterBack:ee,onLeaveBack:U}=r,Z=window.matchMedia("(prefers-reduced-motion: reduce)").matches,E=typeof s=="function"?s:ae[s]??ae["ease-out"],M=le(l.start??"top bottom"),C=le(l.end??"bottom top"),g=typeof h=="string"?document.querySelector(h):h??null,x=Object.entries(t).map(([i,d])=>({prop:Nt(i),from:Array.isArray(d)?d[0]:"",to:Array.isArray(d)?d[1]:d}));function k(){let i=window.getComputedStyle(e);for(let d of x)d.from===""&&(d.from=i.getPropertyValue(d.prop).trim()||"0");}function G(){for(let i of x)e.style.setProperty(i.prop,String(i.to));}if(Z)return G(),Y?.(),n;k();function O(){if(!P||!Ht()||typeof s!="string"||!(s in ht)||u!=="y"||g||c||m!==1||S||Y||he||V||ee||U||H!==false||(l.start??"top bottom").trim()!=="top bottom"||(l.end??"bottom top").trim()!=="bottom top")return false;for(let i of x)if(!Dt.has(i.prop))return false;return true}function se(){let i=`ssd-a-${++Rt}`,d=x.map(I=>`${I.prop}:${I.from}`).join(";"),F=x.map(I=>`${I.prop}:${I.to}`).join(";"),ne=document.createElement("style");ne.setAttribute("data-ssd-animate",""),ne.textContent=`@keyframes ${i}{from{${d}}to{${F}}}.${i}{animation-name:${i};animation-duration:auto;animation-timing-function:${ht[s]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(ne),e.classList.add(i);let $=()=>u==="x"?window.scrollX:window.scrollY,R=()=>u==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(i),ne.remove();},replay(){e.classList.remove(i),e.offsetWidth,e.classList.add(i);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(I){let ie=Math.min(1,Math.max(0,I));e.classList.remove(i);for(let ce of x)e.style.setProperty(ce.prop,yt(ce.from,ce.to,ie));},getProgress(){let I=e.getBoundingClientRect(),ie=$(),ce=R(),{tStart:re,tEnd:de}=ye({top:I.top,height:I.height},ie,ce,M,C);return E(Q(ie,re,de,m))}}}if(O())return se();let L=0,W=0,_=0,j=false,z=false,p=-1,T=0,b=false,y=NaN,q=-1,Ae=0,Me=()=>g?u==="x"?g.scrollLeft:g.scrollTop:u==="x"?window.scrollX:window.scrollY,be=()=>g?u==="x"?g.clientWidth:g.clientHeight:u==="x"?window.innerWidth:window.innerHeight;function we(){let i=e.getBoundingClientRect(),d,F;if(g){let $=g.getBoundingClientRect();d=u==="x"?i.left-$.left+g.scrollLeft:i.top-$.top+g.scrollTop,F=u==="x"?i.width:i.height;}else d=u==="x"?i.left:i.top,F=u==="x"?i.width:i.height;let ne=ye({top:d,height:F},Me(),be(),M,C);L=ne.tStart,W=ne.tEnd;}function ke(i){e.style.setProperty("--scroll-draw-progress",String(i));for(let d of x)e.style.setProperty(d.prop,yt(d.from,d.to,i));S?.(i);}function qe(i){if(isNaN(y)){y=i;return}y<=0&&i>0?he?.():y>0&&i<=0&&U?.(),y<1&&i>=1?V?.():y>=1&&i<1&&ee?.(),y=i;}function te(){if(!j||z)return;let i=performance.now(),d=Me(),F=m;if(H!==false){let R=i-Ae,I=R>0?Math.abs(d-(q<0?d:q))/R:0;F=m*Math.max(.2,1+I*(typeof H=="number"?H:1)*.04);}q=d,Ae=i;let ne=W===L?0:(d-L)/(W-L);qe(ne);let $=E(Q(d,L,W,F));c&&(p=Math.max(p,$),$=p),T=$,ke($),$>=1&&!b?(b=true,Y?.()):$<1&&!c&&(b=false),_=requestAnimationFrame(te);}we();{let i=E(Q(Me(),L,W,m));c&&i>0&&(p=i),T=i,ke(i);}let pe=new IntersectionObserver(i=>{i.forEach(d=>{j=d.isIntersecting,j&&!z?_=requestAnimationFrame(te):cancelAnimationFrame(_);});},{root:g??null}),J;function K(){clearTimeout(J),J=setTimeout(we,150);}return window.addEventListener("resize",K),window.addEventListener("orientationchange",K),pe.observe(e),Pe(e,{type:"animate",getProgress:()=>T,getTrigger:()=>({tStart:L,tEnd:W})}),{destroy(){cancelAnimationFrame(_),pe.disconnect(),window.removeEventListener("resize",K),window.removeEventListener("orientationchange",K),clearTimeout(J),Oe(e);},replay(){p=-1,b=false,T=0,z=false,ke(0);},pause(){z=true,cancelAnimationFrame(_);},resume(){z&&(z=false,j&&(_=requestAnimationFrame(te)));},seek(i){let d=Math.min(1,Math.max(0,i));T=d,p=d,z=true,cancelAnimationFrame(_),ke(d);},getProgress(){return T}}}var tt={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function nt(e,r){if(typeof window>"u")return tt;let n=typeof e=="string"?document.querySelector(e):e;if(!n)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollCounter: element not found:",e),tt;let t=n,{from:l=0,to:s,format:m,easing:c="ease-out",trigger:u={},once:h=true,decimals:P,onComplete:H}=r,S=P!==void 0?p=>p.toFixed(P):m??(p=>String(Math.round(p))),Y=typeof c=="function"?c:ae[c]??ae["ease-out"],he=le(u.start??"top 80%"),V=le(u.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=S(s),H?.(),tt;t.textContent=S(l);let U=0,Z=0,E=0,M=false,C=false,g=-1,x=0,k=false,G=()=>window.scrollY,O=()=>window.innerHeight;function se(){let p=t.getBoundingClientRect(),T=ye({top:p.top,height:p.height},G(),O(),he,V);U=T.tStart,Z=T.tEnd;}function L(p){t.textContent=S(l+(s-l)*p),t.style.setProperty("--scroll-draw-progress",String(p));}function W(){if(!M||C)return;let p=Y(Q(G(),U,Z,1));h&&(g=Math.max(g,p),p=g),x=p,L(p),p>=1&&!k?(k=true,H?.()):p<1&&!h&&(k=false),E=requestAnimationFrame(W);}se();{let p=Y(Q(G(),U,Z,1));h&&p>0&&(g=p),x=p,L(p);}let _=new IntersectionObserver(p=>{p.forEach(T=>{M=T.isIntersecting,M&&!C?E=requestAnimationFrame(W):cancelAnimationFrame(E);});}),j;function z(){clearTimeout(j),j=setTimeout(se,150);}return window.addEventListener("resize",z),window.addEventListener("orientationchange",z),_.observe(t),Pe(t,{type:"counter",getProgress:()=>x,getTrigger:()=>({tStart:U,tEnd:Z})}),{destroy(){cancelAnimationFrame(E),_.disconnect(),window.removeEventListener("resize",z),window.removeEventListener("orientationchange",z),clearTimeout(j),Oe(t);},replay(){g=-1,k=false,x=0,C=false,L(0);},pause(){C=true,cancelAnimationFrame(E);},resume(){C&&(C=false,M&&(E=requestAnimationFrame(W)));},seek(p){let T=Math.min(1,Math.max(0,p));x=T,g=T,C=true,cancelAnimationFrame(E),L(T);},getProgress(){return x}}}var bt={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function rt(e,r={}){if(typeof window>"u")return bt;let n=typeof e=="string"?document.querySelector(e):e;if(!n||n.tagName.toLowerCase()!=="video")return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollVideo: <video> element not found:",e),bt;let t=n,{trigger:l={},easing:s="linear",once:m=false,axis:c="y",preload:u="auto",onReady:h,onComplete:P,onProgress:H}=r,S=window.matchMedia("(prefers-reduced-motion: reduce)").matches,Y=typeof s=="function"?s:ae[s]??ae.linear,he=le(l.start??"top top"),V=le(l.end??"bottom top");t.pause(),t.hasAttribute("preload")||(t.preload=u);let ee=r.from??0,U=r.to,Z=0,E=0,M=0,C=false,g=false,x=-1,k=0,G=false,O=false,se=()=>c==="x"?window.scrollX:window.scrollY,L=()=>c==="x"?window.innerWidth:window.innerHeight;function W(){let y=t.getBoundingClientRect(),q=c==="x"?y.left:y.top,Ae=c==="x"?y.width:y.height,Me=ye({top:q,height:Ae},se(),L(),he,V);Z=Me.tStart,E=Me.tEnd;}function _(y){if(!O)return;let q=U??t.duration??0;t.currentTime=ee+(q-ee)*y,t.style.setProperty("--scroll-draw-progress",String(y)),H?.(y);}function j(){if(!C||g||!O)return;let y=Y(Q(se(),Z,E,1));m&&(x=Math.max(x,y),y=x),k=y,_(y),y>=1&&!G?(G=true,P?.()):y<1&&!m&&(G=false),M=requestAnimationFrame(j);}function z(){if(O=true,U===void 0&&(U=t.duration),S){_(1),h?.();return}W(),h?.(),C&&!g&&(M=requestAnimationFrame(j));}t.readyState>=1?z():t.addEventListener("loadedmetadata",z,{once:true}),O||W();let p=new IntersectionObserver(y=>{y.forEach(q=>{C=q.isIntersecting,C&&!g&&O?M=requestAnimationFrame(j):cancelAnimationFrame(M);});}),T;function b(){clearTimeout(T),T=setTimeout(W,150);}return window.addEventListener("resize",b),window.addEventListener("orientationchange",b),p.observe(t),Pe(t,{type:"video",getProgress:()=>k,getTrigger:()=>({tStart:Z,tEnd:E})}),{destroy(){cancelAnimationFrame(M),p.disconnect(),t.removeEventListener("loadedmetadata",z),window.removeEventListener("resize",b),window.removeEventListener("orientationchange",b),clearTimeout(T),Oe(t);},replay(){x=-1,G=false,k=0,g=false,_(0);},pause(){g=true,cancelAnimationFrame(M);},resume(){g&&(g=false,C&&O&&(M=requestAnimationFrame(j)));},seek(y){let q=Math.min(1,Math.max(0,y));k=q,x=q,g=true,cancelAnimationFrame(M),_(q);},getProgress(){return k}}}function St(e){let r=e.textContent??"";return e.textContent="",r.split(/(\s+)/).filter(Boolean).map(n=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),/^\s+$/.test(n)?(t.textContent=n,t.style.whiteSpace="pre"):(t.textContent=n,t.style.display="inline-block"),e.appendChild(t),/^\s+$/.test(n)?null:t}).filter(n=>n!==null)}function Vt(e){let r=e.textContent??"";return e.textContent="",r.split("").map(n=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),t.textContent=n,n===" "?t.style.whiteSpace="pre":t.style.display="inline-block",e.appendChild(t),n===" "?null:t}).filter(n=>n!==null)}function wt(e){let r=St(e),n=new Map;for(let s of r){let m=s.offsetTop;n.has(m)||n.set(m,[]),n.get(m).push(s);}let t=[],l=Array.from(n.keys()).sort((s,m)=>s-m);for(let s of l){let m=n.get(s),c=document.createElement("span");c.setAttribute("aria-hidden","true"),c.style.display="inline-block";for(let u of m)c.appendChild(u);t.push(c);}e.textContent="";for(let s of t)e.appendChild(s),e.appendChild(document.createTextNode(" "));return t}function zt(e,r,n,t){if(n<=1||t===0)return e;let l=(n-1)*t,s=r*t,m=s+(1-l);return m<=s?e>=s?1:0:Math.min(1,Math.max(0,(e-s)/(m-s)))}function qt(e,r){let n=[];if(r?.y!==void 0&&n.push(`translateY(${r.y*(1-e)}px)`),r?.x!==void 0&&n.push(`translateX(${r.x*(1-e)}px)`),r?.rotate!==void 0&&n.push(`rotate(${r.rotate*(1-e)}deg)`),r?.scale!==void 0){let t=r.scale+(1-r.scale)*e;n.push(`scale(${t})`);}return n.join(" ")||""}var vt={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function ot(e,r={}){if(typeof window>"u")return vt;let n=typeof e=="string"?document.querySelector(e):e;if(!n)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollText: element not found:",e),vt;let t=n,{split:l="words",stagger:s=.04,easing:m="ease-out",from:c={opacity:0,y:24},trigger:u={},once:h=true,onComplete:P}=r,H=window.matchMedia("(prefers-reduced-motion: reduce)").matches,S=typeof m=="function"?m:ae[m]??ae["ease-out"],Y=le(u.start??"top 85%"),he=le(u.end??"top 40%"),V=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let ee;l==="chars"?ee=Vt(t):l==="lines"?ee=wt(t):ee=St(t);let U=ee.length;function Z(b,y){c?.opacity!==void 0&&(b.style.opacity=String(c.opacity+(1-c.opacity)*y));let q=qt(y,c);q&&(b.style.transform=q);}function E(b){t.style.setProperty("--scroll-draw-progress",String(b)),ee.forEach((y,q)=>{let Ae=S(zt(b,q,U,s));Z(y,Ae);});}if(H)return E(1),P?.(),{destroy(){t.innerHTML=V,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};E(0);let M=0,C=0,g=0,x=false,k=false,G=-1,O=0,se=false,L=()=>window.scrollY,W=()=>window.innerHeight;function _(){let b=t.getBoundingClientRect(),y=ye({top:b.top,height:b.height},L(),W(),Y,he);M=y.tStart,C=y.tEnd;}function j(){if(!x||k)return;let b=Q(L(),M,C,1);h&&(G=Math.max(G,b),b=G),O=b,E(b),b>=1&&!se?(se=true,P?.()):b<1&&!h&&(se=false),g=requestAnimationFrame(j);}_();let z=new IntersectionObserver(b=>{b.forEach(y=>{x=y.isIntersecting,x&&!k?g=requestAnimationFrame(j):cancelAnimationFrame(g);});}),p;function T(){clearTimeout(p),p=setTimeout(()=>{if(l==="lines"){let b=O;t.innerHTML=V,t.setAttribute("aria-label",t.textContent??""),ee=wt(t),E(b);}_();},150);}return window.addEventListener("resize",T),window.addEventListener("orientationchange",T),z.observe(t),Pe(t,{type:"text",getProgress:()=>O,getTrigger:()=>({tStart:M,tEnd:C})}),{destroy(){cancelAnimationFrame(g),z.disconnect(),window.removeEventListener("resize",T),window.removeEventListener("orientationchange",T),clearTimeout(p),t.innerHTML=V,t.removeAttribute("aria-label"),Oe(t);},replay(){G=-1,se=false,O=0,k=false,E(0);},pause(){k=true,cancelAnimationFrame(g);},resume(){k&&(k=false,x&&(g=requestAnimationFrame(j)));},seek(b){let y=Math.min(1,Math.max(0,b));O=y,G=y,k=true,cancelAnimationFrame(g),E(y);},getProgress(){return O}}}function pn(e={}){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Qe(r.value,e);onUnmounted(()=>n.destroy());}),r}var dn=defineComponent({name:"ScrollDraw",props:{selector:{type:String},speed:{type:Number},fade:{type:Boolean},stagger:{type:Number},easing:{type:[String,Function]},direction:{type:String},trigger:{type:Object},onProgress:{type:Function},onStart:{type:Function},onComplete:{type:Function},once:{type:Boolean},debug:{type:Boolean}},setup(e,{slots:r}){let n=ref(null);return onMounted(()=>{if(!n.value)return;let t={};e.selector!=null&&(t.selector=e.selector),e.speed!=null&&(t.speed=e.speed),e.fade!=null&&(t.fade=e.fade),e.stagger!=null&&(t.stagger=e.stagger),e.easing!=null&&(t.easing=e.easing),e.direction!=null&&(t.direction=e.direction),e.trigger!=null&&(t.trigger=e.trigger),e.once!=null&&(t.once=e.once),e.debug!=null&&(t.debug=e.debug),e.onProgress!=null&&(t.onProgress=e.onProgress),e.onStart!=null&&(t.onStart=e.onStart),e.onComplete!=null&&(t.onComplete=e.onComplete);let l=Qe(n.value,t);onUnmounted(()=>l.destroy());}),()=>h("div",{ref:n},r.default?.())}});function gn(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=et(r.value,e);onUnmounted(()=>n.destroy());}),r}var yn=defineComponent({name:"ScrollAnimate",props:{options:{type:Object,required:true}},setup(e,{slots:r}){let n=ref(null);return onMounted(()=>{if(!n.value)return;let t=et(n.value,e.options);onUnmounted(()=>t.destroy());}),()=>h("div",{ref:n},r.default?.())}});function hn(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=nt(r.value,e);onUnmounted(()=>n.destroy());}),r}var bn=defineComponent({name:"ScrollCounter",props:{to:{type:Number,required:true},from:{type:Number},format:{type:Function},easing:{type:[String,Function]},trigger:{type:Object},once:{type:Boolean},decimals:{type:Number},onComplete:{type:Function}},setup(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n={to:e.to};e.from!=null&&(n.from=e.from),e.format!=null&&(n.format=e.format),e.easing!=null&&(n.easing=e.easing),e.trigger!=null&&(n.trigger=e.trigger),e.once!=null&&(n.once=e.once),e.decimals!=null&&(n.decimals=e.decimals),e.onComplete!=null&&(n.onComplete=e.onComplete);let t=nt(r.value,n);onUnmounted(()=>t.destroy());}),()=>h("span",{ref:r})}});function wn(e={}){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=rt(r.value,e);onUnmounted(()=>n.destroy());}),r}var vn=defineComponent({name:"ScrollVideo",props:{src:{type:String,required:true},options:{type:Object},muted:{type:Boolean,default:true},playsInline:{type:Boolean,default:true},class:{type:String}},setup(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=rt(r.value,e.options??{});onUnmounted(()=>n.destroy());}),()=>h("video",{ref:r,src:e.src,muted:e.muted,playsinline:e.playsInline,preload:"auto",class:e.class})}});function Sn(e={}){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=ot(r.value,e);onUnmounted(()=>n.destroy());}),r}var En=defineComponent({name:"ScrollText",props:{options:{type:Object},tag:{type:String,default:"p"}},setup(e,{slots:r}){let n=ref(null);return onMounted(()=>{if(!n.value)return;let t=ot(n.value,e.options??{});onUnmounted(()=>t.destroy());}),()=>h(e.tag,{ref:n},r.default?.())}});export{yn as ScrollAnimate,bn as ScrollCounter,dn as ScrollDraw,En as ScrollText,vn as ScrollVideo,gn as useScrollAnimate,hn as useScrollCounter,pn as useScrollDraw,Sn as useScrollText,wn as useScrollVideo};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';function
|
|
2
|
-
<div style="position:absolute;${
|
|
3
|
-
<div style="position:absolute;${S?`left:${b}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${b}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(o),window.addEventListener("scroll",m,{passive:true}),m(),o}function Ie(e,s,r){let o=(s.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),m=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,p=>{let $=parseFloat(p),b=o[m++]??$;return String(+($+(b-$)*r).toFixed(4))})}function Ue(e,s={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...o}=s,m=r?{...Be[r],...o}:o,p=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:$="path, polyline, line, polygon, rect, circle",speed:b=1,fade:S=false,easing:y="linear",trigger:x={},stagger:G=0,direction:h="forward",once:K=false,debug:je=false,axis:N="y",scrollContainer:xe,autoReverse:me=false,delay:ue=0,strokeColor:Q,strokeWidth:Y,fillOpacity:Z,waypoints:ee,velocityScale:pe=false,threshold:Oe=0,rootMargin:Ce="0px",repeat:te=0,repeatDelay:Ae=0,morphTo:H,clip:Me,autoplay:Je=false,duration:Ke=1e3,native:Qe=true,onProgress:ce,onStart:de,onComplete:ae}=m,_=Me===true?"left":typeof Me=="string"?Me:false,re=typeof y=="function"?y:Pe[y]??Pe.linear,Re=Le(x.start??"top bottom"),Ne=Le(x.end??"bottom top"),I=typeof xe=="string"?document.querySelector(xe):xe??null,W=Array.isArray(Q)?Q[0]:null,k=Array.isArray(Q)?Q[1]:typeof Q=="string"?Q:null,F=Array.isArray(Y)?Y[0]:null,T=Array.isArray(Y)?Y[1]:typeof Y=="number"?Y:null,O=Array.isArray(Z)?Z[0]:null,P=Array.isArray(Z)?Z[1]:typeof Z=="number"?Z:null;function ne(t){let n=t*100;switch(_){case "right":return `inset(0 0 0 ${100-n}%)`;case "top":return `inset(0 0 ${100-n}% 0)`;case "bottom":return `inset(${100-n}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-n}% 0 0)`}}let A=_?[]:Array.from(e.querySelectorAll($)),v=[],z=[],X=0,U=0,M=false,R=false,E=0,ye=false,q=-1,he=-1,L=false,se=0,B=0,j,Se=null,J=new Set,ge=-1,He=performance.now();function fe(){return I?N==="x"?I.scrollLeft:I.scrollTop:N==="x"?window.scrollX:window.scrollY}function We(){return I?N==="x"?I.clientWidth:I.clientHeight:N==="x"?window.innerWidth:window.innerHeight}function ze(){let t=e.getBoundingClientRect(),n,l,g;if(I){let D=I.getBoundingClientRect();n=N==="x"?t.left-D.left+I.scrollLeft:t.top-D.top+I.scrollTop,l=N==="x"?t.width:t.height,g=fe();}else n=N==="x"?t.left:t.top,l=N==="x"?t.width:t.height,g=fe();let C=De({top:n,height:l},g,We(),Re,Ne);X=C.tStart,U=C.tEnd,je&&process.env.NODE_ENV!=="production"&&(Se?.remove(),Se=lt(X,U,N));}function Ye(t,n){if(e.style.setProperty("--scroll-draw-progress",String(t)),_){let l=n==="reverse"?1-t:t;e.style.clipPath=ne(l);return}A.forEach((l,g)=>{l.style.strokeDashoffset=n==="reverse"?`${v[g]*t}`:`${v[g]*(1-t)}`,S&&(l.style.opacity=n==="reverse"?`${1-t}`:`${t}`),W&&k?l.style.stroke=$e(W,k,t):k&&(l.style.stroke=k),F!==null&&T!==null?l.style.strokeWidth=`${F+(T-F)*t}`:T!==null&&(l.style.strokeWidth=`${T}`),O!==null&&P!==null?l.style.fillOpacity=`${O+(P-O)*t}`:P!==null&&(l.style.fillOpacity=`${P}`),H&&l.tagName.toLowerCase()==="path"&&z[g]&&l.setAttribute("d",Ie(z[g],H,t));});}function be(){if(e.style.setProperty("--scroll-draw-progress","0"),_){e.style.clipPath=ne(0);return}A.forEach((t,n)=>{t.style.strokeDasharray=`${v[n]}`,t.style.strokeDashoffset=h==="reverse"?"0":`${v[n]}`,S?t.style.opacity=h==="reverse"?"1":"0":t.style.opacity="",W&&(t.style.stroke=W),F!==null&&(t.style.strokeWidth=`${F}`),O!==null&&(t.style.fillOpacity=`${O}`),H&&t.tagName.toLowerCase()==="path"&&z[n]&&t.setAttribute("d",z[n]);});}if(A.forEach(t=>{at(t);let n=Ee(t);v.push(n),t.tagName.toLowerCase()==="path"?z.push(t.getAttribute("d")??""):z.push(""),p?(t.style.strokeDasharray=`${n}`,t.style.strokeDashoffset=h==="reverse"?`${n}`:"0",S&&(t.style.opacity="1"),k&&(t.style.stroke=k),T!==null&&(t.style.strokeWidth=`${T}`),P!==null&&(t.style.fillOpacity=`${P}`),H&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",H)):(t.style.strokeDasharray=`${n}`,t.style.strokeDashoffset=h==="reverse"?"0":`${n}`,S?t.style.opacity=h==="reverse"?"1":"0":t.style.opacity="",W&&(t.style.stroke=W),F!==null&&(t.style.strokeWidth=`${F}`),O!==null&&(t.style.fillOpacity=`${O}`));}),_){if(p)return e.style.clipPath=ne(1),ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ne(0);}else if(p)return ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Ze(){return !(Qe===false||!it()||!A.length||typeof y!="string"||!(y in Xe)||_||N!=="y"||I||b!==1||G!==0||K||me||pe!==false||H||ee||te||ue>0||ce||de||ae||Q!=null||Y!=null||Z!=null||(x.start??"top bottom").trim()!=="top bottom"||(x.end??"bottom top").trim()!=="bottom top")}function et(){let t=`svg-scroll-draw-${++ot}`,n=h==="reverse"?"0":"var(--ssd-len)",l=h==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${n};`,C=`stroke-dashoffset:${l};`;S&&(g+=`opacity:${h==="reverse"?1:0};`,C+=`opacity:${h==="reverse"?0:1};`);let D=document.createElement("style");D.setAttribute("data-svg-scroll-draw",""),D.textContent=`@keyframes ${t}{from{${g}}to{${C}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Xe[y]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(D);function a(i,c){i.style.setProperty("--ssd-len",String(v[c])),i.style.strokeDasharray=`${v[c]}`,i.style.strokeDashoffset="",i.style.opacity="",i.style.animationPlayState="",i.classList.add(t);}A.forEach(a);let f=false,w=-1;function u(){if(w>=0)return w;let i=e.getBoundingClientRect(),{tStart:c,tEnd:d}=De({top:i.top,height:i.height},fe(),We(),Re,Ne);return re(ie(fe(),c,d,b))}return {destroy(){A.forEach(i=>{i.classList.remove(t),i.style.removeProperty("--ssd-len"),i.style.animationPlayState="";}),D.remove();},replay(){f=false,w=-1,A.forEach(a);},pause(){f=true,A.forEach(i=>{i.style.animationPlayState="paused";});},resume(){f&&(f=false,A.forEach(i=>{i.style.animationPlayState="running";}));},seek(i){let c=Math.min(1,Math.max(0,i));w=c,f=true,A.forEach((d,oe)=>{d.classList.remove(t),d.style.strokeDashoffset=h==="reverse"?`${v[oe]*c}`:`${v[oe]*(1-c)}`,S&&(d.style.opacity=h==="reverse"?`${1-c}`:`${c}`);});},getProgress(){return u()}}}if(Ze())return et();function tt(){let t=Math.max(1,Ke),n=0,l=0;function g(u){let i=true;if(_){let c=Math.min(1,Math.max(0,u/t)),d=re(c);se=d,e.style.setProperty("--scroll-draw-progress",String(d)),e.style.clipPath=ne(h==="reverse"?1-d:d),ce?.(d),c<1&&(i=false);}else A.forEach((c,d)=>{let oe=d*G*t,le=Math.min(1,Math.max(0,(u-oe)/t)),V=re(le);c.style.strokeDashoffset=h==="reverse"?`${v[d]*V}`:`${v[d]*(1-V)}`,S&&(c.style.opacity=h==="reverse"?`${1-V}`:`${V}`),W&&k?c.style.stroke=$e(W,k,V):k&&(c.style.stroke=k),F!==null&&T!==null?c.style.strokeWidth=`${F+(T-F)*V}`:T!==null&&(c.style.strokeWidth=`${T}`),O!==null&&P!==null?c.style.fillOpacity=`${O+(P-O)*V}`:P!==null&&(c.style.fillOpacity=`${P}`),H&&c.tagName.toLowerCase()==="path"&&z[d]&&c.setAttribute("d",Ie(z[d],H,V)),d===0&&(ce?.(V),e.style.setProperty("--scroll-draw-progress",String(V))),le<1&&(i=false);});if(ee){let c=Math.min(1,Math.max(0,u/t)),d=re(c);for(let oe in ee){let le=parseFloat(oe);d>=le&&!J.has(le)&&(J.add(le),ee[oe]?.());}}return i}function C(u){if(L)return;let i=u-n;R||(R=true,de?.());let c=g(i);if(c&&!M){M=true,g(t*(1+Math.max(0,A.length-1)*G)),ae?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{n=performance.now(),R=false,M=false,J.clear(),be(),E=requestAnimationFrame(C);},Ae));return}c||(E=requestAnimationFrame(C));}function D(){cancelAnimationFrame(E),clearTimeout(j),n=performance.now(),l=0,L=false,R=false,M=false,B=0,J.clear(),be(),E=requestAnimationFrame(C);}let a=new IntersectionObserver(u=>{u.forEach(i=>{i.isIntersecting&&!(K&&M)?D():!i.isIntersecting&&!K&&!M&&(cancelAnimationFrame(E),clearTimeout(j),n=null);});},{root:I??null,threshold:Oe,rootMargin:Ce}),f;function w(){clearTimeout(f),f=setTimeout(()=>{A.forEach((u,i)=>{v[i]=Ee(u),u.style.strokeDasharray=`${v[i]}`;});},150);}return window.addEventListener("resize",w),window.addEventListener("orientationchange",w),ue>0?setTimeout(()=>a.observe(e),ue):a.observe(e),{destroy(){cancelAnimationFrame(E),clearTimeout(j),a.disconnect(),window.removeEventListener("resize",w),window.removeEventListener("orientationchange",w),clearTimeout(f);},replay(){B=0,D();},pause(){L||(L=true,l=performance.now()-n,cancelAnimationFrame(E));},resume(){L&&(L=false,n=performance.now()-l,E=requestAnimationFrame(C));},seek(u){let i=Math.min(1,Math.max(0,u));se=i,L=true,l=i*t,n=performance.now()-l,cancelAnimationFrame(E),g(l);},getProgress(){return se}}}if(Je)return tt();ze();function we(){if(!ye||L)return;let t=performance.now(),n=fe(),l=b;if(pe!==false){let a=t-He,f=a>0?Math.abs(n-(ge<0?n:ge))/a:0;l=b*Math.max(.2,1+f*(typeof pe=="number"?pe:1)*.04);}ge=n,He=t;let g=me?he===-1||n>=he?"forward":"reverse":h;he=n;let C=U-X,D=true;if(_){let a=re(ie(n,X,U,l));K&&!me&&(q=Math.max(q,a),a=q),se=a,e.style.setProperty("--scroll-draw-progress",String(a));let f=g==="reverse"?1-a:a;e.style.clipPath=ne(f),ce?.(a),!R&&ie(n,X,U,l)>0&&(R=true,de?.()),a>=1&&!M?(M=true,ae?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{q=-1,R=false,M=false,e.style.clipPath=ne(0);},Ae))):a<1&&!K&&(M=false),E=requestAnimationFrame(we);return}if(A.forEach((a,f)=>{let w=f*G*C,u=re(ie(n,X+w,U+w,l));K&&!me&&(q=Math.max(q,u),u=q),se=u,a.style.strokeDashoffset=g==="reverse"?`${v[f]*u}`:`${v[f]*(1-u)}`,S&&(a.style.opacity=g==="reverse"?`${1-u}`:`${u}`),W&&k?a.style.stroke=$e(W,k,u):k&&(a.style.stroke=k),F!==null&&T!==null?a.style.strokeWidth=`${F+(T-F)*u}`:T!==null&&(a.style.strokeWidth=`${T}`),O!==null&&P!==null?a.style.fillOpacity=`${O+(P-O)*u}`:P!==null&&(a.style.fillOpacity=`${P}`),H&&a.tagName.toLowerCase()==="path"&&z[f]&&a.setAttribute("d",Ie(z[f],H,u)),f===0&&(ce?.(u),e.style.setProperty("--scroll-draw-progress",String(u))),u<1&&(D=false);}),ee){let a=re(ie(n,X,U,l));for(let f in ee){let w=parseFloat(f);a>=w&&!J.has(w)&&(J.add(w),ee[f]?.());}}!R&&ie(n,X,U,l)>0&&(R=true,de?.()),D&&!M?(M=true,ae?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{q=-1,R=false,M=false,J.clear(),be();},Ae))):!D&&!K&&(M=false),E=requestAnimationFrame(we);}let ke=new IntersectionObserver(t=>{t.forEach(n=>{ye=n.isIntersecting,ye&&!L?E=requestAnimationFrame(we):cancelAnimationFrame(E);});},{root:I??null,threshold:Oe,rootMargin:Ce}),Te;function ve(){clearTimeout(Te),Te=setTimeout(()=>{A.forEach((t,n)=>{v[n]=Ee(t),t.style.strokeDasharray=`${v[n]}`;}),ze();},150);}return window.addEventListener("resize",ve),window.addEventListener("orientationchange",ve),ue>0?setTimeout(()=>ke.observe(e),ue):ke.observe(e),{destroy(){cancelAnimationFrame(E),clearTimeout(j),ke.disconnect(),window.removeEventListener("resize",ve),window.removeEventListener("orientationchange",ve),clearTimeout(Te),Se?.remove();},replay(){q=-1,he=-1,ge=-1,R=false,M=false,B=0,L=false,J.clear(),clearTimeout(j),be();},pause(){L=true,cancelAnimationFrame(E);},resume(){L&&(L=false,ye&&(E=requestAnimationFrame(we)));},seek(t){let n=Math.min(1,Math.max(0,t));se=n,q=n,L=true,cancelAnimationFrame(E),Ye(n,h);},getProgress(){return se}}}var Fe=class extends HTMLElement{constructor(){super(...arguments);this.instance=null;}connectedCallback(){let r={},o=this.getAttribute("speed"),m=this.getAttribute("easing"),p=this.getAttribute("stagger"),$=this.getAttribute("direction"),b=this.getAttribute("selector");o&&(r.speed=parseFloat(o)),m&&(r.easing=m),p&&(r.stagger=parseFloat(p)),$&&(r.direction=$),b&&(r.selector=b),this.hasAttribute("fade")&&(r.fade=this.getAttribute("fade")!=="false"),this.instance=Ue(this,r);}disconnectedCallback(){this.instance?.destroy(),this.instance=null;}};typeof customElements<"u"&&!customElements.get("scroll-draw")&&customElements.define("scroll-draw",Fe);
|
|
1
|
+
'use strict';function at({bounces:e=3,decay:s=.5}={}){let r=Math.max(1,Math.round(e)),i=Math.max(.01,Math.min(.99,s)),m=Math.sqrt(i),p=0,E=[];for(let y=0;y<r;y++){let $=Math.pow(m,y);E.push($),p+=$;}let b=[0],M=0;for(let y=0;y<r;y++)M+=E[y]/p,b.push(M);return y=>{if(y<=0)return 0;if(y>=1)return 1;for(let $=0;$<r;$++)if(y<=b[$+1]){let G=(y-b[$])/(b[$+1]-b[$]);if($===0)return G*(2-G);let h=1-Math.pow(i,$);return h+(1-h)*(2*G-1)*(2*G-1)}return 1}}function lt({amplitude:e=1,period:s=.4}={}){let r=Math.max(1,e),i=Math.max(.1,s),m=r<=1?i/4:i/(2*Math.PI)*Math.asin(1/r);return p=>p<=0?0:p>=1?1:r*Math.pow(2,-10*p)*Math.sin((p-m)*(2*Math.PI)/i)+1}var Le={linear:e=>e,"ease-in":e=>e*e,"ease-out":e=>e*(2-e),"ease-in-out":e=>e<.5?2*e*e:-1+(4-2*e)*e,spring:e=>1-Math.cos(e*Math.PI*2.5)*Math.pow(1-e,2.2),bounce:at(),elastic:lt()};function De(e="top bottom"){let s=e.trim();if(/^\d+(\.\d+)?%$/.test(s))return {element:"top",viewport:s};let[r="top",i="bottom"]=s.split(/\s+/).filter(Boolean);return {element:r,viewport:i}}function Xe(e,s,r,i){switch(i){case "top":return e+r;case "center":return e+r+s/2;case "bottom":return e+r+s;default:return e+r}}function Ue(e,s){if(/^\d+(\.\d+)?%$/.test(e))return s*(parseFloat(e)/100);switch(e){case "top":return 0;case "center":return s/2;case "bottom":return s;default:return s}}function $e(e){let s=e.tagName.toLowerCase();if(s==="rect"){let r=parseFloat(e.getAttribute("width")??"0"),i=parseFloat(e.getAttribute("height")??"0");return 2*(r+i)}if(s==="circle"){let r=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*r}return e.getTotalLength()}function ut(e,s,r){return Math.min(r,Math.max(s,e))}function ie(e,s,r,i){return r===s?0:ut((e-s)/(r-s)*i,0,1)}function Ie(e,s,r,i,m){let p=Xe(e.top,e.height,s,i.element)-Ue(i.viewport,r),E=Xe(e.top,e.height,s,m.element)-Ue(m.viewport,r);return {tStart:p,tEnd:E}}function je(e){let s=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(s)return [parseInt(s[1]+s[1],16),parseInt(s[2]+s[2],16),parseInt(s[3]+s[3],16)];let r=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(r)return [parseInt(r[1],16),parseInt(r[2],16),parseInt(r[3],16)];let i=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return i?[parseInt(i[1]),parseInt(i[2]),parseInt(i[3])]:null}function xe(e,s,r){let i=je(e),m=je(s);return !i||!m?e:`rgb(${Math.round(i[0]+(m[0]-i[0])*r)},${Math.round(i[1]+(m[1]-i[1])*r)},${Math.round(i[2]+(m[2]-i[2])*r)})`}var Je={sketch:{easing:"ease-in",stagger:.1,speed:.9,fade:false},reveal:{easing:"ease-out",fade:true,speed:1.2,once:true},typewriter:{easing:"linear",stagger:.05,speed:1.5},cinematic:{easing:"ease-in-out",fade:true,speed:.75},spring:{easing:"spring",speed:1.1}};function Ke(e,s){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,s);}var Qe={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},ct=0;function ft(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function mt(e){let s=e.getAttribute("stroke"),r=e.getAttribute("fill");!s||s==="none"?Ke("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&&Ke("Element has a fill \u2014 it may obscure the stroke animation.",e);}function pt(e,s,r){let i=document.createElement("div");i.setAttribute("data-svg-scroll-draw-debug",""),i.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function m(){let p=r==="x"?window.scrollX:window.scrollY,E=e-p,b=s-p,M=r==="x";i.innerHTML=`
|
|
2
|
+
<div style="position:absolute;${M?`left:${E}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${E}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
|
|
3
|
+
<div style="position:absolute;${M?`left:${b}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${b}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(i),window.addEventListener("scroll",m,{passive:true}),m(),i}function Fe(e,s,r){let i=(s.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),m=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,p=>{let E=parseFloat(p),b=i[m++]??E;return String(+(E+(b-E)*r).toFixed(4))})}function Ye(e,s={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...i}=s,m=r?{...Je[r],...i}:i,p=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:E="path, polyline, line, polygon, rect, circle",speed:b=1,fade:M=false,easing:y="linear",trigger:$={},stagger:G=0,direction:h="forward",once:K=false,debug:Ze=false,axis:R="y",scrollContainer:Ae,autoReverse:pe=false,delay:ce=0,strokeColor:Q,strokeWidth:Y,fillOpacity:Z,waypoints:ee,velocityScale:de=false,threshold:Ce=0,rootMargin:Ne="0px",repeat:te=0,repeatDelay:Me=0,morphTo:H,clip:Se,autoplay:et=false,duration:tt=1e3,native:rt=true,onProgress:fe,onStart:ye,onComplete:ae,onEnter:Re,onLeave:He,onEnterBack:We,onLeaveBack:ze}=m,X=Se===true?"left":typeof Se=="string"?Se:false,re=typeof y=="function"?y:Le[y]??Le.linear,qe=De($.start??"top bottom"),Ve=De($.end??"bottom top"),I=typeof Ae=="string"?document.querySelector(Ae):Ae??null,W=Array.isArray(Q)?Q[0]:null,S=Array.isArray(Q)?Q[1]:typeof Q=="string"?Q:null,F=Array.isArray(Y)?Y[0]:null,k=Array.isArray(Y)?Y[1]:typeof Y=="number"?Y:null,O=Array.isArray(Z)?Z[0]:null,T=Array.isArray(Z)?Z[1]:typeof Z=="number"?Z:null;function ne(t){let n=t*100;switch(X){case "right":return `inset(0 0 0 ${100-n}%)`;case "top":return `inset(0 0 ${100-n}% 0)`;case "bottom":return `inset(${100-n}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-n}% 0 0)`}}let x=X?[]:Array.from(e.querySelectorAll(E)),w=[],z=[],B=0,U=0,A=false,N=false,v=0,he=false,q=-1,ge=-1,P=false,se=0,_=0,j,ke=null,J=new Set,be=-1,Ge=performance.now(),le=NaN;function me(){return I?R==="x"?I.scrollLeft:I.scrollTop:R==="x"?window.scrollX:window.scrollY}function Be(){return I?R==="x"?I.clientWidth:I.clientHeight:R==="x"?window.innerWidth:window.innerHeight}function _e(){let t=e.getBoundingClientRect(),n,l,g;if(I){let D=I.getBoundingClientRect();n=R==="x"?t.left-D.left+I.scrollLeft:t.top-D.top+I.scrollTop,l=R==="x"?t.width:t.height,g=me();}else n=R==="x"?t.left:t.top,l=R==="x"?t.width:t.height,g=me();let L=Ie({top:n,height:l},g,Be(),qe,Ve);B=L.tStart,U=L.tEnd,Ze&&process.env.NODE_ENV!=="production"&&(ke?.remove(),ke=pt(B,U,R));}function nt(t,n){if(e.style.setProperty("--scroll-draw-progress",String(t)),X){let l=n==="reverse"?1-t:t;e.style.clipPath=ne(l);return}x.forEach((l,g)=>{l.style.strokeDashoffset=n==="reverse"?`${w[g]*t}`:`${w[g]*(1-t)}`,M&&(l.style.opacity=n==="reverse"?`${1-t}`:`${t}`),W&&S?l.style.stroke=xe(W,S,t):S&&(l.style.stroke=S),F!==null&&k!==null?l.style.strokeWidth=`${F+(k-F)*t}`:k!==null&&(l.style.strokeWidth=`${k}`),O!==null&&T!==null?l.style.fillOpacity=`${O+(T-O)*t}`:T!==null&&(l.style.fillOpacity=`${T}`),H&&l.tagName.toLowerCase()==="path"&&z[g]&&l.setAttribute("d",Fe(z[g],H,t));});}function we(){if(e.style.setProperty("--scroll-draw-progress","0"),X){e.style.clipPath=ne(0);return}x.forEach((t,n)=>{t.style.strokeDasharray=`${w[n]}`,t.style.strokeDashoffset=h==="reverse"?"0":`${w[n]}`,M?t.style.opacity=h==="reverse"?"1":"0":t.style.opacity="",W&&(t.style.stroke=W),F!==null&&(t.style.strokeWidth=`${F}`),O!==null&&(t.style.fillOpacity=`${O}`),H&&t.tagName.toLowerCase()==="path"&&z[n]&&t.setAttribute("d",z[n]);});}if(x.forEach(t=>{mt(t);let n=$e(t);w.push(n),t.tagName.toLowerCase()==="path"?z.push(t.getAttribute("d")??""):z.push(""),p?(t.style.strokeDasharray=`${n}`,t.style.strokeDashoffset=h==="reverse"?`${n}`:"0",M&&(t.style.opacity="1"),S&&(t.style.stroke=S),k!==null&&(t.style.strokeWidth=`${k}`),T!==null&&(t.style.fillOpacity=`${T}`),H&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",H)):(t.style.strokeDasharray=`${n}`,t.style.strokeDashoffset=h==="reverse"?"0":`${n}`,M?t.style.opacity=h==="reverse"?"1":"0":t.style.opacity="",W&&(t.style.stroke=W),F!==null&&(t.style.strokeWidth=`${F}`),O!==null&&(t.style.fillOpacity=`${O}`));}),X){if(p)return e.style.clipPath=ne(1),ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ne(0);}else if(p)return ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function st(){return !(rt===false||!ft()||!x.length||typeof y!="string"||!(y in Qe)||X||R!=="y"||I||b!==1||G!==0||K||pe||de!==false||H||ee||te||ce>0||fe||ye||ae||Re||He||We||ze||Q!=null||Y!=null||Z!=null||($.start??"top bottom").trim()!=="top bottom"||($.end??"bottom top").trim()!=="bottom top")}function ot(){let t=`svg-scroll-draw-${++ct}`,n=h==="reverse"?"0":"var(--ssd-len)",l=h==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${n};`,L=`stroke-dashoffset:${l};`;M&&(g+=`opacity:${h==="reverse"?1:0};`,L+=`opacity:${h==="reverse"?0:1};`);let D=document.createElement("style");D.setAttribute("data-svg-scroll-draw",""),D.textContent=`@keyframes ${t}{from{${g}}to{${L}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Qe[y]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(D);function C(o,u){o.style.setProperty("--ssd-len",String(w[u])),o.style.strokeDasharray=`${w[u]}`,o.style.strokeDashoffset="",o.style.opacity="",o.style.animationPlayState="",o.classList.add(t);}x.forEach(C);let a=false,c=-1;function f(){if(c>=0)return c;let o=e.getBoundingClientRect(),{tStart:u,tEnd:d}=Ie({top:o.top,height:o.height},me(),Be(),qe,Ve);return re(ie(me(),u,d,b))}return {destroy(){x.forEach(o=>{o.classList.remove(t),o.style.removeProperty("--ssd-len"),o.style.animationPlayState="";}),D.remove();},replay(){a=false,c=-1,x.forEach(C);},pause(){a=true,x.forEach(o=>{o.style.animationPlayState="paused";});},resume(){a&&(a=false,x.forEach(o=>{o.style.animationPlayState="running";}));},seek(o){let u=Math.min(1,Math.max(0,o));c=u,a=true,x.forEach((d,oe)=>{d.classList.remove(t),d.style.strokeDashoffset=h==="reverse"?`${w[oe]*u}`:`${w[oe]*(1-u)}`,M&&(d.style.opacity=h==="reverse"?`${1-u}`:`${u}`);});},getProgress(){return f()}}}if(st())return ot();function it(){let t=Math.max(1,tt),n=0,l=0;function g(f){let o=true;if(X){let u=Math.min(1,Math.max(0,f/t)),d=re(u);se=d,e.style.setProperty("--scroll-draw-progress",String(d)),e.style.clipPath=ne(h==="reverse"?1-d:d),fe?.(d),u<1&&(o=false);}else x.forEach((u,d)=>{let oe=d*G*t,ue=Math.min(1,Math.max(0,(f-oe)/t)),V=re(ue);u.style.strokeDashoffset=h==="reverse"?`${w[d]*V}`:`${w[d]*(1-V)}`,M&&(u.style.opacity=h==="reverse"?`${1-V}`:`${V}`),W&&S?u.style.stroke=xe(W,S,V):S&&(u.style.stroke=S),F!==null&&k!==null?u.style.strokeWidth=`${F+(k-F)*V}`:k!==null&&(u.style.strokeWidth=`${k}`),O!==null&&T!==null?u.style.fillOpacity=`${O+(T-O)*V}`:T!==null&&(u.style.fillOpacity=`${T}`),H&&u.tagName.toLowerCase()==="path"&&z[d]&&u.setAttribute("d",Fe(z[d],H,V)),d===0&&(fe?.(V),e.style.setProperty("--scroll-draw-progress",String(V))),ue<1&&(o=false);});if(ee){let u=Math.min(1,Math.max(0,f/t)),d=re(u);for(let oe in ee){let ue=parseFloat(oe);d>=ue&&!J.has(ue)&&(J.add(ue),ee[oe]?.());}}return o}function L(f){if(P)return;let o=f-n;N||(N=true,ye?.());let u=g(o);if(u&&!A){A=true,g(t*(1+Math.max(0,x.length-1)*G)),ae?.(),_<(te==="infinite"?1/0:te??0)&&(_++,j=setTimeout(()=>{n=performance.now(),N=false,A=false,J.clear(),we(),v=requestAnimationFrame(L);},Me));return}u||(v=requestAnimationFrame(L));}function D(){cancelAnimationFrame(v),clearTimeout(j),n=performance.now(),l=0,P=false,N=false,A=false,_=0,J.clear(),we(),v=requestAnimationFrame(L);}let C=new IntersectionObserver(f=>{f.forEach(o=>{o.isIntersecting&&!(K&&A)?D():!o.isIntersecting&&!K&&!A&&(cancelAnimationFrame(v),clearTimeout(j),n=null);});},{root:I??null,threshold:Ce,rootMargin:Ne}),a;function c(){clearTimeout(a),a=setTimeout(()=>{x.forEach((f,o)=>{w[o]=$e(f),f.style.strokeDasharray=`${w[o]}`;});},150);}return window.addEventListener("resize",c),window.addEventListener("orientationchange",c),ce>0?setTimeout(()=>C.observe(e),ce):C.observe(e),{destroy(){cancelAnimationFrame(v),clearTimeout(j),C.disconnect(),window.removeEventListener("resize",c),window.removeEventListener("orientationchange",c),clearTimeout(a);},replay(){_=0,D();},pause(){P||(P=true,l=performance.now()-n,cancelAnimationFrame(v));},resume(){P&&(P=false,n=performance.now()-l,v=requestAnimationFrame(L));},seek(f){let o=Math.min(1,Math.max(0,f));se=o,P=true,l=o*t,n=performance.now()-l,cancelAnimationFrame(v),g(l);},getProgress(){return se}}}if(et)return it();_e();function ve(){if(!he||P)return;let t=performance.now(),n=me(),l=b;if(de!==false){let a=t-Ge,c=a>0?Math.abs(n-(be<0?n:be))/a:0;l=b*Math.max(.2,1+c*(typeof de=="number"?de:1)*.04);}be=n,Ge=t;let g=pe?ge===-1||n>=ge?"forward":"reverse":h;ge=n;let L=U-B,D=true,C=L===0?0:(n-B)/L;if(isNaN(le)||(le<=0&&C>0?Re?.():le>0&&C<=0&&ze?.(),le<1&&C>=1?He?.():le>=1&&C<1&&We?.()),le=C,X){let a=re(ie(n,B,U,l));K&&!pe&&(q=Math.max(q,a),a=q),se=a,e.style.setProperty("--scroll-draw-progress",String(a));let c=g==="reverse"?1-a:a;e.style.clipPath=ne(c),fe?.(a),!N&&ie(n,B,U,l)>0&&(N=true,ye?.()),a>=1&&!A?(A=true,ae?.(),_<(te==="infinite"?1/0:te??0)&&(_++,j=setTimeout(()=>{q=-1,N=false,A=false,e.style.clipPath=ne(0);},Me))):a<1&&!K&&(A=false),v=requestAnimationFrame(ve);return}if(x.forEach((a,c)=>{let f=c*G*L,o=re(ie(n,B+f,U+f,l));K&&!pe&&(q=Math.max(q,o),o=q),se=o,a.style.strokeDashoffset=g==="reverse"?`${w[c]*o}`:`${w[c]*(1-o)}`,M&&(a.style.opacity=g==="reverse"?`${1-o}`:`${o}`),W&&S?a.style.stroke=xe(W,S,o):S&&(a.style.stroke=S),F!==null&&k!==null?a.style.strokeWidth=`${F+(k-F)*o}`:k!==null&&(a.style.strokeWidth=`${k}`),O!==null&&T!==null?a.style.fillOpacity=`${O+(T-O)*o}`:T!==null&&(a.style.fillOpacity=`${T}`),H&&a.tagName.toLowerCase()==="path"&&z[c]&&a.setAttribute("d",Fe(z[c],H,o)),c===0&&(fe?.(o),e.style.setProperty("--scroll-draw-progress",String(o))),o<1&&(D=false);}),ee){let a=re(ie(n,B,U,l));for(let c in ee){let f=parseFloat(c);a>=f&&!J.has(f)&&(J.add(f),ee[c]?.());}}!N&&ie(n,B,U,l)>0&&(N=true,ye?.()),D&&!A?(A=true,ae?.(),_<(te==="infinite"?1/0:te??0)&&(_++,j=setTimeout(()=>{q=-1,N=false,A=false,J.clear(),we();},Me))):!D&&!K&&(A=false),v=requestAnimationFrame(ve);}let Te=new IntersectionObserver(t=>{t.forEach(n=>{he=n.isIntersecting,he&&!P?v=requestAnimationFrame(ve):cancelAnimationFrame(v);});},{root:I??null,threshold:Ce,rootMargin:Ne}),Pe;function Ee(){clearTimeout(Pe),Pe=setTimeout(()=>{x.forEach((t,n)=>{w[n]=$e(t),t.style.strokeDasharray=`${w[n]}`;}),_e();},150);}return window.addEventListener("resize",Ee),window.addEventListener("orientationchange",Ee),ce>0?setTimeout(()=>Te.observe(e),ce):Te.observe(e),{destroy(){cancelAnimationFrame(v),clearTimeout(j),Te.disconnect(),window.removeEventListener("resize",Ee),window.removeEventListener("orientationchange",Ee),clearTimeout(Pe),ke?.remove();},replay(){q=-1,ge=-1,be=-1,N=false,A=false,_=0,P=false,J.clear(),clearTimeout(j),we();},pause(){P=true,cancelAnimationFrame(v);},resume(){P&&(P=false,he&&(v=requestAnimationFrame(ve)));},seek(t){let n=Math.min(1,Math.max(0,t));se=n,q=n,P=true,cancelAnimationFrame(v),nt(n,h);},getProgress(){return se}}}var Oe=class extends HTMLElement{constructor(){super(...arguments);this.instance=null;}connectedCallback(){let r={},i=this.getAttribute("speed"),m=this.getAttribute("easing"),p=this.getAttribute("stagger"),E=this.getAttribute("direction"),b=this.getAttribute("selector");i&&(r.speed=parseFloat(i)),m&&(r.easing=m),p&&(r.stagger=parseFloat(p)),E&&(r.direction=E),b&&(r.selector=b),this.hasAttribute("fade")&&(r.fade=this.getAttribute("fade")!=="false"),this.instance=Ye(this,r);}disconnectedCallback(){this.instance?.destroy(),this.instance=null;}};typeof customElements<"u"&&!customElements.get("scroll-draw")&&customElements.define("scroll-draw",Oe);
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
function
|
|
2
|
-
<div style="position:absolute;${
|
|
3
|
-
<div style="position:absolute;${S?`left:${b}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${b}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(o),window.addEventListener("scroll",m,{passive:true}),m(),o}function Ie(e,s,r){let o=(s.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),m=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,p=>{let $=parseFloat(p),b=o[m++]??$;return String(+($+(b-$)*r).toFixed(4))})}function Ue(e,s={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...o}=s,m=r?{...Be[r],...o}:o,p=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:$="path, polyline, line, polygon, rect, circle",speed:b=1,fade:S=false,easing:y="linear",trigger:x={},stagger:G=0,direction:h="forward",once:K=false,debug:je=false,axis:N="y",scrollContainer:xe,autoReverse:me=false,delay:ue=0,strokeColor:Q,strokeWidth:Y,fillOpacity:Z,waypoints:ee,velocityScale:pe=false,threshold:Oe=0,rootMargin:Ce="0px",repeat:te=0,repeatDelay:Ae=0,morphTo:H,clip:Me,autoplay:Je=false,duration:Ke=1e3,native:Qe=true,onProgress:ce,onStart:de,onComplete:ae}=m,_=Me===true?"left":typeof Me=="string"?Me:false,re=typeof y=="function"?y:Pe[y]??Pe.linear,Re=Le(x.start??"top bottom"),Ne=Le(x.end??"bottom top"),I=typeof xe=="string"?document.querySelector(xe):xe??null,W=Array.isArray(Q)?Q[0]:null,k=Array.isArray(Q)?Q[1]:typeof Q=="string"?Q:null,F=Array.isArray(Y)?Y[0]:null,T=Array.isArray(Y)?Y[1]:typeof Y=="number"?Y:null,O=Array.isArray(Z)?Z[0]:null,P=Array.isArray(Z)?Z[1]:typeof Z=="number"?Z:null;function ne(t){let n=t*100;switch(_){case "right":return `inset(0 0 0 ${100-n}%)`;case "top":return `inset(0 0 ${100-n}% 0)`;case "bottom":return `inset(${100-n}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-n}% 0 0)`}}let A=_?[]:Array.from(e.querySelectorAll($)),v=[],z=[],X=0,U=0,M=false,R=false,E=0,ye=false,q=-1,he=-1,L=false,se=0,B=0,j,Se=null,J=new Set,ge=-1,He=performance.now();function fe(){return I?N==="x"?I.scrollLeft:I.scrollTop:N==="x"?window.scrollX:window.scrollY}function We(){return I?N==="x"?I.clientWidth:I.clientHeight:N==="x"?window.innerWidth:window.innerHeight}function ze(){let t=e.getBoundingClientRect(),n,l,g;if(I){let D=I.getBoundingClientRect();n=N==="x"?t.left-D.left+I.scrollLeft:t.top-D.top+I.scrollTop,l=N==="x"?t.width:t.height,g=fe();}else n=N==="x"?t.left:t.top,l=N==="x"?t.width:t.height,g=fe();let C=De({top:n,height:l},g,We(),Re,Ne);X=C.tStart,U=C.tEnd,je&&process.env.NODE_ENV!=="production"&&(Se?.remove(),Se=lt(X,U,N));}function Ye(t,n){if(e.style.setProperty("--scroll-draw-progress",String(t)),_){let l=n==="reverse"?1-t:t;e.style.clipPath=ne(l);return}A.forEach((l,g)=>{l.style.strokeDashoffset=n==="reverse"?`${v[g]*t}`:`${v[g]*(1-t)}`,S&&(l.style.opacity=n==="reverse"?`${1-t}`:`${t}`),W&&k?l.style.stroke=$e(W,k,t):k&&(l.style.stroke=k),F!==null&&T!==null?l.style.strokeWidth=`${F+(T-F)*t}`:T!==null&&(l.style.strokeWidth=`${T}`),O!==null&&P!==null?l.style.fillOpacity=`${O+(P-O)*t}`:P!==null&&(l.style.fillOpacity=`${P}`),H&&l.tagName.toLowerCase()==="path"&&z[g]&&l.setAttribute("d",Ie(z[g],H,t));});}function be(){if(e.style.setProperty("--scroll-draw-progress","0"),_){e.style.clipPath=ne(0);return}A.forEach((t,n)=>{t.style.strokeDasharray=`${v[n]}`,t.style.strokeDashoffset=h==="reverse"?"0":`${v[n]}`,S?t.style.opacity=h==="reverse"?"1":"0":t.style.opacity="",W&&(t.style.stroke=W),F!==null&&(t.style.strokeWidth=`${F}`),O!==null&&(t.style.fillOpacity=`${O}`),H&&t.tagName.toLowerCase()==="path"&&z[n]&&t.setAttribute("d",z[n]);});}if(A.forEach(t=>{at(t);let n=Ee(t);v.push(n),t.tagName.toLowerCase()==="path"?z.push(t.getAttribute("d")??""):z.push(""),p?(t.style.strokeDasharray=`${n}`,t.style.strokeDashoffset=h==="reverse"?`${n}`:"0",S&&(t.style.opacity="1"),k&&(t.style.stroke=k),T!==null&&(t.style.strokeWidth=`${T}`),P!==null&&(t.style.fillOpacity=`${P}`),H&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",H)):(t.style.strokeDasharray=`${n}`,t.style.strokeDashoffset=h==="reverse"?"0":`${n}`,S?t.style.opacity=h==="reverse"?"1":"0":t.style.opacity="",W&&(t.style.stroke=W),F!==null&&(t.style.strokeWidth=`${F}`),O!==null&&(t.style.fillOpacity=`${O}`));}),_){if(p)return e.style.clipPath=ne(1),ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ne(0);}else if(p)return ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Ze(){return !(Qe===false||!it()||!A.length||typeof y!="string"||!(y in Xe)||_||N!=="y"||I||b!==1||G!==0||K||me||pe!==false||H||ee||te||ue>0||ce||de||ae||Q!=null||Y!=null||Z!=null||(x.start??"top bottom").trim()!=="top bottom"||(x.end??"bottom top").trim()!=="bottom top")}function et(){let t=`svg-scroll-draw-${++ot}`,n=h==="reverse"?"0":"var(--ssd-len)",l=h==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${n};`,C=`stroke-dashoffset:${l};`;S&&(g+=`opacity:${h==="reverse"?1:0};`,C+=`opacity:${h==="reverse"?0:1};`);let D=document.createElement("style");D.setAttribute("data-svg-scroll-draw",""),D.textContent=`@keyframes ${t}{from{${g}}to{${C}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Xe[y]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(D);function a(i,c){i.style.setProperty("--ssd-len",String(v[c])),i.style.strokeDasharray=`${v[c]}`,i.style.strokeDashoffset="",i.style.opacity="",i.style.animationPlayState="",i.classList.add(t);}A.forEach(a);let f=false,w=-1;function u(){if(w>=0)return w;let i=e.getBoundingClientRect(),{tStart:c,tEnd:d}=De({top:i.top,height:i.height},fe(),We(),Re,Ne);return re(ie(fe(),c,d,b))}return {destroy(){A.forEach(i=>{i.classList.remove(t),i.style.removeProperty("--ssd-len"),i.style.animationPlayState="";}),D.remove();},replay(){f=false,w=-1,A.forEach(a);},pause(){f=true,A.forEach(i=>{i.style.animationPlayState="paused";});},resume(){f&&(f=false,A.forEach(i=>{i.style.animationPlayState="running";}));},seek(i){let c=Math.min(1,Math.max(0,i));w=c,f=true,A.forEach((d,oe)=>{d.classList.remove(t),d.style.strokeDashoffset=h==="reverse"?`${v[oe]*c}`:`${v[oe]*(1-c)}`,S&&(d.style.opacity=h==="reverse"?`${1-c}`:`${c}`);});},getProgress(){return u()}}}if(Ze())return et();function tt(){let t=Math.max(1,Ke),n=0,l=0;function g(u){let i=true;if(_){let c=Math.min(1,Math.max(0,u/t)),d=re(c);se=d,e.style.setProperty("--scroll-draw-progress",String(d)),e.style.clipPath=ne(h==="reverse"?1-d:d),ce?.(d),c<1&&(i=false);}else A.forEach((c,d)=>{let oe=d*G*t,le=Math.min(1,Math.max(0,(u-oe)/t)),V=re(le);c.style.strokeDashoffset=h==="reverse"?`${v[d]*V}`:`${v[d]*(1-V)}`,S&&(c.style.opacity=h==="reverse"?`${1-V}`:`${V}`),W&&k?c.style.stroke=$e(W,k,V):k&&(c.style.stroke=k),F!==null&&T!==null?c.style.strokeWidth=`${F+(T-F)*V}`:T!==null&&(c.style.strokeWidth=`${T}`),O!==null&&P!==null?c.style.fillOpacity=`${O+(P-O)*V}`:P!==null&&(c.style.fillOpacity=`${P}`),H&&c.tagName.toLowerCase()==="path"&&z[d]&&c.setAttribute("d",Ie(z[d],H,V)),d===0&&(ce?.(V),e.style.setProperty("--scroll-draw-progress",String(V))),le<1&&(i=false);});if(ee){let c=Math.min(1,Math.max(0,u/t)),d=re(c);for(let oe in ee){let le=parseFloat(oe);d>=le&&!J.has(le)&&(J.add(le),ee[oe]?.());}}return i}function C(u){if(L)return;let i=u-n;R||(R=true,de?.());let c=g(i);if(c&&!M){M=true,g(t*(1+Math.max(0,A.length-1)*G)),ae?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{n=performance.now(),R=false,M=false,J.clear(),be(),E=requestAnimationFrame(C);},Ae));return}c||(E=requestAnimationFrame(C));}function D(){cancelAnimationFrame(E),clearTimeout(j),n=performance.now(),l=0,L=false,R=false,M=false,B=0,J.clear(),be(),E=requestAnimationFrame(C);}let a=new IntersectionObserver(u=>{u.forEach(i=>{i.isIntersecting&&!(K&&M)?D():!i.isIntersecting&&!K&&!M&&(cancelAnimationFrame(E),clearTimeout(j),n=null);});},{root:I??null,threshold:Oe,rootMargin:Ce}),f;function w(){clearTimeout(f),f=setTimeout(()=>{A.forEach((u,i)=>{v[i]=Ee(u),u.style.strokeDasharray=`${v[i]}`;});},150);}return window.addEventListener("resize",w),window.addEventListener("orientationchange",w),ue>0?setTimeout(()=>a.observe(e),ue):a.observe(e),{destroy(){cancelAnimationFrame(E),clearTimeout(j),a.disconnect(),window.removeEventListener("resize",w),window.removeEventListener("orientationchange",w),clearTimeout(f);},replay(){B=0,D();},pause(){L||(L=true,l=performance.now()-n,cancelAnimationFrame(E));},resume(){L&&(L=false,n=performance.now()-l,E=requestAnimationFrame(C));},seek(u){let i=Math.min(1,Math.max(0,u));se=i,L=true,l=i*t,n=performance.now()-l,cancelAnimationFrame(E),g(l);},getProgress(){return se}}}if(Je)return tt();ze();function we(){if(!ye||L)return;let t=performance.now(),n=fe(),l=b;if(pe!==false){let a=t-He,f=a>0?Math.abs(n-(ge<0?n:ge))/a:0;l=b*Math.max(.2,1+f*(typeof pe=="number"?pe:1)*.04);}ge=n,He=t;let g=me?he===-1||n>=he?"forward":"reverse":h;he=n;let C=U-X,D=true;if(_){let a=re(ie(n,X,U,l));K&&!me&&(q=Math.max(q,a),a=q),se=a,e.style.setProperty("--scroll-draw-progress",String(a));let f=g==="reverse"?1-a:a;e.style.clipPath=ne(f),ce?.(a),!R&&ie(n,X,U,l)>0&&(R=true,de?.()),a>=1&&!M?(M=true,ae?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{q=-1,R=false,M=false,e.style.clipPath=ne(0);},Ae))):a<1&&!K&&(M=false),E=requestAnimationFrame(we);return}if(A.forEach((a,f)=>{let w=f*G*C,u=re(ie(n,X+w,U+w,l));K&&!me&&(q=Math.max(q,u),u=q),se=u,a.style.strokeDashoffset=g==="reverse"?`${v[f]*u}`:`${v[f]*(1-u)}`,S&&(a.style.opacity=g==="reverse"?`${1-u}`:`${u}`),W&&k?a.style.stroke=$e(W,k,u):k&&(a.style.stroke=k),F!==null&&T!==null?a.style.strokeWidth=`${F+(T-F)*u}`:T!==null&&(a.style.strokeWidth=`${T}`),O!==null&&P!==null?a.style.fillOpacity=`${O+(P-O)*u}`:P!==null&&(a.style.fillOpacity=`${P}`),H&&a.tagName.toLowerCase()==="path"&&z[f]&&a.setAttribute("d",Ie(z[f],H,u)),f===0&&(ce?.(u),e.style.setProperty("--scroll-draw-progress",String(u))),u<1&&(D=false);}),ee){let a=re(ie(n,X,U,l));for(let f in ee){let w=parseFloat(f);a>=w&&!J.has(w)&&(J.add(w),ee[f]?.());}}!R&&ie(n,X,U,l)>0&&(R=true,de?.()),D&&!M?(M=true,ae?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{q=-1,R=false,M=false,J.clear(),be();},Ae))):!D&&!K&&(M=false),E=requestAnimationFrame(we);}let ke=new IntersectionObserver(t=>{t.forEach(n=>{ye=n.isIntersecting,ye&&!L?E=requestAnimationFrame(we):cancelAnimationFrame(E);});},{root:I??null,threshold:Oe,rootMargin:Ce}),Te;function ve(){clearTimeout(Te),Te=setTimeout(()=>{A.forEach((t,n)=>{v[n]=Ee(t),t.style.strokeDasharray=`${v[n]}`;}),ze();},150);}return window.addEventListener("resize",ve),window.addEventListener("orientationchange",ve),ue>0?setTimeout(()=>ke.observe(e),ue):ke.observe(e),{destroy(){cancelAnimationFrame(E),clearTimeout(j),ke.disconnect(),window.removeEventListener("resize",ve),window.removeEventListener("orientationchange",ve),clearTimeout(Te),Se?.remove();},replay(){q=-1,he=-1,ge=-1,R=false,M=false,B=0,L=false,J.clear(),clearTimeout(j),be();},pause(){L=true,cancelAnimationFrame(E);},resume(){L&&(L=false,ye&&(E=requestAnimationFrame(we)));},seek(t){let n=Math.min(1,Math.max(0,t));se=n,q=n,L=true,cancelAnimationFrame(E),Ye(n,h);},getProgress(){return se}}}var Fe=class extends HTMLElement{constructor(){super(...arguments);this.instance=null;}connectedCallback(){let r={},o=this.getAttribute("speed"),m=this.getAttribute("easing"),p=this.getAttribute("stagger"),$=this.getAttribute("direction"),b=this.getAttribute("selector");o&&(r.speed=parseFloat(o)),m&&(r.easing=m),p&&(r.stagger=parseFloat(p)),$&&(r.direction=$),b&&(r.selector=b),this.hasAttribute("fade")&&(r.fade=this.getAttribute("fade")!=="false"),this.instance=Ue(this,r);}disconnectedCallback(){this.instance?.destroy(),this.instance=null;}};typeof customElements<"u"&&!customElements.get("scroll-draw")&&customElements.define("scroll-draw",Fe);
|
|
1
|
+
function at({bounces:e=3,decay:s=.5}={}){let r=Math.max(1,Math.round(e)),i=Math.max(.01,Math.min(.99,s)),m=Math.sqrt(i),p=0,E=[];for(let y=0;y<r;y++){let $=Math.pow(m,y);E.push($),p+=$;}let b=[0],M=0;for(let y=0;y<r;y++)M+=E[y]/p,b.push(M);return y=>{if(y<=0)return 0;if(y>=1)return 1;for(let $=0;$<r;$++)if(y<=b[$+1]){let G=(y-b[$])/(b[$+1]-b[$]);if($===0)return G*(2-G);let h=1-Math.pow(i,$);return h+(1-h)*(2*G-1)*(2*G-1)}return 1}}function lt({amplitude:e=1,period:s=.4}={}){let r=Math.max(1,e),i=Math.max(.1,s),m=r<=1?i/4:i/(2*Math.PI)*Math.asin(1/r);return p=>p<=0?0:p>=1?1:r*Math.pow(2,-10*p)*Math.sin((p-m)*(2*Math.PI)/i)+1}var Le={linear:e=>e,"ease-in":e=>e*e,"ease-out":e=>e*(2-e),"ease-in-out":e=>e<.5?2*e*e:-1+(4-2*e)*e,spring:e=>1-Math.cos(e*Math.PI*2.5)*Math.pow(1-e,2.2),bounce:at(),elastic:lt()};function De(e="top bottom"){let s=e.trim();if(/^\d+(\.\d+)?%$/.test(s))return {element:"top",viewport:s};let[r="top",i="bottom"]=s.split(/\s+/).filter(Boolean);return {element:r,viewport:i}}function Xe(e,s,r,i){switch(i){case "top":return e+r;case "center":return e+r+s/2;case "bottom":return e+r+s;default:return e+r}}function Ue(e,s){if(/^\d+(\.\d+)?%$/.test(e))return s*(parseFloat(e)/100);switch(e){case "top":return 0;case "center":return s/2;case "bottom":return s;default:return s}}function $e(e){let s=e.tagName.toLowerCase();if(s==="rect"){let r=parseFloat(e.getAttribute("width")??"0"),i=parseFloat(e.getAttribute("height")??"0");return 2*(r+i)}if(s==="circle"){let r=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*r}return e.getTotalLength()}function ut(e,s,r){return Math.min(r,Math.max(s,e))}function ie(e,s,r,i){return r===s?0:ut((e-s)/(r-s)*i,0,1)}function Ie(e,s,r,i,m){let p=Xe(e.top,e.height,s,i.element)-Ue(i.viewport,r),E=Xe(e.top,e.height,s,m.element)-Ue(m.viewport,r);return {tStart:p,tEnd:E}}function je(e){let s=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(s)return [parseInt(s[1]+s[1],16),parseInt(s[2]+s[2],16),parseInt(s[3]+s[3],16)];let r=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(r)return [parseInt(r[1],16),parseInt(r[2],16),parseInt(r[3],16)];let i=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return i?[parseInt(i[1]),parseInt(i[2]),parseInt(i[3])]:null}function xe(e,s,r){let i=je(e),m=je(s);return !i||!m?e:`rgb(${Math.round(i[0]+(m[0]-i[0])*r)},${Math.round(i[1]+(m[1]-i[1])*r)},${Math.round(i[2]+(m[2]-i[2])*r)})`}var Je={sketch:{easing:"ease-in",stagger:.1,speed:.9,fade:false},reveal:{easing:"ease-out",fade:true,speed:1.2,once:true},typewriter:{easing:"linear",stagger:.05,speed:1.5},cinematic:{easing:"ease-in-out",fade:true,speed:.75},spring:{easing:"spring",speed:1.1}};function Ke(e,s){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,s);}var Qe={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},ct=0;function ft(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function mt(e){let s=e.getAttribute("stroke"),r=e.getAttribute("fill");!s||s==="none"?Ke("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&&Ke("Element has a fill \u2014 it may obscure the stroke animation.",e);}function pt(e,s,r){let i=document.createElement("div");i.setAttribute("data-svg-scroll-draw-debug",""),i.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function m(){let p=r==="x"?window.scrollX:window.scrollY,E=e-p,b=s-p,M=r==="x";i.innerHTML=`
|
|
2
|
+
<div style="position:absolute;${M?`left:${E}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${E}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
|
|
3
|
+
<div style="position:absolute;${M?`left:${b}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${b}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(i),window.addEventListener("scroll",m,{passive:true}),m(),i}function Fe(e,s,r){let i=(s.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),m=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,p=>{let E=parseFloat(p),b=i[m++]??E;return String(+(E+(b-E)*r).toFixed(4))})}function Ye(e,s={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...i}=s,m=r?{...Je[r],...i}:i,p=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:E="path, polyline, line, polygon, rect, circle",speed:b=1,fade:M=false,easing:y="linear",trigger:$={},stagger:G=0,direction:h="forward",once:K=false,debug:Ze=false,axis:R="y",scrollContainer:Ae,autoReverse:pe=false,delay:ce=0,strokeColor:Q,strokeWidth:Y,fillOpacity:Z,waypoints:ee,velocityScale:de=false,threshold:Ce=0,rootMargin:Ne="0px",repeat:te=0,repeatDelay:Me=0,morphTo:H,clip:Se,autoplay:et=false,duration:tt=1e3,native:rt=true,onProgress:fe,onStart:ye,onComplete:ae,onEnter:Re,onLeave:He,onEnterBack:We,onLeaveBack:ze}=m,X=Se===true?"left":typeof Se=="string"?Se:false,re=typeof y=="function"?y:Le[y]??Le.linear,qe=De($.start??"top bottom"),Ve=De($.end??"bottom top"),I=typeof Ae=="string"?document.querySelector(Ae):Ae??null,W=Array.isArray(Q)?Q[0]:null,S=Array.isArray(Q)?Q[1]:typeof Q=="string"?Q:null,F=Array.isArray(Y)?Y[0]:null,k=Array.isArray(Y)?Y[1]:typeof Y=="number"?Y:null,O=Array.isArray(Z)?Z[0]:null,T=Array.isArray(Z)?Z[1]:typeof Z=="number"?Z:null;function ne(t){let n=t*100;switch(X){case "right":return `inset(0 0 0 ${100-n}%)`;case "top":return `inset(0 0 ${100-n}% 0)`;case "bottom":return `inset(${100-n}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-n}% 0 0)`}}let x=X?[]:Array.from(e.querySelectorAll(E)),w=[],z=[],B=0,U=0,A=false,N=false,v=0,he=false,q=-1,ge=-1,P=false,se=0,_=0,j,ke=null,J=new Set,be=-1,Ge=performance.now(),le=NaN;function me(){return I?R==="x"?I.scrollLeft:I.scrollTop:R==="x"?window.scrollX:window.scrollY}function Be(){return I?R==="x"?I.clientWidth:I.clientHeight:R==="x"?window.innerWidth:window.innerHeight}function _e(){let t=e.getBoundingClientRect(),n,l,g;if(I){let D=I.getBoundingClientRect();n=R==="x"?t.left-D.left+I.scrollLeft:t.top-D.top+I.scrollTop,l=R==="x"?t.width:t.height,g=me();}else n=R==="x"?t.left:t.top,l=R==="x"?t.width:t.height,g=me();let L=Ie({top:n,height:l},g,Be(),qe,Ve);B=L.tStart,U=L.tEnd,Ze&&process.env.NODE_ENV!=="production"&&(ke?.remove(),ke=pt(B,U,R));}function nt(t,n){if(e.style.setProperty("--scroll-draw-progress",String(t)),X){let l=n==="reverse"?1-t:t;e.style.clipPath=ne(l);return}x.forEach((l,g)=>{l.style.strokeDashoffset=n==="reverse"?`${w[g]*t}`:`${w[g]*(1-t)}`,M&&(l.style.opacity=n==="reverse"?`${1-t}`:`${t}`),W&&S?l.style.stroke=xe(W,S,t):S&&(l.style.stroke=S),F!==null&&k!==null?l.style.strokeWidth=`${F+(k-F)*t}`:k!==null&&(l.style.strokeWidth=`${k}`),O!==null&&T!==null?l.style.fillOpacity=`${O+(T-O)*t}`:T!==null&&(l.style.fillOpacity=`${T}`),H&&l.tagName.toLowerCase()==="path"&&z[g]&&l.setAttribute("d",Fe(z[g],H,t));});}function we(){if(e.style.setProperty("--scroll-draw-progress","0"),X){e.style.clipPath=ne(0);return}x.forEach((t,n)=>{t.style.strokeDasharray=`${w[n]}`,t.style.strokeDashoffset=h==="reverse"?"0":`${w[n]}`,M?t.style.opacity=h==="reverse"?"1":"0":t.style.opacity="",W&&(t.style.stroke=W),F!==null&&(t.style.strokeWidth=`${F}`),O!==null&&(t.style.fillOpacity=`${O}`),H&&t.tagName.toLowerCase()==="path"&&z[n]&&t.setAttribute("d",z[n]);});}if(x.forEach(t=>{mt(t);let n=$e(t);w.push(n),t.tagName.toLowerCase()==="path"?z.push(t.getAttribute("d")??""):z.push(""),p?(t.style.strokeDasharray=`${n}`,t.style.strokeDashoffset=h==="reverse"?`${n}`:"0",M&&(t.style.opacity="1"),S&&(t.style.stroke=S),k!==null&&(t.style.strokeWidth=`${k}`),T!==null&&(t.style.fillOpacity=`${T}`),H&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",H)):(t.style.strokeDasharray=`${n}`,t.style.strokeDashoffset=h==="reverse"?"0":`${n}`,M?t.style.opacity=h==="reverse"?"1":"0":t.style.opacity="",W&&(t.style.stroke=W),F!==null&&(t.style.strokeWidth=`${F}`),O!==null&&(t.style.fillOpacity=`${O}`));}),X){if(p)return e.style.clipPath=ne(1),ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ne(0);}else if(p)return ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function st(){return !(rt===false||!ft()||!x.length||typeof y!="string"||!(y in Qe)||X||R!=="y"||I||b!==1||G!==0||K||pe||de!==false||H||ee||te||ce>0||fe||ye||ae||Re||He||We||ze||Q!=null||Y!=null||Z!=null||($.start??"top bottom").trim()!=="top bottom"||($.end??"bottom top").trim()!=="bottom top")}function ot(){let t=`svg-scroll-draw-${++ct}`,n=h==="reverse"?"0":"var(--ssd-len)",l=h==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${n};`,L=`stroke-dashoffset:${l};`;M&&(g+=`opacity:${h==="reverse"?1:0};`,L+=`opacity:${h==="reverse"?0:1};`);let D=document.createElement("style");D.setAttribute("data-svg-scroll-draw",""),D.textContent=`@keyframes ${t}{from{${g}}to{${L}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Qe[y]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(D);function C(o,u){o.style.setProperty("--ssd-len",String(w[u])),o.style.strokeDasharray=`${w[u]}`,o.style.strokeDashoffset="",o.style.opacity="",o.style.animationPlayState="",o.classList.add(t);}x.forEach(C);let a=false,c=-1;function f(){if(c>=0)return c;let o=e.getBoundingClientRect(),{tStart:u,tEnd:d}=Ie({top:o.top,height:o.height},me(),Be(),qe,Ve);return re(ie(me(),u,d,b))}return {destroy(){x.forEach(o=>{o.classList.remove(t),o.style.removeProperty("--ssd-len"),o.style.animationPlayState="";}),D.remove();},replay(){a=false,c=-1,x.forEach(C);},pause(){a=true,x.forEach(o=>{o.style.animationPlayState="paused";});},resume(){a&&(a=false,x.forEach(o=>{o.style.animationPlayState="running";}));},seek(o){let u=Math.min(1,Math.max(0,o));c=u,a=true,x.forEach((d,oe)=>{d.classList.remove(t),d.style.strokeDashoffset=h==="reverse"?`${w[oe]*u}`:`${w[oe]*(1-u)}`,M&&(d.style.opacity=h==="reverse"?`${1-u}`:`${u}`);});},getProgress(){return f()}}}if(st())return ot();function it(){let t=Math.max(1,tt),n=0,l=0;function g(f){let o=true;if(X){let u=Math.min(1,Math.max(0,f/t)),d=re(u);se=d,e.style.setProperty("--scroll-draw-progress",String(d)),e.style.clipPath=ne(h==="reverse"?1-d:d),fe?.(d),u<1&&(o=false);}else x.forEach((u,d)=>{let oe=d*G*t,ue=Math.min(1,Math.max(0,(f-oe)/t)),V=re(ue);u.style.strokeDashoffset=h==="reverse"?`${w[d]*V}`:`${w[d]*(1-V)}`,M&&(u.style.opacity=h==="reverse"?`${1-V}`:`${V}`),W&&S?u.style.stroke=xe(W,S,V):S&&(u.style.stroke=S),F!==null&&k!==null?u.style.strokeWidth=`${F+(k-F)*V}`:k!==null&&(u.style.strokeWidth=`${k}`),O!==null&&T!==null?u.style.fillOpacity=`${O+(T-O)*V}`:T!==null&&(u.style.fillOpacity=`${T}`),H&&u.tagName.toLowerCase()==="path"&&z[d]&&u.setAttribute("d",Fe(z[d],H,V)),d===0&&(fe?.(V),e.style.setProperty("--scroll-draw-progress",String(V))),ue<1&&(o=false);});if(ee){let u=Math.min(1,Math.max(0,f/t)),d=re(u);for(let oe in ee){let ue=parseFloat(oe);d>=ue&&!J.has(ue)&&(J.add(ue),ee[oe]?.());}}return o}function L(f){if(P)return;let o=f-n;N||(N=true,ye?.());let u=g(o);if(u&&!A){A=true,g(t*(1+Math.max(0,x.length-1)*G)),ae?.(),_<(te==="infinite"?1/0:te??0)&&(_++,j=setTimeout(()=>{n=performance.now(),N=false,A=false,J.clear(),we(),v=requestAnimationFrame(L);},Me));return}u||(v=requestAnimationFrame(L));}function D(){cancelAnimationFrame(v),clearTimeout(j),n=performance.now(),l=0,P=false,N=false,A=false,_=0,J.clear(),we(),v=requestAnimationFrame(L);}let C=new IntersectionObserver(f=>{f.forEach(o=>{o.isIntersecting&&!(K&&A)?D():!o.isIntersecting&&!K&&!A&&(cancelAnimationFrame(v),clearTimeout(j),n=null);});},{root:I??null,threshold:Ce,rootMargin:Ne}),a;function c(){clearTimeout(a),a=setTimeout(()=>{x.forEach((f,o)=>{w[o]=$e(f),f.style.strokeDasharray=`${w[o]}`;});},150);}return window.addEventListener("resize",c),window.addEventListener("orientationchange",c),ce>0?setTimeout(()=>C.observe(e),ce):C.observe(e),{destroy(){cancelAnimationFrame(v),clearTimeout(j),C.disconnect(),window.removeEventListener("resize",c),window.removeEventListener("orientationchange",c),clearTimeout(a);},replay(){_=0,D();},pause(){P||(P=true,l=performance.now()-n,cancelAnimationFrame(v));},resume(){P&&(P=false,n=performance.now()-l,v=requestAnimationFrame(L));},seek(f){let o=Math.min(1,Math.max(0,f));se=o,P=true,l=o*t,n=performance.now()-l,cancelAnimationFrame(v),g(l);},getProgress(){return se}}}if(et)return it();_e();function ve(){if(!he||P)return;let t=performance.now(),n=me(),l=b;if(de!==false){let a=t-Ge,c=a>0?Math.abs(n-(be<0?n:be))/a:0;l=b*Math.max(.2,1+c*(typeof de=="number"?de:1)*.04);}be=n,Ge=t;let g=pe?ge===-1||n>=ge?"forward":"reverse":h;ge=n;let L=U-B,D=true,C=L===0?0:(n-B)/L;if(isNaN(le)||(le<=0&&C>0?Re?.():le>0&&C<=0&&ze?.(),le<1&&C>=1?He?.():le>=1&&C<1&&We?.()),le=C,X){let a=re(ie(n,B,U,l));K&&!pe&&(q=Math.max(q,a),a=q),se=a,e.style.setProperty("--scroll-draw-progress",String(a));let c=g==="reverse"?1-a:a;e.style.clipPath=ne(c),fe?.(a),!N&&ie(n,B,U,l)>0&&(N=true,ye?.()),a>=1&&!A?(A=true,ae?.(),_<(te==="infinite"?1/0:te??0)&&(_++,j=setTimeout(()=>{q=-1,N=false,A=false,e.style.clipPath=ne(0);},Me))):a<1&&!K&&(A=false),v=requestAnimationFrame(ve);return}if(x.forEach((a,c)=>{let f=c*G*L,o=re(ie(n,B+f,U+f,l));K&&!pe&&(q=Math.max(q,o),o=q),se=o,a.style.strokeDashoffset=g==="reverse"?`${w[c]*o}`:`${w[c]*(1-o)}`,M&&(a.style.opacity=g==="reverse"?`${1-o}`:`${o}`),W&&S?a.style.stroke=xe(W,S,o):S&&(a.style.stroke=S),F!==null&&k!==null?a.style.strokeWidth=`${F+(k-F)*o}`:k!==null&&(a.style.strokeWidth=`${k}`),O!==null&&T!==null?a.style.fillOpacity=`${O+(T-O)*o}`:T!==null&&(a.style.fillOpacity=`${T}`),H&&a.tagName.toLowerCase()==="path"&&z[c]&&a.setAttribute("d",Fe(z[c],H,o)),c===0&&(fe?.(o),e.style.setProperty("--scroll-draw-progress",String(o))),o<1&&(D=false);}),ee){let a=re(ie(n,B,U,l));for(let c in ee){let f=parseFloat(c);a>=f&&!J.has(f)&&(J.add(f),ee[c]?.());}}!N&&ie(n,B,U,l)>0&&(N=true,ye?.()),D&&!A?(A=true,ae?.(),_<(te==="infinite"?1/0:te??0)&&(_++,j=setTimeout(()=>{q=-1,N=false,A=false,J.clear(),we();},Me))):!D&&!K&&(A=false),v=requestAnimationFrame(ve);}let Te=new IntersectionObserver(t=>{t.forEach(n=>{he=n.isIntersecting,he&&!P?v=requestAnimationFrame(ve):cancelAnimationFrame(v);});},{root:I??null,threshold:Ce,rootMargin:Ne}),Pe;function Ee(){clearTimeout(Pe),Pe=setTimeout(()=>{x.forEach((t,n)=>{w[n]=$e(t),t.style.strokeDasharray=`${w[n]}`;}),_e();},150);}return window.addEventListener("resize",Ee),window.addEventListener("orientationchange",Ee),ce>0?setTimeout(()=>Te.observe(e),ce):Te.observe(e),{destroy(){cancelAnimationFrame(v),clearTimeout(j),Te.disconnect(),window.removeEventListener("resize",Ee),window.removeEventListener("orientationchange",Ee),clearTimeout(Pe),ke?.remove();},replay(){q=-1,ge=-1,be=-1,N=false,A=false,_=0,P=false,J.clear(),clearTimeout(j),we();},pause(){P=true,cancelAnimationFrame(v);},resume(){P&&(P=false,he&&(v=requestAnimationFrame(ve)));},seek(t){let n=Math.min(1,Math.max(0,t));se=n,q=n,P=true,cancelAnimationFrame(v),nt(n,h);},getProgress(){return se}}}var Oe=class extends HTMLElement{constructor(){super(...arguments);this.instance=null;}connectedCallback(){let r={},i=this.getAttribute("speed"),m=this.getAttribute("easing"),p=this.getAttribute("stagger"),E=this.getAttribute("direction"),b=this.getAttribute("selector");i&&(r.speed=parseFloat(i)),m&&(r.easing=m),p&&(r.stagger=parseFloat(p)),E&&(r.direction=E),b&&(r.selector=b),this.hasAttribute("fade")&&(r.fade=this.getAttribute("fade")!=="false"),this.instance=Ye(this,r);}disconnectedCallback(){this.instance?.destroy(),this.instance=null;}};typeof customElements<"u"&&!customElements.get("scroll-draw")&&customElements.define("scroll-draw",Oe);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "svg-scroll-draw",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.9.0",
|
|
4
4
|
"description": "Scroll-driven SVG path drawing animation library — zero dependencies, ~4.4 KB gzipped, works with React, Vue, and vanilla JS",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"svg",
|
|
@@ -141,6 +141,36 @@
|
|
|
141
141
|
"types": "./dist/devtools/index.d.ts",
|
|
142
142
|
"import": "./dist/devtools/index.mjs",
|
|
143
143
|
"require": "./dist/devtools/index.cjs"
|
|
144
|
+
},
|
|
145
|
+
"./pin": {
|
|
146
|
+
"types": "./dist/pin/index.d.ts",
|
|
147
|
+
"import": "./dist/pin/index.mjs",
|
|
148
|
+
"require": "./dist/pin/index.cjs"
|
|
149
|
+
},
|
|
150
|
+
"./snap": {
|
|
151
|
+
"types": "./dist/snap/index.d.ts",
|
|
152
|
+
"import": "./dist/snap/index.mjs",
|
|
153
|
+
"require": "./dist/snap/index.cjs"
|
|
154
|
+
},
|
|
155
|
+
"./lenis": {
|
|
156
|
+
"types": "./dist/lenis/index.d.ts",
|
|
157
|
+
"import": "./dist/lenis/index.mjs",
|
|
158
|
+
"require": "./dist/lenis/index.cjs"
|
|
159
|
+
},
|
|
160
|
+
"./reveal": {
|
|
161
|
+
"types": "./dist/reveal/index.d.ts",
|
|
162
|
+
"import": "./dist/reveal/index.mjs",
|
|
163
|
+
"require": "./dist/reveal/index.cjs"
|
|
164
|
+
},
|
|
165
|
+
"./progress": {
|
|
166
|
+
"types": "./dist/progress/index.d.ts",
|
|
167
|
+
"import": "./dist/progress/index.mjs",
|
|
168
|
+
"require": "./dist/progress/index.cjs"
|
|
169
|
+
},
|
|
170
|
+
"./horizontal": {
|
|
171
|
+
"types": "./dist/horizontal/index.d.ts",
|
|
172
|
+
"import": "./dist/horizontal/index.mjs",
|
|
173
|
+
"require": "./dist/horizontal/index.cjs"
|
|
144
174
|
}
|
|
145
175
|
},
|
|
146
176
|
"scripts": {
|