svg-scroll-draw 2.2.0 → 2.6.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/README.md +7 -7
- package/dist/angular/index.cjs +3 -3
- package/dist/angular/index.d.mts +178 -9
- package/dist/angular/index.d.ts +178 -9
- package/dist/angular/index.mjs +3 -3
- package/dist/astro/index.cjs +3 -3
- package/dist/astro/index.d.mts +70 -1
- package/dist/astro/index.d.ts +70 -1
- package/dist/astro/index.mjs +3 -3
- package/dist/devtools/index.d.mts +12 -0
- package/dist/devtools/index.d.ts +12 -0
- package/dist/group/index.cjs +3 -3
- package/dist/group/index.d.mts +72 -1
- package/dist/group/index.d.ts +72 -1
- package/dist/group/index.mjs +3 -3
- package/dist/nuxt/index.cjs +3 -3
- package/dist/nuxt/index.d.mts +270 -5
- package/dist/nuxt/index.d.ts +270 -5
- package/dist/nuxt/index.mjs +3 -3
- package/dist/solid/index.cjs +3 -3
- package/dist/solid/index.d.mts +155 -1
- package/dist/solid/index.d.ts +155 -1
- package/dist/solid/index.mjs +3 -3
- package/dist/svelte/index.cjs +3 -3
- package/dist/svelte/index.d.mts +167 -10
- package/dist/svelte/index.d.ts +167 -10
- package/dist/svelte/index.mjs +3 -3
- package/dist/vue/index.cjs +3 -3
- package/dist/vue/index.d.mts +262 -1
- package/dist/vue/index.d.ts +262 -1
- package/dist/vue/index.mjs +3 -3
- package/package.json +1 -1
package/dist/angular/index.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
function
|
|
2
|
-
<div style="position:absolute;${
|
|
3
|
-
<div style="position:absolute;${S?`left:${x}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${x}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",h,{passive:true}),h(),o}function Ie(e,n,s){let o=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),h=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,g=>{let D=parseFloat(g),x=o[h++]??D;return String(+(D+(x-D)*s).toFixed(4))})}function Xe(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:s,...o}=n,h=s?{...Ge[s],...o}:o,g=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:D="path, polyline, line, polygon, rect, circle",speed:x=1,fade:S=false,easing:p="linear",trigger:E={},stagger:G=0,direction:d="forward",once:K=false,debug:je=false,axis:N="y",scrollContainer:$e,autoReverse:me=false,delay:ue=0,strokeColor:Q,strokeWidth:Y,fillOpacity:Z,waypoints:ee,velocityScale:pe=false,threshold:Oe=0,rootMargin:Fe="0px",repeat:te=0,repeatDelay:Me=0,morphTo:H,clip:Se,autoplay:Je=false,duration:Ke=1e3,native:Qe=true,onProgress:ce,onStart:de,onComplete:ae}=h,_=Se===true?"left":typeof Se=="string"?Se:false,re=typeof p=="function"?p:Pe[p]??Pe.linear,Ce=Le(E.start??"top bottom"),Re=Le(E.end??"bottom top"),I=typeof $e=="string"?document.querySelector($e):$e??null,W=Array.isArray(Q)?Q[0]:null,T=Array.isArray(Q)?Q[1]:typeof Q=="string"?Q:null,O=Array.isArray(Y)?Y[0]:null,k=Array.isArray(Y)?Y[1]:typeof Y=="number"?Y:null,F=Array.isArray(Z)?Z[0]:null,A=Array.isArray(Z)?Z[1]:typeof Z=="number"?Z:null;function ne(t){let r=t*100;switch(_){case "right":return `inset(0 0 0 ${100-r}%)`;case "top":return `inset(0 0 ${100-r}% 0)`;case "bottom":return `inset(${100-r}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-r}% 0 0)`}}let $=_?[]:Array.from(e.querySelectorAll(D)),w=[],z=[],X=0,U=0,M=false,R=false,v=0,ye=false,q=-1,he=-1,P=false,se=0,B=0,j,Te=null,J=new Set,ge=-1,Ne=performance.now();function fe(){return I?N==="x"?I.scrollLeft:I.scrollTop:N==="x"?window.scrollX:window.scrollY}function He(){return I?N==="x"?I.clientWidth:I.clientHeight:N==="x"?window.innerWidth:window.innerHeight}function We(){let t=e.getBoundingClientRect(),r,l,y;if(I){let L=I.getBoundingClientRect();r=N==="x"?t.left-L.left+I.scrollLeft:t.top-L.top+I.scrollTop,l=N==="x"?t.width:t.height,y=fe();}else r=N==="x"?t.left:t.top,l=N==="x"?t.width:t.height,y=fe();let C=De({top:r,height:l},y,He(),Ce,Re);X=C.tStart,U=C.tEnd,je&&process.env.NODE_ENV!=="production"&&(Te?.remove(),Te=lt(X,U,N));}function Ye(t,r){if(e.style.setProperty("--scroll-draw-progress",String(t)),_){let l=r==="reverse"?1-t:t;e.style.clipPath=ne(l);return}$.forEach((l,y)=>{l.style.strokeDashoffset=r==="reverse"?`${w[y]*t}`:`${w[y]*(1-t)}`,S&&(l.style.opacity=r==="reverse"?`${1-t}`:`${t}`),W&&T?l.style.stroke=xe(W,T,t):T&&(l.style.stroke=T),O!==null&&k!==null?l.style.strokeWidth=`${O+(k-O)*t}`:k!==null&&(l.style.strokeWidth=`${k}`),F!==null&&A!==null?l.style.fillOpacity=`${F+(A-F)*t}`:A!==null&&(l.style.fillOpacity=`${A}`),H&&l.tagName.toLowerCase()==="path"&&z[y]&&l.setAttribute("d",Ie(z[y],H,t));});}function be(){if(e.style.setProperty("--scroll-draw-progress","0"),_){e.style.clipPath=ne(0);return}$.forEach((t,r)=>{t.style.strokeDasharray=`${w[r]}`,t.style.strokeDashoffset=d==="reverse"?"0":`${w[r]}`,S?t.style.opacity=d==="reverse"?"1":"0":t.style.opacity="",W&&(t.style.stroke=W),O!==null&&(t.style.strokeWidth=`${O}`),F!==null&&(t.style.fillOpacity=`${F}`),H&&t.tagName.toLowerCase()==="path"&&z[r]&&t.setAttribute("d",z[r]);});}if($.forEach(t=>{at(t);let r=Ee(t);w.push(r),t.tagName.toLowerCase()==="path"?z.push(t.getAttribute("d")??""):z.push(""),g?(t.style.strokeDasharray=`${r}`,t.style.strokeDashoffset=d==="reverse"?`${r}`:"0",S&&(t.style.opacity="1"),T&&(t.style.stroke=T),k!==null&&(t.style.strokeWidth=`${k}`),A!==null&&(t.style.fillOpacity=`${A}`),H&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",H)):(t.style.strokeDasharray=`${r}`,t.style.strokeDashoffset=d==="reverse"?"0":`${r}`,S?t.style.opacity=d==="reverse"?"1":"0":t.style.opacity="",W&&(t.style.stroke=W),O!==null&&(t.style.strokeWidth=`${O}`),F!==null&&(t.style.fillOpacity=`${F}`));}),_){if(g)return e.style.clipPath=ne(1),ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ne(0);}else if(g)return ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Ze(){return !(Qe===false||!it()||!$.length||typeof p!="string"||!(p in _e)||_||N!=="y"||I||x!==1||G!==0||K||me||pe!==false||H||ee||te||ue>0||ce||de||ae||Q!=null||Y!=null||Z!=null||(E.start??"top bottom").trim()!=="top bottom"||(E.end??"bottom top").trim()!=="bottom top")}function et(){let t=`svg-scroll-draw-${++ot}`,r=d==="reverse"?"0":"var(--ssd-len)",l=d==="reverse"?"var(--ssd-len)":"0",y=`stroke-dashoffset:${r};`,C=`stroke-dashoffset:${l};`;S&&(y+=`opacity:${d==="reverse"?1:0};`,C+=`opacity:${d==="reverse"?0:1};`);let L=document.createElement("style");L.setAttribute("data-svg-scroll-draw",""),L.textContent=`@keyframes ${t}{from{${y}}to{${C}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${_e[p]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(L);function a(i,c){i.style.setProperty("--ssd-len",String(w[c])),i.style.strokeDasharray=`${w[c]}`,i.style.strokeDashoffset="",i.style.opacity="",i.style.animationPlayState="",i.classList.add(t);}$.forEach(a);let f=false,b=-1;function u(){if(b>=0)return b;let i=e.getBoundingClientRect(),{tStart:c,tEnd:m}=De({top:i.top,height:i.height},fe(),He(),Ce,Re);return re(ie(fe(),c,m,x))}return {destroy(){$.forEach(i=>{i.classList.remove(t),i.style.removeProperty("--ssd-len"),i.style.animationPlayState="";}),L.remove();},replay(){f=false,b=-1,$.forEach(a);},pause(){f=true,$.forEach(i=>{i.style.animationPlayState="paused";});},resume(){f&&(f=false,$.forEach(i=>{i.style.animationPlayState="running";}));},seek(i){let c=Math.min(1,Math.max(0,i));b=c,f=true,$.forEach((m,oe)=>{m.classList.remove(t),m.style.strokeDashoffset=d==="reverse"?`${w[oe]*c}`:`${w[oe]*(1-c)}`,S&&(m.style.opacity=d==="reverse"?`${1-c}`:`${c}`);});},getProgress(){return u()}}}if(Ze())return et();function tt(){let t=Math.max(1,Ke),r=0,l=0;function y(u){let i=true;if(_){let c=Math.min(1,Math.max(0,u/t)),m=re(c);se=m,e.style.setProperty("--scroll-draw-progress",String(m)),e.style.clipPath=ne(d==="reverse"?1-m:m),ce?.(m),c<1&&(i=false);}else $.forEach((c,m)=>{let oe=m*G*t,le=Math.min(1,Math.max(0,(u-oe)/t)),V=re(le);c.style.strokeDashoffset=d==="reverse"?`${w[m]*V}`:`${w[m]*(1-V)}`,S&&(c.style.opacity=d==="reverse"?`${1-V}`:`${V}`),W&&T?c.style.stroke=xe(W,T,V):T&&(c.style.stroke=T),O!==null&&k!==null?c.style.strokeWidth=`${O+(k-O)*V}`:k!==null&&(c.style.strokeWidth=`${k}`),F!==null&&A!==null?c.style.fillOpacity=`${F+(A-F)*V}`:A!==null&&(c.style.fillOpacity=`${A}`),H&&c.tagName.toLowerCase()==="path"&&z[m]&&c.setAttribute("d",Ie(z[m],H,V)),m===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)),m=re(c);for(let oe in ee){let le=parseFloat(oe);m>=le&&!J.has(le)&&(J.add(le),ee[oe]?.());}}return i}function C(u){if(P)return;let i=u-r;R||(R=true,de?.());let c=y(i);if(c&&!M){M=true,y(t*(1+Math.max(0,$.length-1)*G)),ae?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{r=performance.now(),R=false,M=false,J.clear(),be(),v=requestAnimationFrame(C);},Me));return}c||(v=requestAnimationFrame(C));}function L(){cancelAnimationFrame(v),clearTimeout(j),r=performance.now(),l=0,P=false,R=false,M=false,B=0,J.clear(),be(),v=requestAnimationFrame(C);}let a=new IntersectionObserver(u=>{u.forEach(i=>{i.isIntersecting&&!(K&&M)?L():!i.isIntersecting&&!K&&!M&&(cancelAnimationFrame(v),clearTimeout(j),r=null);});},{root:I??null,threshold:Oe,rootMargin:Fe}),f;function b(){clearTimeout(f),f=setTimeout(()=>{$.forEach((u,i)=>{w[i]=Ee(u),u.style.strokeDasharray=`${w[i]}`;});},150);}return window.addEventListener("resize",b),window.addEventListener("orientationchange",b),ue>0?setTimeout(()=>a.observe(e),ue):a.observe(e),{destroy(){cancelAnimationFrame(v),clearTimeout(j),a.disconnect(),window.removeEventListener("resize",b),window.removeEventListener("orientationchange",b),clearTimeout(f);},replay(){B=0,L();},pause(){P||(P=true,l=performance.now()-r,cancelAnimationFrame(v));},resume(){P&&(P=false,r=performance.now()-l,v=requestAnimationFrame(C));},seek(u){let i=Math.min(1,Math.max(0,u));se=i,P=true,l=i*t,r=performance.now()-l,cancelAnimationFrame(v),y(l);},getProgress(){return se}}}if(Je)return tt();We();function we(){if(!ye||P)return;let t=performance.now(),r=fe(),l=x;if(pe!==false){let a=t-Ne,f=a>0?Math.abs(r-(ge<0?r:ge))/a:0;l=x*Math.max(.2,1+f*(typeof pe=="number"?pe:1)*.04);}ge=r,Ne=t;let y=me?he===-1||r>=he?"forward":"reverse":d;he=r;let C=U-X,L=true;if(_){let a=re(ie(r,X,U,l));K&&!me&&(q=Math.max(q,a),a=q),se=a,e.style.setProperty("--scroll-draw-progress",String(a));let f=y==="reverse"?1-a:a;e.style.clipPath=ne(f),ce?.(a),!R&&ie(r,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);},Me))):a<1&&!K&&(M=false),v=requestAnimationFrame(we);return}if($.forEach((a,f)=>{let b=f*G*C,u=re(ie(r,X+b,U+b,l));K&&!me&&(q=Math.max(q,u),u=q),se=u,a.style.strokeDashoffset=y==="reverse"?`${w[f]*u}`:`${w[f]*(1-u)}`,S&&(a.style.opacity=y==="reverse"?`${1-u}`:`${u}`),W&&T?a.style.stroke=xe(W,T,u):T&&(a.style.stroke=T),O!==null&&k!==null?a.style.strokeWidth=`${O+(k-O)*u}`:k!==null&&(a.style.strokeWidth=`${k}`),F!==null&&A!==null?a.style.fillOpacity=`${F+(A-F)*u}`:A!==null&&(a.style.fillOpacity=`${A}`),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&&(L=false);}),ee){let a=re(ie(r,X,U,l));for(let f in ee){let b=parseFloat(f);a>=b&&!J.has(b)&&(J.add(b),ee[f]?.());}}!R&&ie(r,X,U,l)>0&&(R=true,de?.()),L&&!M?(M=true,ae?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{q=-1,R=false,M=false,J.clear(),be();},Me))):!L&&!K&&(M=false),v=requestAnimationFrame(we);}let ke=new IntersectionObserver(t=>{t.forEach(r=>{ye=r.isIntersecting,ye&&!P?v=requestAnimationFrame(we):cancelAnimationFrame(v);});},{root:I??null,threshold:Oe,rootMargin:Fe}),Ae;function ve(){clearTimeout(Ae),Ae=setTimeout(()=>{$.forEach((t,r)=>{w[r]=Ee(t),t.style.strokeDasharray=`${w[r]}`;}),We();},150);}return window.addEventListener("resize",ve),window.addEventListener("orientationchange",ve),ue>0?setTimeout(()=>ke.observe(e),ue):ke.observe(e),{destroy(){cancelAnimationFrame(v),clearTimeout(j),ke.disconnect(),window.removeEventListener("resize",ve),window.removeEventListener("orientationchange",ve),clearTimeout(Ae),Te?.remove();},replay(){q=-1,he=-1,ge=-1,R=false,M=false,B=0,P=false,J.clear(),clearTimeout(j),be();},pause(){P=true,cancelAnimationFrame(v);},resume(){P&&(P=false,ye&&(v=requestAnimationFrame(we)));},seek(t){let r=Math.min(1,Math.max(0,t));se=r,q=r,P=true,cancelAnimationFrame(v),Ye(r,d);},getProgress(){return se}}}var Ue=class{constructor(){this.instance=null;}init(n,s={}){return this.destroy(),this.instance=Xe(n,s),this}replay(){return this.instance?.replay(),this}destroy(){return this.instance?.destroy(),this.instance=null,this}};export{Ue as ScrollDrawRef};
|
|
1
|
+
function Et({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,r)),u=Math.sqrt(t),o=0,m=[];for(let d=0;d<n;d++){let I=Math.pow(u,d);m.push(I),o+=I;}let l=[0],c=0;for(let d=0;d<n;d++)c+=m[d]/o,l.push(c);return d=>{if(d<=0)return 0;if(d>=1)return 1;for(let I=0;I<n;I++)if(d<=l[I+1]){let B=(d-l[I])/(l[I+1]-l[I]);if(I===0)return B*(2-B);let E=1-Math.pow(t,I);return E+(1-E)*(2*B-1)*(2*B-1)}return 1}}function St({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),t=Math.max(.1,r),u=n<=1?t/4:t/(2*Math.PI)*Math.asin(1/n);return o=>o<=0?0:o>=1?1:n*Math.pow(2,-10*o)*Math.sin((o-u)*(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:Et(),elastic:St()};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 Ye(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 je(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 Re(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 xt(e,r,n){return Math.min(n,Math.max(r,e))}function J(e,r,n,t){return n===r?0:xt((e-r)/(n-r)*t,0,1)}function fe(e,r,n,t,u){let o=Ye(e.top,e.height,r,t.element)-je(t.viewport,n),m=Ye(e.top,e.height,r,u.element)-je(u.viewport,n);return {tStart:o,tEnd:m}}function Ue(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 Ce(e,r,n){let t=Ue(e),u=Ue(r);return !t||!u?e:`rgb(${Math.round(t[0]+(u[0]-t[0])*n)},${Math.round(t[1]+(u[1]-t[1])*n)},${Math.round(t[2]+(u[2]-t[2])*n)})`}var Ze={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 Je(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r);}var Ke={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Tt=0;function At(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Mt(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?Je("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&Je("Element has a fill \u2014 it may obscure the stroke animation.",e);}function $t(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 u(){let o=n==="x"?window.scrollX:window.scrollY,m=e-o,l=r-o,c=n==="x";t.innerHTML=`
|
|
2
|
+
<div style="position:absolute;${c?`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;${c?`left:${l}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${l}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",u,{passive:true}),u(),t}function We(e,r,n){let t=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),u=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,o=>{let m=parseFloat(o),l=t[u++]??m;return String(+(m+(l-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,u=n?{...Ze[n],...t}:t,o=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:m="path, polyline, line, polygon, rect, circle",speed:l=1,fade:c=false,easing:d="linear",trigger:I={},stagger:B=0,direction:E="forward",once:re=false,debug:de=false,axis:q="y",scrollContainer:K,autoReverse:T=false,delay:N=0,strokeColor:A,strokeWidth:$,fillOpacity:P,waypoints:b,velocityScale:L=false,threshold:O=0,rootMargin:D="0px",repeat:M=0,repeatDelay:z=0,morphTo:C,clip:_,autoplay:Q=false,duration:j=1e3,native:oe=true,onProgress:f,onStart:k,onComplete:h}=u,p=_===true?"left":typeof _=="string"?_:false,F=typeof d=="function"?d:ae[d]??ae.linear,ge=le(I.start??"top bottom"),a=le(I.end??"bottom top"),g=typeof K=="string"?document.querySelector(K):K??null,ne=Array.isArray(A)?A[0]:null,V=Array.isArray(A)?A[1]:typeof A=="string"?A:null,U=Array.isArray($)?$[0]:null,se=Array.isArray($)?$[1]:typeof $=="number"?$:null,H=Array.isArray(P)?P[0]:null,G=Array.isArray(P)?P[1]:typeof P=="number"?P:null;function me(s){let i=s*100;switch(p){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(${s*150}% at 50% 50%)`;default:return `inset(0 ${100-i}% 0 0)`}}let ee=p?[]:Array.from(e.querySelectorAll(m)),X=[],ye=[],Ee=0,Se=0,ie=false,he=false,te=0,Ie=false,be=-1,Oe=-1,ce=false,$e=0,ve=0,xe,ze=null,Te=new Set,Fe=-1,Be=performance.now();function ke(){return g?q==="x"?g.scrollLeft:g.scrollTop:q==="x"?window.scrollX:window.scrollY}function Ge(){return g?q==="x"?g.clientWidth:g.clientHeight:q==="x"?window.innerWidth:window.innerHeight}function Xe(){let s=e.getBoundingClientRect(),i,v,Y;if(g){let ue=g.getBoundingClientRect();i=q==="x"?s.left-ue.left+g.scrollLeft:s.top-ue.top+g.scrollTop,v=q==="x"?s.width:s.height,Y=ke();}else i=q==="x"?s.left:s.top,v=q==="x"?s.width:s.height,Y=ke();let pe=fe({top:i,height:v},Y,Ge(),ge,a);Ee=pe.tStart,Se=pe.tEnd,de&&process.env.NODE_ENV!=="production"&&(ze?.remove(),ze=$t(Ee,Se,q));}function yt(s,i){if(e.style.setProperty("--scroll-draw-progress",String(s)),p){let v=i==="reverse"?1-s:s;e.style.clipPath=me(v);return}ee.forEach((v,Y)=>{v.style.strokeDashoffset=i==="reverse"?`${X[Y]*s}`:`${X[Y]*(1-s)}`,c&&(v.style.opacity=i==="reverse"?`${1-s}`:`${s}`),ne&&V?v.style.stroke=Ce(ne,V,s):V&&(v.style.stroke=V),U!==null&&se!==null?v.style.strokeWidth=`${U+(se-U)*s}`:se!==null&&(v.style.strokeWidth=`${se}`),H!==null&&G!==null?v.style.fillOpacity=`${H+(G-H)*s}`:G!==null&&(v.style.fillOpacity=`${G}`),C&&v.tagName.toLowerCase()==="path"&&ye[Y]&&v.setAttribute("d",We(ye[Y],C,s));});}function De(){if(e.style.setProperty("--scroll-draw-progress","0"),p){e.style.clipPath=me(0);return}ee.forEach((s,i)=>{s.style.strokeDasharray=`${X[i]}`,s.style.strokeDashoffset=E==="reverse"?"0":`${X[i]}`,c?s.style.opacity=E==="reverse"?"1":"0":s.style.opacity="",ne&&(s.style.stroke=ne),U!==null&&(s.style.strokeWidth=`${U}`),H!==null&&(s.style.fillOpacity=`${H}`),C&&s.tagName.toLowerCase()==="path"&&ye[i]&&s.setAttribute("d",ye[i]);});}if(ee.forEach(s=>{Mt(s);let i=Re(s);X.push(i),s.tagName.toLowerCase()==="path"?ye.push(s.getAttribute("d")??""):ye.push(""),o?(s.style.strokeDasharray=`${i}`,s.style.strokeDashoffset=E==="reverse"?`${i}`:"0",c&&(s.style.opacity="1"),V&&(s.style.stroke=V),se!==null&&(s.style.strokeWidth=`${se}`),G!==null&&(s.style.fillOpacity=`${G}`),C&&s.tagName.toLowerCase()==="path"&&s.setAttribute("d",C)):(s.style.strokeDasharray=`${i}`,s.style.strokeDashoffset=E==="reverse"?"0":`${i}`,c?s.style.opacity=E==="reverse"?"1":"0":s.style.opacity="",ne&&(s.style.stroke=ne),U!==null&&(s.style.strokeWidth=`${U}`),H!==null&&(s.style.fillOpacity=`${H}`));}),p){if(o)return e.style.clipPath=me(1),h?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=me(0);}else if(o)return h?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function bt(){return !(oe===false||!At()||!ee.length||typeof d!="string"||!(d in Ke)||p||q!=="y"||g||l!==1||B!==0||re||T||L!==false||C||b||M||N>0||f||k||h||A!=null||$!=null||P!=null||(I.start??"top bottom").trim()!=="top bottom"||(I.end??"bottom top").trim()!=="bottom top")}function wt(){let s=`svg-scroll-draw-${++Tt}`,i=E==="reverse"?"0":"var(--ssd-len)",v=E==="reverse"?"var(--ssd-len)":"0",Y=`stroke-dashoffset:${i};`,pe=`stroke-dashoffset:${v};`;c&&(Y+=`opacity:${E==="reverse"?1:0};`,pe+=`opacity:${E==="reverse"?0:1};`);let ue=document.createElement("style");ue.setAttribute("data-svg-scroll-draw",""),ue.textContent=`@keyframes ${s}{from{${Y}}to{${pe}}}.${s}{animation-name:${s};animation-duration:auto;animation-timing-function:${Ke[d]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(ue);function w(y,x){y.style.setProperty("--ssd-len",String(X[x])),y.style.strokeDasharray=`${X[x]}`,y.style.strokeDashoffset="",y.style.opacity="",y.style.animationPlayState="",y.classList.add(s);}ee.forEach(w);let R=false,Z=-1;function S(){if(Z>=0)return Z;let y=e.getBoundingClientRect(),{tStart:x,tEnd:W}=fe({top:y.top,height:y.height},ke(),Ge(),ge,a);return F(J(ke(),x,W,l))}return {destroy(){ee.forEach(y=>{y.classList.remove(s),y.style.removeProperty("--ssd-len"),y.style.animationPlayState="";}),ue.remove();},replay(){R=false,Z=-1,ee.forEach(w);},pause(){R=true,ee.forEach(y=>{y.style.animationPlayState="paused";});},resume(){R&&(R=false,ee.forEach(y=>{y.style.animationPlayState="running";}));},seek(y){let x=Math.min(1,Math.max(0,y));Z=x,R=true,ee.forEach((W,Pe)=>{W.classList.remove(s),W.style.strokeDashoffset=E==="reverse"?`${X[Pe]*x}`:`${X[Pe]*(1-x)}`,c&&(W.style.opacity=E==="reverse"?`${1-x}`:`${x}`);});},getProgress(){return S()}}}if(bt())return wt();function vt(){let s=Math.max(1,j),i=0,v=0;function Y(S){let y=true;if(p){let x=Math.min(1,Math.max(0,S/s)),W=F(x);$e=W,e.style.setProperty("--scroll-draw-progress",String(W)),e.style.clipPath=me(E==="reverse"?1-W:W),f?.(W),x<1&&(y=false);}else ee.forEach((x,W)=>{let Pe=W*B*s,Le=Math.min(1,Math.max(0,(S-Pe)/s)),we=F(Le);x.style.strokeDashoffset=E==="reverse"?`${X[W]*we}`:`${X[W]*(1-we)}`,c&&(x.style.opacity=E==="reverse"?`${1-we}`:`${we}`),ne&&V?x.style.stroke=Ce(ne,V,we):V&&(x.style.stroke=V),U!==null&&se!==null?x.style.strokeWidth=`${U+(se-U)*we}`:se!==null&&(x.style.strokeWidth=`${se}`),H!==null&&G!==null?x.style.fillOpacity=`${H+(G-H)*we}`:G!==null&&(x.style.fillOpacity=`${G}`),C&&x.tagName.toLowerCase()==="path"&&ye[W]&&x.setAttribute("d",We(ye[W],C,we)),W===0&&(f?.(we),e.style.setProperty("--scroll-draw-progress",String(we))),Le<1&&(y=false);});if(b){let x=Math.min(1,Math.max(0,S/s)),W=F(x);for(let Pe in b){let Le=parseFloat(Pe);W>=Le&&!Te.has(Le)&&(Te.add(Le),b[Pe]?.());}}return y}function pe(S){if(ce)return;let y=S-i;he||(he=true,k?.());let x=Y(y);if(x&&!ie){ie=true,Y(s*(1+Math.max(0,ee.length-1)*B)),h?.(),ve<(M==="infinite"?1/0:M??0)&&(ve++,xe=setTimeout(()=>{i=performance.now(),he=false,ie=false,Te.clear(),De(),te=requestAnimationFrame(pe);},z));return}x||(te=requestAnimationFrame(pe));}function ue(){cancelAnimationFrame(te),clearTimeout(xe),i=performance.now(),v=0,ce=false,he=false,ie=false,ve=0,Te.clear(),De(),te=requestAnimationFrame(pe);}let w=new IntersectionObserver(S=>{S.forEach(y=>{y.isIntersecting&&!(re&&ie)?ue():!y.isIntersecting&&!re&&!ie&&(cancelAnimationFrame(te),clearTimeout(xe),i=null);});},{root:g??null,threshold:O,rootMargin:D}),R;function Z(){clearTimeout(R),R=setTimeout(()=>{ee.forEach((S,y)=>{X[y]=Re(S),S.style.strokeDasharray=`${X[y]}`;});},150);}return window.addEventListener("resize",Z),window.addEventListener("orientationchange",Z),N>0?setTimeout(()=>w.observe(e),N):w.observe(e),{destroy(){cancelAnimationFrame(te),clearTimeout(xe),w.disconnect(),window.removeEventListener("resize",Z),window.removeEventListener("orientationchange",Z),clearTimeout(R);},replay(){ve=0,ue();},pause(){ce||(ce=true,v=performance.now()-i,cancelAnimationFrame(te));},resume(){ce&&(ce=false,i=performance.now()-v,te=requestAnimationFrame(pe));},seek(S){let y=Math.min(1,Math.max(0,S));$e=y,ce=true,v=y*s,i=performance.now()-v,cancelAnimationFrame(te),Y(v);},getProgress(){return $e}}}if(Q)return vt();Xe();function Ne(){if(!Ie||ce)return;let s=performance.now(),i=ke(),v=l;if(L!==false){let w=s-Be,R=w>0?Math.abs(i-(Fe<0?i:Fe))/w:0;v=l*Math.max(.2,1+R*(typeof L=="number"?L:1)*.04);}Fe=i,Be=s;let Y=T?Oe===-1||i>=Oe?"forward":"reverse":E;Oe=i;let pe=Se-Ee,ue=true;if(p){let w=F(J(i,Ee,Se,v));re&&!T&&(be=Math.max(be,w),w=be),$e=w,e.style.setProperty("--scroll-draw-progress",String(w));let R=Y==="reverse"?1-w:w;e.style.clipPath=me(R),f?.(w),!he&&J(i,Ee,Se,v)>0&&(he=true,k?.()),w>=1&&!ie?(ie=true,h?.(),ve<(M==="infinite"?1/0:M??0)&&(ve++,xe=setTimeout(()=>{be=-1,he=false,ie=false,e.style.clipPath=me(0);},z))):w<1&&!re&&(ie=false),te=requestAnimationFrame(Ne);return}if(ee.forEach((w,R)=>{let Z=R*B*pe,S=F(J(i,Ee+Z,Se+Z,v));re&&!T&&(be=Math.max(be,S),S=be),$e=S,w.style.strokeDashoffset=Y==="reverse"?`${X[R]*S}`:`${X[R]*(1-S)}`,c&&(w.style.opacity=Y==="reverse"?`${1-S}`:`${S}`),ne&&V?w.style.stroke=Ce(ne,V,S):V&&(w.style.stroke=V),U!==null&&se!==null?w.style.strokeWidth=`${U+(se-U)*S}`:se!==null&&(w.style.strokeWidth=`${se}`),H!==null&&G!==null?w.style.fillOpacity=`${H+(G-H)*S}`:G!==null&&(w.style.fillOpacity=`${G}`),C&&w.tagName.toLowerCase()==="path"&&ye[R]&&w.setAttribute("d",We(ye[R],C,S)),R===0&&(f?.(S),e.style.setProperty("--scroll-draw-progress",String(S))),S<1&&(ue=false);}),b){let w=F(J(i,Ee,Se,v));for(let R in b){let Z=parseFloat(R);w>=Z&&!Te.has(Z)&&(Te.add(Z),b[R]?.());}}!he&&J(i,Ee,Se,v)>0&&(he=true,k?.()),ue&&!ie?(ie=true,h?.(),ve<(M==="infinite"?1/0:M??0)&&(ve++,xe=setTimeout(()=>{be=-1,he=false,ie=false,Te.clear(),De();},z))):!ue&&!re&&(ie=false),te=requestAnimationFrame(Ne);}let Ve=new IntersectionObserver(s=>{s.forEach(i=>{Ie=i.isIntersecting,Ie&&!ce?te=requestAnimationFrame(Ne):cancelAnimationFrame(te);});},{root:g??null,threshold:O,rootMargin:D}),qe;function He(){clearTimeout(qe),qe=setTimeout(()=>{ee.forEach((s,i)=>{X[i]=Re(s),s.style.strokeDasharray=`${X[i]}`;}),Xe();},150);}return window.addEventListener("resize",He),window.addEventListener("orientationchange",He),N>0?setTimeout(()=>Ve.observe(e),N):Ve.observe(e),{destroy(){cancelAnimationFrame(te),clearTimeout(xe),Ve.disconnect(),window.removeEventListener("resize",He),window.removeEventListener("orientationchange",He),clearTimeout(qe),ze?.remove();},replay(){be=-1,Oe=-1,Fe=-1,he=false,ie=false,ve=0,ce=false,Te.clear(),clearTimeout(xe),De();},pause(){ce=true,cancelAnimationFrame(te);},resume(){ce&&(ce=false,Ie&&(te=requestAnimationFrame(Ne)));},seek(s){let i=Math.min(1,Math.max(0,s));$e=i,be=i,ce=true,cancelAnimationFrame(te),yt(i,E);},getProgress(){return $e}}}var et=new Map;function Ae(e,r){et.set(e,r);}function Me(e){et.delete(e);}function Pt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function tt(e){let r=[],n=/([\w]+)\(([^)]*)\)/g,t;for(;(t=n.exec(e))!==null;){let u=[],o=[],m=t[2].trim();if(m)for(let l of m.split(/[\s,]+/)){let c=l.match(/^([-+]?[\d.eE]+)(.*)$/);u.push(c?parseFloat(c[1]):0),o.push(c?c[2]:"");}r.push({fn:t[1],nums:u,units:o});}return r}function Lt(e,r,n){let t=tt(e),u=tt(r);return t.length===0||t.length!==u.length?n<1?e:r:t.map((o,m)=>{let l=u[m];return o.fn!==l.fn||o.nums.length!==l.nums.length?n<1?`${o.fn}(${o.nums.map((c,d)=>`${c}${o.units[d]}`).join(", ")})`:`${l.fn}(${l.nums.map((c,d)=>`${c}${l.units[d]}`).join(", ")})`:`${o.fn}(${o.nums.map((c,d)=>`${c+(l.nums[d]-c)*n}${o.units[d]}`).join(", ")})`}).join(" ")}function rt(e,r,n){if(typeof e=="number"&&typeof r=="number")return String(e+(r-e)*n);let t=String(e),u=String(r);if(Pt(t))return Ce(t,u,n);if(t.includes("("))return Lt(t,u,n);let o=t.match(/^([-+]?[\d.]+)(.*)$/),m=u.match(/^([-+]?[\d.]+)(.*)$/);if(o&&m){let l=parseFloat(o[1]),c=parseFloat(m[1]);return `${l+(c-l)*n}${o[2]||m[2]}`}return n<1?t:u}function Ct(e){return e.replace(/([A-Z])/g,r=>`-${r.toLowerCase()}`)}var nt={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},kt=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),It=0;function Ot(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function st(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let{props:t,trigger:u={},easing:o="ease-out",speed:m=1,once:l=false,axis:c="y",scrollContainer:d,native:I=true,onProgress:B,onComplete:E}=r,re=window.matchMedia("(prefers-reduced-motion: reduce)").matches,de=typeof o=="function"?o:ae[o]??ae["ease-out"],q=le(u.start??"top bottom"),K=le(u.end??"bottom top"),T=typeof d=="string"?document.querySelector(d):d??null,N=Object.entries(t).map(([a,g])=>({prop:Ct(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 N)g.from===""&&(g.from=a.getPropertyValue(g.prop).trim()||"0");}function $(){for(let a of N)e.style.setProperty(a.prop,String(a.to));}if(re)return $(),E?.(),n;A();function P(){if(!I||!Ot()||typeof o!="string"||!(o in nt)||c!=="y"||T||l||m!==1||B||E||(u.start??"top bottom").trim()!=="top bottom"||(u.end??"bottom top").trim()!=="bottom top")return false;for(let a of N)if(!kt.has(a.prop))return false;return true}function b(){let a=`ssd-a-${++It}`,g=N.map(H=>`${H.prop}:${H.from}`).join(";"),ne=N.map(H=>`${H.prop}:${H.to}`).join(";"),V=document.createElement("style");V.setAttribute("data-ssd-animate",""),V.textContent=`@keyframes ${a}{from{${g}}to{${ne}}}.${a}{animation-name:${a};animation-duration:auto;animation-timing-function:${nt[o]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(V),e.classList.add(a);let U=()=>c==="x"?window.scrollX:window.scrollY,se=()=>c==="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(H){let G=Math.min(1,Math.max(0,H));e.classList.remove(a);for(let me of N)e.style.setProperty(me.prop,rt(me.from,me.to,G));},getProgress(){let H=e.getBoundingClientRect(),G=U(),me=se(),{tStart:ee,tEnd:X}=fe({top:H.top,height:H.height},G,me,q,K);return de(J(G,ee,X,m))}}}if(P())return b();let L=0,O=0,D=0,M=false,z=false,C=-1,_=0,Q=false,j=()=>T?c==="x"?T.scrollLeft:T.scrollTop:c==="x"?window.scrollX:window.scrollY,oe=()=>T?c==="x"?T.clientWidth:T.clientHeight:c==="x"?window.innerWidth:window.innerHeight;function f(){let a=e.getBoundingClientRect(),g,ne;if(T){let U=T.getBoundingClientRect();g=c==="x"?a.left-U.left+T.scrollLeft:a.top-U.top+T.scrollTop,ne=c==="x"?a.width:a.height;}else g=c==="x"?a.left:a.top,ne=c==="x"?a.width:a.height;let V=fe({top:g,height:ne},j(),oe(),q,K);L=V.tStart,O=V.tEnd;}function k(a){e.style.setProperty("--scroll-draw-progress",String(a));for(let g of N)e.style.setProperty(g.prop,rt(g.from,g.to,a));B?.(a);}function h(){if(!M||z)return;let a=de(J(j(),L,O,m));l&&(C=Math.max(C,a),a=C),_=a,k(a),a>=1&&!Q?(Q=true,E?.()):a<1&&!l&&(Q=false),D=requestAnimationFrame(h);}f();{let a=de(J(j(),L,O,m));l&&a>0&&(C=a),_=a,k(a);}let p=new IntersectionObserver(a=>{a.forEach(g=>{M=g.isIntersecting,M&&!z?D=requestAnimationFrame(h):cancelAnimationFrame(D);});},{root:T??null}),F;function ge(){clearTimeout(F),F=setTimeout(f,150);}return window.addEventListener("resize",ge),window.addEventListener("orientationchange",ge),p.observe(e),Ae(e,{type:"animate",getProgress:()=>_,getTrigger:()=>({tStart:L,tEnd:O})}),{destroy(){cancelAnimationFrame(D),p.disconnect(),window.removeEventListener("resize",ge),window.removeEventListener("orientationchange",ge),clearTimeout(F),Me(e);},replay(){C=-1,Q=false,_=0,z=false,k(0);},pause(){z=true,cancelAnimationFrame(D);},resume(){z&&(z=false,M&&(D=requestAnimationFrame(h)));},seek(a){let g=Math.min(1,Math.max(0,a));_=g,C=g,z=true,cancelAnimationFrame(D),k(g);},getProgress(){return _}}}var _e={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function ot(e,r){if(typeof window>"u")return _e;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),_e;let t=n,{from:u=0,to:o,format:m,easing:l="ease-out",trigger:c={},once:d=true,decimals:I,onComplete:B}=r,E=I!==void 0?f=>f.toFixed(I):m??(f=>String(Math.round(f))),re=typeof l=="function"?l:ae[l]??ae["ease-out"],de=le(c.start??"top 80%"),q=le(c.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=E(o),B?.(),_e;t.textContent=E(u);let T=0,N=0,A=0,$=false,P=false,b=-1,L=0,O=false,D=()=>window.scrollY,M=()=>window.innerHeight;function z(){let f=t.getBoundingClientRect(),k=fe({top:f.top,height:f.height},D(),M(),de,q);T=k.tStart,N=k.tEnd;}function C(f){t.textContent=E(u+(o-u)*f),t.style.setProperty("--scroll-draw-progress",String(f));}function _(){if(!$||P)return;let f=re(J(D(),T,N,1));d&&(b=Math.max(b,f),f=b),L=f,C(f),f>=1&&!O?(O=true,B?.()):f<1&&!d&&(O=false),A=requestAnimationFrame(_);}z();{let f=re(J(D(),T,N,1));d&&f>0&&(b=f),L=f,C(f);}let Q=new IntersectionObserver(f=>{f.forEach(k=>{$=k.isIntersecting,$&&!P?A=requestAnimationFrame(_):cancelAnimationFrame(A);});}),j;function oe(){clearTimeout(j),j=setTimeout(z,150);}return window.addEventListener("resize",oe),window.addEventListener("orientationchange",oe),Q.observe(t),Ae(t,{type:"counter",getProgress:()=>L,getTrigger:()=>({tStart:T,tEnd:N})}),{destroy(){cancelAnimationFrame(A),Q.disconnect(),window.removeEventListener("resize",oe),window.removeEventListener("orientationchange",oe),clearTimeout(j),Me(t);},replay(){b=-1,O=false,L=0,P=false,C(0);},pause(){P=true,cancelAnimationFrame(A);},resume(){P&&(P=false,$&&(A=requestAnimationFrame(_)));},seek(f){let k=Math.min(1,Math.max(0,f));L=k,b=k,P=true,cancelAnimationFrame(A),C(k);},getProgress(){return L}}}var it={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function at(e,r={}){if(typeof window>"u")return it;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),it;let t=n,{trigger:u={},easing:o="linear",once:m=false,axis:l="y",preload:c="auto",onReady:d,onComplete:I,onProgress:B}=r,E=window.matchMedia("(prefers-reduced-motion: reduce)").matches,re=typeof o=="function"?o:ae[o]??ae.linear,de=le(u.start??"top top"),q=le(u.end??"bottom top");t.pause(),t.hasAttribute("preload")||(t.preload=c);let K=r.from??0,T=r.to,N=0,A=0,$=0,P=false,b=false,L=-1,O=0,D=false,M=false,z=()=>l==="x"?window.scrollX:window.scrollY,C=()=>l==="x"?window.innerWidth:window.innerHeight;function _(){let p=t.getBoundingClientRect(),F=l==="x"?p.left:p.top,ge=l==="x"?p.width:p.height,a=fe({top:F,height:ge},z(),C(),de,q);N=a.tStart,A=a.tEnd;}function Q(p){if(!M)return;let F=T??t.duration??0;t.currentTime=K+(F-K)*p,t.style.setProperty("--scroll-draw-progress",String(p)),B?.(p);}function j(){if(!P||b||!M)return;let p=re(J(z(),N,A,1));m&&(L=Math.max(L,p),p=L),O=p,Q(p),p>=1&&!D?(D=true,I?.()):p<1&&!m&&(D=false),$=requestAnimationFrame(j);}function oe(){if(M=true,T===void 0&&(T=t.duration),E){Q(1),d?.();return}_(),d?.(),P&&!b&&($=requestAnimationFrame(j));}t.readyState>=1?oe():t.addEventListener("loadedmetadata",oe,{once:true}),M||_();let f=new IntersectionObserver(p=>{p.forEach(F=>{P=F.isIntersecting,P&&!b&&M?$=requestAnimationFrame(j):cancelAnimationFrame($);});}),k;function h(){clearTimeout(k),k=setTimeout(_,150);}return window.addEventListener("resize",h),window.addEventListener("orientationchange",h),f.observe(t),Ae(t,{type:"video",getProgress:()=>O,getTrigger:()=>({tStart:N,tEnd:A})}),{destroy(){cancelAnimationFrame($),f.disconnect(),t.removeEventListener("loadedmetadata",oe),window.removeEventListener("resize",h),window.removeEventListener("orientationchange",h),clearTimeout(k),Me(t);},replay(){L=-1,D=false,O=0,b=false,Q(0);},pause(){b=true,cancelAnimationFrame($);},resume(){b&&(b=false,P&&M&&($=requestAnimationFrame(j)));},seek(p){let F=Math.min(1,Math.max(0,p));O=F,L=F,b=true,cancelAnimationFrame($),Q(F);},getProgress(){return O}}}function ut(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 Ft(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 lt(e){let r=ut(e),n=new Map;for(let o of r){let m=o.offsetTop;n.has(m)||n.set(m,[]),n.get(m).push(o);}let t=[],u=Array.from(n.keys()).sort((o,m)=>o-m);for(let o of u){let m=n.get(o),l=document.createElement("span");l.setAttribute("aria-hidden","true"),l.style.display="inline-block";for(let c of m)l.appendChild(c);t.push(l);}e.textContent="";for(let o of t)e.appendChild(o),e.appendChild(document.createTextNode(" "));return t}function Dt(e,r,n,t){if(n<=1||t===0)return e;let u=(n-1)*t,o=r*t,m=o+(1-u);return m<=o?e>=o?1:0:Math.min(1,Math.max(0,(e-o)/(m-o)))}function Nt(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 ct={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function mt(e,r={}){if(typeof window>"u")return ct;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),ct;let t=n,{split:u="words",stagger:o=.04,easing:m="ease-out",from:l={opacity:0,y:24},trigger:c={},once:d=true,onComplete:I}=r,B=window.matchMedia("(prefers-reduced-motion: reduce)").matches,E=typeof m=="function"?m:ae[m]??ae["ease-out"],re=le(c.start??"top 85%"),de=le(c.end??"top 40%"),q=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let K;u==="chars"?K=Ft(t):u==="lines"?K=lt(t):K=ut(t);let T=K.length;function N(h,p){l?.opacity!==void 0&&(h.style.opacity=String(l.opacity+(1-l.opacity)*p));let F=Nt(p,l);F&&(h.style.transform=F);}function A(h){t.style.setProperty("--scroll-draw-progress",String(h)),K.forEach((p,F)=>{let ge=E(Dt(h,F,T,o));N(p,ge);});}if(B)return A(1),I?.(),{destroy(){t.innerHTML=q,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};A(0);let $=0,P=0,b=0,L=false,O=false,D=-1,M=0,z=false,C=()=>window.scrollY,_=()=>window.innerHeight;function Q(){let h=t.getBoundingClientRect(),p=fe({top:h.top,height:h.height},C(),_(),re,de);$=p.tStart,P=p.tEnd;}function j(){if(!L||O)return;let h=J(C(),$,P,1);d&&(D=Math.max(D,h),h=D),M=h,A(h),h>=1&&!z?(z=true,I?.()):h<1&&!d&&(z=false),b=requestAnimationFrame(j);}Q();let oe=new IntersectionObserver(h=>{h.forEach(p=>{L=p.isIntersecting,L&&!O?b=requestAnimationFrame(j):cancelAnimationFrame(b);});}),f;function k(){clearTimeout(f),f=setTimeout(()=>{if(u==="lines"){let h=M;t.innerHTML=q,t.setAttribute("aria-label",t.textContent??""),K=lt(t),A(h);}Q();},150);}return window.addEventListener("resize",k),window.addEventListener("orientationchange",k),oe.observe(t),Ae(t,{type:"text",getProgress:()=>M,getTrigger:()=>({tStart:$,tEnd:P})}),{destroy(){cancelAnimationFrame(b),oe.disconnect(),window.removeEventListener("resize",k),window.removeEventListener("orientationchange",k),clearTimeout(f),t.innerHTML=q,t.removeAttribute("aria-label"),Me(t);},replay(){D=-1,z=false,M=0,O=false,A(0);},pause(){O=true,cancelAnimationFrame(b);},resume(){O&&(O=false,L&&(b=requestAnimationFrame(j)));},seek(h){let p=Math.min(1,Math.max(0,h));M=p,D=p,O=true,cancelAnimationFrame(b),A(p);},getProgress(){return M}}}var pt=class{constructor(){this.instance=null;}init(r,n={}){return this.destroy(),this.instance=Qe(r,n),this}replay(){return this.instance?.replay(),this}pause(){return this.instance?.pause(),this}resume(){return this.instance?.resume(),this}seek(r){return this.instance?.seek(r),this}getProgress(){return this.instance?.getProgress()??0}destroy(){return this.instance?.destroy(),this.instance=null,this}},ft=class{constructor(){this.instance=null;}init(r,n){return this.destroy(),this.instance=st(r,n),this}replay(){return this.instance?.replay(),this}pause(){return this.instance?.pause(),this}resume(){return this.instance?.resume(),this}seek(r){return this.instance?.seek(r),this}getProgress(){return this.instance?.getProgress()??0}destroy(){return this.instance?.destroy(),this.instance=null,this}},dt=class{constructor(){this.instance=null;}init(r,n){return this.destroy(),this.instance=ot(r,n),this}replay(){return this.instance?.replay(),this}pause(){return this.instance?.pause(),this}resume(){return this.instance?.resume(),this}seek(r){return this.instance?.seek(r),this}getProgress(){return this.instance?.getProgress()??0}destroy(){return this.instance?.destroy(),this.instance=null,this}},gt=class{constructor(){this.instance=null;}init(r,n={}){return this.destroy(),this.instance=at(r,n),this}replay(){return this.instance?.replay(),this}pause(){return this.instance?.pause(),this}resume(){return this.instance?.resume(),this}seek(r){return this.instance?.seek(r),this}getProgress(){return this.instance?.getProgress()??0}destroy(){return this.instance?.destroy(),this.instance=null,this}},ht=class{constructor(){this.instance=null;}init(r,n={}){return this.destroy(),this.instance=mt(r,n),this}replay(){return this.instance?.replay(),this}pause(){return this.instance?.pause(),this}resume(){return this.instance?.resume(),this}seek(r){return this.instance?.seek(r),this}getProgress(){return this.instance?.getProgress()??0}destroy(){return this.instance?.destroy(),this.instance=null,this}};export{ft as ScrollAnimateRef,dt as ScrollCounterRef,pt as ScrollDrawRef,ht as ScrollTextRef,gt as ScrollVideoRef};
|
package/dist/astro/index.cjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';function
|
|
2
|
-
<div style="position:absolute;${
|
|
3
|
-
<div style="position:absolute;${T?`left:${E}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${E}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(s),window.addEventListener("scroll",y,{passive:true}),y(),s}function Oe(e,r,n){let s=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),y=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,h=>{let L=parseFloat(h),E=s[y++]??L;return String(+(L+(E-L)*n).toFixed(4))})}function $e(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:n,...s}=r,y=n?{...Ie[n],...s}:s,h=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:L="path, polyline, line, polygon, rect, circle",speed:E=1,fade:T=false,easing:p="linear",trigger:S={},stagger:_=0,direction:d="forward",once:Z=false,debug:Ue=false,axis:R="y",scrollContainer:Me,autoReverse:ye=false,delay:ue=0,strokeColor:K,strokeWidth:Q,fillOpacity:ee,waypoints:te,velocityScale:he=false,threshold:Fe=0,rootMargin:Ne="0px",repeat:re=0,repeatDelay:Pe=0,morphTo:H,clip:ke,autoplay:Je=false,duration:Ze=1e3,native:Ke=true,onProgress:me,onStart:be,onComplete:ae}=y,j=ke===true?"left":typeof ke=="string"?ke:false,ne=typeof p=="function"?p:ce[p]??ce.linear,Re=pe(S.start??"top bottom"),He=pe(S.end??"bottom top"),D=typeof Me=="string"?document.querySelector(Me):Me??null,q=Array.isArray(K)?K[0]:null,$=Array.isArray(K)?K[1]:typeof K=="string"?K:null,I=Array.isArray(Q)?Q[0]:null,M=Array.isArray(Q)?Q[1]:typeof Q=="number"?Q:null,O=Array.isArray(ee)?ee[0]:null,P=Array.isArray(ee)?ee[1]:typeof ee=="number"?ee:null;function oe(t){let o=t*100;switch(j){case "right":return `inset(0 0 0 ${100-o}%)`;case "top":return `inset(0 0 ${100-o}% 0)`;case "bottom":return `inset(${100-o}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-o}% 0 0)`}}let x=j?[]:Array.from(e.querySelectorAll(L)),w=[],z=[],X=0,Y=0,A=false,N=false,v=0,we=false,V=-1,ve=-1,k=false,se=0,B=0,U,Ce=null,J=new Set,Se=-1,qe=performance.now();function fe(){return D?R==="x"?D.scrollLeft:D.scrollTop:R==="x"?window.scrollX:window.scrollY}function ze(){return D?R==="x"?D.clientWidth:D.clientHeight:R==="x"?window.innerWidth:window.innerHeight}function Ve(){let t=e.getBoundingClientRect(),o,l,g;if(D){let C=D.getBoundingClientRect();o=R==="x"?t.left-C.left+D.scrollLeft:t.top-C.top+D.scrollTop,l=R==="x"?t.width:t.height,g=fe();}else o=R==="x"?t.left:t.top,l=R==="x"?t.width:t.height,g=fe();let F=de({top:o,height:l},g,ze(),Re,He);X=F.tStart,Y=F.tEnd,Ue&&process.env.NODE_ENV!=="production"&&(Ce?.remove(),Ce=at(X,Y,R));}function Qe(t,o){if(e.style.setProperty("--scroll-draw-progress",String(t)),j){let l=o==="reverse"?1-t:t;e.style.clipPath=oe(l);return}x.forEach((l,g)=>{l.style.strokeDashoffset=o==="reverse"?`${w[g]*t}`:`${w[g]*(1-t)}`,T&&(l.style.opacity=o==="reverse"?`${1-t}`:`${t}`),q&&$?l.style.stroke=ge(q,$,t):$&&(l.style.stroke=$),I!==null&&M!==null?l.style.strokeWidth=`${I+(M-I)*t}`:M!==null&&(l.style.strokeWidth=`${M}`),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",Oe(z[g],H,t));});}function Ee(){if(e.style.setProperty("--scroll-draw-progress","0"),j){e.style.clipPath=oe(0);return}x.forEach((t,o)=>{t.style.strokeDasharray=`${w[o]}`,t.style.strokeDashoffset=d==="reverse"?"0":`${w[o]}`,T?t.style.opacity=d==="reverse"?"1":"0":t.style.opacity="",q&&(t.style.stroke=q),I!==null&&(t.style.strokeWidth=`${I}`),O!==null&&(t.style.fillOpacity=`${O}`),H&&t.tagName.toLowerCase()==="path"&&z[o]&&t.setAttribute("d",z[o]);});}if(x.forEach(t=>{it(t);let o=Te(t);w.push(o),t.tagName.toLowerCase()==="path"?z.push(t.getAttribute("d")??""):z.push(""),h?(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=d==="reverse"?`${o}`:"0",T&&(t.style.opacity="1"),$&&(t.style.stroke=$),M!==null&&(t.style.strokeWidth=`${M}`),P!==null&&(t.style.fillOpacity=`${P}`),H&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",H)):(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=d==="reverse"?"0":`${o}`,T?t.style.opacity=d==="reverse"?"1":"0":t.style.opacity="",q&&(t.style.stroke=q),I!==null&&(t.style.strokeWidth=`${I}`),O!==null&&(t.style.fillOpacity=`${O}`));}),j){if(h)return e.style.clipPath=oe(1),ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=oe(0);}else if(h)return ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function et(){return !(Ke===false||!st()||!x.length||typeof p!="string"||!(p in Ye)||j||R!=="y"||D||E!==1||_!==0||Z||ye||he!==false||H||te||re||ue>0||me||be||ae||K!=null||Q!=null||ee!=null||(S.start??"top bottom").trim()!=="top bottom"||(S.end??"bottom top").trim()!=="bottom top")}function tt(){let t=`svg-scroll-draw-${++ot}`,o=d==="reverse"?"0":"var(--ssd-len)",l=d==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${o};`,F=`stroke-dashoffset:${l};`;T&&(g+=`opacity:${d==="reverse"?1:0};`,F+=`opacity:${d==="reverse"?0:1};`);let C=document.createElement("style");C.setAttribute("data-svg-scroll-draw",""),C.textContent=`@keyframes ${t}{from{${g}}to{${F}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Ye[p]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(C);function a(i,u){i.style.setProperty("--ssd-len",String(w[u])),i.style.strokeDasharray=`${w[u]}`,i.style.strokeDashoffset="",i.style.opacity="",i.style.animationPlayState="",i.classList.add(t);}x.forEach(a);let m=false,b=-1;function c(){if(b>=0)return b;let i=e.getBoundingClientRect(),{tStart:u,tEnd:f}=de({top:i.top,height:i.height},fe(),ze(),Re,He);return ne(G(fe(),u,f,E))}return {destroy(){x.forEach(i=>{i.classList.remove(t),i.style.removeProperty("--ssd-len"),i.style.animationPlayState="";}),C.remove();},replay(){m=false,b=-1,x.forEach(a);},pause(){m=true,x.forEach(i=>{i.style.animationPlayState="paused";});},resume(){m&&(m=false,x.forEach(i=>{i.style.animationPlayState="running";}));},seek(i){let u=Math.min(1,Math.max(0,i));b=u,m=true,x.forEach((f,ie)=>{f.classList.remove(t),f.style.strokeDashoffset=d==="reverse"?`${w[ie]*u}`:`${w[ie]*(1-u)}`,T&&(f.style.opacity=d==="reverse"?`${1-u}`:`${u}`);});},getProgress(){return c()}}}if(et())return tt();function rt(){let t=Math.max(1,Ze),o=0,l=0;function g(c){let i=true;if(j){let u=Math.min(1,Math.max(0,c/t)),f=ne(u);se=f,e.style.setProperty("--scroll-draw-progress",String(f)),e.style.clipPath=oe(d==="reverse"?1-f:f),me?.(f),u<1&&(i=false);}else x.forEach((u,f)=>{let ie=f*_*t,le=Math.min(1,Math.max(0,(c-ie)/t)),W=ne(le);u.style.strokeDashoffset=d==="reverse"?`${w[f]*W}`:`${w[f]*(1-W)}`,T&&(u.style.opacity=d==="reverse"?`${1-W}`:`${W}`),q&&$?u.style.stroke=ge(q,$,W):$&&(u.style.stroke=$),I!==null&&M!==null?u.style.strokeWidth=`${I+(M-I)*W}`:M!==null&&(u.style.strokeWidth=`${M}`),O!==null&&P!==null?u.style.fillOpacity=`${O+(P-O)*W}`:P!==null&&(u.style.fillOpacity=`${P}`),H&&u.tagName.toLowerCase()==="path"&&z[f]&&u.setAttribute("d",Oe(z[f],H,W)),f===0&&(me?.(W),e.style.setProperty("--scroll-draw-progress",String(W))),le<1&&(i=false);});if(te){let u=Math.min(1,Math.max(0,c/t)),f=ne(u);for(let ie in te){let le=parseFloat(ie);f>=le&&!J.has(le)&&(J.add(le),te[ie]?.());}}return i}function F(c){if(k)return;let i=c-o;N||(N=true,be?.());let u=g(i);if(u&&!A){A=true,g(t*(1+Math.max(0,x.length-1)*_)),ae?.(),B<(re==="infinite"?1/0:re??0)&&(B++,U=setTimeout(()=>{o=performance.now(),N=false,A=false,J.clear(),Ee(),v=requestAnimationFrame(F);},Pe));return}u||(v=requestAnimationFrame(F));}function C(){cancelAnimationFrame(v),clearTimeout(U),o=performance.now(),l=0,k=false,N=false,A=false,B=0,J.clear(),Ee(),v=requestAnimationFrame(F);}let a=new IntersectionObserver(c=>{c.forEach(i=>{i.isIntersecting&&!(Z&&A)?C():!i.isIntersecting&&!Z&&!A&&(cancelAnimationFrame(v),clearTimeout(U),o=null);});},{root:D??null,threshold:Fe,rootMargin:Ne}),m;function b(){clearTimeout(m),m=setTimeout(()=>{x.forEach((c,i)=>{w[i]=Te(c),c.style.strokeDasharray=`${w[i]}`;});},150);}return window.addEventListener("resize",b),window.addEventListener("orientationchange",b),ue>0?setTimeout(()=>a.observe(e),ue):a.observe(e),{destroy(){cancelAnimationFrame(v),clearTimeout(U),a.disconnect(),window.removeEventListener("resize",b),window.removeEventListener("orientationchange",b),clearTimeout(m);},replay(){B=0,C();},pause(){k||(k=true,l=performance.now()-o,cancelAnimationFrame(v));},resume(){k&&(k=false,o=performance.now()-l,v=requestAnimationFrame(F));},seek(c){let i=Math.min(1,Math.max(0,c));se=i,k=true,l=i*t,o=performance.now()-l,cancelAnimationFrame(v),g(l);},getProgress(){return se}}}if(Je)return rt();Ve();function xe(){if(!we||k)return;let t=performance.now(),o=fe(),l=E;if(he!==false){let a=t-qe,m=a>0?Math.abs(o-(Se<0?o:Se))/a:0;l=E*Math.max(.2,1+m*(typeof he=="number"?he:1)*.04);}Se=o,qe=t;let g=ye?ve===-1||o>=ve?"forward":"reverse":d;ve=o;let F=Y-X,C=true;if(j){let a=ne(G(o,X,Y,l));Z&&!ye&&(V=Math.max(V,a),a=V),se=a,e.style.setProperty("--scroll-draw-progress",String(a));let m=g==="reverse"?1-a:a;e.style.clipPath=oe(m),me?.(a),!N&&G(o,X,Y,l)>0&&(N=true,be?.()),a>=1&&!A?(A=true,ae?.(),B<(re==="infinite"?1/0:re??0)&&(B++,U=setTimeout(()=>{V=-1,N=false,A=false,e.style.clipPath=oe(0);},Pe))):a<1&&!Z&&(A=false),v=requestAnimationFrame(xe);return}if(x.forEach((a,m)=>{let b=m*_*F,c=ne(G(o,X+b,Y+b,l));Z&&!ye&&(V=Math.max(V,c),c=V),se=c,a.style.strokeDashoffset=g==="reverse"?`${w[m]*c}`:`${w[m]*(1-c)}`,T&&(a.style.opacity=g==="reverse"?`${1-c}`:`${c}`),q&&$?a.style.stroke=ge(q,$,c):$&&(a.style.stroke=$),I!==null&&M!==null?a.style.strokeWidth=`${I+(M-I)*c}`:M!==null&&(a.style.strokeWidth=`${M}`),O!==null&&P!==null?a.style.fillOpacity=`${O+(P-O)*c}`:P!==null&&(a.style.fillOpacity=`${P}`),H&&a.tagName.toLowerCase()==="path"&&z[m]&&a.setAttribute("d",Oe(z[m],H,c)),m===0&&(me?.(c),e.style.setProperty("--scroll-draw-progress",String(c))),c<1&&(C=false);}),te){let a=ne(G(o,X,Y,l));for(let m in te){let b=parseFloat(m);a>=b&&!J.has(b)&&(J.add(b),te[m]?.());}}!N&&G(o,X,Y,l)>0&&(N=true,be?.()),C&&!A?(A=true,ae?.(),B<(re==="infinite"?1/0:re??0)&&(B++,U=setTimeout(()=>{V=-1,N=false,A=false,J.clear(),Ee();},Pe))):!C&&!Z&&(A=false),v=requestAnimationFrame(xe);}let Le=new IntersectionObserver(t=>{t.forEach(o=>{we=o.isIntersecting,we&&!k?v=requestAnimationFrame(xe):cancelAnimationFrame(v);});},{root:D??null,threshold:Fe,rootMargin:Ne}),De;function Ae(){clearTimeout(De),De=setTimeout(()=>{x.forEach((t,o)=>{w[o]=Te(t),t.style.strokeDasharray=`${w[o]}`;}),Ve();},150);}return window.addEventListener("resize",Ae),window.addEventListener("orientationchange",Ae),ue>0?setTimeout(()=>Le.observe(e),ue):Le.observe(e),{destroy(){cancelAnimationFrame(v),clearTimeout(U),Le.disconnect(),window.removeEventListener("resize",Ae),window.removeEventListener("orientationchange",Ae),clearTimeout(De),Ce?.remove();},replay(){V=-1,ve=-1,Se=-1,N=false,A=false,B=0,k=false,J.clear(),clearTimeout(U),Ee();},pause(){k=true,cancelAnimationFrame(v);},resume(){k&&(k=false,we&&(v=requestAnimationFrame(xe)));},seek(t){let o=Math.min(1,Math.max(0,t));se=o,V=o,k=true,cancelAnimationFrame(v),Qe(o,d);},getProgress(){return se}}}function ut(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let s=typeof e=="string"?document.querySelector(e):e;return s?$e(s,r):(console.warn("[svg-scroll-draw] Container not found:",e),n)}function Ht(e=document){return Array.from(e.querySelectorAll("[data-scroll-draw]")).map(r=>{let n={};try{let s=r.dataset.scrollDrawOptions??r.dataset.scrollDrawoptions??"";s&&(n=JSON.parse(s));}catch{}return $e(r,n)})}exports.initScrollDraw=Ht;exports.scrollDraw=ut;
|
|
1
|
+
'use strict';function Qe({bounces:e=3,decay:n=.5}={}){let r=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,n)),c=Math.sqrt(t),s=0,m=[];for(let d=0;d<r;d++){let T=Math.pow(c,d);m.push(T),s+=T;}let u=[0],l=0;for(let d=0;d<r;d++)l+=m[d]/s,u.push(l);return d=>{if(d<=0)return 0;if(d>=1)return 1;for(let T=0;T<r;T++)if(d<=u[T+1]){let Y=(d-u[T])/(u[T+1]-u[T]);if(T===0)return Y*(2-Y);let b=1-Math.pow(t,T);return b+(1-b)*(2*Y-1)*(2*Y-1)}return 1}}function et({amplitude:e=1,period:n=.4}={}){let r=Math.max(1,e),t=Math.max(.1,n),c=r<=1?t/4:t/(2*Math.PI)*Math.asin(1/r);return s=>s<=0?0:s>=1?1:r*Math.pow(2,-10*s)*Math.sin((s-c)*(2*Math.PI)/t)+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:Qe(),elastic:et()};function me(e="top bottom"){let n=e.trim();if(/^\d+(\.\d+)?%$/.test(n))return {element:"top",viewport:n};let[r="top",t="bottom"]=n.split(/\s+/).filter(Boolean);return {element:r,viewport:t}}function Ue(e,n,r,t){switch(t){case "top":return e+r;case "center":return e+r+n/2;case "bottom":return e+r+n;default:return e+r}}function Ze(e,n){if(/^\d+(\.\d+)?%$/.test(e))return n*(parseFloat(e)/100);switch(e){case "top":return 0;case "center":return n/2;case "bottom":return n;default:return n}}function Re(e){let n=e.tagName.toLowerCase();if(n==="rect"){let r=parseFloat(e.getAttribute("width")??"0"),t=parseFloat(e.getAttribute("height")??"0");return 2*(r+t)}if(n==="circle"){let r=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*r}return e.getTotalLength()}function yt(e,n,r){return Math.min(r,Math.max(n,e))}function ee(e,n,r,t){return r===n?0:yt((e-n)/(r-n)*t,0,1)}function he(e,n,r,t,c){let s=Ue(e.top,e.height,n,t.element)-Ze(t.viewport,r),m=Ue(e.top,e.height,n,c.element)-Ze(c.viewport,r);return {tStart:s,tEnd:m}}function Ke(e){let n=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(n)return [parseInt(n[1]+n[1],16),parseInt(n[2]+n[2],16),parseInt(n[3]+n[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 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 Ce(e,n,r){let t=Ke(e),c=Ke(n);return !t||!c?e:`rgb(${Math.round(t[0]+(c[0]-t[0])*r)},${Math.round(t[1]+(c[1]-t[1])*r)},${Math.round(t[2]+(c[2]-t[2])*r)})`}var _e={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 tt(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n);}var rt={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},ht=0;function wt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function bt(e){let n=e.getAttribute("stroke"),r=e.getAttribute("fill");!n||n==="none"?tt("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&&tt("Element has a fill \u2014 it may obscure the stroke animation.",e);}function St(e,n,r){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 c(){let s=r==="x"?window.scrollX:window.scrollY,m=e-s,u=n-s,l=r==="x";t.innerHTML=`
|
|
2
|
+
<div style="position:absolute;${l?`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;${l?`left:${u}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${u}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",c,{passive:true}),c(),t}function Be(e,n,r){let t=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),c=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,s=>{let m=parseFloat(s),u=t[c++]??m;return String(+(m+(u-m)*r).toFixed(4))})}function qe(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...t}=n,c=r?{..._e[r],...t}:t,s=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:m="path, polyline, line, polygon, rect, circle",speed:u=1,fade:l=false,easing:d="linear",trigger:T={},stagger:Y=0,direction:b="forward",once:re=false,debug:we=false,axis:q="y",scrollContainer:ne,autoReverse:A=false,delay:N=0,strokeColor:M,strokeWidth:B,fillOpacity:O,waypoints:$,velocityScale:D=false,threshold:H=0,rootMargin:R="0px",repeat:I=0,repeatDelay:z=0,morphTo:E,clip:U,autoplay:ce=false,duration:ie=1e3,native:pe=true,onProgress:f,onStart:P,onComplete:h}=c,x=U===true?"left":typeof U=="string"?U:false,Z=typeof d=="function"?d:le[d]??le.linear,be=me(T.start??"top bottom"),a=me(T.end??"bottom top"),p=typeof ne=="string"?document.querySelector(ne):ne??null,K=Array.isArray(M)?M[0]:null,k=Array.isArray(M)?M[1]:typeof M=="string"?M:null,G=Array.isArray(B)?B[0]:null,Q=Array.isArray(B)?B[1]:typeof B=="number"?B:null,C=Array.isArray(O)?O[0]:null,V=Array.isArray(O)?O[1]:typeof O=="number"?O:null;function ae(o){let i=o*100;switch(x){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 X=x?[]:Array.from(e.querySelectorAll(m)),W=[],de=[],ve=0,Ee=0,te=false,fe=false,J=0,Oe=false,ge=-1,De=-1,oe=false,Ae=0,Se=0,xe,ze=null,Te=new Set,Ie=-1,Ye=performance.now();function ke(){return p?q==="x"?p.scrollLeft:p.scrollTop:q==="x"?window.scrollX:window.scrollY}function Xe(){return p?q==="x"?p.clientWidth:p.clientHeight:q==="x"?window.innerWidth:window.innerHeight}function Je(){let o=e.getBoundingClientRect(),i,w,_;if(p){let se=p.getBoundingClientRect();i=q==="x"?o.left-se.left+p.scrollLeft:o.top-se.top+p.scrollTop,w=q==="x"?o.width:o.height,_=ke();}else i=q==="x"?o.left:o.top,w=q==="x"?o.width:o.height,_=ke();let ue=he({top:i,height:w},_,Xe(),be,a);ve=ue.tStart,Ee=ue.tEnd,we&&process.env.NODE_ENV!=="production"&&(ze?.remove(),ze=St(ve,Ee,q));}function pt(o,i){if(e.style.setProperty("--scroll-draw-progress",String(o)),x){let w=i==="reverse"?1-o:o;e.style.clipPath=ae(w);return}X.forEach((w,_)=>{w.style.strokeDashoffset=i==="reverse"?`${W[_]*o}`:`${W[_]*(1-o)}`,l&&(w.style.opacity=i==="reverse"?`${1-o}`:`${o}`),K&&k?w.style.stroke=Ce(K,k,o):k&&(w.style.stroke=k),G!==null&&Q!==null?w.style.strokeWidth=`${G+(Q-G)*o}`:Q!==null&&(w.style.strokeWidth=`${Q}`),C!==null&&V!==null?w.style.fillOpacity=`${C+(V-C)*o}`:V!==null&&(w.style.fillOpacity=`${V}`),E&&w.tagName.toLowerCase()==="path"&&de[_]&&w.setAttribute("d",Be(de[_],E,o));});}function Fe(){if(e.style.setProperty("--scroll-draw-progress","0"),x){e.style.clipPath=ae(0);return}X.forEach((o,i)=>{o.style.strokeDasharray=`${W[i]}`,o.style.strokeDashoffset=b==="reverse"?"0":`${W[i]}`,l?o.style.opacity=b==="reverse"?"1":"0":o.style.opacity="",K&&(o.style.stroke=K),G!==null&&(o.style.strokeWidth=`${G}`),C!==null&&(o.style.fillOpacity=`${C}`),E&&o.tagName.toLowerCase()==="path"&&de[i]&&o.setAttribute("d",de[i]);});}if(X.forEach(o=>{bt(o);let i=Re(o);W.push(i),o.tagName.toLowerCase()==="path"?de.push(o.getAttribute("d")??""):de.push(""),s?(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=b==="reverse"?`${i}`:"0",l&&(o.style.opacity="1"),k&&(o.style.stroke=k),Q!==null&&(o.style.strokeWidth=`${Q}`),V!==null&&(o.style.fillOpacity=`${V}`),E&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",E)):(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=b==="reverse"?"0":`${i}`,l?o.style.opacity=b==="reverse"?"1":"0":o.style.opacity="",K&&(o.style.stroke=K),G!==null&&(o.style.strokeWidth=`${G}`),C!==null&&(o.style.fillOpacity=`${C}`));}),x){if(s)return e.style.clipPath=ae(1),h?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ae(0);}else if(s)return h?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function ft(){return !(pe===false||!wt()||!X.length||typeof d!="string"||!(d in rt)||x||q!=="y"||p||u!==1||Y!==0||re||A||D!==false||E||$||I||N>0||f||P||h||M!=null||B!=null||O!=null||(T.start??"top bottom").trim()!=="top bottom"||(T.end??"bottom top").trim()!=="bottom top")}function dt(){let o=`svg-scroll-draw-${++ht}`,i=b==="reverse"?"0":"var(--ssd-len)",w=b==="reverse"?"var(--ssd-len)":"0",_=`stroke-dashoffset:${i};`,ue=`stroke-dashoffset:${w};`;l&&(_+=`opacity:${b==="reverse"?1:0};`,ue+=`opacity:${b==="reverse"?0:1};`);let se=document.createElement("style");se.setAttribute("data-svg-scroll-draw",""),se.textContent=`@keyframes ${o}{from{${_}}to{${ue}}}.${o}{animation-name:${o};animation-duration:auto;animation-timing-function:${rt[d]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(se);function y(g,v){g.style.setProperty("--ssd-len",String(W[v])),g.style.strokeDasharray=`${W[v]}`,g.style.strokeDashoffset="",g.style.opacity="",g.style.animationPlayState="",g.classList.add(o);}X.forEach(y);let L=false,j=-1;function S(){if(j>=0)return j;let g=e.getBoundingClientRect(),{tStart:v,tEnd:F}=he({top:g.top,height:g.height},ke(),Xe(),be,a);return Z(ee(ke(),v,F,u))}return {destroy(){X.forEach(g=>{g.classList.remove(o),g.style.removeProperty("--ssd-len"),g.style.animationPlayState="";}),se.remove();},replay(){L=false,j=-1,X.forEach(y);},pause(){L=true,X.forEach(g=>{g.style.animationPlayState="paused";});},resume(){L&&(L=false,X.forEach(g=>{g.style.animationPlayState="running";}));},seek(g){let v=Math.min(1,Math.max(0,g));j=v,L=true,X.forEach((F,Me)=>{F.classList.remove(o),F.style.strokeDashoffset=b==="reverse"?`${W[Me]*v}`:`${W[Me]*(1-v)}`,l&&(F.style.opacity=b==="reverse"?`${1-v}`:`${v}`);});},getProgress(){return S()}}}if(ft())return dt();function gt(){let o=Math.max(1,ie),i=0,w=0;function _(S){let g=true;if(x){let v=Math.min(1,Math.max(0,S/o)),F=Z(v);Ae=F,e.style.setProperty("--scroll-draw-progress",String(F)),e.style.clipPath=ae(b==="reverse"?1-F:F),f?.(F),v<1&&(g=false);}else X.forEach((v,F)=>{let Me=F*Y*o,$e=Math.min(1,Math.max(0,(S-Me)/o)),ye=Z($e);v.style.strokeDashoffset=b==="reverse"?`${W[F]*ye}`:`${W[F]*(1-ye)}`,l&&(v.style.opacity=b==="reverse"?`${1-ye}`:`${ye}`),K&&k?v.style.stroke=Ce(K,k,ye):k&&(v.style.stroke=k),G!==null&&Q!==null?v.style.strokeWidth=`${G+(Q-G)*ye}`:Q!==null&&(v.style.strokeWidth=`${Q}`),C!==null&&V!==null?v.style.fillOpacity=`${C+(V-C)*ye}`:V!==null&&(v.style.fillOpacity=`${V}`),E&&v.tagName.toLowerCase()==="path"&&de[F]&&v.setAttribute("d",Be(de[F],E,ye)),F===0&&(f?.(ye),e.style.setProperty("--scroll-draw-progress",String(ye))),$e<1&&(g=false);});if($){let v=Math.min(1,Math.max(0,S/o)),F=Z(v);for(let Me in $){let $e=parseFloat(Me);F>=$e&&!Te.has($e)&&(Te.add($e),$[Me]?.());}}return g}function ue(S){if(oe)return;let g=S-i;fe||(fe=true,P?.());let v=_(g);if(v&&!te){te=true,_(o*(1+Math.max(0,X.length-1)*Y)),h?.(),Se<(I==="infinite"?1/0:I??0)&&(Se++,xe=setTimeout(()=>{i=performance.now(),fe=false,te=false,Te.clear(),Fe(),J=requestAnimationFrame(ue);},z));return}v||(J=requestAnimationFrame(ue));}function se(){cancelAnimationFrame(J),clearTimeout(xe),i=performance.now(),w=0,oe=false,fe=false,te=false,Se=0,Te.clear(),Fe(),J=requestAnimationFrame(ue);}let y=new IntersectionObserver(S=>{S.forEach(g=>{g.isIntersecting&&!(re&&te)?se():!g.isIntersecting&&!re&&!te&&(cancelAnimationFrame(J),clearTimeout(xe),i=null);});},{root:p??null,threshold:H,rootMargin:R}),L;function j(){clearTimeout(L),L=setTimeout(()=>{X.forEach((S,g)=>{W[g]=Re(S),S.style.strokeDasharray=`${W[g]}`;});},150);}return window.addEventListener("resize",j),window.addEventListener("orientationchange",j),N>0?setTimeout(()=>y.observe(e),N):y.observe(e),{destroy(){cancelAnimationFrame(J),clearTimeout(xe),y.disconnect(),window.removeEventListener("resize",j),window.removeEventListener("orientationchange",j),clearTimeout(L);},replay(){Se=0,se();},pause(){oe||(oe=true,w=performance.now()-i,cancelAnimationFrame(J));},resume(){oe&&(oe=false,i=performance.now()-w,J=requestAnimationFrame(ue));},seek(S){let g=Math.min(1,Math.max(0,S));Ae=g,oe=true,w=g*o,i=performance.now()-w,cancelAnimationFrame(J),_(w);},getProgress(){return Ae}}}if(ce)return gt();Je();function Ne(){if(!Oe||oe)return;let o=performance.now(),i=ke(),w=u;if(D!==false){let y=o-Ye,L=y>0?Math.abs(i-(Ie<0?i:Ie))/y:0;w=u*Math.max(.2,1+L*(typeof D=="number"?D:1)*.04);}Ie=i,Ye=o;let _=A?De===-1||i>=De?"forward":"reverse":b;De=i;let ue=Ee-ve,se=true;if(x){let y=Z(ee(i,ve,Ee,w));re&&!A&&(ge=Math.max(ge,y),y=ge),Ae=y,e.style.setProperty("--scroll-draw-progress",String(y));let L=_==="reverse"?1-y:y;e.style.clipPath=ae(L),f?.(y),!fe&&ee(i,ve,Ee,w)>0&&(fe=true,P?.()),y>=1&&!te?(te=true,h?.(),Se<(I==="infinite"?1/0:I??0)&&(Se++,xe=setTimeout(()=>{ge=-1,fe=false,te=false,e.style.clipPath=ae(0);},z))):y<1&&!re&&(te=false),J=requestAnimationFrame(Ne);return}if(X.forEach((y,L)=>{let j=L*Y*ue,S=Z(ee(i,ve+j,Ee+j,w));re&&!A&&(ge=Math.max(ge,S),S=ge),Ae=S,y.style.strokeDashoffset=_==="reverse"?`${W[L]*S}`:`${W[L]*(1-S)}`,l&&(y.style.opacity=_==="reverse"?`${1-S}`:`${S}`),K&&k?y.style.stroke=Ce(K,k,S):k&&(y.style.stroke=k),G!==null&&Q!==null?y.style.strokeWidth=`${G+(Q-G)*S}`:Q!==null&&(y.style.strokeWidth=`${Q}`),C!==null&&V!==null?y.style.fillOpacity=`${C+(V-C)*S}`:V!==null&&(y.style.fillOpacity=`${V}`),E&&y.tagName.toLowerCase()==="path"&&de[L]&&y.setAttribute("d",Be(de[L],E,S)),L===0&&(f?.(S),e.style.setProperty("--scroll-draw-progress",String(S))),S<1&&(se=false);}),$){let y=Z(ee(i,ve,Ee,w));for(let L in $){let j=parseFloat(L);y>=j&&!Te.has(j)&&(Te.add(j),$[L]?.());}}!fe&&ee(i,ve,Ee,w)>0&&(fe=true,P?.()),se&&!te?(te=true,h?.(),Se<(I==="infinite"?1/0:I??0)&&(Se++,xe=setTimeout(()=>{ge=-1,fe=false,te=false,Te.clear(),Fe();},z))):!se&&!re&&(te=false),J=requestAnimationFrame(Ne);}let Ve=new IntersectionObserver(o=>{o.forEach(i=>{Oe=i.isIntersecting,Oe&&!oe?J=requestAnimationFrame(Ne):cancelAnimationFrame(J);});},{root:p??null,threshold:H,rootMargin:R}),We;function He(){clearTimeout(We),We=setTimeout(()=>{X.forEach((o,i)=>{W[i]=Re(o),o.style.strokeDasharray=`${W[i]}`;}),Je();},150);}return window.addEventListener("resize",He),window.addEventListener("orientationchange",He),N>0?setTimeout(()=>Ve.observe(e),N):Ve.observe(e),{destroy(){cancelAnimationFrame(J),clearTimeout(xe),Ve.disconnect(),window.removeEventListener("resize",He),window.removeEventListener("orientationchange",He),clearTimeout(We),ze?.remove();},replay(){ge=-1,De=-1,Ie=-1,fe=false,te=false,Se=0,oe=false,Te.clear(),clearTimeout(xe),Fe();},pause(){oe=true,cancelAnimationFrame(J);},resume(){oe&&(oe=false,Oe&&(J=requestAnimationFrame(Ne)));},seek(o){let i=Math.min(1,Math.max(0,o));Ae=i,ge=i,oe=true,cancelAnimationFrame(J),pt(i,b);},getProgress(){return Ae}}}var nt=new Map;function Pe(e,n){nt.set(e,n);}function Le(e){nt.delete(e);}function vt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function ot(e){let n=[],r=/([\w]+)\(([^)]*)\)/g,t;for(;(t=r.exec(e))!==null;){let c=[],s=[],m=t[2].trim();if(m)for(let u of m.split(/[\s,]+/)){let l=u.match(/^([-+]?[\d.eE]+)(.*)$/);c.push(l?parseFloat(l[1]):0),s.push(l?l[2]:"");}n.push({fn:t[1],nums:c,units:s});}return n}function Et(e,n,r){let t=ot(e),c=ot(n);return t.length===0||t.length!==c.length?r<1?e:n:t.map((s,m)=>{let u=c[m];return s.fn!==u.fn||s.nums.length!==u.nums.length?r<1?`${s.fn}(${s.nums.map((l,d)=>`${l}${s.units[d]}`).join(", ")})`:`${u.fn}(${u.nums.map((l,d)=>`${l}${u.units[d]}`).join(", ")})`:`${s.fn}(${s.nums.map((l,d)=>`${l+(u.nums[d]-l)*r}${s.units[d]}`).join(", ")})`}).join(" ")}function st(e,n,r){if(typeof e=="number"&&typeof n=="number")return String(e+(n-e)*r);let t=String(e),c=String(n);if(vt(t))return Ce(t,c,r);if(t.includes("("))return Et(t,c,r);let s=t.match(/^([-+]?[\d.]+)(.*)$/),m=c.match(/^([-+]?[\d.]+)(.*)$/);if(s&&m){let u=parseFloat(s[1]),l=parseFloat(m[1]);return `${u+(l-u)*r}${s[2]||m[2]}`}return r<1?t:c}function xt(e){return e.replace(/([A-Z])/g,n=>`-${n.toLowerCase()}`)}var it={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Tt=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),At=0;function Mt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function at(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let{props:t,trigger:c={},easing:s="ease-out",speed:m=1,once:u=false,axis:l="y",scrollContainer:d,native:T=true,onProgress:Y,onComplete:b}=n,re=window.matchMedia("(prefers-reduced-motion: reduce)").matches,we=typeof s=="function"?s:le[s]??le["ease-out"],q=me(c.start??"top bottom"),ne=me(c.end??"bottom top"),A=typeof d=="string"?document.querySelector(d):d??null,N=Object.entries(t).map(([a,p])=>({prop:xt(a),from:Array.isArray(p)?p[0]:"",to:Array.isArray(p)?p[1]:p}));function M(){let a=window.getComputedStyle(e);for(let p of N)p.from===""&&(p.from=a.getPropertyValue(p.prop).trim()||"0");}function B(){for(let a of N)e.style.setProperty(a.prop,String(a.to));}if(re)return B(),b?.(),r;M();function O(){if(!T||!Mt()||typeof s!="string"||!(s in it)||l!=="y"||A||u||m!==1||Y||b||(c.start??"top bottom").trim()!=="top bottom"||(c.end??"bottom top").trim()!=="bottom top")return false;for(let a of N)if(!Tt.has(a.prop))return false;return true}function $(){let a=`ssd-a-${++At}`,p=N.map(C=>`${C.prop}:${C.from}`).join(";"),K=N.map(C=>`${C.prop}:${C.to}`).join(";"),k=document.createElement("style");k.setAttribute("data-ssd-animate",""),k.textContent=`@keyframes ${a}{from{${p}}to{${K}}}.${a}{animation-name:${a};animation-duration:auto;animation-timing-function:${it[s]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(k),e.classList.add(a);let G=()=>l==="x"?window.scrollX:window.scrollY,Q=()=>l==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(a),k.remove();},replay(){e.classList.remove(a),e.offsetWidth,e.classList.add(a);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(C){let V=Math.min(1,Math.max(0,C));e.classList.remove(a);for(let ae of N)e.style.setProperty(ae.prop,st(ae.from,ae.to,V));},getProgress(){let C=e.getBoundingClientRect(),V=G(),ae=Q(),{tStart:X,tEnd:W}=he({top:C.top,height:C.height},V,ae,q,ne);return we(ee(V,X,W,m))}}}if(O())return $();let D=0,H=0,R=0,I=false,z=false,E=-1,U=0,ce=false,ie=()=>A?l==="x"?A.scrollLeft:A.scrollTop:l==="x"?window.scrollX:window.scrollY,pe=()=>A?l==="x"?A.clientWidth:A.clientHeight:l==="x"?window.innerWidth:window.innerHeight;function f(){let a=e.getBoundingClientRect(),p,K;if(A){let G=A.getBoundingClientRect();p=l==="x"?a.left-G.left+A.scrollLeft:a.top-G.top+A.scrollTop,K=l==="x"?a.width:a.height;}else p=l==="x"?a.left:a.top,K=l==="x"?a.width:a.height;let k=he({top:p,height:K},ie(),pe(),q,ne);D=k.tStart,H=k.tEnd;}function P(a){e.style.setProperty("--scroll-draw-progress",String(a));for(let p of N)e.style.setProperty(p.prop,st(p.from,p.to,a));Y?.(a);}function h(){if(!I||z)return;let a=we(ee(ie(),D,H,m));u&&(E=Math.max(E,a),a=E),U=a,P(a),a>=1&&!ce?(ce=true,b?.()):a<1&&!u&&(ce=false),R=requestAnimationFrame(h);}f();{let a=we(ee(ie(),D,H,m));u&&a>0&&(E=a),U=a,P(a);}let x=new IntersectionObserver(a=>{a.forEach(p=>{I=p.isIntersecting,I&&!z?R=requestAnimationFrame(h):cancelAnimationFrame(R);});},{root:A??null}),Z;function be(){clearTimeout(Z),Z=setTimeout(f,150);}return window.addEventListener("resize",be),window.addEventListener("orientationchange",be),x.observe(e),Pe(e,{type:"animate",getProgress:()=>U,getTrigger:()=>({tStart:D,tEnd:H})}),{destroy(){cancelAnimationFrame(R),x.disconnect(),window.removeEventListener("resize",be),window.removeEventListener("orientationchange",be),clearTimeout(Z),Le(e);},replay(){E=-1,ce=false,U=0,z=false,P(0);},pause(){z=true,cancelAnimationFrame(R);},resume(){z&&(z=false,I&&(R=requestAnimationFrame(h)));},seek(a){let p=Math.min(1,Math.max(0,a));U=p,E=p,z=true,cancelAnimationFrame(R),P(p);},getProgress(){return U}}}var Ge={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function je(e,n){if(typeof window>"u")return Ge;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollCounter: element not found:",e),Ge;let t=r,{from:c=0,to:s,format:m,easing:u="ease-out",trigger:l={},once:d=true,decimals:T,onComplete:Y}=n,b=T!==void 0?f=>f.toFixed(T):m??(f=>String(Math.round(f))),re=typeof u=="function"?u:le[u]??le["ease-out"],we=me(l.start??"top 80%"),q=me(l.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=b(s),Y?.(),Ge;t.textContent=b(c);let A=0,N=0,M=0,B=false,O=false,$=-1,D=0,H=false,R=()=>window.scrollY,I=()=>window.innerHeight;function z(){let f=t.getBoundingClientRect(),P=he({top:f.top,height:f.height},R(),I(),we,q);A=P.tStart,N=P.tEnd;}function E(f){t.textContent=b(c+(s-c)*f),t.style.setProperty("--scroll-draw-progress",String(f));}function U(){if(!B||O)return;let f=re(ee(R(),A,N,1));d&&($=Math.max($,f),f=$),D=f,E(f),f>=1&&!H?(H=true,Y?.()):f<1&&!d&&(H=false),M=requestAnimationFrame(U);}z();{let f=re(ee(R(),A,N,1));d&&f>0&&($=f),D=f,E(f);}let ce=new IntersectionObserver(f=>{f.forEach(P=>{B=P.isIntersecting,B&&!O?M=requestAnimationFrame(U):cancelAnimationFrame(M);});}),ie;function pe(){clearTimeout(ie),ie=setTimeout(z,150);}return window.addEventListener("resize",pe),window.addEventListener("orientationchange",pe),ce.observe(t),Pe(t,{type:"counter",getProgress:()=>D,getTrigger:()=>({tStart:A,tEnd:N})}),{destroy(){cancelAnimationFrame(M),ce.disconnect(),window.removeEventListener("resize",pe),window.removeEventListener("orientationchange",pe),clearTimeout(ie),Le(t);},replay(){$=-1,H=false,D=0,O=false,E(0);},pause(){O=true,cancelAnimationFrame(M);},resume(){O&&(O=false,B&&(M=requestAnimationFrame(U)));},seek(f){let P=Math.min(1,Math.max(0,f));D=P,$=P,O=true,cancelAnimationFrame(M),E(P);},getProgress(){return D}}}function ut(e){let n=e.textContent??"";return e.textContent="",n.split(/(\s+)/).filter(Boolean).map(r=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),/^\s+$/.test(r)?(t.textContent=r,t.style.whiteSpace="pre"):(t.textContent=r,t.style.display="inline-block"),e.appendChild(t),/^\s+$/.test(r)?null:t}).filter(r=>r!==null)}function $t(e){let n=e.textContent??"";return e.textContent="",n.split("").map(r=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),t.textContent=r,r===" "?t.style.whiteSpace="pre":t.style.display="inline-block",e.appendChild(t),r===" "?null:t}).filter(r=>r!==null)}function lt(e){let n=ut(e),r=new Map;for(let s of n){let m=s.offsetTop;r.has(m)||r.set(m,[]),r.get(m).push(s);}let t=[],c=Array.from(r.keys()).sort((s,m)=>s-m);for(let s of c){let m=r.get(s),u=document.createElement("span");u.setAttribute("aria-hidden","true"),u.style.display="inline-block";for(let l of m)u.appendChild(l);t.push(u);}e.textContent="";for(let s of t)e.appendChild(s),e.appendChild(document.createTextNode(" "));return t}function Ct(e,n,r,t){if(r<=1||t===0)return e;let c=(r-1)*t,s=n*t,m=s+(1-c);return m<=s?e>=s?1:0:Math.min(1,Math.max(0,(e-s)/(m-s)))}function Pt(e,n){let r=[];if(n?.y!==void 0&&r.push(`translateY(${n.y*(1-e)}px)`),n?.x!==void 0&&r.push(`translateX(${n.x*(1-e)}px)`),n?.rotate!==void 0&&r.push(`rotate(${n.rotate*(1-e)}deg)`),n?.scale!==void 0){let t=n.scale+(1-n.scale)*e;r.push(`scale(${t})`);}return r.join(" ")||""}var ct={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function mt(e,n={}){if(typeof window>"u")return ct;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollText: element not found:",e),ct;let t=r,{split:c="words",stagger:s=.04,easing:m="ease-out",from:u={opacity:0,y:24},trigger:l={},once:d=true,onComplete:T}=n,Y=window.matchMedia("(prefers-reduced-motion: reduce)").matches,b=typeof m=="function"?m:le[m]??le["ease-out"],re=me(l.start??"top 85%"),we=me(l.end??"top 40%"),q=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let ne;c==="chars"?ne=$t(t):c==="lines"?ne=lt(t):ne=ut(t);let A=ne.length;function N(h,x){u?.opacity!==void 0&&(h.style.opacity=String(u.opacity+(1-u.opacity)*x));let Z=Pt(x,u);Z&&(h.style.transform=Z);}function M(h){t.style.setProperty("--scroll-draw-progress",String(h)),ne.forEach((x,Z)=>{let be=b(Ct(h,Z,A,s));N(x,be);});}if(Y)return M(1),T?.(),{destroy(){t.innerHTML=q,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};M(0);let B=0,O=0,$=0,D=false,H=false,R=-1,I=0,z=false,E=()=>window.scrollY,U=()=>window.innerHeight;function ce(){let h=t.getBoundingClientRect(),x=he({top:h.top,height:h.height},E(),U(),re,we);B=x.tStart,O=x.tEnd;}function ie(){if(!D||H)return;let h=ee(E(),B,O,1);d&&(R=Math.max(R,h),h=R),I=h,M(h),h>=1&&!z?(z=true,T?.()):h<1&&!d&&(z=false),$=requestAnimationFrame(ie);}ce();let pe=new IntersectionObserver(h=>{h.forEach(x=>{D=x.isIntersecting,D&&!H?$=requestAnimationFrame(ie):cancelAnimationFrame($);});}),f;function P(){clearTimeout(f),f=setTimeout(()=>{if(c==="lines"){let h=I;t.innerHTML=q,t.setAttribute("aria-label",t.textContent??""),ne=lt(t),M(h);}ce();},150);}return window.addEventListener("resize",P),window.addEventListener("orientationchange",P),pe.observe(t),Pe(t,{type:"text",getProgress:()=>I,getTrigger:()=>({tStart:B,tEnd:O})}),{destroy(){cancelAnimationFrame($),pe.disconnect(),window.removeEventListener("resize",P),window.removeEventListener("orientationchange",P),clearTimeout(f),t.innerHTML=q,t.removeAttribute("aria-label"),Le(t);},replay(){R=-1,z=false,I=0,H=false,M(0);},pause(){H=true,cancelAnimationFrame($);},resume(){H&&(H=false,D&&($=requestAnimationFrame(ie)));},seek(h){let x=Math.min(1,Math.max(0,h));I=x,R=x,H=true,cancelAnimationFrame($),M(x);},getProgress(){return I}}}function Lt(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let t=typeof e=="string"?document.querySelector(e):e;return t?qe(t,n):(console.warn("[svg-scroll-draw] Container not found:",e),r)}function kt(e=document){return Array.from(e.querySelectorAll("[data-scroll-draw]")).map(n=>{let r={};try{let t=n.dataset.scrollDrawOptions??n.dataset.scrollDrawoptions??"";t&&(r=JSON.parse(t));}catch{}return qe(n,r)})}function Ot(e=document){return Array.from(e.querySelectorAll("[data-scroll-animate]")).map(n=>{let r={props:{}};try{let t=n.dataset.scrollAnimateOptions??"";t&&(r=JSON.parse(t));}catch{}return at(n,r)})}function Dt(e=document){return Array.from(e.querySelectorAll("[data-scroll-counter]")).map(n=>{let r={};try{let t=n.dataset.scrollCounterOptions??"";t&&(r=JSON.parse(t));}catch{}return !r.to&&r.to!==0&&(process.env.NODE_ENV!=="production"&&console.warn('[svg-scroll-draw] initScrollCounter: element missing "to" in options JSON:',n),r.to=0),je(n,r)})}function It(e=document){return Array.from(e.querySelectorAll("[data-scroll-text]")).map(n=>{let r={};try{let t=n.dataset.scrollTextOptions??"";t&&(r=JSON.parse(t));}catch{}return mt(n,r)})}function fr(e=document){return {draw:kt(e),animate:Ot(e),counter:Dt(e),text:It(e)}}exports.initAll=fr;exports.initScrollAnimate=Ot;exports.initScrollCounter=Dt;exports.initScrollDraw=kt;exports.initScrollText=It;exports.scrollDraw=Lt;
|
package/dist/astro/index.d.mts
CHANGED
|
@@ -137,5 +137,74 @@ declare function scrollDraw(target: string | Element, options?: ScrollDrawOption
|
|
|
137
137
|
* </script>
|
|
138
138
|
*/
|
|
139
139
|
declare function initScrollDraw(root?: Element | Document): ScrollDrawInstance[];
|
|
140
|
+
/**
|
|
141
|
+
* Auto-initialises all [data-scroll-animate] elements on the page.
|
|
142
|
+
* Options (including `props`) are read from the data-scroll-animate-options JSON attribute.
|
|
143
|
+
*
|
|
144
|
+
* @example
|
|
145
|
+
* <div
|
|
146
|
+
* data-scroll-animate
|
|
147
|
+
* data-scroll-animate-options='{"props":{"opacity":[0,1],"transform":["translateY(40px)","translateY(0)"]},"easing":"ease-out","once":true}'
|
|
148
|
+
* >
|
|
149
|
+
* Content that fades and slides in
|
|
150
|
+
* </div>
|
|
151
|
+
*
|
|
152
|
+
* <script>
|
|
153
|
+
* import { initScrollAnimate } from 'svg-scroll-draw/astro';
|
|
154
|
+
* initScrollAnimate();
|
|
155
|
+
* </script>
|
|
156
|
+
*/
|
|
157
|
+
declare function initScrollAnimate(root?: Element | Document): ScrollDrawInstance[];
|
|
158
|
+
/**
|
|
159
|
+
* Auto-initialises all [data-scroll-counter] elements on the page.
|
|
160
|
+
* Options are read from the data-scroll-counter-options JSON attribute.
|
|
161
|
+
* The `to` value is required — pass it via JSON options.
|
|
162
|
+
*
|
|
163
|
+
* @example
|
|
164
|
+
* <span
|
|
165
|
+
* data-scroll-counter
|
|
166
|
+
* data-scroll-counter-options='{"to":1250000,"format":"$%d","once":true}'
|
|
167
|
+
* />
|
|
168
|
+
*
|
|
169
|
+
* <script>
|
|
170
|
+
* import { initScrollCounter } from 'svg-scroll-draw/astro';
|
|
171
|
+
* initScrollCounter();
|
|
172
|
+
* </script>
|
|
173
|
+
*/
|
|
174
|
+
declare function initScrollCounter(root?: Element | Document): ScrollDrawInstance[];
|
|
175
|
+
/**
|
|
176
|
+
* Auto-initialises all [data-scroll-text] elements on the page.
|
|
177
|
+
* Options are read from the data-scroll-text-options JSON attribute.
|
|
178
|
+
*
|
|
179
|
+
* @example
|
|
180
|
+
* <h2
|
|
181
|
+
* data-scroll-text
|
|
182
|
+
* data-scroll-text-options='{"split":"words","stagger":0.05,"once":true}'
|
|
183
|
+
* >
|
|
184
|
+
* Animate on scroll.
|
|
185
|
+
* </h2>
|
|
186
|
+
*
|
|
187
|
+
* <script>
|
|
188
|
+
* import { initScrollText } from 'svg-scroll-draw/astro';
|
|
189
|
+
* initScrollText();
|
|
190
|
+
* </script>
|
|
191
|
+
*/
|
|
192
|
+
declare function initScrollText(root?: Element | Document): ScrollDrawInstance[];
|
|
193
|
+
/**
|
|
194
|
+
* Convenience — runs all four init functions in one call.
|
|
195
|
+
* Pass a root element to scope to a specific subtree.
|
|
196
|
+
*
|
|
197
|
+
* @example
|
|
198
|
+
* <script>
|
|
199
|
+
* import { initAll } from 'svg-scroll-draw/astro';
|
|
200
|
+
* initAll(); // Initialises scrollDraw, scrollAnimate, scrollCounter, scrollText
|
|
201
|
+
* </script>
|
|
202
|
+
*/
|
|
203
|
+
declare function initAll(root?: Element | Document): {
|
|
204
|
+
draw: ScrollDrawInstance[];
|
|
205
|
+
animate: ScrollDrawInstance[];
|
|
206
|
+
counter: ScrollDrawInstance[];
|
|
207
|
+
text: ScrollDrawInstance[];
|
|
208
|
+
};
|
|
140
209
|
|
|
141
|
-
export { type ScrollDrawInstance, type ScrollDrawOptions, initScrollDraw, scrollDraw };
|
|
210
|
+
export { type ScrollDrawInstance, type ScrollDrawOptions, initAll, initScrollAnimate, initScrollCounter, initScrollDraw, initScrollText, scrollDraw };
|
package/dist/astro/index.d.ts
CHANGED
|
@@ -137,5 +137,74 @@ declare function scrollDraw(target: string | Element, options?: ScrollDrawOption
|
|
|
137
137
|
* </script>
|
|
138
138
|
*/
|
|
139
139
|
declare function initScrollDraw(root?: Element | Document): ScrollDrawInstance[];
|
|
140
|
+
/**
|
|
141
|
+
* Auto-initialises all [data-scroll-animate] elements on the page.
|
|
142
|
+
* Options (including `props`) are read from the data-scroll-animate-options JSON attribute.
|
|
143
|
+
*
|
|
144
|
+
* @example
|
|
145
|
+
* <div
|
|
146
|
+
* data-scroll-animate
|
|
147
|
+
* data-scroll-animate-options='{"props":{"opacity":[0,1],"transform":["translateY(40px)","translateY(0)"]},"easing":"ease-out","once":true}'
|
|
148
|
+
* >
|
|
149
|
+
* Content that fades and slides in
|
|
150
|
+
* </div>
|
|
151
|
+
*
|
|
152
|
+
* <script>
|
|
153
|
+
* import { initScrollAnimate } from 'svg-scroll-draw/astro';
|
|
154
|
+
* initScrollAnimate();
|
|
155
|
+
* </script>
|
|
156
|
+
*/
|
|
157
|
+
declare function initScrollAnimate(root?: Element | Document): ScrollDrawInstance[];
|
|
158
|
+
/**
|
|
159
|
+
* Auto-initialises all [data-scroll-counter] elements on the page.
|
|
160
|
+
* Options are read from the data-scroll-counter-options JSON attribute.
|
|
161
|
+
* The `to` value is required — pass it via JSON options.
|
|
162
|
+
*
|
|
163
|
+
* @example
|
|
164
|
+
* <span
|
|
165
|
+
* data-scroll-counter
|
|
166
|
+
* data-scroll-counter-options='{"to":1250000,"format":"$%d","once":true}'
|
|
167
|
+
* />
|
|
168
|
+
*
|
|
169
|
+
* <script>
|
|
170
|
+
* import { initScrollCounter } from 'svg-scroll-draw/astro';
|
|
171
|
+
* initScrollCounter();
|
|
172
|
+
* </script>
|
|
173
|
+
*/
|
|
174
|
+
declare function initScrollCounter(root?: Element | Document): ScrollDrawInstance[];
|
|
175
|
+
/**
|
|
176
|
+
* Auto-initialises all [data-scroll-text] elements on the page.
|
|
177
|
+
* Options are read from the data-scroll-text-options JSON attribute.
|
|
178
|
+
*
|
|
179
|
+
* @example
|
|
180
|
+
* <h2
|
|
181
|
+
* data-scroll-text
|
|
182
|
+
* data-scroll-text-options='{"split":"words","stagger":0.05,"once":true}'
|
|
183
|
+
* >
|
|
184
|
+
* Animate on scroll.
|
|
185
|
+
* </h2>
|
|
186
|
+
*
|
|
187
|
+
* <script>
|
|
188
|
+
* import { initScrollText } from 'svg-scroll-draw/astro';
|
|
189
|
+
* initScrollText();
|
|
190
|
+
* </script>
|
|
191
|
+
*/
|
|
192
|
+
declare function initScrollText(root?: Element | Document): ScrollDrawInstance[];
|
|
193
|
+
/**
|
|
194
|
+
* Convenience — runs all four init functions in one call.
|
|
195
|
+
* Pass a root element to scope to a specific subtree.
|
|
196
|
+
*
|
|
197
|
+
* @example
|
|
198
|
+
* <script>
|
|
199
|
+
* import { initAll } from 'svg-scroll-draw/astro';
|
|
200
|
+
* initAll(); // Initialises scrollDraw, scrollAnimate, scrollCounter, scrollText
|
|
201
|
+
* </script>
|
|
202
|
+
*/
|
|
203
|
+
declare function initAll(root?: Element | Document): {
|
|
204
|
+
draw: ScrollDrawInstance[];
|
|
205
|
+
animate: ScrollDrawInstance[];
|
|
206
|
+
counter: ScrollDrawInstance[];
|
|
207
|
+
text: ScrollDrawInstance[];
|
|
208
|
+
};
|
|
140
209
|
|
|
141
|
-
export { type ScrollDrawInstance, type ScrollDrawOptions, initScrollDraw, scrollDraw };
|
|
210
|
+
export { type ScrollDrawInstance, type ScrollDrawOptions, initAll, initScrollAnimate, initScrollCounter, initScrollDraw, initScrollText, scrollDraw };
|
package/dist/astro/index.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
function
|
|
2
|
-
<div style="position:absolute;${
|
|
3
|
-
<div style="position:absolute;${T?`left:${E}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${E}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(s),window.addEventListener("scroll",y,{passive:true}),y(),s}function Oe(e,r,n){let s=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),y=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,h=>{let L=parseFloat(h),E=s[y++]??L;return String(+(L+(E-L)*n).toFixed(4))})}function $e(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:n,...s}=r,y=n?{...Ie[n],...s}:s,h=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:L="path, polyline, line, polygon, rect, circle",speed:E=1,fade:T=false,easing:p="linear",trigger:S={},stagger:_=0,direction:d="forward",once:Z=false,debug:Ue=false,axis:R="y",scrollContainer:Me,autoReverse:ye=false,delay:ue=0,strokeColor:K,strokeWidth:Q,fillOpacity:ee,waypoints:te,velocityScale:he=false,threshold:Fe=0,rootMargin:Ne="0px",repeat:re=0,repeatDelay:Pe=0,morphTo:H,clip:ke,autoplay:Je=false,duration:Ze=1e3,native:Ke=true,onProgress:me,onStart:be,onComplete:ae}=y,j=ke===true?"left":typeof ke=="string"?ke:false,ne=typeof p=="function"?p:ce[p]??ce.linear,Re=pe(S.start??"top bottom"),He=pe(S.end??"bottom top"),D=typeof Me=="string"?document.querySelector(Me):Me??null,q=Array.isArray(K)?K[0]:null,$=Array.isArray(K)?K[1]:typeof K=="string"?K:null,I=Array.isArray(Q)?Q[0]:null,M=Array.isArray(Q)?Q[1]:typeof Q=="number"?Q:null,O=Array.isArray(ee)?ee[0]:null,P=Array.isArray(ee)?ee[1]:typeof ee=="number"?ee:null;function oe(t){let o=t*100;switch(j){case "right":return `inset(0 0 0 ${100-o}%)`;case "top":return `inset(0 0 ${100-o}% 0)`;case "bottom":return `inset(${100-o}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-o}% 0 0)`}}let x=j?[]:Array.from(e.querySelectorAll(L)),w=[],z=[],X=0,Y=0,A=false,N=false,v=0,we=false,V=-1,ve=-1,k=false,se=0,B=0,U,Ce=null,J=new Set,Se=-1,qe=performance.now();function fe(){return D?R==="x"?D.scrollLeft:D.scrollTop:R==="x"?window.scrollX:window.scrollY}function ze(){return D?R==="x"?D.clientWidth:D.clientHeight:R==="x"?window.innerWidth:window.innerHeight}function Ve(){let t=e.getBoundingClientRect(),o,l,g;if(D){let C=D.getBoundingClientRect();o=R==="x"?t.left-C.left+D.scrollLeft:t.top-C.top+D.scrollTop,l=R==="x"?t.width:t.height,g=fe();}else o=R==="x"?t.left:t.top,l=R==="x"?t.width:t.height,g=fe();let F=de({top:o,height:l},g,ze(),Re,He);X=F.tStart,Y=F.tEnd,Ue&&process.env.NODE_ENV!=="production"&&(Ce?.remove(),Ce=at(X,Y,R));}function Qe(t,o){if(e.style.setProperty("--scroll-draw-progress",String(t)),j){let l=o==="reverse"?1-t:t;e.style.clipPath=oe(l);return}x.forEach((l,g)=>{l.style.strokeDashoffset=o==="reverse"?`${w[g]*t}`:`${w[g]*(1-t)}`,T&&(l.style.opacity=o==="reverse"?`${1-t}`:`${t}`),q&&$?l.style.stroke=ge(q,$,t):$&&(l.style.stroke=$),I!==null&&M!==null?l.style.strokeWidth=`${I+(M-I)*t}`:M!==null&&(l.style.strokeWidth=`${M}`),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",Oe(z[g],H,t));});}function Ee(){if(e.style.setProperty("--scroll-draw-progress","0"),j){e.style.clipPath=oe(0);return}x.forEach((t,o)=>{t.style.strokeDasharray=`${w[o]}`,t.style.strokeDashoffset=d==="reverse"?"0":`${w[o]}`,T?t.style.opacity=d==="reverse"?"1":"0":t.style.opacity="",q&&(t.style.stroke=q),I!==null&&(t.style.strokeWidth=`${I}`),O!==null&&(t.style.fillOpacity=`${O}`),H&&t.tagName.toLowerCase()==="path"&&z[o]&&t.setAttribute("d",z[o]);});}if(x.forEach(t=>{it(t);let o=Te(t);w.push(o),t.tagName.toLowerCase()==="path"?z.push(t.getAttribute("d")??""):z.push(""),h?(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=d==="reverse"?`${o}`:"0",T&&(t.style.opacity="1"),$&&(t.style.stroke=$),M!==null&&(t.style.strokeWidth=`${M}`),P!==null&&(t.style.fillOpacity=`${P}`),H&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",H)):(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=d==="reverse"?"0":`${o}`,T?t.style.opacity=d==="reverse"?"1":"0":t.style.opacity="",q&&(t.style.stroke=q),I!==null&&(t.style.strokeWidth=`${I}`),O!==null&&(t.style.fillOpacity=`${O}`));}),j){if(h)return e.style.clipPath=oe(1),ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=oe(0);}else if(h)return ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function et(){return !(Ke===false||!st()||!x.length||typeof p!="string"||!(p in Ye)||j||R!=="y"||D||E!==1||_!==0||Z||ye||he!==false||H||te||re||ue>0||me||be||ae||K!=null||Q!=null||ee!=null||(S.start??"top bottom").trim()!=="top bottom"||(S.end??"bottom top").trim()!=="bottom top")}function tt(){let t=`svg-scroll-draw-${++ot}`,o=d==="reverse"?"0":"var(--ssd-len)",l=d==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${o};`,F=`stroke-dashoffset:${l};`;T&&(g+=`opacity:${d==="reverse"?1:0};`,F+=`opacity:${d==="reverse"?0:1};`);let C=document.createElement("style");C.setAttribute("data-svg-scroll-draw",""),C.textContent=`@keyframes ${t}{from{${g}}to{${F}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Ye[p]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(C);function a(i,u){i.style.setProperty("--ssd-len",String(w[u])),i.style.strokeDasharray=`${w[u]}`,i.style.strokeDashoffset="",i.style.opacity="",i.style.animationPlayState="",i.classList.add(t);}x.forEach(a);let m=false,b=-1;function c(){if(b>=0)return b;let i=e.getBoundingClientRect(),{tStart:u,tEnd:f}=de({top:i.top,height:i.height},fe(),ze(),Re,He);return ne(G(fe(),u,f,E))}return {destroy(){x.forEach(i=>{i.classList.remove(t),i.style.removeProperty("--ssd-len"),i.style.animationPlayState="";}),C.remove();},replay(){m=false,b=-1,x.forEach(a);},pause(){m=true,x.forEach(i=>{i.style.animationPlayState="paused";});},resume(){m&&(m=false,x.forEach(i=>{i.style.animationPlayState="running";}));},seek(i){let u=Math.min(1,Math.max(0,i));b=u,m=true,x.forEach((f,ie)=>{f.classList.remove(t),f.style.strokeDashoffset=d==="reverse"?`${w[ie]*u}`:`${w[ie]*(1-u)}`,T&&(f.style.opacity=d==="reverse"?`${1-u}`:`${u}`);});},getProgress(){return c()}}}if(et())return tt();function rt(){let t=Math.max(1,Ze),o=0,l=0;function g(c){let i=true;if(j){let u=Math.min(1,Math.max(0,c/t)),f=ne(u);se=f,e.style.setProperty("--scroll-draw-progress",String(f)),e.style.clipPath=oe(d==="reverse"?1-f:f),me?.(f),u<1&&(i=false);}else x.forEach((u,f)=>{let ie=f*_*t,le=Math.min(1,Math.max(0,(c-ie)/t)),W=ne(le);u.style.strokeDashoffset=d==="reverse"?`${w[f]*W}`:`${w[f]*(1-W)}`,T&&(u.style.opacity=d==="reverse"?`${1-W}`:`${W}`),q&&$?u.style.stroke=ge(q,$,W):$&&(u.style.stroke=$),I!==null&&M!==null?u.style.strokeWidth=`${I+(M-I)*W}`:M!==null&&(u.style.strokeWidth=`${M}`),O!==null&&P!==null?u.style.fillOpacity=`${O+(P-O)*W}`:P!==null&&(u.style.fillOpacity=`${P}`),H&&u.tagName.toLowerCase()==="path"&&z[f]&&u.setAttribute("d",Oe(z[f],H,W)),f===0&&(me?.(W),e.style.setProperty("--scroll-draw-progress",String(W))),le<1&&(i=false);});if(te){let u=Math.min(1,Math.max(0,c/t)),f=ne(u);for(let ie in te){let le=parseFloat(ie);f>=le&&!J.has(le)&&(J.add(le),te[ie]?.());}}return i}function F(c){if(k)return;let i=c-o;N||(N=true,be?.());let u=g(i);if(u&&!A){A=true,g(t*(1+Math.max(0,x.length-1)*_)),ae?.(),B<(re==="infinite"?1/0:re??0)&&(B++,U=setTimeout(()=>{o=performance.now(),N=false,A=false,J.clear(),Ee(),v=requestAnimationFrame(F);},Pe));return}u||(v=requestAnimationFrame(F));}function C(){cancelAnimationFrame(v),clearTimeout(U),o=performance.now(),l=0,k=false,N=false,A=false,B=0,J.clear(),Ee(),v=requestAnimationFrame(F);}let a=new IntersectionObserver(c=>{c.forEach(i=>{i.isIntersecting&&!(Z&&A)?C():!i.isIntersecting&&!Z&&!A&&(cancelAnimationFrame(v),clearTimeout(U),o=null);});},{root:D??null,threshold:Fe,rootMargin:Ne}),m;function b(){clearTimeout(m),m=setTimeout(()=>{x.forEach((c,i)=>{w[i]=Te(c),c.style.strokeDasharray=`${w[i]}`;});},150);}return window.addEventListener("resize",b),window.addEventListener("orientationchange",b),ue>0?setTimeout(()=>a.observe(e),ue):a.observe(e),{destroy(){cancelAnimationFrame(v),clearTimeout(U),a.disconnect(),window.removeEventListener("resize",b),window.removeEventListener("orientationchange",b),clearTimeout(m);},replay(){B=0,C();},pause(){k||(k=true,l=performance.now()-o,cancelAnimationFrame(v));},resume(){k&&(k=false,o=performance.now()-l,v=requestAnimationFrame(F));},seek(c){let i=Math.min(1,Math.max(0,c));se=i,k=true,l=i*t,o=performance.now()-l,cancelAnimationFrame(v),g(l);},getProgress(){return se}}}if(Je)return rt();Ve();function xe(){if(!we||k)return;let t=performance.now(),o=fe(),l=E;if(he!==false){let a=t-qe,m=a>0?Math.abs(o-(Se<0?o:Se))/a:0;l=E*Math.max(.2,1+m*(typeof he=="number"?he:1)*.04);}Se=o,qe=t;let g=ye?ve===-1||o>=ve?"forward":"reverse":d;ve=o;let F=Y-X,C=true;if(j){let a=ne(G(o,X,Y,l));Z&&!ye&&(V=Math.max(V,a),a=V),se=a,e.style.setProperty("--scroll-draw-progress",String(a));let m=g==="reverse"?1-a:a;e.style.clipPath=oe(m),me?.(a),!N&&G(o,X,Y,l)>0&&(N=true,be?.()),a>=1&&!A?(A=true,ae?.(),B<(re==="infinite"?1/0:re??0)&&(B++,U=setTimeout(()=>{V=-1,N=false,A=false,e.style.clipPath=oe(0);},Pe))):a<1&&!Z&&(A=false),v=requestAnimationFrame(xe);return}if(x.forEach((a,m)=>{let b=m*_*F,c=ne(G(o,X+b,Y+b,l));Z&&!ye&&(V=Math.max(V,c),c=V),se=c,a.style.strokeDashoffset=g==="reverse"?`${w[m]*c}`:`${w[m]*(1-c)}`,T&&(a.style.opacity=g==="reverse"?`${1-c}`:`${c}`),q&&$?a.style.stroke=ge(q,$,c):$&&(a.style.stroke=$),I!==null&&M!==null?a.style.strokeWidth=`${I+(M-I)*c}`:M!==null&&(a.style.strokeWidth=`${M}`),O!==null&&P!==null?a.style.fillOpacity=`${O+(P-O)*c}`:P!==null&&(a.style.fillOpacity=`${P}`),H&&a.tagName.toLowerCase()==="path"&&z[m]&&a.setAttribute("d",Oe(z[m],H,c)),m===0&&(me?.(c),e.style.setProperty("--scroll-draw-progress",String(c))),c<1&&(C=false);}),te){let a=ne(G(o,X,Y,l));for(let m in te){let b=parseFloat(m);a>=b&&!J.has(b)&&(J.add(b),te[m]?.());}}!N&&G(o,X,Y,l)>0&&(N=true,be?.()),C&&!A?(A=true,ae?.(),B<(re==="infinite"?1/0:re??0)&&(B++,U=setTimeout(()=>{V=-1,N=false,A=false,J.clear(),Ee();},Pe))):!C&&!Z&&(A=false),v=requestAnimationFrame(xe);}let Le=new IntersectionObserver(t=>{t.forEach(o=>{we=o.isIntersecting,we&&!k?v=requestAnimationFrame(xe):cancelAnimationFrame(v);});},{root:D??null,threshold:Fe,rootMargin:Ne}),De;function Ae(){clearTimeout(De),De=setTimeout(()=>{x.forEach((t,o)=>{w[o]=Te(t),t.style.strokeDasharray=`${w[o]}`;}),Ve();},150);}return window.addEventListener("resize",Ae),window.addEventListener("orientationchange",Ae),ue>0?setTimeout(()=>Le.observe(e),ue):Le.observe(e),{destroy(){cancelAnimationFrame(v),clearTimeout(U),Le.disconnect(),window.removeEventListener("resize",Ae),window.removeEventListener("orientationchange",Ae),clearTimeout(De),Ce?.remove();},replay(){V=-1,ve=-1,Se=-1,N=false,A=false,B=0,k=false,J.clear(),clearTimeout(U),Ee();},pause(){k=true,cancelAnimationFrame(v);},resume(){k&&(k=false,we&&(v=requestAnimationFrame(xe)));},seek(t){let o=Math.min(1,Math.max(0,t));se=o,V=o,k=true,cancelAnimationFrame(v),Qe(o,d);},getProgress(){return se}}}function ut(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let s=typeof e=="string"?document.querySelector(e):e;return s?$e(s,r):(console.warn("[svg-scroll-draw] Container not found:",e),n)}function Ht(e=document){return Array.from(e.querySelectorAll("[data-scroll-draw]")).map(r=>{let n={};try{let s=r.dataset.scrollDrawOptions??r.dataset.scrollDrawoptions??"";s&&(n=JSON.parse(s));}catch{}return $e(r,n)})}export{Ht as initScrollDraw,ut as scrollDraw};
|
|
1
|
+
function Qe({bounces:e=3,decay:n=.5}={}){let r=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,n)),c=Math.sqrt(t),s=0,m=[];for(let d=0;d<r;d++){let T=Math.pow(c,d);m.push(T),s+=T;}let u=[0],l=0;for(let d=0;d<r;d++)l+=m[d]/s,u.push(l);return d=>{if(d<=0)return 0;if(d>=1)return 1;for(let T=0;T<r;T++)if(d<=u[T+1]){let Y=(d-u[T])/(u[T+1]-u[T]);if(T===0)return Y*(2-Y);let b=1-Math.pow(t,T);return b+(1-b)*(2*Y-1)*(2*Y-1)}return 1}}function et({amplitude:e=1,period:n=.4}={}){let r=Math.max(1,e),t=Math.max(.1,n),c=r<=1?t/4:t/(2*Math.PI)*Math.asin(1/r);return s=>s<=0?0:s>=1?1:r*Math.pow(2,-10*s)*Math.sin((s-c)*(2*Math.PI)/t)+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:Qe(),elastic:et()};function me(e="top bottom"){let n=e.trim();if(/^\d+(\.\d+)?%$/.test(n))return {element:"top",viewport:n};let[r="top",t="bottom"]=n.split(/\s+/).filter(Boolean);return {element:r,viewport:t}}function Ue(e,n,r,t){switch(t){case "top":return e+r;case "center":return e+r+n/2;case "bottom":return e+r+n;default:return e+r}}function Ze(e,n){if(/^\d+(\.\d+)?%$/.test(e))return n*(parseFloat(e)/100);switch(e){case "top":return 0;case "center":return n/2;case "bottom":return n;default:return n}}function Re(e){let n=e.tagName.toLowerCase();if(n==="rect"){let r=parseFloat(e.getAttribute("width")??"0"),t=parseFloat(e.getAttribute("height")??"0");return 2*(r+t)}if(n==="circle"){let r=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*r}return e.getTotalLength()}function yt(e,n,r){return Math.min(r,Math.max(n,e))}function ee(e,n,r,t){return r===n?0:yt((e-n)/(r-n)*t,0,1)}function he(e,n,r,t,c){let s=Ue(e.top,e.height,n,t.element)-Ze(t.viewport,r),m=Ue(e.top,e.height,n,c.element)-Ze(c.viewport,r);return {tStart:s,tEnd:m}}function Ke(e){let n=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(n)return [parseInt(n[1]+n[1],16),parseInt(n[2]+n[2],16),parseInt(n[3]+n[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 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 Ce(e,n,r){let t=Ke(e),c=Ke(n);return !t||!c?e:`rgb(${Math.round(t[0]+(c[0]-t[0])*r)},${Math.round(t[1]+(c[1]-t[1])*r)},${Math.round(t[2]+(c[2]-t[2])*r)})`}var _e={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 tt(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n);}var rt={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},ht=0;function wt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function bt(e){let n=e.getAttribute("stroke"),r=e.getAttribute("fill");!n||n==="none"?tt("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&&tt("Element has a fill \u2014 it may obscure the stroke animation.",e);}function St(e,n,r){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 c(){let s=r==="x"?window.scrollX:window.scrollY,m=e-s,u=n-s,l=r==="x";t.innerHTML=`
|
|
2
|
+
<div style="position:absolute;${l?`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;${l?`left:${u}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${u}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",c,{passive:true}),c(),t}function Be(e,n,r){let t=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),c=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,s=>{let m=parseFloat(s),u=t[c++]??m;return String(+(m+(u-m)*r).toFixed(4))})}function qe(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...t}=n,c=r?{..._e[r],...t}:t,s=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:m="path, polyline, line, polygon, rect, circle",speed:u=1,fade:l=false,easing:d="linear",trigger:T={},stagger:Y=0,direction:b="forward",once:re=false,debug:we=false,axis:q="y",scrollContainer:ne,autoReverse:A=false,delay:N=0,strokeColor:M,strokeWidth:B,fillOpacity:O,waypoints:$,velocityScale:D=false,threshold:H=0,rootMargin:R="0px",repeat:I=0,repeatDelay:z=0,morphTo:E,clip:U,autoplay:ce=false,duration:ie=1e3,native:pe=true,onProgress:f,onStart:P,onComplete:h}=c,x=U===true?"left":typeof U=="string"?U:false,Z=typeof d=="function"?d:le[d]??le.linear,be=me(T.start??"top bottom"),a=me(T.end??"bottom top"),p=typeof ne=="string"?document.querySelector(ne):ne??null,K=Array.isArray(M)?M[0]:null,k=Array.isArray(M)?M[1]:typeof M=="string"?M:null,G=Array.isArray(B)?B[0]:null,Q=Array.isArray(B)?B[1]:typeof B=="number"?B:null,C=Array.isArray(O)?O[0]:null,V=Array.isArray(O)?O[1]:typeof O=="number"?O:null;function ae(o){let i=o*100;switch(x){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 X=x?[]:Array.from(e.querySelectorAll(m)),W=[],de=[],ve=0,Ee=0,te=false,fe=false,J=0,Oe=false,ge=-1,De=-1,oe=false,Ae=0,Se=0,xe,ze=null,Te=new Set,Ie=-1,Ye=performance.now();function ke(){return p?q==="x"?p.scrollLeft:p.scrollTop:q==="x"?window.scrollX:window.scrollY}function Xe(){return p?q==="x"?p.clientWidth:p.clientHeight:q==="x"?window.innerWidth:window.innerHeight}function Je(){let o=e.getBoundingClientRect(),i,w,_;if(p){let se=p.getBoundingClientRect();i=q==="x"?o.left-se.left+p.scrollLeft:o.top-se.top+p.scrollTop,w=q==="x"?o.width:o.height,_=ke();}else i=q==="x"?o.left:o.top,w=q==="x"?o.width:o.height,_=ke();let ue=he({top:i,height:w},_,Xe(),be,a);ve=ue.tStart,Ee=ue.tEnd,we&&process.env.NODE_ENV!=="production"&&(ze?.remove(),ze=St(ve,Ee,q));}function pt(o,i){if(e.style.setProperty("--scroll-draw-progress",String(o)),x){let w=i==="reverse"?1-o:o;e.style.clipPath=ae(w);return}X.forEach((w,_)=>{w.style.strokeDashoffset=i==="reverse"?`${W[_]*o}`:`${W[_]*(1-o)}`,l&&(w.style.opacity=i==="reverse"?`${1-o}`:`${o}`),K&&k?w.style.stroke=Ce(K,k,o):k&&(w.style.stroke=k),G!==null&&Q!==null?w.style.strokeWidth=`${G+(Q-G)*o}`:Q!==null&&(w.style.strokeWidth=`${Q}`),C!==null&&V!==null?w.style.fillOpacity=`${C+(V-C)*o}`:V!==null&&(w.style.fillOpacity=`${V}`),E&&w.tagName.toLowerCase()==="path"&&de[_]&&w.setAttribute("d",Be(de[_],E,o));});}function Fe(){if(e.style.setProperty("--scroll-draw-progress","0"),x){e.style.clipPath=ae(0);return}X.forEach((o,i)=>{o.style.strokeDasharray=`${W[i]}`,o.style.strokeDashoffset=b==="reverse"?"0":`${W[i]}`,l?o.style.opacity=b==="reverse"?"1":"0":o.style.opacity="",K&&(o.style.stroke=K),G!==null&&(o.style.strokeWidth=`${G}`),C!==null&&(o.style.fillOpacity=`${C}`),E&&o.tagName.toLowerCase()==="path"&&de[i]&&o.setAttribute("d",de[i]);});}if(X.forEach(o=>{bt(o);let i=Re(o);W.push(i),o.tagName.toLowerCase()==="path"?de.push(o.getAttribute("d")??""):de.push(""),s?(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=b==="reverse"?`${i}`:"0",l&&(o.style.opacity="1"),k&&(o.style.stroke=k),Q!==null&&(o.style.strokeWidth=`${Q}`),V!==null&&(o.style.fillOpacity=`${V}`),E&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",E)):(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=b==="reverse"?"0":`${i}`,l?o.style.opacity=b==="reverse"?"1":"0":o.style.opacity="",K&&(o.style.stroke=K),G!==null&&(o.style.strokeWidth=`${G}`),C!==null&&(o.style.fillOpacity=`${C}`));}),x){if(s)return e.style.clipPath=ae(1),h?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ae(0);}else if(s)return h?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function ft(){return !(pe===false||!wt()||!X.length||typeof d!="string"||!(d in rt)||x||q!=="y"||p||u!==1||Y!==0||re||A||D!==false||E||$||I||N>0||f||P||h||M!=null||B!=null||O!=null||(T.start??"top bottom").trim()!=="top bottom"||(T.end??"bottom top").trim()!=="bottom top")}function dt(){let o=`svg-scroll-draw-${++ht}`,i=b==="reverse"?"0":"var(--ssd-len)",w=b==="reverse"?"var(--ssd-len)":"0",_=`stroke-dashoffset:${i};`,ue=`stroke-dashoffset:${w};`;l&&(_+=`opacity:${b==="reverse"?1:0};`,ue+=`opacity:${b==="reverse"?0:1};`);let se=document.createElement("style");se.setAttribute("data-svg-scroll-draw",""),se.textContent=`@keyframes ${o}{from{${_}}to{${ue}}}.${o}{animation-name:${o};animation-duration:auto;animation-timing-function:${rt[d]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(se);function y(g,v){g.style.setProperty("--ssd-len",String(W[v])),g.style.strokeDasharray=`${W[v]}`,g.style.strokeDashoffset="",g.style.opacity="",g.style.animationPlayState="",g.classList.add(o);}X.forEach(y);let L=false,j=-1;function S(){if(j>=0)return j;let g=e.getBoundingClientRect(),{tStart:v,tEnd:F}=he({top:g.top,height:g.height},ke(),Xe(),be,a);return Z(ee(ke(),v,F,u))}return {destroy(){X.forEach(g=>{g.classList.remove(o),g.style.removeProperty("--ssd-len"),g.style.animationPlayState="";}),se.remove();},replay(){L=false,j=-1,X.forEach(y);},pause(){L=true,X.forEach(g=>{g.style.animationPlayState="paused";});},resume(){L&&(L=false,X.forEach(g=>{g.style.animationPlayState="running";}));},seek(g){let v=Math.min(1,Math.max(0,g));j=v,L=true,X.forEach((F,Me)=>{F.classList.remove(o),F.style.strokeDashoffset=b==="reverse"?`${W[Me]*v}`:`${W[Me]*(1-v)}`,l&&(F.style.opacity=b==="reverse"?`${1-v}`:`${v}`);});},getProgress(){return S()}}}if(ft())return dt();function gt(){let o=Math.max(1,ie),i=0,w=0;function _(S){let g=true;if(x){let v=Math.min(1,Math.max(0,S/o)),F=Z(v);Ae=F,e.style.setProperty("--scroll-draw-progress",String(F)),e.style.clipPath=ae(b==="reverse"?1-F:F),f?.(F),v<1&&(g=false);}else X.forEach((v,F)=>{let Me=F*Y*o,$e=Math.min(1,Math.max(0,(S-Me)/o)),ye=Z($e);v.style.strokeDashoffset=b==="reverse"?`${W[F]*ye}`:`${W[F]*(1-ye)}`,l&&(v.style.opacity=b==="reverse"?`${1-ye}`:`${ye}`),K&&k?v.style.stroke=Ce(K,k,ye):k&&(v.style.stroke=k),G!==null&&Q!==null?v.style.strokeWidth=`${G+(Q-G)*ye}`:Q!==null&&(v.style.strokeWidth=`${Q}`),C!==null&&V!==null?v.style.fillOpacity=`${C+(V-C)*ye}`:V!==null&&(v.style.fillOpacity=`${V}`),E&&v.tagName.toLowerCase()==="path"&&de[F]&&v.setAttribute("d",Be(de[F],E,ye)),F===0&&(f?.(ye),e.style.setProperty("--scroll-draw-progress",String(ye))),$e<1&&(g=false);});if($){let v=Math.min(1,Math.max(0,S/o)),F=Z(v);for(let Me in $){let $e=parseFloat(Me);F>=$e&&!Te.has($e)&&(Te.add($e),$[Me]?.());}}return g}function ue(S){if(oe)return;let g=S-i;fe||(fe=true,P?.());let v=_(g);if(v&&!te){te=true,_(o*(1+Math.max(0,X.length-1)*Y)),h?.(),Se<(I==="infinite"?1/0:I??0)&&(Se++,xe=setTimeout(()=>{i=performance.now(),fe=false,te=false,Te.clear(),Fe(),J=requestAnimationFrame(ue);},z));return}v||(J=requestAnimationFrame(ue));}function se(){cancelAnimationFrame(J),clearTimeout(xe),i=performance.now(),w=0,oe=false,fe=false,te=false,Se=0,Te.clear(),Fe(),J=requestAnimationFrame(ue);}let y=new IntersectionObserver(S=>{S.forEach(g=>{g.isIntersecting&&!(re&&te)?se():!g.isIntersecting&&!re&&!te&&(cancelAnimationFrame(J),clearTimeout(xe),i=null);});},{root:p??null,threshold:H,rootMargin:R}),L;function j(){clearTimeout(L),L=setTimeout(()=>{X.forEach((S,g)=>{W[g]=Re(S),S.style.strokeDasharray=`${W[g]}`;});},150);}return window.addEventListener("resize",j),window.addEventListener("orientationchange",j),N>0?setTimeout(()=>y.observe(e),N):y.observe(e),{destroy(){cancelAnimationFrame(J),clearTimeout(xe),y.disconnect(),window.removeEventListener("resize",j),window.removeEventListener("orientationchange",j),clearTimeout(L);},replay(){Se=0,se();},pause(){oe||(oe=true,w=performance.now()-i,cancelAnimationFrame(J));},resume(){oe&&(oe=false,i=performance.now()-w,J=requestAnimationFrame(ue));},seek(S){let g=Math.min(1,Math.max(0,S));Ae=g,oe=true,w=g*o,i=performance.now()-w,cancelAnimationFrame(J),_(w);},getProgress(){return Ae}}}if(ce)return gt();Je();function Ne(){if(!Oe||oe)return;let o=performance.now(),i=ke(),w=u;if(D!==false){let y=o-Ye,L=y>0?Math.abs(i-(Ie<0?i:Ie))/y:0;w=u*Math.max(.2,1+L*(typeof D=="number"?D:1)*.04);}Ie=i,Ye=o;let _=A?De===-1||i>=De?"forward":"reverse":b;De=i;let ue=Ee-ve,se=true;if(x){let y=Z(ee(i,ve,Ee,w));re&&!A&&(ge=Math.max(ge,y),y=ge),Ae=y,e.style.setProperty("--scroll-draw-progress",String(y));let L=_==="reverse"?1-y:y;e.style.clipPath=ae(L),f?.(y),!fe&&ee(i,ve,Ee,w)>0&&(fe=true,P?.()),y>=1&&!te?(te=true,h?.(),Se<(I==="infinite"?1/0:I??0)&&(Se++,xe=setTimeout(()=>{ge=-1,fe=false,te=false,e.style.clipPath=ae(0);},z))):y<1&&!re&&(te=false),J=requestAnimationFrame(Ne);return}if(X.forEach((y,L)=>{let j=L*Y*ue,S=Z(ee(i,ve+j,Ee+j,w));re&&!A&&(ge=Math.max(ge,S),S=ge),Ae=S,y.style.strokeDashoffset=_==="reverse"?`${W[L]*S}`:`${W[L]*(1-S)}`,l&&(y.style.opacity=_==="reverse"?`${1-S}`:`${S}`),K&&k?y.style.stroke=Ce(K,k,S):k&&(y.style.stroke=k),G!==null&&Q!==null?y.style.strokeWidth=`${G+(Q-G)*S}`:Q!==null&&(y.style.strokeWidth=`${Q}`),C!==null&&V!==null?y.style.fillOpacity=`${C+(V-C)*S}`:V!==null&&(y.style.fillOpacity=`${V}`),E&&y.tagName.toLowerCase()==="path"&&de[L]&&y.setAttribute("d",Be(de[L],E,S)),L===0&&(f?.(S),e.style.setProperty("--scroll-draw-progress",String(S))),S<1&&(se=false);}),$){let y=Z(ee(i,ve,Ee,w));for(let L in $){let j=parseFloat(L);y>=j&&!Te.has(j)&&(Te.add(j),$[L]?.());}}!fe&&ee(i,ve,Ee,w)>0&&(fe=true,P?.()),se&&!te?(te=true,h?.(),Se<(I==="infinite"?1/0:I??0)&&(Se++,xe=setTimeout(()=>{ge=-1,fe=false,te=false,Te.clear(),Fe();},z))):!se&&!re&&(te=false),J=requestAnimationFrame(Ne);}let Ve=new IntersectionObserver(o=>{o.forEach(i=>{Oe=i.isIntersecting,Oe&&!oe?J=requestAnimationFrame(Ne):cancelAnimationFrame(J);});},{root:p??null,threshold:H,rootMargin:R}),We;function He(){clearTimeout(We),We=setTimeout(()=>{X.forEach((o,i)=>{W[i]=Re(o),o.style.strokeDasharray=`${W[i]}`;}),Je();},150);}return window.addEventListener("resize",He),window.addEventListener("orientationchange",He),N>0?setTimeout(()=>Ve.observe(e),N):Ve.observe(e),{destroy(){cancelAnimationFrame(J),clearTimeout(xe),Ve.disconnect(),window.removeEventListener("resize",He),window.removeEventListener("orientationchange",He),clearTimeout(We),ze?.remove();},replay(){ge=-1,De=-1,Ie=-1,fe=false,te=false,Se=0,oe=false,Te.clear(),clearTimeout(xe),Fe();},pause(){oe=true,cancelAnimationFrame(J);},resume(){oe&&(oe=false,Oe&&(J=requestAnimationFrame(Ne)));},seek(o){let i=Math.min(1,Math.max(0,o));Ae=i,ge=i,oe=true,cancelAnimationFrame(J),pt(i,b);},getProgress(){return Ae}}}var nt=new Map;function Pe(e,n){nt.set(e,n);}function Le(e){nt.delete(e);}function vt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function ot(e){let n=[],r=/([\w]+)\(([^)]*)\)/g,t;for(;(t=r.exec(e))!==null;){let c=[],s=[],m=t[2].trim();if(m)for(let u of m.split(/[\s,]+/)){let l=u.match(/^([-+]?[\d.eE]+)(.*)$/);c.push(l?parseFloat(l[1]):0),s.push(l?l[2]:"");}n.push({fn:t[1],nums:c,units:s});}return n}function Et(e,n,r){let t=ot(e),c=ot(n);return t.length===0||t.length!==c.length?r<1?e:n:t.map((s,m)=>{let u=c[m];return s.fn!==u.fn||s.nums.length!==u.nums.length?r<1?`${s.fn}(${s.nums.map((l,d)=>`${l}${s.units[d]}`).join(", ")})`:`${u.fn}(${u.nums.map((l,d)=>`${l}${u.units[d]}`).join(", ")})`:`${s.fn}(${s.nums.map((l,d)=>`${l+(u.nums[d]-l)*r}${s.units[d]}`).join(", ")})`}).join(" ")}function st(e,n,r){if(typeof e=="number"&&typeof n=="number")return String(e+(n-e)*r);let t=String(e),c=String(n);if(vt(t))return Ce(t,c,r);if(t.includes("("))return Et(t,c,r);let s=t.match(/^([-+]?[\d.]+)(.*)$/),m=c.match(/^([-+]?[\d.]+)(.*)$/);if(s&&m){let u=parseFloat(s[1]),l=parseFloat(m[1]);return `${u+(l-u)*r}${s[2]||m[2]}`}return r<1?t:c}function xt(e){return e.replace(/([A-Z])/g,n=>`-${n.toLowerCase()}`)}var it={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Tt=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),At=0;function Mt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function at(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let{props:t,trigger:c={},easing:s="ease-out",speed:m=1,once:u=false,axis:l="y",scrollContainer:d,native:T=true,onProgress:Y,onComplete:b}=n,re=window.matchMedia("(prefers-reduced-motion: reduce)").matches,we=typeof s=="function"?s:le[s]??le["ease-out"],q=me(c.start??"top bottom"),ne=me(c.end??"bottom top"),A=typeof d=="string"?document.querySelector(d):d??null,N=Object.entries(t).map(([a,p])=>({prop:xt(a),from:Array.isArray(p)?p[0]:"",to:Array.isArray(p)?p[1]:p}));function M(){let a=window.getComputedStyle(e);for(let p of N)p.from===""&&(p.from=a.getPropertyValue(p.prop).trim()||"0");}function B(){for(let a of N)e.style.setProperty(a.prop,String(a.to));}if(re)return B(),b?.(),r;M();function O(){if(!T||!Mt()||typeof s!="string"||!(s in it)||l!=="y"||A||u||m!==1||Y||b||(c.start??"top bottom").trim()!=="top bottom"||(c.end??"bottom top").trim()!=="bottom top")return false;for(let a of N)if(!Tt.has(a.prop))return false;return true}function $(){let a=`ssd-a-${++At}`,p=N.map(C=>`${C.prop}:${C.from}`).join(";"),K=N.map(C=>`${C.prop}:${C.to}`).join(";"),k=document.createElement("style");k.setAttribute("data-ssd-animate",""),k.textContent=`@keyframes ${a}{from{${p}}to{${K}}}.${a}{animation-name:${a};animation-duration:auto;animation-timing-function:${it[s]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(k),e.classList.add(a);let G=()=>l==="x"?window.scrollX:window.scrollY,Q=()=>l==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(a),k.remove();},replay(){e.classList.remove(a),e.offsetWidth,e.classList.add(a);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(C){let V=Math.min(1,Math.max(0,C));e.classList.remove(a);for(let ae of N)e.style.setProperty(ae.prop,st(ae.from,ae.to,V));},getProgress(){let C=e.getBoundingClientRect(),V=G(),ae=Q(),{tStart:X,tEnd:W}=he({top:C.top,height:C.height},V,ae,q,ne);return we(ee(V,X,W,m))}}}if(O())return $();let D=0,H=0,R=0,I=false,z=false,E=-1,U=0,ce=false,ie=()=>A?l==="x"?A.scrollLeft:A.scrollTop:l==="x"?window.scrollX:window.scrollY,pe=()=>A?l==="x"?A.clientWidth:A.clientHeight:l==="x"?window.innerWidth:window.innerHeight;function f(){let a=e.getBoundingClientRect(),p,K;if(A){let G=A.getBoundingClientRect();p=l==="x"?a.left-G.left+A.scrollLeft:a.top-G.top+A.scrollTop,K=l==="x"?a.width:a.height;}else p=l==="x"?a.left:a.top,K=l==="x"?a.width:a.height;let k=he({top:p,height:K},ie(),pe(),q,ne);D=k.tStart,H=k.tEnd;}function P(a){e.style.setProperty("--scroll-draw-progress",String(a));for(let p of N)e.style.setProperty(p.prop,st(p.from,p.to,a));Y?.(a);}function h(){if(!I||z)return;let a=we(ee(ie(),D,H,m));u&&(E=Math.max(E,a),a=E),U=a,P(a),a>=1&&!ce?(ce=true,b?.()):a<1&&!u&&(ce=false),R=requestAnimationFrame(h);}f();{let a=we(ee(ie(),D,H,m));u&&a>0&&(E=a),U=a,P(a);}let x=new IntersectionObserver(a=>{a.forEach(p=>{I=p.isIntersecting,I&&!z?R=requestAnimationFrame(h):cancelAnimationFrame(R);});},{root:A??null}),Z;function be(){clearTimeout(Z),Z=setTimeout(f,150);}return window.addEventListener("resize",be),window.addEventListener("orientationchange",be),x.observe(e),Pe(e,{type:"animate",getProgress:()=>U,getTrigger:()=>({tStart:D,tEnd:H})}),{destroy(){cancelAnimationFrame(R),x.disconnect(),window.removeEventListener("resize",be),window.removeEventListener("orientationchange",be),clearTimeout(Z),Le(e);},replay(){E=-1,ce=false,U=0,z=false,P(0);},pause(){z=true,cancelAnimationFrame(R);},resume(){z&&(z=false,I&&(R=requestAnimationFrame(h)));},seek(a){let p=Math.min(1,Math.max(0,a));U=p,E=p,z=true,cancelAnimationFrame(R),P(p);},getProgress(){return U}}}var Ge={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function je(e,n){if(typeof window>"u")return Ge;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollCounter: element not found:",e),Ge;let t=r,{from:c=0,to:s,format:m,easing:u="ease-out",trigger:l={},once:d=true,decimals:T,onComplete:Y}=n,b=T!==void 0?f=>f.toFixed(T):m??(f=>String(Math.round(f))),re=typeof u=="function"?u:le[u]??le["ease-out"],we=me(l.start??"top 80%"),q=me(l.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=b(s),Y?.(),Ge;t.textContent=b(c);let A=0,N=0,M=0,B=false,O=false,$=-1,D=0,H=false,R=()=>window.scrollY,I=()=>window.innerHeight;function z(){let f=t.getBoundingClientRect(),P=he({top:f.top,height:f.height},R(),I(),we,q);A=P.tStart,N=P.tEnd;}function E(f){t.textContent=b(c+(s-c)*f),t.style.setProperty("--scroll-draw-progress",String(f));}function U(){if(!B||O)return;let f=re(ee(R(),A,N,1));d&&($=Math.max($,f),f=$),D=f,E(f),f>=1&&!H?(H=true,Y?.()):f<1&&!d&&(H=false),M=requestAnimationFrame(U);}z();{let f=re(ee(R(),A,N,1));d&&f>0&&($=f),D=f,E(f);}let ce=new IntersectionObserver(f=>{f.forEach(P=>{B=P.isIntersecting,B&&!O?M=requestAnimationFrame(U):cancelAnimationFrame(M);});}),ie;function pe(){clearTimeout(ie),ie=setTimeout(z,150);}return window.addEventListener("resize",pe),window.addEventListener("orientationchange",pe),ce.observe(t),Pe(t,{type:"counter",getProgress:()=>D,getTrigger:()=>({tStart:A,tEnd:N})}),{destroy(){cancelAnimationFrame(M),ce.disconnect(),window.removeEventListener("resize",pe),window.removeEventListener("orientationchange",pe),clearTimeout(ie),Le(t);},replay(){$=-1,H=false,D=0,O=false,E(0);},pause(){O=true,cancelAnimationFrame(M);},resume(){O&&(O=false,B&&(M=requestAnimationFrame(U)));},seek(f){let P=Math.min(1,Math.max(0,f));D=P,$=P,O=true,cancelAnimationFrame(M),E(P);},getProgress(){return D}}}function ut(e){let n=e.textContent??"";return e.textContent="",n.split(/(\s+)/).filter(Boolean).map(r=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),/^\s+$/.test(r)?(t.textContent=r,t.style.whiteSpace="pre"):(t.textContent=r,t.style.display="inline-block"),e.appendChild(t),/^\s+$/.test(r)?null:t}).filter(r=>r!==null)}function $t(e){let n=e.textContent??"";return e.textContent="",n.split("").map(r=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),t.textContent=r,r===" "?t.style.whiteSpace="pre":t.style.display="inline-block",e.appendChild(t),r===" "?null:t}).filter(r=>r!==null)}function lt(e){let n=ut(e),r=new Map;for(let s of n){let m=s.offsetTop;r.has(m)||r.set(m,[]),r.get(m).push(s);}let t=[],c=Array.from(r.keys()).sort((s,m)=>s-m);for(let s of c){let m=r.get(s),u=document.createElement("span");u.setAttribute("aria-hidden","true"),u.style.display="inline-block";for(let l of m)u.appendChild(l);t.push(u);}e.textContent="";for(let s of t)e.appendChild(s),e.appendChild(document.createTextNode(" "));return t}function Ct(e,n,r,t){if(r<=1||t===0)return e;let c=(r-1)*t,s=n*t,m=s+(1-c);return m<=s?e>=s?1:0:Math.min(1,Math.max(0,(e-s)/(m-s)))}function Pt(e,n){let r=[];if(n?.y!==void 0&&r.push(`translateY(${n.y*(1-e)}px)`),n?.x!==void 0&&r.push(`translateX(${n.x*(1-e)}px)`),n?.rotate!==void 0&&r.push(`rotate(${n.rotate*(1-e)}deg)`),n?.scale!==void 0){let t=n.scale+(1-n.scale)*e;r.push(`scale(${t})`);}return r.join(" ")||""}var ct={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function mt(e,n={}){if(typeof window>"u")return ct;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollText: element not found:",e),ct;let t=r,{split:c="words",stagger:s=.04,easing:m="ease-out",from:u={opacity:0,y:24},trigger:l={},once:d=true,onComplete:T}=n,Y=window.matchMedia("(prefers-reduced-motion: reduce)").matches,b=typeof m=="function"?m:le[m]??le["ease-out"],re=me(l.start??"top 85%"),we=me(l.end??"top 40%"),q=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let ne;c==="chars"?ne=$t(t):c==="lines"?ne=lt(t):ne=ut(t);let A=ne.length;function N(h,x){u?.opacity!==void 0&&(h.style.opacity=String(u.opacity+(1-u.opacity)*x));let Z=Pt(x,u);Z&&(h.style.transform=Z);}function M(h){t.style.setProperty("--scroll-draw-progress",String(h)),ne.forEach((x,Z)=>{let be=b(Ct(h,Z,A,s));N(x,be);});}if(Y)return M(1),T?.(),{destroy(){t.innerHTML=q,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};M(0);let B=0,O=0,$=0,D=false,H=false,R=-1,I=0,z=false,E=()=>window.scrollY,U=()=>window.innerHeight;function ce(){let h=t.getBoundingClientRect(),x=he({top:h.top,height:h.height},E(),U(),re,we);B=x.tStart,O=x.tEnd;}function ie(){if(!D||H)return;let h=ee(E(),B,O,1);d&&(R=Math.max(R,h),h=R),I=h,M(h),h>=1&&!z?(z=true,T?.()):h<1&&!d&&(z=false),$=requestAnimationFrame(ie);}ce();let pe=new IntersectionObserver(h=>{h.forEach(x=>{D=x.isIntersecting,D&&!H?$=requestAnimationFrame(ie):cancelAnimationFrame($);});}),f;function P(){clearTimeout(f),f=setTimeout(()=>{if(c==="lines"){let h=I;t.innerHTML=q,t.setAttribute("aria-label",t.textContent??""),ne=lt(t),M(h);}ce();},150);}return window.addEventListener("resize",P),window.addEventListener("orientationchange",P),pe.observe(t),Pe(t,{type:"text",getProgress:()=>I,getTrigger:()=>({tStart:B,tEnd:O})}),{destroy(){cancelAnimationFrame($),pe.disconnect(),window.removeEventListener("resize",P),window.removeEventListener("orientationchange",P),clearTimeout(f),t.innerHTML=q,t.removeAttribute("aria-label"),Le(t);},replay(){R=-1,z=false,I=0,H=false,M(0);},pause(){H=true,cancelAnimationFrame($);},resume(){H&&(H=false,D&&($=requestAnimationFrame(ie)));},seek(h){let x=Math.min(1,Math.max(0,h));I=x,R=x,H=true,cancelAnimationFrame($),M(x);},getProgress(){return I}}}function Lt(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let t=typeof e=="string"?document.querySelector(e):e;return t?qe(t,n):(console.warn("[svg-scroll-draw] Container not found:",e),r)}function kt(e=document){return Array.from(e.querySelectorAll("[data-scroll-draw]")).map(n=>{let r={};try{let t=n.dataset.scrollDrawOptions??n.dataset.scrollDrawoptions??"";t&&(r=JSON.parse(t));}catch{}return qe(n,r)})}function Ot(e=document){return Array.from(e.querySelectorAll("[data-scroll-animate]")).map(n=>{let r={props:{}};try{let t=n.dataset.scrollAnimateOptions??"";t&&(r=JSON.parse(t));}catch{}return at(n,r)})}function Dt(e=document){return Array.from(e.querySelectorAll("[data-scroll-counter]")).map(n=>{let r={};try{let t=n.dataset.scrollCounterOptions??"";t&&(r=JSON.parse(t));}catch{}return !r.to&&r.to!==0&&(process.env.NODE_ENV!=="production"&&console.warn('[svg-scroll-draw] initScrollCounter: element missing "to" in options JSON:',n),r.to=0),je(n,r)})}function It(e=document){return Array.from(e.querySelectorAll("[data-scroll-text]")).map(n=>{let r={};try{let t=n.dataset.scrollTextOptions??"";t&&(r=JSON.parse(t));}catch{}return mt(n,r)})}function fr(e=document){return {draw:kt(e),animate:Ot(e),counter:Dt(e),text:It(e)}}export{fr as initAll,Ot as initScrollAnimate,Dt as initScrollCounter,kt as initScrollDraw,It as initScrollText,Lt as scrollDraw};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
declare function enable(): void;
|
|
2
|
+
declare function disable(): void;
|
|
3
|
+
declare function toggle(): void;
|
|
4
|
+
declare function highlight(target: string | Element): void;
|
|
5
|
+
declare const devtools: {
|
|
6
|
+
enable: typeof enable;
|
|
7
|
+
disable: typeof disable;
|
|
8
|
+
toggle: typeof toggle;
|
|
9
|
+
highlight: typeof highlight;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export { devtools };
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
declare function enable(): void;
|
|
2
|
+
declare function disable(): void;
|
|
3
|
+
declare function toggle(): void;
|
|
4
|
+
declare function highlight(target: string | Element): void;
|
|
5
|
+
declare const devtools: {
|
|
6
|
+
enable: typeof enable;
|
|
7
|
+
disable: typeof disable;
|
|
8
|
+
toggle: typeof toggle;
|
|
9
|
+
highlight: typeof highlight;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export { devtools };
|