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.
@@ -1,3 +1,3 @@
1
- 'use strict';function rt({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),s=Math.max(.01,Math.min(.99,r)),m=Math.sqrt(s),u=0,S=[];for(let y=0;y<n;y++){let $=Math.pow(m,y);S.push($),u+=$;}let w=[0],p=0;for(let y=0;y<n;y++)p+=S[y]/u,w.push(p);return y=>{if(y<=0)return 0;if(y>=1)return 1;for(let $=0;$<n;$++)if(y<=w[$+1]){let V=(y-w[$])/(w[$+1]-w[$]);if($===0)return V*(2-V);let h=1-Math.pow(s,$);return h+(1-h)*(2*V-1)*(2*V-1)}return 1}}function nt({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),s=Math.max(.1,r),m=n<=1?s/4:s/(2*Math.PI)*Math.asin(1/n);return u=>u<=0?0:u>=1?1:n*Math.pow(2,-10*u)*Math.sin((u-m)*(2*Math.PI)/s)+1}var Pe={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:rt(),elastic:nt()};function De(e="top bottom"){let r=e.trim();if(/^\d+(\.\d+)?%$/.test(r))return {element:"top",viewport:r};let[n="top",s="bottom"]=r.split(/\s+/).filter(Boolean);return {element:n,viewport:s}}function ze(e,r,n,s){switch(s){case "top":return e+n;case "center":return e+n+r/2;case "bottom":return e+n+r;default:return e+n}}function Ge(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 Ee(e){let r=e.tagName.toLowerCase();if(r==="rect"){let n=parseFloat(e.getAttribute("width")??"0"),s=parseFloat(e.getAttribute("height")??"0");return 2*(n+s)}if(r==="circle"){let n=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*n}return e.getTotalLength()}function st(e,r,n){return Math.min(n,Math.max(r,e))}function ae(e,r,n,s){return n===r?0:st((e-r)/(n-r)*s,0,1)}function Le(e,r,n,s,m){let u=ze(e.top,e.height,r,s.element)-Ge(s.viewport,n),S=ze(e.top,e.height,r,m.element)-Ge(m.viewport,n);return {tStart:u,tEnd:S}}function Ve(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 s=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return s?[parseInt(s[1]),parseInt(s[2]),parseInt(s[3])]:null}function xe(e,r,n){let s=Ve(e),m=Ve(r);return !s||!m?e:`rgb(${Math.round(s[0]+(m[0]-s[0])*n)},${Math.round(s[1]+(m[1]-s[1])*n)},${Math.round(s[2]+(m[2]-s[2])*n)})`}var Be={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 _e(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r);}var Xe={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},ot=0;function at(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function it(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?_e("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&_e("Element has a fill \u2014 it may obscure the stroke animation.",e);}function lt(e,r,n){let s=document.createElement("div");s.setAttribute("data-svg-scroll-draw-debug",""),s.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function m(){let u=n==="x"?window.scrollX:window.scrollY,S=e-u,w=r-u,p=n==="x";s.innerHTML=`
2
- <div style="position:absolute;${p?`left:${S}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${S}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;${p?`left:${w}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${w}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",m,{passive:true}),m(),s}function Ie(e,r,n){let s=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),m=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,u=>{let S=parseFloat(u),w=s[m++]??S;return String(+(S+(w-S)*n).toFixed(4))})}function Oe(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:n,...s}=r,m=n?{...Be[n],...s}:s,u=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:S="path, polyline, line, polygon, rect, circle",speed:w=1,fade:p=false,easing:y="linear",trigger:$={},stagger:V=0,direction:h="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:Fe=0,rootMargin:Ce="0px",repeat:te=0,repeatDelay:Se=0,morphTo:W,clip:ke,autoplay:Je=false,duration:Ke=1e3,native:Qe=true,onProgress:ce,onStart:de,onComplete:ie}=m,_=ke===true?"left":typeof ke=="string"?ke:false,re=typeof y=="function"?y:Pe[y]??Pe.linear,Re=De($.start??"top bottom"),Ne=De($.end??"bottom top"),I=typeof $e=="string"?document.querySelector($e):$e??null,q=Array.isArray(Q)?Q[0]:null,A=Array.isArray(Q)?Q[1]:typeof Q=="string"?Q:null,O=Array.isArray(Y)?Y[0]:null,T=Array.isArray(Y)?Y[1]:typeof Y=="number"?Y:null,F=Array.isArray(Z)?Z[0]:null,P=Array.isArray(Z)?Z[1]:typeof Z=="number"?Z:null;function ne(t){let o=t*100;switch(_){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 k=_?[]:Array.from(e.querySelectorAll(S)),E=[],H=[],X=0,U=0,M=false,R=false,x=0,ye=false,z=-1,ge=-1,D=false,se=0,B=0,j,Me=null,J=new Set,he=-1,We=performance.now();function fe(){return I?N==="x"?I.scrollLeft:I.scrollTop:N==="x"?window.scrollX:window.scrollY}function qe(){return I?N==="x"?I.clientWidth:I.clientHeight:N==="x"?window.innerWidth:window.innerHeight}function He(){let t=e.getBoundingClientRect(),o,l,b;if(I){let L=I.getBoundingClientRect();o=N==="x"?t.left-L.left+I.scrollLeft:t.top-L.top+I.scrollTop,l=N==="x"?t.width:t.height,b=fe();}else o=N==="x"?t.left:t.top,l=N==="x"?t.width:t.height,b=fe();let C=Le({top:o,height:l},b,qe(),Re,Ne);X=C.tStart,U=C.tEnd,je&&process.env.NODE_ENV!=="production"&&(Me?.remove(),Me=lt(X,U,N));}function Ye(t,o){if(e.style.setProperty("--scroll-draw-progress",String(t)),_){let l=o==="reverse"?1-t:t;e.style.clipPath=ne(l);return}k.forEach((l,b)=>{l.style.strokeDashoffset=o==="reverse"?`${E[b]*t}`:`${E[b]*(1-t)}`,p&&(l.style.opacity=o==="reverse"?`${1-t}`:`${t}`),q&&A?l.style.stroke=xe(q,A,t):A&&(l.style.stroke=A),O!==null&&T!==null?l.style.strokeWidth=`${O+(T-O)*t}`:T!==null&&(l.style.strokeWidth=`${T}`),F!==null&&P!==null?l.style.fillOpacity=`${F+(P-F)*t}`:P!==null&&(l.style.fillOpacity=`${P}`),W&&l.tagName.toLowerCase()==="path"&&H[b]&&l.setAttribute("d",Ie(H[b],W,t));});}function be(){if(e.style.setProperty("--scroll-draw-progress","0"),_){e.style.clipPath=ne(0);return}k.forEach((t,o)=>{t.style.strokeDasharray=`${E[o]}`,t.style.strokeDashoffset=h==="reverse"?"0":`${E[o]}`,p?t.style.opacity=h==="reverse"?"1":"0":t.style.opacity="",q&&(t.style.stroke=q),O!==null&&(t.style.strokeWidth=`${O}`),F!==null&&(t.style.fillOpacity=`${F}`),W&&t.tagName.toLowerCase()==="path"&&H[o]&&t.setAttribute("d",H[o]);});}if(k.forEach(t=>{it(t);let o=Ee(t);E.push(o),t.tagName.toLowerCase()==="path"?H.push(t.getAttribute("d")??""):H.push(""),u?(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=h==="reverse"?`${o}`:"0",p&&(t.style.opacity="1"),A&&(t.style.stroke=A),T!==null&&(t.style.strokeWidth=`${T}`),P!==null&&(t.style.fillOpacity=`${P}`),W&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",W)):(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=h==="reverse"?"0":`${o}`,p?t.style.opacity=h==="reverse"?"1":"0":t.style.opacity="",q&&(t.style.stroke=q),O!==null&&(t.style.strokeWidth=`${O}`),F!==null&&(t.style.fillOpacity=`${F}`));}),_){if(u)return e.style.clipPath=ne(1),ie?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ne(0);}else if(u)return ie?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Ze(){return !(Qe===false||!at()||!k.length||typeof y!="string"||!(y in Xe)||_||N!=="y"||I||w!==1||V!==0||K||me||pe!==false||W||ee||te||ue>0||ce||de||ie||Q!=null||Y!=null||Z!=null||($.start??"top bottom").trim()!=="top bottom"||($.end??"bottom top").trim()!=="bottom top")}function et(){let t=`svg-scroll-draw-${++ot}`,o=h==="reverse"?"0":"var(--ssd-len)",l=h==="reverse"?"var(--ssd-len)":"0",b=`stroke-dashoffset:${o};`,C=`stroke-dashoffset:${l};`;p&&(b+=`opacity:${h==="reverse"?1:0};`,C+=`opacity:${h==="reverse"?0:1};`);let L=document.createElement("style");L.setAttribute("data-svg-scroll-draw",""),L.textContent=`@keyframes ${t}{from{${b}}to{${C}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Xe[y]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(L);function i(a,f){a.style.setProperty("--ssd-len",String(E[f])),a.style.strokeDasharray=`${E[f]}`,a.style.strokeDashoffset="",a.style.opacity="",a.style.animationPlayState="",a.classList.add(t);}k.forEach(i);let d=false,v=-1;function c(){if(v>=0)return v;let a=e.getBoundingClientRect(),{tStart:f,tEnd:g}=Le({top:a.top,height:a.height},fe(),qe(),Re,Ne);return re(ae(fe(),f,g,w))}return {destroy(){k.forEach(a=>{a.classList.remove(t),a.style.removeProperty("--ssd-len"),a.style.animationPlayState="";}),L.remove();},replay(){d=false,v=-1,k.forEach(i);},pause(){d=true,k.forEach(a=>{a.style.animationPlayState="paused";});},resume(){d&&(d=false,k.forEach(a=>{a.style.animationPlayState="running";}));},seek(a){let f=Math.min(1,Math.max(0,a));v=f,d=true,k.forEach((g,oe)=>{g.classList.remove(t),g.style.strokeDashoffset=h==="reverse"?`${E[oe]*f}`:`${E[oe]*(1-f)}`,p&&(g.style.opacity=h==="reverse"?`${1-f}`:`${f}`);});},getProgress(){return c()}}}if(Ze())return et();function tt(){let t=Math.max(1,Ke),o=0,l=0;function b(c){let a=true;if(_){let f=Math.min(1,Math.max(0,c/t)),g=re(f);se=g,e.style.setProperty("--scroll-draw-progress",String(g)),e.style.clipPath=ne(h==="reverse"?1-g:g),ce?.(g),f<1&&(a=false);}else k.forEach((f,g)=>{let oe=g*V*t,le=Math.min(1,Math.max(0,(c-oe)/t)),G=re(le);f.style.strokeDashoffset=h==="reverse"?`${E[g]*G}`:`${E[g]*(1-G)}`,p&&(f.style.opacity=h==="reverse"?`${1-G}`:`${G}`),q&&A?f.style.stroke=xe(q,A,G):A&&(f.style.stroke=A),O!==null&&T!==null?f.style.strokeWidth=`${O+(T-O)*G}`:T!==null&&(f.style.strokeWidth=`${T}`),F!==null&&P!==null?f.style.fillOpacity=`${F+(P-F)*G}`:P!==null&&(f.style.fillOpacity=`${P}`),W&&f.tagName.toLowerCase()==="path"&&H[g]&&f.setAttribute("d",Ie(H[g],W,G)),g===0&&(ce?.(G),e.style.setProperty("--scroll-draw-progress",String(G))),le<1&&(a=false);});if(ee){let f=Math.min(1,Math.max(0,c/t)),g=re(f);for(let oe in ee){let le=parseFloat(oe);g>=le&&!J.has(le)&&(J.add(le),ee[oe]?.());}}return a}function C(c){if(D)return;let a=c-o;R||(R=true,de?.());let f=b(a);if(f&&!M){M=true,b(t*(1+Math.max(0,k.length-1)*V)),ie?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{o=performance.now(),R=false,M=false,J.clear(),be(),x=requestAnimationFrame(C);},Se));return}f||(x=requestAnimationFrame(C));}function L(){cancelAnimationFrame(x),clearTimeout(j),o=performance.now(),l=0,D=false,R=false,M=false,B=0,J.clear(),be(),x=requestAnimationFrame(C);}let i=new IntersectionObserver(c=>{c.forEach(a=>{a.isIntersecting&&!(K&&M)?L():!a.isIntersecting&&!K&&!M&&(cancelAnimationFrame(x),clearTimeout(j),o=null);});},{root:I??null,threshold:Fe,rootMargin:Ce}),d;function v(){clearTimeout(d),d=setTimeout(()=>{k.forEach((c,a)=>{E[a]=Ee(c),c.style.strokeDasharray=`${E[a]}`;});},150);}return window.addEventListener("resize",v),window.addEventListener("orientationchange",v),ue>0?setTimeout(()=>i.observe(e),ue):i.observe(e),{destroy(){cancelAnimationFrame(x),clearTimeout(j),i.disconnect(),window.removeEventListener("resize",v),window.removeEventListener("orientationchange",v),clearTimeout(d);},replay(){B=0,L();},pause(){D||(D=true,l=performance.now()-o,cancelAnimationFrame(x));},resume(){D&&(D=false,o=performance.now()-l,x=requestAnimationFrame(C));},seek(c){let a=Math.min(1,Math.max(0,c));se=a,D=true,l=a*t,o=performance.now()-l,cancelAnimationFrame(x),b(l);},getProgress(){return se}}}if(Je)return tt();He();function we(){if(!ye||D)return;let t=performance.now(),o=fe(),l=w;if(pe!==false){let i=t-We,d=i>0?Math.abs(o-(he<0?o:he))/i:0;l=w*Math.max(.2,1+d*(typeof pe=="number"?pe:1)*.04);}he=o,We=t;let b=me?ge===-1||o>=ge?"forward":"reverse":h;ge=o;let C=U-X,L=true;if(_){let i=re(ae(o,X,U,l));K&&!me&&(z=Math.max(z,i),i=z),se=i,e.style.setProperty("--scroll-draw-progress",String(i));let d=b==="reverse"?1-i:i;e.style.clipPath=ne(d),ce?.(i),!R&&ae(o,X,U,l)>0&&(R=true,de?.()),i>=1&&!M?(M=true,ie?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{z=-1,R=false,M=false,e.style.clipPath=ne(0);},Se))):i<1&&!K&&(M=false),x=requestAnimationFrame(we);return}if(k.forEach((i,d)=>{let v=d*V*C,c=re(ae(o,X+v,U+v,l));K&&!me&&(z=Math.max(z,c),c=z),se=c,i.style.strokeDashoffset=b==="reverse"?`${E[d]*c}`:`${E[d]*(1-c)}`,p&&(i.style.opacity=b==="reverse"?`${1-c}`:`${c}`),q&&A?i.style.stroke=xe(q,A,c):A&&(i.style.stroke=A),O!==null&&T!==null?i.style.strokeWidth=`${O+(T-O)*c}`:T!==null&&(i.style.strokeWidth=`${T}`),F!==null&&P!==null?i.style.fillOpacity=`${F+(P-F)*c}`:P!==null&&(i.style.fillOpacity=`${P}`),W&&i.tagName.toLowerCase()==="path"&&H[d]&&i.setAttribute("d",Ie(H[d],W,c)),d===0&&(ce?.(c),e.style.setProperty("--scroll-draw-progress",String(c))),c<1&&(L=false);}),ee){let i=re(ae(o,X,U,l));for(let d in ee){let v=parseFloat(d);i>=v&&!J.has(v)&&(J.add(v),ee[d]?.());}}!R&&ae(o,X,U,l)>0&&(R=true,de?.()),L&&!M?(M=true,ie?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{z=-1,R=false,M=false,J.clear(),be();},Se))):!L&&!K&&(M=false),x=requestAnimationFrame(we);}let Ae=new IntersectionObserver(t=>{t.forEach(o=>{ye=o.isIntersecting,ye&&!D?x=requestAnimationFrame(we):cancelAnimationFrame(x);});},{root:I??null,threshold:Fe,rootMargin:Ce}),Te;function ve(){clearTimeout(Te),Te=setTimeout(()=>{k.forEach((t,o)=>{E[o]=Ee(t),t.style.strokeDasharray=`${E[o]}`;}),He();},150);}return window.addEventListener("resize",ve),window.addEventListener("orientationchange",ve),ue>0?setTimeout(()=>Ae.observe(e),ue):Ae.observe(e),{destroy(){cancelAnimationFrame(x),clearTimeout(j),Ae.disconnect(),window.removeEventListener("resize",ve),window.removeEventListener("orientationchange",ve),clearTimeout(Te),Me?.remove();},replay(){z=-1,ge=-1,he=-1,R=false,M=false,B=0,D=false,J.clear(),clearTimeout(j),be();},pause(){D=true,cancelAnimationFrame(x);},resume(){D&&(D=false,ye&&(x=requestAnimationFrame(we)));},seek(t){let o=Math.min(1,Math.max(0,t));se=o,z=o,D=true,cancelAnimationFrame(x),Ye(o,h);},getProgress(){return se}}}function Ue(e){return e.map(r=>typeof r=="string"?document.querySelector(r):r).filter(r=>r!==null)}function yt(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let n=Ue(e).map(s=>Oe(s,r));return {destroy(){n.forEach(s=>s.destroy());},replay(){n.forEach(s=>s.replay());},pause(){n.forEach(s=>s.pause());},resume(){n.forEach(s=>s.resume());},seek(s){n.forEach(m=>m.seek(s));},getProgress(){return n[0]?.getProgress()??0}}}function gt(e,r={}){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let s=Ue(e);if(s.length===0)return n;let m=0,u=[];function S(p){return Oe(s[p],{...r,once:true,onComplete(){r.onComplete?.(),m=p+1,u[m]?.resume();}})}function w(){s.forEach((p,y)=>{u[y]=S(y);});for(let p=1;p<u.length;p++)u[p].pause();}return w(),{destroy(){u.forEach(p=>p.destroy()),u.length=0;},replay(){u.forEach(p=>p.destroy()),u.length=0,m=0,w();},pause(){u[m]?.pause();},resume(){u[m]?.resume();},seek(p){u[m]?.seek(p);},getProgress(){return u[m]?.getProgress()??0}}}exports.scrollDrawGroup=yt;exports.scrollDrawSequence=gt;
1
+ 'use strict';function mt({bounces:e=3,decay:n=.5}={}){let r=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,n)),o=Math.sqrt(t),c=0,m=[];for(let g=0;g<r;g++){let x=Math.pow(o,g);m.push(x),c+=x;}let i=[0],l=0;for(let g=0;g<r;g++)l+=m[g]/c,i.push(l);return g=>{if(g<=0)return 0;if(g>=1)return 1;for(let x=0;x<r;x++)if(g<=i[x+1]){let V=(g-i[x])/(i[x+1]-i[x]);if(x===0)return V*(2-V);let E=1-Math.pow(t,x);return E+(1-E)*(2*V-1)*(2*V-1)}return 1}}function pt({amplitude:e=1,period:n=.4}={}){let r=Math.max(1,e),t=Math.max(.1,n),o=r<=1?t/4:t/(2*Math.PI)*Math.asin(1/r);return c=>c<=0?0:c>=1?1:r*Math.pow(2,-10*c)*Math.sin((c-o)*(2*Math.PI)/t)+1}var xe={linear:e=>e,"ease-in":e=>e*e,"ease-out":e=>e*(2-e),"ease-in-out":e=>e<.5?2*e*e:-1+(4-2*e)*e,spring:e=>1-Math.cos(e*Math.PI*2.5)*Math.pow(1-e,2.2),bounce:mt(),elastic:pt()};function $e(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 Ye(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 Ue(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 dt(e,n,r){return Math.min(r,Math.max(n,e))}function U(e,n,r,t){return r===n?0:dt((e-n)/(r-n)*t,0,1)}function Ae(e,n,r,t,o){let c=Ye(e.top,e.height,n,t.element)-Ue(t.viewport,r),m=Ye(e.top,e.height,n,o.element)-Ue(o.viewport,r);return {tStart:c,tEnd:m}}function Ze(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 Te(e,n,r){let t=Ze(e),o=Ze(n);return !t||!o?e:`rgb(${Math.round(t[0]+(o[0]-t[0])*r)},${Math.round(t[1]+(o[1]-t[1])*r)},${Math.round(t[2]+(o[2]-t[2])*r)})`}var Je={sketch:{easing:"ease-in",stagger:.1,speed:.9,fade:false},reveal:{easing:"ease-out",fade:true,speed:1.2,once:true},typewriter:{easing:"linear",stagger:.05,speed:1.5},cinematic:{easing:"ease-in-out",fade:true,speed:.75},spring:{easing:"spring",speed:1.1}};function Ke(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n);}var Qe={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},gt=0;function yt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function ht(e){let n=e.getAttribute("stroke"),r=e.getAttribute("fill");!n||n==="none"?Ke("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&&Ke("Element has a fill \u2014 it may obscure the stroke animation.",e);}function bt(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 o(){let c=r==="x"?window.scrollX:window.scrollY,m=e-c,i=n-c,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:${i}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${i}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",o,{passive:true}),o(),t}function _e(e,n,r){let t=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),o=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,c=>{let m=parseFloat(c),i=t[o++]??m;return String(+(m+(i-m)*r).toFixed(4))})}function Ge(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...t}=n,o=r?{...Je[r],...t}:t,c=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:m="path, polyline, line, polygon, rect, circle",speed:i=1,fade:l=false,easing:g="linear",trigger:x={},stagger:V=0,direction:E="forward",once:re=false,debug:Pe=false,axis:z="y",scrollContainer:Ee,autoReverse:L=false,delay:W=0,strokeColor:ne,strokeWidth:se,fillOpacity:oe,waypoints:ie,velocityScale:ae=false,threshold:ge=0,rootMargin:Z="0px",repeat:_=0,repeatDelay:B=0,morphTo:D,clip:J,autoplay:ve=false,duration:Me=1e3,native:ze=true,onProgress:ce,onStart:le,onComplete:K}=o,j=J===true?"left":typeof J=="string"?J:false,X=typeof g=="function"?g:xe[g]??xe.linear,ye=$e(x.start??"top bottom"),u=$e(x.end??"bottom top"),f=typeof Ee=="string"?document.querySelector(Ee):Ee??null,O=Array.isArray(ne)?ne[0]:null,S=Array.isArray(ne)?ne[1]:typeof ne=="string"?ne:null,M=Array.isArray(se)?se[0]:null,F=Array.isArray(se)?se[1]:typeof se=="number"?se:null,w=Array.isArray(oe)?oe[0]:null,A=Array.isArray(oe)?oe[1]:typeof oe=="number"?oe:null;function q(s){let a=s*100;switch(j){case "right":return `inset(0 0 0 ${100-a}%)`;case "top":return `inset(0 0 ${100-a}% 0)`;case "bottom":return `inset(${100-a}% 0 0 0)`;case "center":return `circle(${s*150}% at 50% 50%)`;default:return `inset(0 ${100-a}% 0 0)`}}let I=j?[]:Array.from(e.querySelectorAll(m)),T=[],Q=[],fe=0,me=0,N=false,Y=false,C=0,De=false,ee=-1,Ie=-1,R=false,he=0,ue=0,pe,We=null,de=new Set,Ce=-1,Be=performance.now();function ke(){return f?z==="x"?f.scrollLeft:f.scrollTop:z==="x"?window.scrollX:window.scrollY}function je(){return f?z==="x"?f.clientWidth:f.clientHeight:z==="x"?window.innerWidth:window.innerHeight}function Xe(){let s=e.getBoundingClientRect(),a,y,P;if(f){let H=f.getBoundingClientRect();a=z==="x"?s.left-H.left+f.scrollLeft:s.top-H.top+f.scrollTop,y=z==="x"?s.width:s.height,P=ke();}else a=z==="x"?s.left:s.top,y=z==="x"?s.width:s.height,P=ke();let G=Ae({top:a,height:y},P,je(),ye,u);fe=G.tStart,me=G.tEnd,Pe&&process.env.NODE_ENV!=="production"&&(We?.remove(),We=bt(fe,me,z));}function lt(s,a){if(e.style.setProperty("--scroll-draw-progress",String(s)),j){let y=a==="reverse"?1-s:s;e.style.clipPath=q(y);return}I.forEach((y,P)=>{y.style.strokeDashoffset=a==="reverse"?`${T[P]*s}`:`${T[P]*(1-s)}`,l&&(y.style.opacity=a==="reverse"?`${1-s}`:`${s}`),O&&S?y.style.stroke=Te(O,S,s):S&&(y.style.stroke=S),M!==null&&F!==null?y.style.strokeWidth=`${M+(F-M)*s}`:F!==null&&(y.style.strokeWidth=`${F}`),w!==null&&A!==null?y.style.fillOpacity=`${w+(A-w)*s}`:A!==null&&(y.style.fillOpacity=`${A}`),D&&y.tagName.toLowerCase()==="path"&&Q[P]&&y.setAttribute("d",_e(Q[P],D,s));});}function Oe(){if(e.style.setProperty("--scroll-draw-progress","0"),j){e.style.clipPath=q(0);return}I.forEach((s,a)=>{s.style.strokeDasharray=`${T[a]}`,s.style.strokeDashoffset=E==="reverse"?"0":`${T[a]}`,l?s.style.opacity=E==="reverse"?"1":"0":s.style.opacity="",O&&(s.style.stroke=O),M!==null&&(s.style.strokeWidth=`${M}`),w!==null&&(s.style.fillOpacity=`${w}`),D&&s.tagName.toLowerCase()==="path"&&Q[a]&&s.setAttribute("d",Q[a]);});}if(I.forEach(s=>{ht(s);let a=Re(s);T.push(a),s.tagName.toLowerCase()==="path"?Q.push(s.getAttribute("d")??""):Q.push(""),c?(s.style.strokeDasharray=`${a}`,s.style.strokeDashoffset=E==="reverse"?`${a}`:"0",l&&(s.style.opacity="1"),S&&(s.style.stroke=S),F!==null&&(s.style.strokeWidth=`${F}`),A!==null&&(s.style.fillOpacity=`${A}`),D&&s.tagName.toLowerCase()==="path"&&s.setAttribute("d",D)):(s.style.strokeDasharray=`${a}`,s.style.strokeDashoffset=E==="reverse"?"0":`${a}`,l?s.style.opacity=E==="reverse"?"1":"0":s.style.opacity="",O&&(s.style.stroke=O),M!==null&&(s.style.strokeWidth=`${M}`),w!==null&&(s.style.fillOpacity=`${w}`));}),j){if(c)return e.style.clipPath=q(1),K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=q(0);}else if(c)return K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function ut(){return !(ze===false||!yt()||!I.length||typeof g!="string"||!(g in Qe)||j||z!=="y"||f||i!==1||V!==0||re||L||ae!==false||D||ie||_||W>0||ce||le||K||ne!=null||se!=null||oe!=null||(x.start??"top bottom").trim()!=="top bottom"||(x.end??"bottom top").trim()!=="bottom top")}function ct(){let s=`svg-scroll-draw-${++gt}`,a=E==="reverse"?"0":"var(--ssd-len)",y=E==="reverse"?"var(--ssd-len)":"0",P=`stroke-dashoffset:${a};`,G=`stroke-dashoffset:${y};`;l&&(P+=`opacity:${E==="reverse"?1:0};`,G+=`opacity:${E==="reverse"?0:1};`);let H=document.createElement("style");H.setAttribute("data-svg-scroll-draw",""),H.textContent=`@keyframes ${s}{from{${P}}to{${G}}}.${s}{animation-name:${s};animation-duration:auto;animation-timing-function:${Qe[g]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(H);function d(p,b){p.style.setProperty("--ssd-len",String(T[b])),p.style.strokeDasharray=`${T[b]}`,p.style.strokeDashoffset="",p.style.opacity="",p.style.animationPlayState="",p.classList.add(s);}I.forEach(d);let v=false,k=-1;function h(){if(k>=0)return k;let p=e.getBoundingClientRect(),{tStart:b,tEnd:$}=Ae({top:p.top,height:p.height},ke(),je(),ye,u);return X(U(ke(),b,$,i))}return {destroy(){I.forEach(p=>{p.classList.remove(s),p.style.removeProperty("--ssd-len"),p.style.animationPlayState="";}),H.remove();},replay(){v=false,k=-1,I.forEach(d);},pause(){v=true,I.forEach(p=>{p.style.animationPlayState="paused";});},resume(){v&&(v=false,I.forEach(p=>{p.style.animationPlayState="running";}));},seek(p){let b=Math.min(1,Math.max(0,p));k=b,v=true,I.forEach(($,be)=>{$.classList.remove(s),$.style.strokeDashoffset=E==="reverse"?`${T[be]*b}`:`${T[be]*(1-b)}`,l&&($.style.opacity=E==="reverse"?`${1-b}`:`${b}`);});},getProgress(){return h()}}}if(ut())return ct();function ft(){let s=Math.max(1,Me),a=0,y=0;function P(h){let p=true;if(j){let b=Math.min(1,Math.max(0,h/s)),$=X(b);he=$,e.style.setProperty("--scroll-draw-progress",String($)),e.style.clipPath=q(E==="reverse"?1-$:$),ce?.($),b<1&&(p=false);}else I.forEach((b,$)=>{let be=$*V*s,Se=Math.min(1,Math.max(0,(h-be)/s)),te=X(Se);b.style.strokeDashoffset=E==="reverse"?`${T[$]*te}`:`${T[$]*(1-te)}`,l&&(b.style.opacity=E==="reverse"?`${1-te}`:`${te}`),O&&S?b.style.stroke=Te(O,S,te):S&&(b.style.stroke=S),M!==null&&F!==null?b.style.strokeWidth=`${M+(F-M)*te}`:F!==null&&(b.style.strokeWidth=`${F}`),w!==null&&A!==null?b.style.fillOpacity=`${w+(A-w)*te}`:A!==null&&(b.style.fillOpacity=`${A}`),D&&b.tagName.toLowerCase()==="path"&&Q[$]&&b.setAttribute("d",_e(Q[$],D,te)),$===0&&(ce?.(te),e.style.setProperty("--scroll-draw-progress",String(te))),Se<1&&(p=false);});if(ie){let b=Math.min(1,Math.max(0,h/s)),$=X(b);for(let be in ie){let Se=parseFloat(be);$>=Se&&!de.has(Se)&&(de.add(Se),ie[be]?.());}}return p}function G(h){if(R)return;let p=h-a;Y||(Y=true,le?.());let b=P(p);if(b&&!N){N=true,P(s*(1+Math.max(0,I.length-1)*V)),K?.(),ue<(_==="infinite"?1/0:_??0)&&(ue++,pe=setTimeout(()=>{a=performance.now(),Y=false,N=false,de.clear(),Oe(),C=requestAnimationFrame(G);},B));return}b||(C=requestAnimationFrame(G));}function H(){cancelAnimationFrame(C),clearTimeout(pe),a=performance.now(),y=0,R=false,Y=false,N=false,ue=0,de.clear(),Oe(),C=requestAnimationFrame(G);}let d=new IntersectionObserver(h=>{h.forEach(p=>{p.isIntersecting&&!(re&&N)?H():!p.isIntersecting&&!re&&!N&&(cancelAnimationFrame(C),clearTimeout(pe),a=null);});},{root:f??null,threshold:ge,rootMargin:Z}),v;function k(){clearTimeout(v),v=setTimeout(()=>{I.forEach((h,p)=>{T[p]=Re(h),h.style.strokeDasharray=`${T[p]}`;});},150);}return window.addEventListener("resize",k),window.addEventListener("orientationchange",k),W>0?setTimeout(()=>d.observe(e),W):d.observe(e),{destroy(){cancelAnimationFrame(C),clearTimeout(pe),d.disconnect(),window.removeEventListener("resize",k),window.removeEventListener("orientationchange",k),clearTimeout(v);},replay(){ue=0,H();},pause(){R||(R=true,y=performance.now()-a,cancelAnimationFrame(C));},resume(){R&&(R=false,a=performance.now()-y,C=requestAnimationFrame(G));},seek(h){let p=Math.min(1,Math.max(0,h));he=p,R=true,y=p*s,a=performance.now()-y,cancelAnimationFrame(C),P(y);},getProgress(){return he}}}if(ve)return ft();Xe();function Fe(){if(!De||R)return;let s=performance.now(),a=ke(),y=i;if(ae!==false){let d=s-Be,v=d>0?Math.abs(a-(Ce<0?a:Ce))/d:0;y=i*Math.max(.2,1+v*(typeof ae=="number"?ae:1)*.04);}Ce=a,Be=s;let P=L?Ie===-1||a>=Ie?"forward":"reverse":E;Ie=a;let G=me-fe,H=true;if(j){let d=X(U(a,fe,me,y));re&&!L&&(ee=Math.max(ee,d),d=ee),he=d,e.style.setProperty("--scroll-draw-progress",String(d));let v=P==="reverse"?1-d:d;e.style.clipPath=q(v),ce?.(d),!Y&&U(a,fe,me,y)>0&&(Y=true,le?.()),d>=1&&!N?(N=true,K?.(),ue<(_==="infinite"?1/0:_??0)&&(ue++,pe=setTimeout(()=>{ee=-1,Y=false,N=false,e.style.clipPath=q(0);},B))):d<1&&!re&&(N=false),C=requestAnimationFrame(Fe);return}if(I.forEach((d,v)=>{let k=v*V*G,h=X(U(a,fe+k,me+k,y));re&&!L&&(ee=Math.max(ee,h),h=ee),he=h,d.style.strokeDashoffset=P==="reverse"?`${T[v]*h}`:`${T[v]*(1-h)}`,l&&(d.style.opacity=P==="reverse"?`${1-h}`:`${h}`),O&&S?d.style.stroke=Te(O,S,h):S&&(d.style.stroke=S),M!==null&&F!==null?d.style.strokeWidth=`${M+(F-M)*h}`:F!==null&&(d.style.strokeWidth=`${F}`),w!==null&&A!==null?d.style.fillOpacity=`${w+(A-w)*h}`:A!==null&&(d.style.fillOpacity=`${A}`),D&&d.tagName.toLowerCase()==="path"&&Q[v]&&d.setAttribute("d",_e(Q[v],D,h)),v===0&&(ce?.(h),e.style.setProperty("--scroll-draw-progress",String(h))),h<1&&(H=false);}),ie){let d=X(U(a,fe,me,y));for(let v in ie){let k=parseFloat(v);d>=k&&!de.has(k)&&(de.add(k),ie[v]?.());}}!Y&&U(a,fe,me,y)>0&&(Y=true,le?.()),H&&!N?(N=true,K?.(),ue<(_==="infinite"?1/0:_??0)&&(ue++,pe=setTimeout(()=>{ee=-1,Y=false,N=false,de.clear(),Oe();},B))):!H&&!re&&(N=false),C=requestAnimationFrame(Fe);}let qe=new IntersectionObserver(s=>{s.forEach(a=>{De=a.isIntersecting,De&&!R?C=requestAnimationFrame(Fe):cancelAnimationFrame(C);});},{root:f??null,threshold:ge,rootMargin:Z}),Ve;function Ne(){clearTimeout(Ve),Ve=setTimeout(()=>{I.forEach((s,a)=>{T[a]=Re(s),s.style.strokeDasharray=`${T[a]}`;}),Xe();},150);}return window.addEventListener("resize",Ne),window.addEventListener("orientationchange",Ne),W>0?setTimeout(()=>qe.observe(e),W):qe.observe(e),{destroy(){cancelAnimationFrame(C),clearTimeout(pe),qe.disconnect(),window.removeEventListener("resize",Ne),window.removeEventListener("orientationchange",Ne),clearTimeout(Ve),We?.remove();},replay(){ee=-1,Ie=-1,Ce=-1,Y=false,N=false,ue=0,R=false,de.clear(),clearTimeout(pe),Oe();},pause(){R=true,cancelAnimationFrame(C);},resume(){R&&(R=false,De&&(C=requestAnimationFrame(Fe)));},seek(s){let a=Math.min(1,Math.max(0,s));he=a,ee=a,R=true,cancelAnimationFrame(C),lt(a,E);},getProgress(){return he}}}var et=new Map;function tt(e,n){et.set(e,n);}function rt(e){et.delete(e);}function wt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function nt(e){let n=[],r=/([\w]+)\(([^)]*)\)/g,t;for(;(t=r.exec(e))!==null;){let o=[],c=[],m=t[2].trim();if(m)for(let i of m.split(/[\s,]+/)){let l=i.match(/^([-+]?[\d.eE]+)(.*)$/);o.push(l?parseFloat(l[1]):0),c.push(l?l[2]:"");}n.push({fn:t[1],nums:o,units:c});}return n}function Et(e,n,r){let t=nt(e),o=nt(n);return t.length===0||t.length!==o.length?r<1?e:n:t.map((c,m)=>{let i=o[m];return c.fn!==i.fn||c.nums.length!==i.nums.length?r<1?`${c.fn}(${c.nums.map((l,g)=>`${l}${c.units[g]}`).join(", ")})`:`${i.fn}(${i.nums.map((l,g)=>`${l}${i.units[g]}`).join(", ")})`:`${c.fn}(${c.nums.map((l,g)=>`${l+(i.nums[g]-l)*r}${c.units[g]}`).join(", ")})`}).join(" ")}function st(e,n,r){if(typeof e=="number"&&typeof n=="number")return String(e+(n-e)*r);let t=String(e),o=String(n);if(wt(t))return Te(t,o,r);if(t.includes("("))return Et(t,o,r);let c=t.match(/^([-+]?[\d.]+)(.*)$/),m=o.match(/^([-+]?[\d.]+)(.*)$/);if(c&&m){let i=parseFloat(c[1]),l=parseFloat(m[1]);return `${i+(l-i)*r}${c[2]||m[2]}`}return r<1?t:o}function vt(e){return e.replace(/([A-Z])/g,n=>`-${n.toLowerCase()}`)}var ot={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},St=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),xt=0;function $t(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function He(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let{props:t,trigger:o={},easing:c="ease-out",speed:m=1,once:i=false,axis:l="y",scrollContainer:g,native:x=true,onProgress:V,onComplete:E}=n,re=window.matchMedia("(prefers-reduced-motion: reduce)").matches,Pe=typeof c=="function"?c:xe[c]??xe["ease-out"],z=$e(o.start??"top bottom"),Ee=$e(o.end??"bottom top"),L=typeof g=="string"?document.querySelector(g):g??null,W=Object.entries(t).map(([u,f])=>({prop:vt(u),from:Array.isArray(f)?f[0]:"",to:Array.isArray(f)?f[1]:f}));function ne(){let u=window.getComputedStyle(e);for(let f of W)f.from===""&&(f.from=u.getPropertyValue(f.prop).trim()||"0");}function se(){for(let u of W)e.style.setProperty(u.prop,String(u.to));}if(re)return se(),E?.(),r;ne();function oe(){if(!x||!$t()||typeof c!="string"||!(c in ot)||l!=="y"||L||i||m!==1||V||E||(o.start??"top bottom").trim()!=="top bottom"||(o.end??"bottom top").trim()!=="bottom top")return false;for(let u of W)if(!St.has(u.prop))return false;return true}function ie(){let u=`ssd-a-${++xt}`,f=W.map(w=>`${w.prop}:${w.from}`).join(";"),O=W.map(w=>`${w.prop}:${w.to}`).join(";"),S=document.createElement("style");S.setAttribute("data-ssd-animate",""),S.textContent=`@keyframes ${u}{from{${f}}to{${O}}}.${u}{animation-name:${u};animation-duration:auto;animation-timing-function:${ot[c]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(S),e.classList.add(u);let M=()=>l==="x"?window.scrollX:window.scrollY,F=()=>l==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(u),S.remove();},replay(){e.classList.remove(u),e.offsetWidth,e.classList.add(u);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(w){let A=Math.min(1,Math.max(0,w));e.classList.remove(u);for(let q of W)e.style.setProperty(q.prop,st(q.from,q.to,A));},getProgress(){let w=e.getBoundingClientRect(),A=M(),q=F(),{tStart:I,tEnd:T}=Ae({top:w.top,height:w.height},A,q,z,Ee);return Pe(U(A,I,T,m))}}}if(oe())return ie();let ae=0,ge=0,Z=0,_=false,B=false,D=-1,J=0,ve=false,Me=()=>L?l==="x"?L.scrollLeft:L.scrollTop:l==="x"?window.scrollX:window.scrollY,ze=()=>L?l==="x"?L.clientWidth:L.clientHeight:l==="x"?window.innerWidth:window.innerHeight;function ce(){let u=e.getBoundingClientRect(),f,O;if(L){let M=L.getBoundingClientRect();f=l==="x"?u.left-M.left+L.scrollLeft:u.top-M.top+L.scrollTop,O=l==="x"?u.width:u.height;}else f=l==="x"?u.left:u.top,O=l==="x"?u.width:u.height;let S=Ae({top:f,height:O},Me(),ze(),z,Ee);ae=S.tStart,ge=S.tEnd;}function le(u){e.style.setProperty("--scroll-draw-progress",String(u));for(let f of W)e.style.setProperty(f.prop,st(f.from,f.to,u));V?.(u);}function K(){if(!_||B)return;let u=Pe(U(Me(),ae,ge,m));i&&(D=Math.max(D,u),u=D),J=u,le(u),u>=1&&!ve?(ve=true,E?.()):u<1&&!i&&(ve=false),Z=requestAnimationFrame(K);}ce();{let u=Pe(U(Me(),ae,ge,m));i&&u>0&&(D=u),J=u,le(u);}let j=new IntersectionObserver(u=>{u.forEach(f=>{_=f.isIntersecting,_&&!B?Z=requestAnimationFrame(K):cancelAnimationFrame(Z);});},{root:L??null}),X;function ye(){clearTimeout(X),X=setTimeout(ce,150);}return window.addEventListener("resize",ye),window.addEventListener("orientationchange",ye),j.observe(e),tt(e,{type:"animate",getProgress:()=>J,getTrigger:()=>({tStart:ae,tEnd:ge})}),{destroy(){cancelAnimationFrame(Z),j.disconnect(),window.removeEventListener("resize",ye),window.removeEventListener("orientationchange",ye),clearTimeout(X),rt(e);},replay(){D=-1,ve=false,J=0,B=false,le(0);},pause(){B=true,cancelAnimationFrame(Z);},resume(){B&&(B=false,_&&(Z=requestAnimationFrame(K)));},seek(u){let f=Math.min(1,Math.max(0,u));J=f,D=f,B=true,cancelAnimationFrame(Z),le(f);},getProgress(){return J}}}var it={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function at(e,n={}){if(typeof window>"u")return it;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollParallax: element not found:",e),it;let{speed:t=.3,axis:o="y",easing:c="linear",trigger:m,onProgress:i}=n,l=r.getBoundingClientRect(),g=o==="x"?l.width:l.height,x=t*g;return He(r,{props:o==="x"?{transform:["translateX(0px)",`translateX(${-x}px)`]}:{transform:["translateY(0px)",`translateY(${-x}px)`]},trigger:m??{start:"top bottom",end:"bottom top"},easing:c,native:false,onProgress:i})}function Le(e){return e.map(n=>typeof n=="string"?document.querySelector(n):n).filter(n=>n!==null)}var we={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Nt(e,n={}){if(typeof window>"u")return we;let r=Le(e).map(t=>Ge(t,n));return {destroy(){r.forEach(t=>t.destroy());},replay(){r.forEach(t=>t.replay());},pause(){r.forEach(t=>t.pause());},resume(){r.forEach(t=>t.resume());},seek(t){r.forEach(o=>o.seek(t));},getProgress(){return r[0]?.getProgress()??0}}}function Rt(e,n={}){if(typeof window>"u")return we;let r=Le(e);if(r.length===0)return we;let t=0,o=[];function c(i){return Ge(r[i],{...n,once:true,onComplete(){n.onComplete?.(),t=i+1,o[t]?.resume();}})}function m(){r.forEach((i,l)=>{o[l]=c(l);});for(let i=1;i<o.length;i++)o[i].pause();}return m(),{destroy(){o.forEach(i=>i.destroy()),o.length=0;},replay(){o.forEach(i=>i.destroy()),o.length=0,t=0,m();},pause(){o[t]?.pause();},resume(){o[t]?.resume();},seek(i){o[t]?.seek(i);},getProgress(){return o[t]?.getProgress()??0}}}function Ht(e,n){if(typeof window>"u")return we;let r=Le(e).map(t=>He(t,n));return {destroy(){r.forEach(t=>t.destroy());},replay(){r.forEach(t=>t.replay());},pause(){r.forEach(t=>t.pause());},resume(){r.forEach(t=>t.resume());},seek(t){r.forEach(o=>o.seek(t));},getProgress(){return r[0]?.getProgress()??0}}}function zt(e,n){if(typeof window>"u")return we;let r=Le(e);if(r.length===0)return we;let t=0,o=[];function c(i){return He(r[i],{...n,once:true,onComplete(){n.onComplete?.(),t=i+1,o[t]?.resume();}})}function m(){r.forEach((i,l)=>{o[l]=c(l);});for(let i=1;i<o.length;i++)o[i].pause();}return m(),{destroy(){o.forEach(i=>i.destroy()),o.length=0;},replay(){o.forEach(i=>i.destroy()),o.length=0,t=0,m();},pause(){o[t]?.pause();},resume(){o[t]?.resume();},seek(i){o[t]?.seek(i);},getProgress(){return o[t]?.getProgress()??0}}}function Wt(e,n={}){if(typeof window>"u")return we;let r=Le(e).map(t=>at(t,n));return {destroy(){r.forEach(t=>t.destroy());},replay(){r.forEach(t=>t.replay());},pause(){r.forEach(t=>t.pause());},resume(){r.forEach(t=>t.resume());},seek(t){r.forEach(o=>o.seek(t));},getProgress(){return r[0]?.getProgress()??0}}}exports.scrollAnimateGroup=Ht;exports.scrollAnimateSequence=zt;exports.scrollDrawGroup=Nt;exports.scrollDrawSequence=Rt;exports.scrollParallaxGroup=Wt;
@@ -119,6 +119,26 @@ interface ScrollDrawInstance {
119
119
  getProgress: () => number;
120
120
  }
121
121
 
122
+ interface ScrollAnimateOptions {
123
+ props: Record<string, string | number | [string | number, string | number]>;
124
+ trigger?: TriggerConfig;
125
+ easing?: EasingName | ((t: number) => number);
126
+ speed?: number;
127
+ once?: boolean;
128
+ axis?: 'x' | 'y';
129
+ scrollContainer?: string | Element;
130
+ native?: boolean;
131
+ onProgress?: (alpha: number) => void;
132
+ onComplete?: () => void;
133
+ }
134
+ interface ScrollParallaxOptions {
135
+ speed?: number;
136
+ axis?: 'x' | 'y';
137
+ easing?: EasingName | ((t: number) => number);
138
+ trigger?: TriggerConfig;
139
+ onProgress?: (alpha: number) => void;
140
+ }
141
+
122
142
  /**
123
143
  * Animate multiple SVG containers simultaneously with the same options.
124
144
  * Each container tracks its own scroll position independently.
@@ -152,5 +172,56 @@ declare function scrollDrawGroup(targets: Array<string | Element>, options?: Scr
152
172
  * });
153
173
  */
154
174
  declare function scrollDrawSequence(targets: Array<string | Element>, options?: ScrollDrawOptions): ScrollDrawInstance;
175
+ /**
176
+ * Animate multiple HTML/SVG elements simultaneously with scrollAnimate options.
177
+ * Each element tracks its own scroll position independently. Perfect for
178
+ * staggered card reveals, feature grids, or any multi-element entrance.
179
+ *
180
+ * @example
181
+ * import { scrollAnimateGroup } from 'svg-scroll-draw/group';
182
+ *
183
+ * const group = scrollAnimateGroup(
184
+ * [card1El, card2El, card3El],
185
+ * {
186
+ * props: { opacity: [0, 1], transform: ['translateY(40px)', 'translateY(0)'] },
187
+ * easing: 'ease-out',
188
+ * once: true,
189
+ * }
190
+ * );
191
+ *
192
+ * group.replay();
193
+ * group.destroy();
194
+ */
195
+ declare function scrollAnimateGroup(targets: Array<string | Element>, options: ScrollAnimateOptions): ScrollDrawInstance;
196
+ /**
197
+ * Fan-out scrollAnimate in sequence — each element starts animating only after
198
+ * the previous one has reached 100%. Useful for step-by-step reveals.
199
+ *
200
+ * @example
201
+ * import { scrollAnimateSequence } from 'svg-scroll-draw/group';
202
+ *
203
+ * scrollAnimateSequence(
204
+ * [step1El, step2El, step3El],
205
+ * {
206
+ * props: { opacity: [0, 1], transform: ['translateY(32px)', 'translateY(0)'] },
207
+ * easing: 'ease-out',
208
+ * }
209
+ * );
210
+ */
211
+ declare function scrollAnimateSequence(targets: Array<string | Element>, options: ScrollAnimateOptions): ScrollDrawInstance;
212
+ /**
213
+ * Apply a parallax effect to multiple elements simultaneously.
214
+ * Each element moves at `speed × elementHeight` pixels independently.
215
+ *
216
+ * @example
217
+ * import { scrollParallaxGroup } from 'svg-scroll-draw/group';
218
+ *
219
+ * // Three background layers at the same speed
220
+ * scrollParallaxGroup(['#layer-far', '#layer-mid', '#layer-near'], { speed: 0.4 });
221
+ *
222
+ * // Opposite direction (floats upward as you scroll down)
223
+ * scrollParallaxGroup(['#badge', '#tag'], { speed: -0.2 });
224
+ */
225
+ declare function scrollParallaxGroup(targets: Array<string | Element>, options?: ScrollParallaxOptions): ScrollDrawInstance;
155
226
 
156
- export { type ScrollDrawOptions, scrollDrawGroup, scrollDrawSequence };
227
+ export { type ScrollAnimateOptions, type ScrollDrawOptions, type ScrollParallaxOptions, scrollAnimateGroup, scrollAnimateSequence, scrollDrawGroup, scrollDrawSequence, scrollParallaxGroup };
@@ -119,6 +119,26 @@ interface ScrollDrawInstance {
119
119
  getProgress: () => number;
120
120
  }
121
121
 
122
+ interface ScrollAnimateOptions {
123
+ props: Record<string, string | number | [string | number, string | number]>;
124
+ trigger?: TriggerConfig;
125
+ easing?: EasingName | ((t: number) => number);
126
+ speed?: number;
127
+ once?: boolean;
128
+ axis?: 'x' | 'y';
129
+ scrollContainer?: string | Element;
130
+ native?: boolean;
131
+ onProgress?: (alpha: number) => void;
132
+ onComplete?: () => void;
133
+ }
134
+ interface ScrollParallaxOptions {
135
+ speed?: number;
136
+ axis?: 'x' | 'y';
137
+ easing?: EasingName | ((t: number) => number);
138
+ trigger?: TriggerConfig;
139
+ onProgress?: (alpha: number) => void;
140
+ }
141
+
122
142
  /**
123
143
  * Animate multiple SVG containers simultaneously with the same options.
124
144
  * Each container tracks its own scroll position independently.
@@ -152,5 +172,56 @@ declare function scrollDrawGroup(targets: Array<string | Element>, options?: Scr
152
172
  * });
153
173
  */
154
174
  declare function scrollDrawSequence(targets: Array<string | Element>, options?: ScrollDrawOptions): ScrollDrawInstance;
175
+ /**
176
+ * Animate multiple HTML/SVG elements simultaneously with scrollAnimate options.
177
+ * Each element tracks its own scroll position independently. Perfect for
178
+ * staggered card reveals, feature grids, or any multi-element entrance.
179
+ *
180
+ * @example
181
+ * import { scrollAnimateGroup } from 'svg-scroll-draw/group';
182
+ *
183
+ * const group = scrollAnimateGroup(
184
+ * [card1El, card2El, card3El],
185
+ * {
186
+ * props: { opacity: [0, 1], transform: ['translateY(40px)', 'translateY(0)'] },
187
+ * easing: 'ease-out',
188
+ * once: true,
189
+ * }
190
+ * );
191
+ *
192
+ * group.replay();
193
+ * group.destroy();
194
+ */
195
+ declare function scrollAnimateGroup(targets: Array<string | Element>, options: ScrollAnimateOptions): ScrollDrawInstance;
196
+ /**
197
+ * Fan-out scrollAnimate in sequence — each element starts animating only after
198
+ * the previous one has reached 100%. Useful for step-by-step reveals.
199
+ *
200
+ * @example
201
+ * import { scrollAnimateSequence } from 'svg-scroll-draw/group';
202
+ *
203
+ * scrollAnimateSequence(
204
+ * [step1El, step2El, step3El],
205
+ * {
206
+ * props: { opacity: [0, 1], transform: ['translateY(32px)', 'translateY(0)'] },
207
+ * easing: 'ease-out',
208
+ * }
209
+ * );
210
+ */
211
+ declare function scrollAnimateSequence(targets: Array<string | Element>, options: ScrollAnimateOptions): ScrollDrawInstance;
212
+ /**
213
+ * Apply a parallax effect to multiple elements simultaneously.
214
+ * Each element moves at `speed × elementHeight` pixels independently.
215
+ *
216
+ * @example
217
+ * import { scrollParallaxGroup } from 'svg-scroll-draw/group';
218
+ *
219
+ * // Three background layers at the same speed
220
+ * scrollParallaxGroup(['#layer-far', '#layer-mid', '#layer-near'], { speed: 0.4 });
221
+ *
222
+ * // Opposite direction (floats upward as you scroll down)
223
+ * scrollParallaxGroup(['#badge', '#tag'], { speed: -0.2 });
224
+ */
225
+ declare function scrollParallaxGroup(targets: Array<string | Element>, options?: ScrollParallaxOptions): ScrollDrawInstance;
155
226
 
156
- export { type ScrollDrawOptions, scrollDrawGroup, scrollDrawSequence };
227
+ export { type ScrollAnimateOptions, type ScrollDrawOptions, type ScrollParallaxOptions, scrollAnimateGroup, scrollAnimateSequence, scrollDrawGroup, scrollDrawSequence, scrollParallaxGroup };
@@ -1,3 +1,3 @@
1
- function rt({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),s=Math.max(.01,Math.min(.99,r)),m=Math.sqrt(s),u=0,S=[];for(let y=0;y<n;y++){let $=Math.pow(m,y);S.push($),u+=$;}let w=[0],p=0;for(let y=0;y<n;y++)p+=S[y]/u,w.push(p);return y=>{if(y<=0)return 0;if(y>=1)return 1;for(let $=0;$<n;$++)if(y<=w[$+1]){let V=(y-w[$])/(w[$+1]-w[$]);if($===0)return V*(2-V);let h=1-Math.pow(s,$);return h+(1-h)*(2*V-1)*(2*V-1)}return 1}}function nt({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),s=Math.max(.1,r),m=n<=1?s/4:s/(2*Math.PI)*Math.asin(1/n);return u=>u<=0?0:u>=1?1:n*Math.pow(2,-10*u)*Math.sin((u-m)*(2*Math.PI)/s)+1}var Pe={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:rt(),elastic:nt()};function De(e="top bottom"){let r=e.trim();if(/^\d+(\.\d+)?%$/.test(r))return {element:"top",viewport:r};let[n="top",s="bottom"]=r.split(/\s+/).filter(Boolean);return {element:n,viewport:s}}function ze(e,r,n,s){switch(s){case "top":return e+n;case "center":return e+n+r/2;case "bottom":return e+n+r;default:return e+n}}function Ge(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 Ee(e){let r=e.tagName.toLowerCase();if(r==="rect"){let n=parseFloat(e.getAttribute("width")??"0"),s=parseFloat(e.getAttribute("height")??"0");return 2*(n+s)}if(r==="circle"){let n=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*n}return e.getTotalLength()}function st(e,r,n){return Math.min(n,Math.max(r,e))}function ae(e,r,n,s){return n===r?0:st((e-r)/(n-r)*s,0,1)}function Le(e,r,n,s,m){let u=ze(e.top,e.height,r,s.element)-Ge(s.viewport,n),S=ze(e.top,e.height,r,m.element)-Ge(m.viewport,n);return {tStart:u,tEnd:S}}function Ve(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 s=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return s?[parseInt(s[1]),parseInt(s[2]),parseInt(s[3])]:null}function xe(e,r,n){let s=Ve(e),m=Ve(r);return !s||!m?e:`rgb(${Math.round(s[0]+(m[0]-s[0])*n)},${Math.round(s[1]+(m[1]-s[1])*n)},${Math.round(s[2]+(m[2]-s[2])*n)})`}var Be={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 _e(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r);}var Xe={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},ot=0;function at(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function it(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?_e("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&_e("Element has a fill \u2014 it may obscure the stroke animation.",e);}function lt(e,r,n){let s=document.createElement("div");s.setAttribute("data-svg-scroll-draw-debug",""),s.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function m(){let u=n==="x"?window.scrollX:window.scrollY,S=e-u,w=r-u,p=n==="x";s.innerHTML=`
2
- <div style="position:absolute;${p?`left:${S}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${S}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;${p?`left:${w}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${w}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",m,{passive:true}),m(),s}function Ie(e,r,n){let s=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),m=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,u=>{let S=parseFloat(u),w=s[m++]??S;return String(+(S+(w-S)*n).toFixed(4))})}function Oe(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:n,...s}=r,m=n?{...Be[n],...s}:s,u=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:S="path, polyline, line, polygon, rect, circle",speed:w=1,fade:p=false,easing:y="linear",trigger:$={},stagger:V=0,direction:h="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:Fe=0,rootMargin:Ce="0px",repeat:te=0,repeatDelay:Se=0,morphTo:W,clip:ke,autoplay:Je=false,duration:Ke=1e3,native:Qe=true,onProgress:ce,onStart:de,onComplete:ie}=m,_=ke===true?"left":typeof ke=="string"?ke:false,re=typeof y=="function"?y:Pe[y]??Pe.linear,Re=De($.start??"top bottom"),Ne=De($.end??"bottom top"),I=typeof $e=="string"?document.querySelector($e):$e??null,q=Array.isArray(Q)?Q[0]:null,A=Array.isArray(Q)?Q[1]:typeof Q=="string"?Q:null,O=Array.isArray(Y)?Y[0]:null,T=Array.isArray(Y)?Y[1]:typeof Y=="number"?Y:null,F=Array.isArray(Z)?Z[0]:null,P=Array.isArray(Z)?Z[1]:typeof Z=="number"?Z:null;function ne(t){let o=t*100;switch(_){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 k=_?[]:Array.from(e.querySelectorAll(S)),E=[],H=[],X=0,U=0,M=false,R=false,x=0,ye=false,z=-1,ge=-1,D=false,se=0,B=0,j,Me=null,J=new Set,he=-1,We=performance.now();function fe(){return I?N==="x"?I.scrollLeft:I.scrollTop:N==="x"?window.scrollX:window.scrollY}function qe(){return I?N==="x"?I.clientWidth:I.clientHeight:N==="x"?window.innerWidth:window.innerHeight}function He(){let t=e.getBoundingClientRect(),o,l,b;if(I){let L=I.getBoundingClientRect();o=N==="x"?t.left-L.left+I.scrollLeft:t.top-L.top+I.scrollTop,l=N==="x"?t.width:t.height,b=fe();}else o=N==="x"?t.left:t.top,l=N==="x"?t.width:t.height,b=fe();let C=Le({top:o,height:l},b,qe(),Re,Ne);X=C.tStart,U=C.tEnd,je&&process.env.NODE_ENV!=="production"&&(Me?.remove(),Me=lt(X,U,N));}function Ye(t,o){if(e.style.setProperty("--scroll-draw-progress",String(t)),_){let l=o==="reverse"?1-t:t;e.style.clipPath=ne(l);return}k.forEach((l,b)=>{l.style.strokeDashoffset=o==="reverse"?`${E[b]*t}`:`${E[b]*(1-t)}`,p&&(l.style.opacity=o==="reverse"?`${1-t}`:`${t}`),q&&A?l.style.stroke=xe(q,A,t):A&&(l.style.stroke=A),O!==null&&T!==null?l.style.strokeWidth=`${O+(T-O)*t}`:T!==null&&(l.style.strokeWidth=`${T}`),F!==null&&P!==null?l.style.fillOpacity=`${F+(P-F)*t}`:P!==null&&(l.style.fillOpacity=`${P}`),W&&l.tagName.toLowerCase()==="path"&&H[b]&&l.setAttribute("d",Ie(H[b],W,t));});}function be(){if(e.style.setProperty("--scroll-draw-progress","0"),_){e.style.clipPath=ne(0);return}k.forEach((t,o)=>{t.style.strokeDasharray=`${E[o]}`,t.style.strokeDashoffset=h==="reverse"?"0":`${E[o]}`,p?t.style.opacity=h==="reverse"?"1":"0":t.style.opacity="",q&&(t.style.stroke=q),O!==null&&(t.style.strokeWidth=`${O}`),F!==null&&(t.style.fillOpacity=`${F}`),W&&t.tagName.toLowerCase()==="path"&&H[o]&&t.setAttribute("d",H[o]);});}if(k.forEach(t=>{it(t);let o=Ee(t);E.push(o),t.tagName.toLowerCase()==="path"?H.push(t.getAttribute("d")??""):H.push(""),u?(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=h==="reverse"?`${o}`:"0",p&&(t.style.opacity="1"),A&&(t.style.stroke=A),T!==null&&(t.style.strokeWidth=`${T}`),P!==null&&(t.style.fillOpacity=`${P}`),W&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",W)):(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=h==="reverse"?"0":`${o}`,p?t.style.opacity=h==="reverse"?"1":"0":t.style.opacity="",q&&(t.style.stroke=q),O!==null&&(t.style.strokeWidth=`${O}`),F!==null&&(t.style.fillOpacity=`${F}`));}),_){if(u)return e.style.clipPath=ne(1),ie?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ne(0);}else if(u)return ie?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Ze(){return !(Qe===false||!at()||!k.length||typeof y!="string"||!(y in Xe)||_||N!=="y"||I||w!==1||V!==0||K||me||pe!==false||W||ee||te||ue>0||ce||de||ie||Q!=null||Y!=null||Z!=null||($.start??"top bottom").trim()!=="top bottom"||($.end??"bottom top").trim()!=="bottom top")}function et(){let t=`svg-scroll-draw-${++ot}`,o=h==="reverse"?"0":"var(--ssd-len)",l=h==="reverse"?"var(--ssd-len)":"0",b=`stroke-dashoffset:${o};`,C=`stroke-dashoffset:${l};`;p&&(b+=`opacity:${h==="reverse"?1:0};`,C+=`opacity:${h==="reverse"?0:1};`);let L=document.createElement("style");L.setAttribute("data-svg-scroll-draw",""),L.textContent=`@keyframes ${t}{from{${b}}to{${C}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Xe[y]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(L);function i(a,f){a.style.setProperty("--ssd-len",String(E[f])),a.style.strokeDasharray=`${E[f]}`,a.style.strokeDashoffset="",a.style.opacity="",a.style.animationPlayState="",a.classList.add(t);}k.forEach(i);let d=false,v=-1;function c(){if(v>=0)return v;let a=e.getBoundingClientRect(),{tStart:f,tEnd:g}=Le({top:a.top,height:a.height},fe(),qe(),Re,Ne);return re(ae(fe(),f,g,w))}return {destroy(){k.forEach(a=>{a.classList.remove(t),a.style.removeProperty("--ssd-len"),a.style.animationPlayState="";}),L.remove();},replay(){d=false,v=-1,k.forEach(i);},pause(){d=true,k.forEach(a=>{a.style.animationPlayState="paused";});},resume(){d&&(d=false,k.forEach(a=>{a.style.animationPlayState="running";}));},seek(a){let f=Math.min(1,Math.max(0,a));v=f,d=true,k.forEach((g,oe)=>{g.classList.remove(t),g.style.strokeDashoffset=h==="reverse"?`${E[oe]*f}`:`${E[oe]*(1-f)}`,p&&(g.style.opacity=h==="reverse"?`${1-f}`:`${f}`);});},getProgress(){return c()}}}if(Ze())return et();function tt(){let t=Math.max(1,Ke),o=0,l=0;function b(c){let a=true;if(_){let f=Math.min(1,Math.max(0,c/t)),g=re(f);se=g,e.style.setProperty("--scroll-draw-progress",String(g)),e.style.clipPath=ne(h==="reverse"?1-g:g),ce?.(g),f<1&&(a=false);}else k.forEach((f,g)=>{let oe=g*V*t,le=Math.min(1,Math.max(0,(c-oe)/t)),G=re(le);f.style.strokeDashoffset=h==="reverse"?`${E[g]*G}`:`${E[g]*(1-G)}`,p&&(f.style.opacity=h==="reverse"?`${1-G}`:`${G}`),q&&A?f.style.stroke=xe(q,A,G):A&&(f.style.stroke=A),O!==null&&T!==null?f.style.strokeWidth=`${O+(T-O)*G}`:T!==null&&(f.style.strokeWidth=`${T}`),F!==null&&P!==null?f.style.fillOpacity=`${F+(P-F)*G}`:P!==null&&(f.style.fillOpacity=`${P}`),W&&f.tagName.toLowerCase()==="path"&&H[g]&&f.setAttribute("d",Ie(H[g],W,G)),g===0&&(ce?.(G),e.style.setProperty("--scroll-draw-progress",String(G))),le<1&&(a=false);});if(ee){let f=Math.min(1,Math.max(0,c/t)),g=re(f);for(let oe in ee){let le=parseFloat(oe);g>=le&&!J.has(le)&&(J.add(le),ee[oe]?.());}}return a}function C(c){if(D)return;let a=c-o;R||(R=true,de?.());let f=b(a);if(f&&!M){M=true,b(t*(1+Math.max(0,k.length-1)*V)),ie?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{o=performance.now(),R=false,M=false,J.clear(),be(),x=requestAnimationFrame(C);},Se));return}f||(x=requestAnimationFrame(C));}function L(){cancelAnimationFrame(x),clearTimeout(j),o=performance.now(),l=0,D=false,R=false,M=false,B=0,J.clear(),be(),x=requestAnimationFrame(C);}let i=new IntersectionObserver(c=>{c.forEach(a=>{a.isIntersecting&&!(K&&M)?L():!a.isIntersecting&&!K&&!M&&(cancelAnimationFrame(x),clearTimeout(j),o=null);});},{root:I??null,threshold:Fe,rootMargin:Ce}),d;function v(){clearTimeout(d),d=setTimeout(()=>{k.forEach((c,a)=>{E[a]=Ee(c),c.style.strokeDasharray=`${E[a]}`;});},150);}return window.addEventListener("resize",v),window.addEventListener("orientationchange",v),ue>0?setTimeout(()=>i.observe(e),ue):i.observe(e),{destroy(){cancelAnimationFrame(x),clearTimeout(j),i.disconnect(),window.removeEventListener("resize",v),window.removeEventListener("orientationchange",v),clearTimeout(d);},replay(){B=0,L();},pause(){D||(D=true,l=performance.now()-o,cancelAnimationFrame(x));},resume(){D&&(D=false,o=performance.now()-l,x=requestAnimationFrame(C));},seek(c){let a=Math.min(1,Math.max(0,c));se=a,D=true,l=a*t,o=performance.now()-l,cancelAnimationFrame(x),b(l);},getProgress(){return se}}}if(Je)return tt();He();function we(){if(!ye||D)return;let t=performance.now(),o=fe(),l=w;if(pe!==false){let i=t-We,d=i>0?Math.abs(o-(he<0?o:he))/i:0;l=w*Math.max(.2,1+d*(typeof pe=="number"?pe:1)*.04);}he=o,We=t;let b=me?ge===-1||o>=ge?"forward":"reverse":h;ge=o;let C=U-X,L=true;if(_){let i=re(ae(o,X,U,l));K&&!me&&(z=Math.max(z,i),i=z),se=i,e.style.setProperty("--scroll-draw-progress",String(i));let d=b==="reverse"?1-i:i;e.style.clipPath=ne(d),ce?.(i),!R&&ae(o,X,U,l)>0&&(R=true,de?.()),i>=1&&!M?(M=true,ie?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{z=-1,R=false,M=false,e.style.clipPath=ne(0);},Se))):i<1&&!K&&(M=false),x=requestAnimationFrame(we);return}if(k.forEach((i,d)=>{let v=d*V*C,c=re(ae(o,X+v,U+v,l));K&&!me&&(z=Math.max(z,c),c=z),se=c,i.style.strokeDashoffset=b==="reverse"?`${E[d]*c}`:`${E[d]*(1-c)}`,p&&(i.style.opacity=b==="reverse"?`${1-c}`:`${c}`),q&&A?i.style.stroke=xe(q,A,c):A&&(i.style.stroke=A),O!==null&&T!==null?i.style.strokeWidth=`${O+(T-O)*c}`:T!==null&&(i.style.strokeWidth=`${T}`),F!==null&&P!==null?i.style.fillOpacity=`${F+(P-F)*c}`:P!==null&&(i.style.fillOpacity=`${P}`),W&&i.tagName.toLowerCase()==="path"&&H[d]&&i.setAttribute("d",Ie(H[d],W,c)),d===0&&(ce?.(c),e.style.setProperty("--scroll-draw-progress",String(c))),c<1&&(L=false);}),ee){let i=re(ae(o,X,U,l));for(let d in ee){let v=parseFloat(d);i>=v&&!J.has(v)&&(J.add(v),ee[d]?.());}}!R&&ae(o,X,U,l)>0&&(R=true,de?.()),L&&!M?(M=true,ie?.(),B<(te==="infinite"?1/0:te??0)&&(B++,j=setTimeout(()=>{z=-1,R=false,M=false,J.clear(),be();},Se))):!L&&!K&&(M=false),x=requestAnimationFrame(we);}let Ae=new IntersectionObserver(t=>{t.forEach(o=>{ye=o.isIntersecting,ye&&!D?x=requestAnimationFrame(we):cancelAnimationFrame(x);});},{root:I??null,threshold:Fe,rootMargin:Ce}),Te;function ve(){clearTimeout(Te),Te=setTimeout(()=>{k.forEach((t,o)=>{E[o]=Ee(t),t.style.strokeDasharray=`${E[o]}`;}),He();},150);}return window.addEventListener("resize",ve),window.addEventListener("orientationchange",ve),ue>0?setTimeout(()=>Ae.observe(e),ue):Ae.observe(e),{destroy(){cancelAnimationFrame(x),clearTimeout(j),Ae.disconnect(),window.removeEventListener("resize",ve),window.removeEventListener("orientationchange",ve),clearTimeout(Te),Me?.remove();},replay(){z=-1,ge=-1,he=-1,R=false,M=false,B=0,D=false,J.clear(),clearTimeout(j),be();},pause(){D=true,cancelAnimationFrame(x);},resume(){D&&(D=false,ye&&(x=requestAnimationFrame(we)));},seek(t){let o=Math.min(1,Math.max(0,t));se=o,z=o,D=true,cancelAnimationFrame(x),Ye(o,h);},getProgress(){return se}}}function Ue(e){return e.map(r=>typeof r=="string"?document.querySelector(r):r).filter(r=>r!==null)}function yt(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let n=Ue(e).map(s=>Oe(s,r));return {destroy(){n.forEach(s=>s.destroy());},replay(){n.forEach(s=>s.replay());},pause(){n.forEach(s=>s.pause());},resume(){n.forEach(s=>s.resume());},seek(s){n.forEach(m=>m.seek(s));},getProgress(){return n[0]?.getProgress()??0}}}function gt(e,r={}){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let s=Ue(e);if(s.length===0)return n;let m=0,u=[];function S(p){return Oe(s[p],{...r,once:true,onComplete(){r.onComplete?.(),m=p+1,u[m]?.resume();}})}function w(){s.forEach((p,y)=>{u[y]=S(y);});for(let p=1;p<u.length;p++)u[p].pause();}return w(),{destroy(){u.forEach(p=>p.destroy()),u.length=0;},replay(){u.forEach(p=>p.destroy()),u.length=0,m=0,w();},pause(){u[m]?.pause();},resume(){u[m]?.resume();},seek(p){u[m]?.seek(p);},getProgress(){return u[m]?.getProgress()??0}}}export{yt as scrollDrawGroup,gt as scrollDrawSequence};
1
+ function mt({bounces:e=3,decay:n=.5}={}){let r=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,n)),o=Math.sqrt(t),c=0,m=[];for(let g=0;g<r;g++){let x=Math.pow(o,g);m.push(x),c+=x;}let i=[0],l=0;for(let g=0;g<r;g++)l+=m[g]/c,i.push(l);return g=>{if(g<=0)return 0;if(g>=1)return 1;for(let x=0;x<r;x++)if(g<=i[x+1]){let V=(g-i[x])/(i[x+1]-i[x]);if(x===0)return V*(2-V);let E=1-Math.pow(t,x);return E+(1-E)*(2*V-1)*(2*V-1)}return 1}}function pt({amplitude:e=1,period:n=.4}={}){let r=Math.max(1,e),t=Math.max(.1,n),o=r<=1?t/4:t/(2*Math.PI)*Math.asin(1/r);return c=>c<=0?0:c>=1?1:r*Math.pow(2,-10*c)*Math.sin((c-o)*(2*Math.PI)/t)+1}var xe={linear:e=>e,"ease-in":e=>e*e,"ease-out":e=>e*(2-e),"ease-in-out":e=>e<.5?2*e*e:-1+(4-2*e)*e,spring:e=>1-Math.cos(e*Math.PI*2.5)*Math.pow(1-e,2.2),bounce:mt(),elastic:pt()};function $e(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 Ye(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 Ue(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 dt(e,n,r){return Math.min(r,Math.max(n,e))}function U(e,n,r,t){return r===n?0:dt((e-n)/(r-n)*t,0,1)}function Ae(e,n,r,t,o){let c=Ye(e.top,e.height,n,t.element)-Ue(t.viewport,r),m=Ye(e.top,e.height,n,o.element)-Ue(o.viewport,r);return {tStart:c,tEnd:m}}function Ze(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 Te(e,n,r){let t=Ze(e),o=Ze(n);return !t||!o?e:`rgb(${Math.round(t[0]+(o[0]-t[0])*r)},${Math.round(t[1]+(o[1]-t[1])*r)},${Math.round(t[2]+(o[2]-t[2])*r)})`}var Je={sketch:{easing:"ease-in",stagger:.1,speed:.9,fade:false},reveal:{easing:"ease-out",fade:true,speed:1.2,once:true},typewriter:{easing:"linear",stagger:.05,speed:1.5},cinematic:{easing:"ease-in-out",fade:true,speed:.75},spring:{easing:"spring",speed:1.1}};function Ke(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n);}var Qe={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},gt=0;function yt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function ht(e){let n=e.getAttribute("stroke"),r=e.getAttribute("fill");!n||n==="none"?Ke("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&&Ke("Element has a fill \u2014 it may obscure the stroke animation.",e);}function bt(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 o(){let c=r==="x"?window.scrollX:window.scrollY,m=e-c,i=n-c,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:${i}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${i}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",o,{passive:true}),o(),t}function _e(e,n,r){let t=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),o=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,c=>{let m=parseFloat(c),i=t[o++]??m;return String(+(m+(i-m)*r).toFixed(4))})}function Ge(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...t}=n,o=r?{...Je[r],...t}:t,c=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:m="path, polyline, line, polygon, rect, circle",speed:i=1,fade:l=false,easing:g="linear",trigger:x={},stagger:V=0,direction:E="forward",once:re=false,debug:Pe=false,axis:z="y",scrollContainer:Ee,autoReverse:L=false,delay:W=0,strokeColor:ne,strokeWidth:se,fillOpacity:oe,waypoints:ie,velocityScale:ae=false,threshold:ge=0,rootMargin:Z="0px",repeat:_=0,repeatDelay:B=0,morphTo:D,clip:J,autoplay:ve=false,duration:Me=1e3,native:ze=true,onProgress:ce,onStart:le,onComplete:K}=o,j=J===true?"left":typeof J=="string"?J:false,X=typeof g=="function"?g:xe[g]??xe.linear,ye=$e(x.start??"top bottom"),u=$e(x.end??"bottom top"),f=typeof Ee=="string"?document.querySelector(Ee):Ee??null,O=Array.isArray(ne)?ne[0]:null,S=Array.isArray(ne)?ne[1]:typeof ne=="string"?ne:null,M=Array.isArray(se)?se[0]:null,F=Array.isArray(se)?se[1]:typeof se=="number"?se:null,w=Array.isArray(oe)?oe[0]:null,A=Array.isArray(oe)?oe[1]:typeof oe=="number"?oe:null;function q(s){let a=s*100;switch(j){case "right":return `inset(0 0 0 ${100-a}%)`;case "top":return `inset(0 0 ${100-a}% 0)`;case "bottom":return `inset(${100-a}% 0 0 0)`;case "center":return `circle(${s*150}% at 50% 50%)`;default:return `inset(0 ${100-a}% 0 0)`}}let I=j?[]:Array.from(e.querySelectorAll(m)),T=[],Q=[],fe=0,me=0,N=false,Y=false,C=0,De=false,ee=-1,Ie=-1,R=false,he=0,ue=0,pe,We=null,de=new Set,Ce=-1,Be=performance.now();function ke(){return f?z==="x"?f.scrollLeft:f.scrollTop:z==="x"?window.scrollX:window.scrollY}function je(){return f?z==="x"?f.clientWidth:f.clientHeight:z==="x"?window.innerWidth:window.innerHeight}function Xe(){let s=e.getBoundingClientRect(),a,y,P;if(f){let H=f.getBoundingClientRect();a=z==="x"?s.left-H.left+f.scrollLeft:s.top-H.top+f.scrollTop,y=z==="x"?s.width:s.height,P=ke();}else a=z==="x"?s.left:s.top,y=z==="x"?s.width:s.height,P=ke();let G=Ae({top:a,height:y},P,je(),ye,u);fe=G.tStart,me=G.tEnd,Pe&&process.env.NODE_ENV!=="production"&&(We?.remove(),We=bt(fe,me,z));}function lt(s,a){if(e.style.setProperty("--scroll-draw-progress",String(s)),j){let y=a==="reverse"?1-s:s;e.style.clipPath=q(y);return}I.forEach((y,P)=>{y.style.strokeDashoffset=a==="reverse"?`${T[P]*s}`:`${T[P]*(1-s)}`,l&&(y.style.opacity=a==="reverse"?`${1-s}`:`${s}`),O&&S?y.style.stroke=Te(O,S,s):S&&(y.style.stroke=S),M!==null&&F!==null?y.style.strokeWidth=`${M+(F-M)*s}`:F!==null&&(y.style.strokeWidth=`${F}`),w!==null&&A!==null?y.style.fillOpacity=`${w+(A-w)*s}`:A!==null&&(y.style.fillOpacity=`${A}`),D&&y.tagName.toLowerCase()==="path"&&Q[P]&&y.setAttribute("d",_e(Q[P],D,s));});}function Oe(){if(e.style.setProperty("--scroll-draw-progress","0"),j){e.style.clipPath=q(0);return}I.forEach((s,a)=>{s.style.strokeDasharray=`${T[a]}`,s.style.strokeDashoffset=E==="reverse"?"0":`${T[a]}`,l?s.style.opacity=E==="reverse"?"1":"0":s.style.opacity="",O&&(s.style.stroke=O),M!==null&&(s.style.strokeWidth=`${M}`),w!==null&&(s.style.fillOpacity=`${w}`),D&&s.tagName.toLowerCase()==="path"&&Q[a]&&s.setAttribute("d",Q[a]);});}if(I.forEach(s=>{ht(s);let a=Re(s);T.push(a),s.tagName.toLowerCase()==="path"?Q.push(s.getAttribute("d")??""):Q.push(""),c?(s.style.strokeDasharray=`${a}`,s.style.strokeDashoffset=E==="reverse"?`${a}`:"0",l&&(s.style.opacity="1"),S&&(s.style.stroke=S),F!==null&&(s.style.strokeWidth=`${F}`),A!==null&&(s.style.fillOpacity=`${A}`),D&&s.tagName.toLowerCase()==="path"&&s.setAttribute("d",D)):(s.style.strokeDasharray=`${a}`,s.style.strokeDashoffset=E==="reverse"?"0":`${a}`,l?s.style.opacity=E==="reverse"?"1":"0":s.style.opacity="",O&&(s.style.stroke=O),M!==null&&(s.style.strokeWidth=`${M}`),w!==null&&(s.style.fillOpacity=`${w}`));}),j){if(c)return e.style.clipPath=q(1),K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=q(0);}else if(c)return K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function ut(){return !(ze===false||!yt()||!I.length||typeof g!="string"||!(g in Qe)||j||z!=="y"||f||i!==1||V!==0||re||L||ae!==false||D||ie||_||W>0||ce||le||K||ne!=null||se!=null||oe!=null||(x.start??"top bottom").trim()!=="top bottom"||(x.end??"bottom top").trim()!=="bottom top")}function ct(){let s=`svg-scroll-draw-${++gt}`,a=E==="reverse"?"0":"var(--ssd-len)",y=E==="reverse"?"var(--ssd-len)":"0",P=`stroke-dashoffset:${a};`,G=`stroke-dashoffset:${y};`;l&&(P+=`opacity:${E==="reverse"?1:0};`,G+=`opacity:${E==="reverse"?0:1};`);let H=document.createElement("style");H.setAttribute("data-svg-scroll-draw",""),H.textContent=`@keyframes ${s}{from{${P}}to{${G}}}.${s}{animation-name:${s};animation-duration:auto;animation-timing-function:${Qe[g]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(H);function d(p,b){p.style.setProperty("--ssd-len",String(T[b])),p.style.strokeDasharray=`${T[b]}`,p.style.strokeDashoffset="",p.style.opacity="",p.style.animationPlayState="",p.classList.add(s);}I.forEach(d);let v=false,k=-1;function h(){if(k>=0)return k;let p=e.getBoundingClientRect(),{tStart:b,tEnd:$}=Ae({top:p.top,height:p.height},ke(),je(),ye,u);return X(U(ke(),b,$,i))}return {destroy(){I.forEach(p=>{p.classList.remove(s),p.style.removeProperty("--ssd-len"),p.style.animationPlayState="";}),H.remove();},replay(){v=false,k=-1,I.forEach(d);},pause(){v=true,I.forEach(p=>{p.style.animationPlayState="paused";});},resume(){v&&(v=false,I.forEach(p=>{p.style.animationPlayState="running";}));},seek(p){let b=Math.min(1,Math.max(0,p));k=b,v=true,I.forEach(($,be)=>{$.classList.remove(s),$.style.strokeDashoffset=E==="reverse"?`${T[be]*b}`:`${T[be]*(1-b)}`,l&&($.style.opacity=E==="reverse"?`${1-b}`:`${b}`);});},getProgress(){return h()}}}if(ut())return ct();function ft(){let s=Math.max(1,Me),a=0,y=0;function P(h){let p=true;if(j){let b=Math.min(1,Math.max(0,h/s)),$=X(b);he=$,e.style.setProperty("--scroll-draw-progress",String($)),e.style.clipPath=q(E==="reverse"?1-$:$),ce?.($),b<1&&(p=false);}else I.forEach((b,$)=>{let be=$*V*s,Se=Math.min(1,Math.max(0,(h-be)/s)),te=X(Se);b.style.strokeDashoffset=E==="reverse"?`${T[$]*te}`:`${T[$]*(1-te)}`,l&&(b.style.opacity=E==="reverse"?`${1-te}`:`${te}`),O&&S?b.style.stroke=Te(O,S,te):S&&(b.style.stroke=S),M!==null&&F!==null?b.style.strokeWidth=`${M+(F-M)*te}`:F!==null&&(b.style.strokeWidth=`${F}`),w!==null&&A!==null?b.style.fillOpacity=`${w+(A-w)*te}`:A!==null&&(b.style.fillOpacity=`${A}`),D&&b.tagName.toLowerCase()==="path"&&Q[$]&&b.setAttribute("d",_e(Q[$],D,te)),$===0&&(ce?.(te),e.style.setProperty("--scroll-draw-progress",String(te))),Se<1&&(p=false);});if(ie){let b=Math.min(1,Math.max(0,h/s)),$=X(b);for(let be in ie){let Se=parseFloat(be);$>=Se&&!de.has(Se)&&(de.add(Se),ie[be]?.());}}return p}function G(h){if(R)return;let p=h-a;Y||(Y=true,le?.());let b=P(p);if(b&&!N){N=true,P(s*(1+Math.max(0,I.length-1)*V)),K?.(),ue<(_==="infinite"?1/0:_??0)&&(ue++,pe=setTimeout(()=>{a=performance.now(),Y=false,N=false,de.clear(),Oe(),C=requestAnimationFrame(G);},B));return}b||(C=requestAnimationFrame(G));}function H(){cancelAnimationFrame(C),clearTimeout(pe),a=performance.now(),y=0,R=false,Y=false,N=false,ue=0,de.clear(),Oe(),C=requestAnimationFrame(G);}let d=new IntersectionObserver(h=>{h.forEach(p=>{p.isIntersecting&&!(re&&N)?H():!p.isIntersecting&&!re&&!N&&(cancelAnimationFrame(C),clearTimeout(pe),a=null);});},{root:f??null,threshold:ge,rootMargin:Z}),v;function k(){clearTimeout(v),v=setTimeout(()=>{I.forEach((h,p)=>{T[p]=Re(h),h.style.strokeDasharray=`${T[p]}`;});},150);}return window.addEventListener("resize",k),window.addEventListener("orientationchange",k),W>0?setTimeout(()=>d.observe(e),W):d.observe(e),{destroy(){cancelAnimationFrame(C),clearTimeout(pe),d.disconnect(),window.removeEventListener("resize",k),window.removeEventListener("orientationchange",k),clearTimeout(v);},replay(){ue=0,H();},pause(){R||(R=true,y=performance.now()-a,cancelAnimationFrame(C));},resume(){R&&(R=false,a=performance.now()-y,C=requestAnimationFrame(G));},seek(h){let p=Math.min(1,Math.max(0,h));he=p,R=true,y=p*s,a=performance.now()-y,cancelAnimationFrame(C),P(y);},getProgress(){return he}}}if(ve)return ft();Xe();function Fe(){if(!De||R)return;let s=performance.now(),a=ke(),y=i;if(ae!==false){let d=s-Be,v=d>0?Math.abs(a-(Ce<0?a:Ce))/d:0;y=i*Math.max(.2,1+v*(typeof ae=="number"?ae:1)*.04);}Ce=a,Be=s;let P=L?Ie===-1||a>=Ie?"forward":"reverse":E;Ie=a;let G=me-fe,H=true;if(j){let d=X(U(a,fe,me,y));re&&!L&&(ee=Math.max(ee,d),d=ee),he=d,e.style.setProperty("--scroll-draw-progress",String(d));let v=P==="reverse"?1-d:d;e.style.clipPath=q(v),ce?.(d),!Y&&U(a,fe,me,y)>0&&(Y=true,le?.()),d>=1&&!N?(N=true,K?.(),ue<(_==="infinite"?1/0:_??0)&&(ue++,pe=setTimeout(()=>{ee=-1,Y=false,N=false,e.style.clipPath=q(0);},B))):d<1&&!re&&(N=false),C=requestAnimationFrame(Fe);return}if(I.forEach((d,v)=>{let k=v*V*G,h=X(U(a,fe+k,me+k,y));re&&!L&&(ee=Math.max(ee,h),h=ee),he=h,d.style.strokeDashoffset=P==="reverse"?`${T[v]*h}`:`${T[v]*(1-h)}`,l&&(d.style.opacity=P==="reverse"?`${1-h}`:`${h}`),O&&S?d.style.stroke=Te(O,S,h):S&&(d.style.stroke=S),M!==null&&F!==null?d.style.strokeWidth=`${M+(F-M)*h}`:F!==null&&(d.style.strokeWidth=`${F}`),w!==null&&A!==null?d.style.fillOpacity=`${w+(A-w)*h}`:A!==null&&(d.style.fillOpacity=`${A}`),D&&d.tagName.toLowerCase()==="path"&&Q[v]&&d.setAttribute("d",_e(Q[v],D,h)),v===0&&(ce?.(h),e.style.setProperty("--scroll-draw-progress",String(h))),h<1&&(H=false);}),ie){let d=X(U(a,fe,me,y));for(let v in ie){let k=parseFloat(v);d>=k&&!de.has(k)&&(de.add(k),ie[v]?.());}}!Y&&U(a,fe,me,y)>0&&(Y=true,le?.()),H&&!N?(N=true,K?.(),ue<(_==="infinite"?1/0:_??0)&&(ue++,pe=setTimeout(()=>{ee=-1,Y=false,N=false,de.clear(),Oe();},B))):!H&&!re&&(N=false),C=requestAnimationFrame(Fe);}let qe=new IntersectionObserver(s=>{s.forEach(a=>{De=a.isIntersecting,De&&!R?C=requestAnimationFrame(Fe):cancelAnimationFrame(C);});},{root:f??null,threshold:ge,rootMargin:Z}),Ve;function Ne(){clearTimeout(Ve),Ve=setTimeout(()=>{I.forEach((s,a)=>{T[a]=Re(s),s.style.strokeDasharray=`${T[a]}`;}),Xe();},150);}return window.addEventListener("resize",Ne),window.addEventListener("orientationchange",Ne),W>0?setTimeout(()=>qe.observe(e),W):qe.observe(e),{destroy(){cancelAnimationFrame(C),clearTimeout(pe),qe.disconnect(),window.removeEventListener("resize",Ne),window.removeEventListener("orientationchange",Ne),clearTimeout(Ve),We?.remove();},replay(){ee=-1,Ie=-1,Ce=-1,Y=false,N=false,ue=0,R=false,de.clear(),clearTimeout(pe),Oe();},pause(){R=true,cancelAnimationFrame(C);},resume(){R&&(R=false,De&&(C=requestAnimationFrame(Fe)));},seek(s){let a=Math.min(1,Math.max(0,s));he=a,ee=a,R=true,cancelAnimationFrame(C),lt(a,E);},getProgress(){return he}}}var et=new Map;function tt(e,n){et.set(e,n);}function rt(e){et.delete(e);}function wt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function nt(e){let n=[],r=/([\w]+)\(([^)]*)\)/g,t;for(;(t=r.exec(e))!==null;){let o=[],c=[],m=t[2].trim();if(m)for(let i of m.split(/[\s,]+/)){let l=i.match(/^([-+]?[\d.eE]+)(.*)$/);o.push(l?parseFloat(l[1]):0),c.push(l?l[2]:"");}n.push({fn:t[1],nums:o,units:c});}return n}function Et(e,n,r){let t=nt(e),o=nt(n);return t.length===0||t.length!==o.length?r<1?e:n:t.map((c,m)=>{let i=o[m];return c.fn!==i.fn||c.nums.length!==i.nums.length?r<1?`${c.fn}(${c.nums.map((l,g)=>`${l}${c.units[g]}`).join(", ")})`:`${i.fn}(${i.nums.map((l,g)=>`${l}${i.units[g]}`).join(", ")})`:`${c.fn}(${c.nums.map((l,g)=>`${l+(i.nums[g]-l)*r}${c.units[g]}`).join(", ")})`}).join(" ")}function st(e,n,r){if(typeof e=="number"&&typeof n=="number")return String(e+(n-e)*r);let t=String(e),o=String(n);if(wt(t))return Te(t,o,r);if(t.includes("("))return Et(t,o,r);let c=t.match(/^([-+]?[\d.]+)(.*)$/),m=o.match(/^([-+]?[\d.]+)(.*)$/);if(c&&m){let i=parseFloat(c[1]),l=parseFloat(m[1]);return `${i+(l-i)*r}${c[2]||m[2]}`}return r<1?t:o}function vt(e){return e.replace(/([A-Z])/g,n=>`-${n.toLowerCase()}`)}var ot={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},St=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),xt=0;function $t(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function He(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let{props:t,trigger:o={},easing:c="ease-out",speed:m=1,once:i=false,axis:l="y",scrollContainer:g,native:x=true,onProgress:V,onComplete:E}=n,re=window.matchMedia("(prefers-reduced-motion: reduce)").matches,Pe=typeof c=="function"?c:xe[c]??xe["ease-out"],z=$e(o.start??"top bottom"),Ee=$e(o.end??"bottom top"),L=typeof g=="string"?document.querySelector(g):g??null,W=Object.entries(t).map(([u,f])=>({prop:vt(u),from:Array.isArray(f)?f[0]:"",to:Array.isArray(f)?f[1]:f}));function ne(){let u=window.getComputedStyle(e);for(let f of W)f.from===""&&(f.from=u.getPropertyValue(f.prop).trim()||"0");}function se(){for(let u of W)e.style.setProperty(u.prop,String(u.to));}if(re)return se(),E?.(),r;ne();function oe(){if(!x||!$t()||typeof c!="string"||!(c in ot)||l!=="y"||L||i||m!==1||V||E||(o.start??"top bottom").trim()!=="top bottom"||(o.end??"bottom top").trim()!=="bottom top")return false;for(let u of W)if(!St.has(u.prop))return false;return true}function ie(){let u=`ssd-a-${++xt}`,f=W.map(w=>`${w.prop}:${w.from}`).join(";"),O=W.map(w=>`${w.prop}:${w.to}`).join(";"),S=document.createElement("style");S.setAttribute("data-ssd-animate",""),S.textContent=`@keyframes ${u}{from{${f}}to{${O}}}.${u}{animation-name:${u};animation-duration:auto;animation-timing-function:${ot[c]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(S),e.classList.add(u);let M=()=>l==="x"?window.scrollX:window.scrollY,F=()=>l==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(u),S.remove();},replay(){e.classList.remove(u),e.offsetWidth,e.classList.add(u);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(w){let A=Math.min(1,Math.max(0,w));e.classList.remove(u);for(let q of W)e.style.setProperty(q.prop,st(q.from,q.to,A));},getProgress(){let w=e.getBoundingClientRect(),A=M(),q=F(),{tStart:I,tEnd:T}=Ae({top:w.top,height:w.height},A,q,z,Ee);return Pe(U(A,I,T,m))}}}if(oe())return ie();let ae=0,ge=0,Z=0,_=false,B=false,D=-1,J=0,ve=false,Me=()=>L?l==="x"?L.scrollLeft:L.scrollTop:l==="x"?window.scrollX:window.scrollY,ze=()=>L?l==="x"?L.clientWidth:L.clientHeight:l==="x"?window.innerWidth:window.innerHeight;function ce(){let u=e.getBoundingClientRect(),f,O;if(L){let M=L.getBoundingClientRect();f=l==="x"?u.left-M.left+L.scrollLeft:u.top-M.top+L.scrollTop,O=l==="x"?u.width:u.height;}else f=l==="x"?u.left:u.top,O=l==="x"?u.width:u.height;let S=Ae({top:f,height:O},Me(),ze(),z,Ee);ae=S.tStart,ge=S.tEnd;}function le(u){e.style.setProperty("--scroll-draw-progress",String(u));for(let f of W)e.style.setProperty(f.prop,st(f.from,f.to,u));V?.(u);}function K(){if(!_||B)return;let u=Pe(U(Me(),ae,ge,m));i&&(D=Math.max(D,u),u=D),J=u,le(u),u>=1&&!ve?(ve=true,E?.()):u<1&&!i&&(ve=false),Z=requestAnimationFrame(K);}ce();{let u=Pe(U(Me(),ae,ge,m));i&&u>0&&(D=u),J=u,le(u);}let j=new IntersectionObserver(u=>{u.forEach(f=>{_=f.isIntersecting,_&&!B?Z=requestAnimationFrame(K):cancelAnimationFrame(Z);});},{root:L??null}),X;function ye(){clearTimeout(X),X=setTimeout(ce,150);}return window.addEventListener("resize",ye),window.addEventListener("orientationchange",ye),j.observe(e),tt(e,{type:"animate",getProgress:()=>J,getTrigger:()=>({tStart:ae,tEnd:ge})}),{destroy(){cancelAnimationFrame(Z),j.disconnect(),window.removeEventListener("resize",ye),window.removeEventListener("orientationchange",ye),clearTimeout(X),rt(e);},replay(){D=-1,ve=false,J=0,B=false,le(0);},pause(){B=true,cancelAnimationFrame(Z);},resume(){B&&(B=false,_&&(Z=requestAnimationFrame(K)));},seek(u){let f=Math.min(1,Math.max(0,u));J=f,D=f,B=true,cancelAnimationFrame(Z),le(f);},getProgress(){return J}}}var it={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function at(e,n={}){if(typeof window>"u")return it;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollParallax: element not found:",e),it;let{speed:t=.3,axis:o="y",easing:c="linear",trigger:m,onProgress:i}=n,l=r.getBoundingClientRect(),g=o==="x"?l.width:l.height,x=t*g;return He(r,{props:o==="x"?{transform:["translateX(0px)",`translateX(${-x}px)`]}:{transform:["translateY(0px)",`translateY(${-x}px)`]},trigger:m??{start:"top bottom",end:"bottom top"},easing:c,native:false,onProgress:i})}function Le(e){return e.map(n=>typeof n=="string"?document.querySelector(n):n).filter(n=>n!==null)}var we={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Nt(e,n={}){if(typeof window>"u")return we;let r=Le(e).map(t=>Ge(t,n));return {destroy(){r.forEach(t=>t.destroy());},replay(){r.forEach(t=>t.replay());},pause(){r.forEach(t=>t.pause());},resume(){r.forEach(t=>t.resume());},seek(t){r.forEach(o=>o.seek(t));},getProgress(){return r[0]?.getProgress()??0}}}function Rt(e,n={}){if(typeof window>"u")return we;let r=Le(e);if(r.length===0)return we;let t=0,o=[];function c(i){return Ge(r[i],{...n,once:true,onComplete(){n.onComplete?.(),t=i+1,o[t]?.resume();}})}function m(){r.forEach((i,l)=>{o[l]=c(l);});for(let i=1;i<o.length;i++)o[i].pause();}return m(),{destroy(){o.forEach(i=>i.destroy()),o.length=0;},replay(){o.forEach(i=>i.destroy()),o.length=0,t=0,m();},pause(){o[t]?.pause();},resume(){o[t]?.resume();},seek(i){o[t]?.seek(i);},getProgress(){return o[t]?.getProgress()??0}}}function Ht(e,n){if(typeof window>"u")return we;let r=Le(e).map(t=>He(t,n));return {destroy(){r.forEach(t=>t.destroy());},replay(){r.forEach(t=>t.replay());},pause(){r.forEach(t=>t.pause());},resume(){r.forEach(t=>t.resume());},seek(t){r.forEach(o=>o.seek(t));},getProgress(){return r[0]?.getProgress()??0}}}function zt(e,n){if(typeof window>"u")return we;let r=Le(e);if(r.length===0)return we;let t=0,o=[];function c(i){return He(r[i],{...n,once:true,onComplete(){n.onComplete?.(),t=i+1,o[t]?.resume();}})}function m(){r.forEach((i,l)=>{o[l]=c(l);});for(let i=1;i<o.length;i++)o[i].pause();}return m(),{destroy(){o.forEach(i=>i.destroy()),o.length=0;},replay(){o.forEach(i=>i.destroy()),o.length=0,t=0,m();},pause(){o[t]?.pause();},resume(){o[t]?.resume();},seek(i){o[t]?.seek(i);},getProgress(){return o[t]?.getProgress()??0}}}function Wt(e,n={}){if(typeof window>"u")return we;let r=Le(e).map(t=>at(t,n));return {destroy(){r.forEach(t=>t.destroy());},replay(){r.forEach(t=>t.replay());},pause(){r.forEach(t=>t.pause());},resume(){r.forEach(t=>t.resume());},seek(t){r.forEach(o=>o.seek(t));},getProgress(){return r[0]?.getProgress()??0}}}export{Ht as scrollAnimateGroup,zt as scrollAnimateSequence,Nt as scrollDrawGroup,Rt as scrollDrawSequence,Wt as scrollParallaxGroup};
@@ -1,3 +1,3 @@
1
- 'use strict';var vue=require('vue');function ot({bounces:e=3,decay:n=.5}={}){let s=Math.max(1,Math.round(e)),r=Math.max(.01,Math.min(.99,n)),p=Math.sqrt(r),h=0,L=[];for(let d=0;d<s;d++){let S=Math.pow(p,d);L.push(S),h+=S;}let E=[0],M=0;for(let d=0;d<s;d++)M+=L[d]/h,E.push(M);return d=>{if(d<=0)return 0;if(d>=1)return 1;for(let S=0;S<s;S++)if(d<=E[S+1]){let B=(d-E[S])/(E[S+1]-E[S]);if(S===0)return B*(2-B);let y=1-Math.pow(r,S);return y+(1-y)*(2*B-1)*(2*B-1)}return 1}}function it({amplitude:e=1,period:n=.4}={}){let s=Math.max(1,e),r=Math.max(.1,n),p=s<=1?r/4:r/(2*Math.PI)*Math.asin(1/s);return h=>h<=0?0:h>=1?1:s*Math.pow(2,-10*h)*Math.sin((h-p)*(2*Math.PI)/r)+1}var De={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:ot(),elastic:it()};function Pe(e="top bottom"){let n=e.trim();if(/^\d+(\.\d+)?%$/.test(n))return {element:"top",viewport:n};let[s="top",r="bottom"]=n.split(/\s+/).filter(Boolean);return {element:s,viewport:r}}function Ve(e,n,s,r){switch(r){case "top":return e+s;case "center":return e+s+n/2;case "bottom":return e+s+n;default:return e+s}}function Be(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 Se(e){let n=e.tagName.toLowerCase();if(n==="rect"){let s=parseFloat(e.getAttribute("width")??"0"),r=parseFloat(e.getAttribute("height")??"0");return 2*(s+r)}if(n==="circle"){let s=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*s}return e.getTotalLength()}function at(e,n,s){return Math.min(s,Math.max(n,e))}function ie(e,n,s,r){return s===n?0:at((e-n)/(s-n)*r,0,1)}function Le(e,n,s,r,p){let h=Ve(e.top,e.height,n,r.element)-Be(r.viewport,s),L=Ve(e.top,e.height,n,p.element)-Be(p.viewport,s);return {tStart:h,tEnd:L}}function Ge(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 s=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(s)return [parseInt(s[1],16),parseInt(s[2],16),parseInt(s[3],16)];let r=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return r?[parseInt(r[1]),parseInt(r[2]),parseInt(r[3])]:null}function Ee(e,n,s){let r=Ge(e),p=Ge(n);return !r||!p?e:`rgb(${Math.round(r[0]+(p[0]-r[0])*s)},${Math.round(r[1]+(p[1]-r[1])*s)},${Math.round(r[2]+(p[2]-r[2])*s)})`}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 Ue(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n);}var Xe={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},lt=0;function ut(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function ct(e){let n=e.getAttribute("stroke"),s=e.getAttribute("fill");!n||n==="none"?Ue("Element has no stroke \u2014 path will not be visible.",e):s&&s!=="none"&&s!=="transparent"&&Ue("Element has a fill \u2014 it may obscure the stroke animation.",e);}function ft(e,n,s){let r=document.createElement("div");r.setAttribute("data-svg-scroll-draw-debug",""),r.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 p(){let h=s==="x"?window.scrollX:window.scrollY,L=e-h,E=n-h,M=s==="x";r.innerHTML=`
2
- <div style="position:absolute;${M?`left:${L}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${L}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
3
- <div style="position:absolute;${M?`left:${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(r),window.addEventListener("scroll",p,{passive:true}),p(),r}function Oe(e,n,s){let r=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),p=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,h=>{let L=parseFloat(h),E=r[p++]??L;return String(+(L+(E-L)*s).toFixed(4))})}function Fe(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:s,...r}=n,p=s?{..._e[s],...r}:r,h=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:L="path, polyline, line, polygon, rect, circle",speed:E=1,fade:M=false,easing:d="linear",trigger:S={},stagger:B=0,direction:y="forward",once:K=false,debug:Qe=false,axis:N="y",scrollContainer:xe,autoReverse:me=false,delay:ue=0,strokeColor:Q,strokeWidth:Y,fillOpacity:Z,waypoints:ee,velocityScale:pe=false,threshold:Ie=0,rootMargin:Re="0px",repeat:te=0,repeatDelay:$e=0,morphTo:H,clip:Me,autoplay:Ye=false,duration:Ze=1e3,native:et=true,onProgress:ce,onStart:de,onComplete:ae}=p,_=Me===true?"left":typeof Me=="string"?Me:false,re=typeof d=="function"?d:De[d]??De.linear,Ne=Pe(S.start??"top bottom"),He=Pe(S.end??"bottom top"),O=typeof xe=="string"?document.querySelector(xe):xe??null,W=Array.isArray(Q)?Q[0]:null,T=Array.isArray(Q)?Q[1]:typeof Q=="string"?Q:null,F=Array.isArray(Y)?Y[0]:null,A=Array.isArray(Y)?Y[1]:typeof Y=="number"?Y:null,C=Array.isArray(Z)?Z[0]:null,k=Array.isArray(Z)?Z[1]:typeof Z=="number"?Z:null;function ne(t){let o=t*100;switch(_){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=_?[]:Array.from(e.querySelectorAll(L)),w=[],z=[],U=0,X=0,$=false,R=false,v=0,ye=false,q=-1,ge=-1,D=false,se=0,G=0,j,Te=null,J=new Set,he=-1,We=performance.now();function fe(){return O?N==="x"?O.scrollLeft:O.scrollTop:N==="x"?window.scrollX:window.scrollY}function ze(){return O?N==="x"?O.clientWidth:O.clientHeight:N==="x"?window.innerWidth:window.innerHeight}function qe(){let t=e.getBoundingClientRect(),o,l,g;if(O){let P=O.getBoundingClientRect();o=N==="x"?t.left-P.left+O.scrollLeft:t.top-P.top+O.scrollTop,l=N==="x"?t.width:t.height,g=fe();}else o=N==="x"?t.left:t.top,l=N==="x"?t.width:t.height,g=fe();let I=Le({top:o,height:l},g,ze(),Ne,He);U=I.tStart,X=I.tEnd,Qe&&process.env.NODE_ENV!=="production"&&(Te?.remove(),Te=ft(U,X,N));}function tt(t,o){if(e.style.setProperty("--scroll-draw-progress",String(t)),_){let l=o==="reverse"?1-t:t;e.style.clipPath=ne(l);return}x.forEach((l,g)=>{l.style.strokeDashoffset=o==="reverse"?`${w[g]*t}`:`${w[g]*(1-t)}`,M&&(l.style.opacity=o==="reverse"?`${1-t}`:`${t}`),W&&T?l.style.stroke=Ee(W,T,t):T&&(l.style.stroke=T),F!==null&&A!==null?l.style.strokeWidth=`${F+(A-F)*t}`:A!==null&&(l.style.strokeWidth=`${A}`),C!==null&&k!==null?l.style.fillOpacity=`${C+(k-C)*t}`:k!==null&&(l.style.fillOpacity=`${k}`),H&&l.tagName.toLowerCase()==="path"&&z[g]&&l.setAttribute("d",Oe(z[g],H,t));});}function be(){if(e.style.setProperty("--scroll-draw-progress","0"),_){e.style.clipPath=ne(0);return}x.forEach((t,o)=>{t.style.strokeDasharray=`${w[o]}`,t.style.strokeDashoffset=y==="reverse"?"0":`${w[o]}`,M?t.style.opacity=y==="reverse"?"1":"0":t.style.opacity="",W&&(t.style.stroke=W),F!==null&&(t.style.strokeWidth=`${F}`),C!==null&&(t.style.fillOpacity=`${C}`),H&&t.tagName.toLowerCase()==="path"&&z[o]&&t.setAttribute("d",z[o]);});}if(x.forEach(t=>{ct(t);let o=Se(t);w.push(o),t.tagName.toLowerCase()==="path"?z.push(t.getAttribute("d")??""):z.push(""),h?(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=y==="reverse"?`${o}`:"0",M&&(t.style.opacity="1"),T&&(t.style.stroke=T),A!==null&&(t.style.strokeWidth=`${A}`),k!==null&&(t.style.fillOpacity=`${k}`),H&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",H)):(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=y==="reverse"?"0":`${o}`,M?t.style.opacity=y==="reverse"?"1":"0":t.style.opacity="",W&&(t.style.stroke=W),F!==null&&(t.style.strokeWidth=`${F}`),C!==null&&(t.style.fillOpacity=`${C}`));}),_){if(h)return e.style.clipPath=ne(1),ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ne(0);}else if(h)return ae?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function rt(){return !(et===false||!ut()||!x.length||typeof d!="string"||!(d in Xe)||_||N!=="y"||O||E!==1||B!==0||K||me||pe!==false||H||ee||te||ue>0||ce||de||ae||Q!=null||Y!=null||Z!=null||(S.start??"top bottom").trim()!=="top bottom"||(S.end??"bottom top").trim()!=="bottom top")}function nt(){let t=`svg-scroll-draw-${++lt}`,o=y==="reverse"?"0":"var(--ssd-len)",l=y==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${o};`,I=`stroke-dashoffset:${l};`;M&&(g+=`opacity:${y==="reverse"?1:0};`,I+=`opacity:${y==="reverse"?0:1};`);let P=document.createElement("style");P.setAttribute("data-svg-scroll-draw",""),P.textContent=`@keyframes ${t}{from{${g}}to{${I}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Xe[d]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(P);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);}x.forEach(a);let f=false,b=-1;function u(){if(b>=0)return b;let i=e.getBoundingClientRect(),{tStart:c,tEnd:m}=Le({top:i.top,height:i.height},fe(),ze(),Ne,He);return re(ie(fe(),c,m,E))}return {destroy(){x.forEach(i=>{i.classList.remove(t),i.style.removeProperty("--ssd-len"),i.style.animationPlayState="";}),P.remove();},replay(){f=false,b=-1,x.forEach(a);},pause(){f=true,x.forEach(i=>{i.style.animationPlayState="paused";});},resume(){f&&(f=false,x.forEach(i=>{i.style.animationPlayState="running";}));},seek(i){let c=Math.min(1,Math.max(0,i));b=c,f=true,x.forEach((m,oe)=>{m.classList.remove(t),m.style.strokeDashoffset=y==="reverse"?`${w[oe]*c}`:`${w[oe]*(1-c)}`,M&&(m.style.opacity=y==="reverse"?`${1-c}`:`${c}`);});},getProgress(){return u()}}}if(rt())return nt();function st(){let t=Math.max(1,Ze),o=0,l=0;function g(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(y==="reverse"?1-m:m),ce?.(m),c<1&&(i=false);}else x.forEach((c,m)=>{let oe=m*B*t,le=Math.min(1,Math.max(0,(u-oe)/t)),V=re(le);c.style.strokeDashoffset=y==="reverse"?`${w[m]*V}`:`${w[m]*(1-V)}`,M&&(c.style.opacity=y==="reverse"?`${1-V}`:`${V}`),W&&T?c.style.stroke=Ee(W,T,V):T&&(c.style.stroke=T),F!==null&&A!==null?c.style.strokeWidth=`${F+(A-F)*V}`:A!==null&&(c.style.strokeWidth=`${A}`),C!==null&&k!==null?c.style.fillOpacity=`${C+(k-C)*V}`:k!==null&&(c.style.fillOpacity=`${k}`),H&&c.tagName.toLowerCase()==="path"&&z[m]&&c.setAttribute("d",Oe(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 I(u){if(D)return;let i=u-o;R||(R=true,de?.());let c=g(i);if(c&&!$){$=true,g(t*(1+Math.max(0,x.length-1)*B)),ae?.(),G<(te==="infinite"?1/0:te??0)&&(G++,j=setTimeout(()=>{o=performance.now(),R=false,$=false,J.clear(),be(),v=requestAnimationFrame(I);},$e));return}c||(v=requestAnimationFrame(I));}function P(){cancelAnimationFrame(v),clearTimeout(j),o=performance.now(),l=0,D=false,R=false,$=false,G=0,J.clear(),be(),v=requestAnimationFrame(I);}let a=new IntersectionObserver(u=>{u.forEach(i=>{i.isIntersecting&&!(K&&$)?P():!i.isIntersecting&&!K&&!$&&(cancelAnimationFrame(v),clearTimeout(j),o=null);});},{root:O??null,threshold:Ie,rootMargin:Re}),f;function b(){clearTimeout(f),f=setTimeout(()=>{x.forEach((u,i)=>{w[i]=Se(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(){G=0,P();},pause(){D||(D=true,l=performance.now()-o,cancelAnimationFrame(v));},resume(){D&&(D=false,o=performance.now()-l,v=requestAnimationFrame(I));},seek(u){let i=Math.min(1,Math.max(0,u));se=i,D=true,l=i*t,o=performance.now()-l,cancelAnimationFrame(v),g(l);},getProgress(){return se}}}if(Ye)return st();qe();function we(){if(!ye||D)return;let t=performance.now(),o=fe(),l=E;if(pe!==false){let a=t-We,f=a>0?Math.abs(o-(he<0?o:he))/a:0;l=E*Math.max(.2,1+f*(typeof pe=="number"?pe:1)*.04);}he=o,We=t;let g=me?ge===-1||o>=ge?"forward":"reverse":y;ge=o;let I=X-U,P=true;if(_){let a=re(ie(o,U,X,l));K&&!me&&(q=Math.max(q,a),a=q),se=a,e.style.setProperty("--scroll-draw-progress",String(a));let f=g==="reverse"?1-a:a;e.style.clipPath=ne(f),ce?.(a),!R&&ie(o,U,X,l)>0&&(R=true,de?.()),a>=1&&!$?($=true,ae?.(),G<(te==="infinite"?1/0:te??0)&&(G++,j=setTimeout(()=>{q=-1,R=false,$=false,e.style.clipPath=ne(0);},$e))):a<1&&!K&&($=false),v=requestAnimationFrame(we);return}if(x.forEach((a,f)=>{let b=f*B*I,u=re(ie(o,U+b,X+b,l));K&&!me&&(q=Math.max(q,u),u=q),se=u,a.style.strokeDashoffset=g==="reverse"?`${w[f]*u}`:`${w[f]*(1-u)}`,M&&(a.style.opacity=g==="reverse"?`${1-u}`:`${u}`),W&&T?a.style.stroke=Ee(W,T,u):T&&(a.style.stroke=T),F!==null&&A!==null?a.style.strokeWidth=`${F+(A-F)*u}`:A!==null&&(a.style.strokeWidth=`${A}`),C!==null&&k!==null?a.style.fillOpacity=`${C+(k-C)*u}`:k!==null&&(a.style.fillOpacity=`${k}`),H&&a.tagName.toLowerCase()==="path"&&z[f]&&a.setAttribute("d",Oe(z[f],H,u)),f===0&&(ce?.(u),e.style.setProperty("--scroll-draw-progress",String(u))),u<1&&(P=false);}),ee){let a=re(ie(o,U,X,l));for(let f in ee){let b=parseFloat(f);a>=b&&!J.has(b)&&(J.add(b),ee[f]?.());}}!R&&ie(o,U,X,l)>0&&(R=true,de?.()),P&&!$?($=true,ae?.(),G<(te==="infinite"?1/0:te??0)&&(G++,j=setTimeout(()=>{q=-1,R=false,$=false,J.clear(),be();},$e))):!P&&!K&&($=false),v=requestAnimationFrame(we);}let Ae=new IntersectionObserver(t=>{t.forEach(o=>{ye=o.isIntersecting,ye&&!D?v=requestAnimationFrame(we):cancelAnimationFrame(v);});},{root:O??null,threshold:Ie,rootMargin:Re}),ke;function ve(){clearTimeout(ke),ke=setTimeout(()=>{x.forEach((t,o)=>{w[o]=Se(t),t.style.strokeDasharray=`${w[o]}`;}),qe();},150);}return window.addEventListener("resize",ve),window.addEventListener("orientationchange",ve),ue>0?setTimeout(()=>Ae.observe(e),ue):Ae.observe(e),{destroy(){cancelAnimationFrame(v),clearTimeout(j),Ae.disconnect(),window.removeEventListener("resize",ve),window.removeEventListener("orientationchange",ve),clearTimeout(ke),Te?.remove();},replay(){q=-1,ge=-1,he=-1,R=false,$=false,G=0,D=false,J.clear(),clearTimeout(j),be();},pause(){D=true,cancelAnimationFrame(v);},resume(){D&&(D=false,ye&&(v=requestAnimationFrame(we)));},seek(t){let o=Math.min(1,Math.max(0,t));se=o,q=o,D=true,cancelAnimationFrame(v),tt(o,y);},getProgress(){return se}}}function dt(e={}){let n=vue.ref(null);return vue.onMounted(()=>{if(!n.value)return;let s=Fe(n.value,e);vue.onUnmounted(()=>s.destroy());}),n}var Ce=vue.defineComponent({name:"ScrollDraw",props:{selector:{type:String},speed:{type:Number},fade:{type:Boolean},stagger:{type:Number},easing:{type:[String,Function]},direction:{type:String},trigger:{type:Object},onProgress:{type:Function},onStart:{type:Function},onComplete:{type:Function},once:{type:Boolean},debug:{type:Boolean}},setup(e,{slots:n}){let s=vue.ref(null);return vue.onMounted(()=>{if(!s.value)return;let r={};e.selector!=null&&(r.selector=e.selector),e.speed!=null&&(r.speed=e.speed),e.fade!=null&&(r.fade=e.fade),e.stagger!=null&&(r.stagger=e.stagger),e.easing!=null&&(r.easing=e.easing),e.direction!=null&&(r.direction=e.direction),e.trigger!=null&&(r.trigger=e.trigger),e.once!=null&&(r.once=e.once),e.debug!=null&&(r.debug=e.debug),e.onProgress!=null&&(r.onProgress=e.onProgress),e.onStart!=null&&(r.onStart=e.onStart),e.onComplete!=null&&(r.onComplete=e.onComplete);let p=Fe(s.value,r);vue.onUnmounted(()=>p.destroy());}),()=>vue.h("div",{ref:s},n.default?.())}});function $t(){return {install(e){e.component("ScrollDraw",Ce);}}}exports.ScrollDraw=Ce;exports.createScrollDrawPlugin=$t;exports.useScrollDraw=dt;
1
+ 'use strict';var vue=require('vue');function Mt({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,r)),l=Math.sqrt(t),s=0,m=[];for(let d=0;d<n;d++){let F=Math.pow(l,d);m.push(F),s+=F;}let c=[0],u=0;for(let d=0;d<n;d++)u+=m[d]/s,c.push(u);return d=>{if(d<=0)return 0;if(d>=1)return 1;for(let F=0;F<n;F++)if(d<=c[F+1]){let B=(d-c[F])/(c[F+1]-c[F]);if(F===0)return B*(2-B);let S=1-Math.pow(t,F);return S+(1-S)*(2*B-1)*(2*B-1)}return 1}}function Ct({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),t=Math.max(.1,r),l=n<=1?t/4:t/(2*Math.PI)*Math.asin(1/n);return s=>s<=0?0:s>=1?1:n*Math.pow(2,-10*s)*Math.sin((s-l)*(2*Math.PI)/t)+1}var ae={linear:e=>e,"ease-in":e=>e*e,"ease-out":e=>e*(2-e),"ease-in-out":e=>e<.5?2*e*e:-1+(4-2*e)*e,spring:e=>1-Math.cos(e*Math.PI*2.5)*Math.pow(1-e,2.2),bounce:Mt(),elastic:Ct()};function le(e="top bottom"){let r=e.trim();if(/^\d+(\.\d+)?%$/.test(r))return {element:"top",viewport:r};let[n="top",t="bottom"]=r.split(/\s+/).filter(Boolean);return {element:n,viewport:t}}function lt(e,r,n,t){switch(t){case "top":return e+n;case "center":return e+n+r/2;case "bottom":return e+n+r;default:return e+n}}function ct(e,r){if(/^\d+(\.\d+)?%$/.test(e))return r*(parseFloat(e)/100);switch(e){case "top":return 0;case "center":return r/2;case "bottom":return r;default:return r}}function _e(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 $t(e,r,n){return Math.min(n,Math.max(r,e))}function J(e,r,n,t){return n===r?0:$t((e-r)/(n-r)*t,0,1)}function pe(e,r,n,t,l){let s=lt(e.top,e.height,r,t.element)-ct(t.viewport,n),m=lt(e.top,e.height,r,l.element)-ct(l.viewport,n);return {tStart:s,tEnd:m}}function ut(e){let r=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(r)return [parseInt(r[1]+r[1],16),parseInt(r[2]+r[2],16),parseInt(r[3]+r[3],16)];let n=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(n)return [parseInt(n[1],16),parseInt(n[2],16),parseInt(n[3],16)];let t=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return t?[parseInt(t[1]),parseInt(t[2]),parseInt(t[3])]:null}function De(e,r,n){let t=ut(e),l=ut(r);return !t||!l?e:`rgb(${Math.round(t[0]+(l[0]-t[0])*n)},${Math.round(t[1]+(l[1]-t[1])*n)},${Math.round(t[2]+(l[2]-t[2])*n)})`}var mt={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 ft(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r);}var pt={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Lt=0;function Pt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Ot(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?ft("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&ft("Element has a fill \u2014 it may obscure the stroke animation.",e);}function Ft(e,r,n){let t=document.createElement("div");t.setAttribute("data-svg-scroll-draw-debug",""),t.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function l(){let s=n==="x"?window.scrollX:window.scrollY,m=e-s,c=r-s,u=n==="x";t.innerHTML=`
2
+ <div style="position:absolute;${u?`left:${m}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${m}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
3
+ <div style="position:absolute;${u?`left:${c}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${c}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(t),window.addEventListener("scroll",l,{passive:true}),l(),t}function Xe(e,r,n){let t=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),l=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,s=>{let m=parseFloat(s),c=t[l++]??m;return String(+(m+(c-m)*n).toFixed(4))})}function Ye(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:n,...t}=r,l=n?{...mt[n],...t}:t,s=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:m="path, polyline, line, polygon, rect, circle",speed:c=1,fade:u=false,easing:d="linear",trigger:F={},stagger:B=0,direction:S="forward",once:ne=false,debug:de=false,axis:q="y",scrollContainer:K,autoReverse:T=false,delay:R=0,strokeColor:A,strokeWidth:C,fillOpacity:$,waypoints:b,velocityScale:L=false,threshold:D=0,rootMargin:I="0px",repeat:M=0,repeatDelay:V=0,morphTo:P,clip:_,autoplay:Q=false,duration:Y=1e3,native:se=true,onProgress:p,onStart:O,onComplete:y}=l,f=_===true?"left":typeof _=="string"?_:false,k=typeof d=="function"?d:ae[d]??ae.linear,ge=le(F.start??"top bottom"),a=le(F.end??"bottom top"),g=typeof K=="string"?document.querySelector(K):K??null,re=Array.isArray(A)?A[0]:null,z=Array.isArray(A)?A[1]:typeof A=="string"?A:null,U=Array.isArray(C)?C[0]:null,oe=Array.isArray(C)?C[1]:typeof C=="number"?C:null,N=Array.isArray($)?$[0]:null,G=Array.isArray($)?$[1]:typeof $=="number"?$:null;function me(o){let i=o*100;switch(f){case "right":return `inset(0 0 0 ${100-i}%)`;case "top":return `inset(0 0 ${100-i}% 0)`;case "bottom":return `inset(${100-i}% 0 0 0)`;case "center":return `circle(${o*150}% at 50% 50%)`;default:return `inset(0 ${100-i}% 0 0)`}}let ee=f?[]:Array.from(e.querySelectorAll(m)),j=[],he=[],Te=0,Ae=0,ie=false,ye=false,te=0,Ne=false,be=-1,He=-1,ce=false,Pe=0,xe=0,Me,Be=null,Ce=new Set,Ve=-1,st=performance.now();function ke(){return g?q==="x"?g.scrollLeft:g.scrollTop:q==="x"?window.scrollX:window.scrollY}function it(){return g?q==="x"?g.clientWidth:g.clientHeight:q==="x"?window.innerWidth:window.innerHeight}function at(){let o=e.getBoundingClientRect(),i,v,X;if(g){let ue=g.getBoundingClientRect();i=q==="x"?o.left-ue.left+g.scrollLeft:o.top-ue.top+g.scrollTop,v=q==="x"?o.width:o.height,X=ke();}else i=q==="x"?o.left:o.top,v=q==="x"?o.width:o.height,X=ke();let fe=pe({top:i,height:v},X,it(),ge,a);Te=fe.tStart,Ae=fe.tEnd,de&&process.env.NODE_ENV!=="production"&&(Be?.remove(),Be=Ft(Te,Ae,q));}function Et(o,i){if(e.style.setProperty("--scroll-draw-progress",String(o)),f){let v=i==="reverse"?1-o:o;e.style.clipPath=me(v);return}ee.forEach((v,X)=>{v.style.strokeDashoffset=i==="reverse"?`${j[X]*o}`:`${j[X]*(1-o)}`,u&&(v.style.opacity=i==="reverse"?`${1-o}`:`${o}`),re&&z?v.style.stroke=De(re,z,o):z&&(v.style.stroke=z),U!==null&&oe!==null?v.style.strokeWidth=`${U+(oe-U)*o}`:oe!==null&&(v.style.strokeWidth=`${oe}`),N!==null&&G!==null?v.style.fillOpacity=`${N+(G-N)*o}`:G!==null&&(v.style.fillOpacity=`${G}`),P&&v.tagName.toLowerCase()==="path"&&he[X]&&v.setAttribute("d",Xe(he[X],P,o));});}function ze(){if(e.style.setProperty("--scroll-draw-progress","0"),f){e.style.clipPath=me(0);return}ee.forEach((o,i)=>{o.style.strokeDasharray=`${j[i]}`,o.style.strokeDashoffset=S==="reverse"?"0":`${j[i]}`,u?o.style.opacity=S==="reverse"?"1":"0":o.style.opacity="",re&&(o.style.stroke=re),U!==null&&(o.style.strokeWidth=`${U}`),N!==null&&(o.style.fillOpacity=`${N}`),P&&o.tagName.toLowerCase()==="path"&&he[i]&&o.setAttribute("d",he[i]);});}if(ee.forEach(o=>{Ot(o);let i=_e(o);j.push(i),o.tagName.toLowerCase()==="path"?he.push(o.getAttribute("d")??""):he.push(""),s?(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=S==="reverse"?`${i}`:"0",u&&(o.style.opacity="1"),z&&(o.style.stroke=z),oe!==null&&(o.style.strokeWidth=`${oe}`),G!==null&&(o.style.fillOpacity=`${G}`),P&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",P)):(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=S==="reverse"?"0":`${i}`,u?o.style.opacity=S==="reverse"?"1":"0":o.style.opacity="",re&&(o.style.stroke=re),U!==null&&(o.style.strokeWidth=`${U}`),N!==null&&(o.style.fillOpacity=`${N}`));}),f){if(s)return e.style.clipPath=me(1),y?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=me(0);}else if(s)return y?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function xt(){return !(se===false||!Pt()||!ee.length||typeof d!="string"||!(d in pt)||f||q!=="y"||g||c!==1||B!==0||ne||T||L!==false||P||b||M||R>0||p||O||y||A!=null||C!=null||$!=null||(F.start??"top bottom").trim()!=="top bottom"||(F.end??"bottom top").trim()!=="bottom top")}function Tt(){let o=`svg-scroll-draw-${++Lt}`,i=S==="reverse"?"0":"var(--ssd-len)",v=S==="reverse"?"var(--ssd-len)":"0",X=`stroke-dashoffset:${i};`,fe=`stroke-dashoffset:${v};`;u&&(X+=`opacity:${S==="reverse"?1:0};`,fe+=`opacity:${S==="reverse"?0:1};`);let ue=document.createElement("style");ue.setAttribute("data-svg-scroll-draw",""),ue.textContent=`@keyframes ${o}{from{${X}}to{${fe}}}.${o}{animation-name:${o};animation-duration:auto;animation-timing-function:${pt[d]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(ue);function w(h,x){h.style.setProperty("--ssd-len",String(j[x])),h.style.strokeDasharray=`${j[x]}`,h.style.strokeDashoffset="",h.style.opacity="",h.style.animationPlayState="",h.classList.add(o);}ee.forEach(w);let H=false,Z=-1;function E(){if(Z>=0)return Z;let h=e.getBoundingClientRect(),{tStart:x,tEnd:W}=pe({top:h.top,height:h.height},ke(),it(),ge,a);return k(J(ke(),x,W,c))}return {destroy(){ee.forEach(h=>{h.classList.remove(o),h.style.removeProperty("--ssd-len"),h.style.animationPlayState="";}),ue.remove();},replay(){H=false,Z=-1,ee.forEach(w);},pause(){H=true,ee.forEach(h=>{h.style.animationPlayState="paused";});},resume(){H&&(H=false,ee.forEach(h=>{h.style.animationPlayState="running";}));},seek(h){let x=Math.min(1,Math.max(0,h));Z=x,H=true,ee.forEach((W,Oe)=>{W.classList.remove(o),W.style.strokeDashoffset=S==="reverse"?`${j[Oe]*x}`:`${j[Oe]*(1-x)}`,u&&(W.style.opacity=S==="reverse"?`${1-x}`:`${x}`);});},getProgress(){return E()}}}if(xt())return Tt();function At(){let o=Math.max(1,Y),i=0,v=0;function X(E){let h=true;if(f){let x=Math.min(1,Math.max(0,E/o)),W=k(x);Pe=W,e.style.setProperty("--scroll-draw-progress",String(W)),e.style.clipPath=me(S==="reverse"?1-W:W),p?.(W),x<1&&(h=false);}else ee.forEach((x,W)=>{let Oe=W*B*o,Fe=Math.min(1,Math.max(0,(E-Oe)/o)),we=k(Fe);x.style.strokeDashoffset=S==="reverse"?`${j[W]*we}`:`${j[W]*(1-we)}`,u&&(x.style.opacity=S==="reverse"?`${1-we}`:`${we}`),re&&z?x.style.stroke=De(re,z,we):z&&(x.style.stroke=z),U!==null&&oe!==null?x.style.strokeWidth=`${U+(oe-U)*we}`:oe!==null&&(x.style.strokeWidth=`${oe}`),N!==null&&G!==null?x.style.fillOpacity=`${N+(G-N)*we}`:G!==null&&(x.style.fillOpacity=`${G}`),P&&x.tagName.toLowerCase()==="path"&&he[W]&&x.setAttribute("d",Xe(he[W],P,we)),W===0&&(p?.(we),e.style.setProperty("--scroll-draw-progress",String(we))),Fe<1&&(h=false);});if(b){let x=Math.min(1,Math.max(0,E/o)),W=k(x);for(let Oe in b){let Fe=parseFloat(Oe);W>=Fe&&!Ce.has(Fe)&&(Ce.add(Fe),b[Oe]?.());}}return h}function fe(E){if(ce)return;let h=E-i;ye||(ye=true,O?.());let x=X(h);if(x&&!ie){ie=true,X(o*(1+Math.max(0,ee.length-1)*B)),y?.(),xe<(M==="infinite"?1/0:M??0)&&(xe++,Me=setTimeout(()=>{i=performance.now(),ye=false,ie=false,Ce.clear(),ze(),te=requestAnimationFrame(fe);},V));return}x||(te=requestAnimationFrame(fe));}function ue(){cancelAnimationFrame(te),clearTimeout(Me),i=performance.now(),v=0,ce=false,ye=false,ie=false,xe=0,Ce.clear(),ze(),te=requestAnimationFrame(fe);}let w=new IntersectionObserver(E=>{E.forEach(h=>{h.isIntersecting&&!(ne&&ie)?ue():!h.isIntersecting&&!ne&&!ie&&(cancelAnimationFrame(te),clearTimeout(Me),i=null);});},{root:g??null,threshold:D,rootMargin:I}),H;function Z(){clearTimeout(H),H=setTimeout(()=>{ee.forEach((E,h)=>{j[h]=_e(E),E.style.strokeDasharray=`${j[h]}`;});},150);}return window.addEventListener("resize",Z),window.addEventListener("orientationchange",Z),R>0?setTimeout(()=>w.observe(e),R):w.observe(e),{destroy(){cancelAnimationFrame(te),clearTimeout(Me),w.disconnect(),window.removeEventListener("resize",Z),window.removeEventListener("orientationchange",Z),clearTimeout(H);},replay(){xe=0,ue();},pause(){ce||(ce=true,v=performance.now()-i,cancelAnimationFrame(te));},resume(){ce&&(ce=false,i=performance.now()-v,te=requestAnimationFrame(fe));},seek(E){let h=Math.min(1,Math.max(0,E));Pe=h,ce=true,v=h*o,i=performance.now()-v,cancelAnimationFrame(te),X(v);},getProgress(){return Pe}}}if(Q)return At();at();function qe(){if(!Ne||ce)return;let o=performance.now(),i=ke(),v=c;if(L!==false){let w=o-st,H=w>0?Math.abs(i-(Ve<0?i:Ve))/w:0;v=c*Math.max(.2,1+H*(typeof L=="number"?L:1)*.04);}Ve=i,st=o;let X=T?He===-1||i>=He?"forward":"reverse":S;He=i;let fe=Ae-Te,ue=true;if(f){let w=k(J(i,Te,Ae,v));ne&&!T&&(be=Math.max(be,w),w=be),Pe=w,e.style.setProperty("--scroll-draw-progress",String(w));let H=X==="reverse"?1-w:w;e.style.clipPath=me(H),p?.(w),!ye&&J(i,Te,Ae,v)>0&&(ye=true,O?.()),w>=1&&!ie?(ie=true,y?.(),xe<(M==="infinite"?1/0:M??0)&&(xe++,Me=setTimeout(()=>{be=-1,ye=false,ie=false,e.style.clipPath=me(0);},V))):w<1&&!ne&&(ie=false),te=requestAnimationFrame(qe);return}if(ee.forEach((w,H)=>{let Z=H*B*fe,E=k(J(i,Te+Z,Ae+Z,v));ne&&!T&&(be=Math.max(be,E),E=be),Pe=E,w.style.strokeDashoffset=X==="reverse"?`${j[H]*E}`:`${j[H]*(1-E)}`,u&&(w.style.opacity=X==="reverse"?`${1-E}`:`${E}`),re&&z?w.style.stroke=De(re,z,E):z&&(w.style.stroke=z),U!==null&&oe!==null?w.style.strokeWidth=`${U+(oe-U)*E}`:oe!==null&&(w.style.strokeWidth=`${oe}`),N!==null&&G!==null?w.style.fillOpacity=`${N+(G-N)*E}`:G!==null&&(w.style.fillOpacity=`${G}`),P&&w.tagName.toLowerCase()==="path"&&he[H]&&w.setAttribute("d",Xe(he[H],P,E)),H===0&&(p?.(E),e.style.setProperty("--scroll-draw-progress",String(E))),E<1&&(ue=false);}),b){let w=k(J(i,Te,Ae,v));for(let H in b){let Z=parseFloat(H);w>=Z&&!Ce.has(Z)&&(Ce.add(Z),b[H]?.());}}!ye&&J(i,Te,Ae,v)>0&&(ye=true,O?.()),ue&&!ie?(ie=true,y?.(),xe<(M==="infinite"?1/0:M??0)&&(xe++,Me=setTimeout(()=>{be=-1,ye=false,ie=false,Ce.clear(),ze();},V))):!ue&&!ne&&(ie=false),te=requestAnimationFrame(qe);}let Ge=new IntersectionObserver(o=>{o.forEach(i=>{Ne=i.isIntersecting,Ne&&!ce?te=requestAnimationFrame(qe):cancelAnimationFrame(te);});},{root:g??null,threshold:D,rootMargin:I}),je;function We(){clearTimeout(je),je=setTimeout(()=>{ee.forEach((o,i)=>{j[i]=_e(o),o.style.strokeDasharray=`${j[i]}`;}),at();},150);}return window.addEventListener("resize",We),window.addEventListener("orientationchange",We),R>0?setTimeout(()=>Ge.observe(e),R):Ge.observe(e),{destroy(){cancelAnimationFrame(te),clearTimeout(Me),Ge.disconnect(),window.removeEventListener("resize",We),window.removeEventListener("orientationchange",We),clearTimeout(je),Be?.remove();},replay(){be=-1,He=-1,Ve=-1,ye=false,ie=false,xe=0,ce=false,Ce.clear(),clearTimeout(Me),ze();},pause(){ce=true,cancelAnimationFrame(te);},resume(){ce&&(ce=false,Ne&&(te=requestAnimationFrame(qe)));},seek(o){let i=Math.min(1,Math.max(0,o));Pe=i,be=i,ce=true,cancelAnimationFrame(te),Et(i,S);},getProgress(){return Pe}}}var dt=new Map;function $e(e,r){dt.set(e,r);}function Le(e){dt.delete(e);}function Dt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function gt(e){let r=[],n=/([\w]+)\(([^)]*)\)/g,t;for(;(t=n.exec(e))!==null;){let l=[],s=[],m=t[2].trim();if(m)for(let c of m.split(/[\s,]+/)){let u=c.match(/^([-+]?[\d.eE]+)(.*)$/);l.push(u?parseFloat(u[1]):0),s.push(u?u[2]:"");}r.push({fn:t[1],nums:l,units:s});}return r}function kt(e,r,n){let t=gt(e),l=gt(r);return t.length===0||t.length!==l.length?n<1?e:r:t.map((s,m)=>{let c=l[m];return s.fn!==c.fn||s.nums.length!==c.nums.length?n<1?`${s.fn}(${s.nums.map((u,d)=>`${u}${s.units[d]}`).join(", ")})`:`${c.fn}(${c.nums.map((u,d)=>`${u}${c.units[d]}`).join(", ")})`:`${s.fn}(${s.nums.map((u,d)=>`${u+(c.nums[d]-u)*n}${s.units[d]}`).join(", ")})`}).join(" ")}function yt(e,r,n){if(typeof e=="number"&&typeof r=="number")return String(e+(r-e)*n);let t=String(e),l=String(r);if(Dt(t))return De(t,l,n);if(t.includes("("))return kt(t,l,n);let s=t.match(/^([-+]?[\d.]+)(.*)$/),m=l.match(/^([-+]?[\d.]+)(.*)$/);if(s&&m){let c=parseFloat(s[1]),u=parseFloat(m[1]);return `${c+(u-c)*n}${s[2]||m[2]}`}return n<1?t:l}function It(e){return e.replace(/([A-Z])/g,r=>`-${r.toLowerCase()}`)}var ht={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Rt=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),Nt=0;function Ht(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Ue(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let{props:t,trigger:l={},easing:s="ease-out",speed:m=1,once:c=false,axis:u="y",scrollContainer:d,native:F=true,onProgress:B,onComplete:S}=r,ne=window.matchMedia("(prefers-reduced-motion: reduce)").matches,de=typeof s=="function"?s:ae[s]??ae["ease-out"],q=le(l.start??"top bottom"),K=le(l.end??"bottom top"),T=typeof d=="string"?document.querySelector(d):d??null,R=Object.entries(t).map(([a,g])=>({prop:It(a),from:Array.isArray(g)?g[0]:"",to:Array.isArray(g)?g[1]:g}));function A(){let a=window.getComputedStyle(e);for(let g of R)g.from===""&&(g.from=a.getPropertyValue(g.prop).trim()||"0");}function C(){for(let a of R)e.style.setProperty(a.prop,String(a.to));}if(ne)return C(),S?.(),n;A();function $(){if(!F||!Ht()||typeof s!="string"||!(s in ht)||u!=="y"||T||c||m!==1||B||S||(l.start??"top bottom").trim()!=="top bottom"||(l.end??"bottom top").trim()!=="bottom top")return false;for(let a of R)if(!Rt.has(a.prop))return false;return true}function b(){let a=`ssd-a-${++Nt}`,g=R.map(N=>`${N.prop}:${N.from}`).join(";"),re=R.map(N=>`${N.prop}:${N.to}`).join(";"),z=document.createElement("style");z.setAttribute("data-ssd-animate",""),z.textContent=`@keyframes ${a}{from{${g}}to{${re}}}.${a}{animation-name:${a};animation-duration:auto;animation-timing-function:${ht[s]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(z),e.classList.add(a);let U=()=>u==="x"?window.scrollX:window.scrollY,oe=()=>u==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(a),z.remove();},replay(){e.classList.remove(a),e.offsetWidth,e.classList.add(a);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(N){let G=Math.min(1,Math.max(0,N));e.classList.remove(a);for(let me of R)e.style.setProperty(me.prop,yt(me.from,me.to,G));},getProgress(){let N=e.getBoundingClientRect(),G=U(),me=oe(),{tStart:ee,tEnd:j}=pe({top:N.top,height:N.height},G,me,q,K);return de(J(G,ee,j,m))}}}if($())return b();let L=0,D=0,I=0,M=false,V=false,P=-1,_=0,Q=false,Y=()=>T?u==="x"?T.scrollLeft:T.scrollTop:u==="x"?window.scrollX:window.scrollY,se=()=>T?u==="x"?T.clientWidth:T.clientHeight:u==="x"?window.innerWidth:window.innerHeight;function p(){let a=e.getBoundingClientRect(),g,re;if(T){let U=T.getBoundingClientRect();g=u==="x"?a.left-U.left+T.scrollLeft:a.top-U.top+T.scrollTop,re=u==="x"?a.width:a.height;}else g=u==="x"?a.left:a.top,re=u==="x"?a.width:a.height;let z=pe({top:g,height:re},Y(),se(),q,K);L=z.tStart,D=z.tEnd;}function O(a){e.style.setProperty("--scroll-draw-progress",String(a));for(let g of R)e.style.setProperty(g.prop,yt(g.from,g.to,a));B?.(a);}function y(){if(!M||V)return;let a=de(J(Y(),L,D,m));c&&(P=Math.max(P,a),a=P),_=a,O(a),a>=1&&!Q?(Q=true,S?.()):a<1&&!c&&(Q=false),I=requestAnimationFrame(y);}p();{let a=de(J(Y(),L,D,m));c&&a>0&&(P=a),_=a,O(a);}let f=new IntersectionObserver(a=>{a.forEach(g=>{M=g.isIntersecting,M&&!V?I=requestAnimationFrame(y):cancelAnimationFrame(I);});},{root:T??null}),k;function ge(){clearTimeout(k),k=setTimeout(p,150);}return window.addEventListener("resize",ge),window.addEventListener("orientationchange",ge),f.observe(e),$e(e,{type:"animate",getProgress:()=>_,getTrigger:()=>({tStart:L,tEnd:D})}),{destroy(){cancelAnimationFrame(I),f.disconnect(),window.removeEventListener("resize",ge),window.removeEventListener("orientationchange",ge),clearTimeout(k),Le(e);},replay(){P=-1,Q=false,_=0,V=false,O(0);},pause(){V=true,cancelAnimationFrame(I);},resume(){V&&(V=false,M&&(I=requestAnimationFrame(y)));},seek(a){let g=Math.min(1,Math.max(0,a));_=g,P=g,V=true,cancelAnimationFrame(I),O(g);},getProgress(){return _}}}var Ze={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Je(e,r){if(typeof window>"u")return Ze;let n=typeof e=="string"?document.querySelector(e):e;if(!n)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollCounter: element not found:",e),Ze;let t=n,{from:l=0,to:s,format:m,easing:c="ease-out",trigger:u={},once:d=true,decimals:F,onComplete:B}=r,S=F!==void 0?p=>p.toFixed(F):m??(p=>String(Math.round(p))),ne=typeof c=="function"?c:ae[c]??ae["ease-out"],de=le(u.start??"top 80%"),q=le(u.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=S(s),B?.(),Ze;t.textContent=S(l);let T=0,R=0,A=0,C=false,$=false,b=-1,L=0,D=false,I=()=>window.scrollY,M=()=>window.innerHeight;function V(){let p=t.getBoundingClientRect(),O=pe({top:p.top,height:p.height},I(),M(),de,q);T=O.tStart,R=O.tEnd;}function P(p){t.textContent=S(l+(s-l)*p),t.style.setProperty("--scroll-draw-progress",String(p));}function _(){if(!C||$)return;let p=ne(J(I(),T,R,1));d&&(b=Math.max(b,p),p=b),L=p,P(p),p>=1&&!D?(D=true,B?.()):p<1&&!d&&(D=false),A=requestAnimationFrame(_);}V();{let p=ne(J(I(),T,R,1));d&&p>0&&(b=p),L=p,P(p);}let Q=new IntersectionObserver(p=>{p.forEach(O=>{C=O.isIntersecting,C&&!$?A=requestAnimationFrame(_):cancelAnimationFrame(A);});}),Y;function se(){clearTimeout(Y),Y=setTimeout(V,150);}return window.addEventListener("resize",se),window.addEventListener("orientationchange",se),Q.observe(t),$e(t,{type:"counter",getProgress:()=>L,getTrigger:()=>({tStart:T,tEnd:R})}),{destroy(){cancelAnimationFrame(A),Q.disconnect(),window.removeEventListener("resize",se),window.removeEventListener("orientationchange",se),clearTimeout(Y),Le(t);},replay(){b=-1,D=false,L=0,$=false,P(0);},pause(){$=true,cancelAnimationFrame(A);},resume(){$&&($=false,C&&(A=requestAnimationFrame(_)));},seek(p){let O=Math.min(1,Math.max(0,p));L=O,b=O,$=true,cancelAnimationFrame(A),P(O);},getProgress(){return L}}}var bt={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Ke(e,r={}){if(typeof window>"u")return bt;let n=typeof e=="string"?document.querySelector(e):e;if(!n||n.tagName.toLowerCase()!=="video")return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollVideo: <video> element not found:",e),bt;let t=n,{trigger:l={},easing:s="linear",once:m=false,axis:c="y",preload:u="auto",onReady:d,onComplete:F,onProgress:B}=r,S=window.matchMedia("(prefers-reduced-motion: reduce)").matches,ne=typeof s=="function"?s:ae[s]??ae.linear,de=le(l.start??"top top"),q=le(l.end??"bottom top");t.pause(),t.hasAttribute("preload")||(t.preload=u);let K=r.from??0,T=r.to,R=0,A=0,C=0,$=false,b=false,L=-1,D=0,I=false,M=false,V=()=>c==="x"?window.scrollX:window.scrollY,P=()=>c==="x"?window.innerWidth:window.innerHeight;function _(){let f=t.getBoundingClientRect(),k=c==="x"?f.left:f.top,ge=c==="x"?f.width:f.height,a=pe({top:k,height:ge},V(),P(),de,q);R=a.tStart,A=a.tEnd;}function Q(f){if(!M)return;let k=T??t.duration??0;t.currentTime=K+(k-K)*f,t.style.setProperty("--scroll-draw-progress",String(f)),B?.(f);}function Y(){if(!$||b||!M)return;let f=ne(J(V(),R,A,1));m&&(L=Math.max(L,f),f=L),D=f,Q(f),f>=1&&!I?(I=true,F?.()):f<1&&!m&&(I=false),C=requestAnimationFrame(Y);}function se(){if(M=true,T===void 0&&(T=t.duration),S){Q(1),d?.();return}_(),d?.(),$&&!b&&(C=requestAnimationFrame(Y));}t.readyState>=1?se():t.addEventListener("loadedmetadata",se,{once:true}),M||_();let p=new IntersectionObserver(f=>{f.forEach(k=>{$=k.isIntersecting,$&&!b&&M?C=requestAnimationFrame(Y):cancelAnimationFrame(C);});}),O;function y(){clearTimeout(O),O=setTimeout(_,150);}return window.addEventListener("resize",y),window.addEventListener("orientationchange",y),p.observe(t),$e(t,{type:"video",getProgress:()=>D,getTrigger:()=>({tStart:R,tEnd:A})}),{destroy(){cancelAnimationFrame(C),p.disconnect(),t.removeEventListener("loadedmetadata",se),window.removeEventListener("resize",y),window.removeEventListener("orientationchange",y),clearTimeout(O),Le(t);},replay(){L=-1,I=false,D=0,b=false,Q(0);},pause(){b=true,cancelAnimationFrame(C);},resume(){b&&(b=false,$&&M&&(C=requestAnimationFrame(Y)));},seek(f){let k=Math.min(1,Math.max(0,f));D=k,L=k,b=true,cancelAnimationFrame(C),Q(k);},getProgress(){return D}}}function St(e){let r=e.textContent??"";return e.textContent="",r.split(/(\s+)/).filter(Boolean).map(n=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),/^\s+$/.test(n)?(t.textContent=n,t.style.whiteSpace="pre"):(t.textContent=n,t.style.display="inline-block"),e.appendChild(t),/^\s+$/.test(n)?null:t}).filter(n=>n!==null)}function Vt(e){let r=e.textContent??"";return e.textContent="",r.split("").map(n=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),t.textContent=n,n===" "?t.style.whiteSpace="pre":t.style.display="inline-block",e.appendChild(t),n===" "?null:t}).filter(n=>n!==null)}function wt(e){let r=St(e),n=new Map;for(let s of r){let m=s.offsetTop;n.has(m)||n.set(m,[]),n.get(m).push(s);}let t=[],l=Array.from(n.keys()).sort((s,m)=>s-m);for(let s of l){let m=n.get(s),c=document.createElement("span");c.setAttribute("aria-hidden","true"),c.style.display="inline-block";for(let u of m)c.appendChild(u);t.push(c);}e.textContent="";for(let s of t)e.appendChild(s),e.appendChild(document.createTextNode(" "));return t}function zt(e,r,n,t){if(n<=1||t===0)return e;let l=(n-1)*t,s=r*t,m=s+(1-l);return m<=s?e>=s?1:0:Math.min(1,Math.max(0,(e-s)/(m-s)))}function qt(e,r){let n=[];if(r?.y!==void 0&&n.push(`translateY(${r.y*(1-e)}px)`),r?.x!==void 0&&n.push(`translateX(${r.x*(1-e)}px)`),r?.rotate!==void 0&&n.push(`rotate(${r.rotate*(1-e)}deg)`),r?.scale!==void 0){let t=r.scale+(1-r.scale)*e;n.push(`scale(${t})`);}return n.join(" ")||""}var vt={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Qe(e,r={}){if(typeof window>"u")return vt;let n=typeof e=="string"?document.querySelector(e):e;if(!n)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollText: element not found:",e),vt;let t=n,{split:l="words",stagger:s=.04,easing:m="ease-out",from:c={opacity:0,y:24},trigger:u={},once:d=true,onComplete:F}=r,B=window.matchMedia("(prefers-reduced-motion: reduce)").matches,S=typeof m=="function"?m:ae[m]??ae["ease-out"],ne=le(u.start??"top 85%"),de=le(u.end??"top 40%"),q=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let K;l==="chars"?K=Vt(t):l==="lines"?K=wt(t):K=St(t);let T=K.length;function R(y,f){c?.opacity!==void 0&&(y.style.opacity=String(c.opacity+(1-c.opacity)*f));let k=qt(f,c);k&&(y.style.transform=k);}function A(y){t.style.setProperty("--scroll-draw-progress",String(y)),K.forEach((f,k)=>{let ge=S(zt(y,k,T,s));R(f,ge);});}if(B)return A(1),F?.(),{destroy(){t.innerHTML=q,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};A(0);let C=0,$=0,b=0,L=false,D=false,I=-1,M=0,V=false,P=()=>window.scrollY,_=()=>window.innerHeight;function Q(){let y=t.getBoundingClientRect(),f=pe({top:y.top,height:y.height},P(),_(),ne,de);C=f.tStart,$=f.tEnd;}function Y(){if(!L||D)return;let y=J(P(),C,$,1);d&&(I=Math.max(I,y),y=I),M=y,A(y),y>=1&&!V?(V=true,F?.()):y<1&&!d&&(V=false),b=requestAnimationFrame(Y);}Q();let se=new IntersectionObserver(y=>{y.forEach(f=>{L=f.isIntersecting,L&&!D?b=requestAnimationFrame(Y):cancelAnimationFrame(b);});}),p;function O(){clearTimeout(p),p=setTimeout(()=>{if(l==="lines"){let y=M;t.innerHTML=q,t.setAttribute("aria-label",t.textContent??""),K=wt(t),A(y);}Q();},150);}return window.addEventListener("resize",O),window.addEventListener("orientationchange",O),se.observe(t),$e(t,{type:"text",getProgress:()=>M,getTrigger:()=>({tStart:C,tEnd:$})}),{destroy(){cancelAnimationFrame(b),se.disconnect(),window.removeEventListener("resize",O),window.removeEventListener("orientationchange",O),clearTimeout(p),t.innerHTML=q,t.removeAttribute("aria-label"),Le(t);},replay(){I=-1,V=false,M=0,D=false,A(0);},pause(){D=true,cancelAnimationFrame(b);},resume(){D&&(D=false,L&&(b=requestAnimationFrame(Y)));},seek(y){let f=Math.min(1,Math.max(0,y));M=f,I=f,D=true,cancelAnimationFrame(b),A(f);},getProgress(){return M}}}function Wt(e={}){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=Ye(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var et=vue.defineComponent({name:"ScrollDraw",props:{selector:{type:String},speed:{type:Number},fade:{type:Boolean},stagger:{type:Number},easing:{type:[String,Function]},direction:{type:String},trigger:{type:Object},onProgress:{type:Function},onStart:{type:Function},onComplete:{type:Function},once:{type:Boolean},debug:{type:Boolean}},setup(e,{slots:r}){let n=vue.ref(null);return vue.onMounted(()=>{if(!n.value)return;let t={};e.selector!=null&&(t.selector=e.selector),e.speed!=null&&(t.speed=e.speed),e.fade!=null&&(t.fade=e.fade),e.stagger!=null&&(t.stagger=e.stagger),e.easing!=null&&(t.easing=e.easing),e.direction!=null&&(t.direction=e.direction),e.trigger!=null&&(t.trigger=e.trigger),e.once!=null&&(t.once=e.once),e.debug!=null&&(t.debug=e.debug),e.onProgress!=null&&(t.onProgress=e.onProgress),e.onStart!=null&&(t.onStart=e.onStart),e.onComplete!=null&&(t.onComplete=e.onComplete);let l=Ye(n.value,t);vue.onUnmounted(()=>l.destroy());}),()=>vue.h("div",{ref:n},r.default?.())}});function _t(e){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=Ue(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var tt=vue.defineComponent({name:"ScrollAnimate",props:{options:{type:Object,required:true}},setup(e,{slots:r}){let n=vue.ref(null);return vue.onMounted(()=>{if(!n.value)return;let t=Ue(n.value,e.options);vue.onUnmounted(()=>t.destroy());}),()=>vue.h("div",{ref:n},r.default?.())}});function Bt(e){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=Je(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var nt=vue.defineComponent({name:"ScrollCounter",props:{to:{type:Number,required:true},from:{type:Number},format:{type:Function},easing:{type:[String,Function]},trigger:{type:Object},once:{type:Boolean},decimals:{type:Number},onComplete:{type:Function}},setup(e){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n={to:e.to};e.from!=null&&(n.from=e.from),e.format!=null&&(n.format=e.format),e.easing!=null&&(n.easing=e.easing),e.trigger!=null&&(n.trigger=e.trigger),e.once!=null&&(n.once=e.once),e.decimals!=null&&(n.decimals=e.decimals),e.onComplete!=null&&(n.onComplete=e.onComplete);let t=Je(r.value,n);vue.onUnmounted(()=>t.destroy());}),()=>vue.h("span",{ref:r})}});function Gt(e={}){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=Ke(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var rt=vue.defineComponent({name:"ScrollVideo",props:{src:{type:String,required:true},options:{type:Object},muted:{type:Boolean,default:true},playsInline:{type:Boolean,default:true},class:{type:String}},setup(e){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=Ke(r.value,e.options??{});vue.onUnmounted(()=>n.destroy());}),()=>vue.h("video",{ref:r,src:e.src,muted:e.muted,playsinline:e.playsInline,preload:"auto",class:e.class})}});function jt(e={}){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=Qe(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var ot=vue.defineComponent({name:"ScrollText",props:{options:{type:Object},tag:{type:String,default:"p"}},setup(e,{slots:r}){let n=vue.ref(null);return vue.onMounted(()=>{if(!n.value)return;let t=Qe(n.value,e.options??{});vue.onUnmounted(()=>t.destroy());}),()=>vue.h(e.tag,{ref:n},r.default?.())}});function vn(){return {install(e){e.component("ScrollDraw",et),e.component("ScrollAnimate",tt),e.component("ScrollCounter",nt),e.component("ScrollVideo",rt),e.component("ScrollText",ot);}}}exports.ScrollAnimate=tt;exports.ScrollCounter=nt;exports.ScrollDraw=et;exports.ScrollText=ot;exports.ScrollVideo=rt;exports.createScrollDrawPlugin=vn;exports.useScrollAnimate=_t;exports.useScrollCounter=Bt;exports.useScrollDraw=Wt;exports.useScrollText=jt;exports.useScrollVideo=Gt;