svg-scroll-draw 2.6.0 → 2.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (66) hide show
  1. package/dist/angular/index.cjs +3 -3
  2. package/dist/angular/index.d.mts +22 -0
  3. package/dist/angular/index.d.ts +22 -0
  4. package/dist/angular/index.mjs +3 -3
  5. package/dist/astro/index.cjs +3 -3
  6. package/dist/astro/index.d.mts +8 -0
  7. package/dist/astro/index.d.ts +8 -0
  8. package/dist/astro/index.mjs +3 -3
  9. package/dist/cdn/svg-scroll-draw.global.js +3 -3
  10. package/dist/devtools/index.cjs +1 -1
  11. package/dist/devtools/index.mjs +1 -1
  12. package/dist/group/index.cjs +3 -3
  13. package/dist/group/index.d.mts +22 -0
  14. package/dist/group/index.d.ts +22 -0
  15. package/dist/group/index.mjs +3 -3
  16. package/dist/horizontal/index.cjs +1 -0
  17. package/dist/horizontal/index.d.mts +61 -0
  18. package/dist/horizontal/index.d.ts +61 -0
  19. package/dist/horizontal/index.mjs +1 -0
  20. package/dist/index.cjs +4 -4
  21. package/dist/index.d.mts +22 -0
  22. package/dist/index.d.ts +22 -0
  23. package/dist/index.mjs +4 -4
  24. package/dist/lenis/index.cjs +1 -0
  25. package/dist/lenis/index.d.mts +51 -0
  26. package/dist/lenis/index.d.ts +51 -0
  27. package/dist/lenis/index.mjs +1 -0
  28. package/dist/nuxt/index.cjs +2 -2
  29. package/dist/nuxt/index.d.mts +22 -0
  30. package/dist/nuxt/index.d.ts +22 -0
  31. package/dist/nuxt/index.mjs +2 -2
  32. package/dist/pin/index.cjs +1 -0
  33. package/dist/pin/index.d.mts +29 -0
  34. package/dist/pin/index.d.ts +29 -0
  35. package/dist/pin/index.mjs +1 -0
  36. package/dist/progress/index.cjs +1 -0
  37. package/dist/progress/index.d.mts +59 -0
  38. package/dist/progress/index.d.ts +59 -0
  39. package/dist/progress/index.mjs +1 -0
  40. package/dist/react/index.cjs +3 -3
  41. package/dist/react/index.d.mts +22 -0
  42. package/dist/react/index.d.ts +22 -0
  43. package/dist/react/index.mjs +3 -3
  44. package/dist/reveal/index.cjs +1 -0
  45. package/dist/reveal/index.d.mts +80 -0
  46. package/dist/reveal/index.d.ts +80 -0
  47. package/dist/reveal/index.mjs +1 -0
  48. package/dist/snap/index.cjs +1 -0
  49. package/dist/snap/index.d.mts +30 -0
  50. package/dist/snap/index.d.ts +30 -0
  51. package/dist/snap/index.mjs +1 -0
  52. package/dist/solid/index.cjs +3 -3
  53. package/dist/solid/index.d.mts +22 -0
  54. package/dist/solid/index.d.ts +22 -0
  55. package/dist/solid/index.mjs +3 -3
  56. package/dist/svelte/index.cjs +3 -3
  57. package/dist/svelte/index.d.mts +22 -0
  58. package/dist/svelte/index.d.ts +22 -0
  59. package/dist/svelte/index.mjs +3 -3
  60. package/dist/vue/index.cjs +2 -2
  61. package/dist/vue/index.d.mts +22 -0
  62. package/dist/vue/index.d.ts +22 -0
  63. package/dist/vue/index.mjs +2 -2
  64. package/dist/web-component/index.cjs +3 -3
  65. package/dist/web-component/index.mjs +3 -3
  66. package/package.json +31 -1
@@ -1,3 +1,3 @@
1
- import {defineComponent,ref,onMounted,onUnmounted,h}from'vue';function Mt({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,r)),l=Math.sqrt(t),s=0,m=[];for(let 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=`
1
+ import {defineComponent,ref,onMounted,onUnmounted,h}from'vue';function Ot({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,r)),l=Math.sqrt(t),s=0,m=[];for(let h=0;h<n;h++){let P=Math.pow(l,h);m.push(P),s+=P;}let c=[0],u=0;for(let h=0;h<n;h++)u+=m[h]/s,c.push(u);return h=>{if(h<=0)return 0;if(h>=1)return 1;for(let P=0;P<n;P++)if(h<=c[P+1]){let H=(h-c[P])/(c[P+1]-c[P]);if(P===0)return H*(2-H);let S=1-Math.pow(t,P);return S+(1-S)*(2*H-1)*(2*H-1)}return 1}}function kt({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:Ot(),elastic:kt()};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 pt(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 dt(e,r){if(/^\d+(\.\d+)?%$/.test(e))return r*(parseFloat(e)/100);switch(e){case "top":return 0;case "center":return r/2;case "bottom":return r;default:return r}}function Ye(e){let r=e.tagName.toLowerCase();if(r==="rect"){let n=parseFloat(e.getAttribute("width")??"0"),t=parseFloat(e.getAttribute("height")??"0");return 2*(n+t)}if(r==="circle"){let n=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*n}return e.getTotalLength()}function Ft(e,r,n){return Math.min(n,Math.max(r,e))}function Q(e,r,n,t){return n===r?0:Ft((e-r)/(n-r)*t,0,1)}function ye(e,r,n,t,l){let s=pt(e.top,e.height,r,t.element)-dt(t.viewport,n),m=pt(e.top,e.height,r,l.element)-dt(l.viewport,n);return {tStart:s,tEnd:m}}function gt(e){let r=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(r)return [parseInt(r[1]+r[1],16),parseInt(r[2]+r[2],16),parseInt(r[3]+r[3],16)];let n=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(n)return [parseInt(n[1],16),parseInt(n[2],16),parseInt(n[3],16)];let t=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return t?[parseInt(t[1]),parseInt(t[2]),parseInt(t[3])]:null}function Re(e,r,n){let t=gt(e),l=gt(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 yt={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 ht(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r);}var bt={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Dt=0;function It(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Nt(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?ht("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&ht("Element has a fill \u2014 it may obscure the stroke animation.",e);}function Rt(e,r,n){let t=document.createElement("div");t.setAttribute("data-svg-scroll-draw-debug",""),t.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function l(){let s=n==="x"?window.scrollX:window.scrollY,m=e-s,c=r-s,u=n==="x";t.innerHTML=`
2
2
  <div style="position:absolute;${u?`left:${m}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${m}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
3
- <div style="position:absolute;${u?`left:${c}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${c}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(t),window.addEventListener("scroll",l,{passive:true}),l(),t}function Xe(e,r,n){let t=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),l=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,s=>{let m=parseFloat(s),c=t[l++]??m;return String(+(m+(c-m)*n).toFixed(4))})}function Ye(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:n,...t}=r,l=n?{...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=ref(null);return onMounted(()=>{if(!r.value)return;let n=Ye(r.value,e);onUnmounted(()=>n.destroy());}),r}var et=defineComponent({name:"ScrollDraw",props:{selector:{type:String},speed:{type:Number},fade:{type:Boolean},stagger:{type:Number},easing:{type:[String,Function]},direction:{type:String},trigger:{type:Object},onProgress:{type:Function},onStart:{type:Function},onComplete:{type:Function},once:{type:Boolean},debug:{type:Boolean}},setup(e,{slots:r}){let n=ref(null);return onMounted(()=>{if(!n.value)return;let t={};e.selector!=null&&(t.selector=e.selector),e.speed!=null&&(t.speed=e.speed),e.fade!=null&&(t.fade=e.fade),e.stagger!=null&&(t.stagger=e.stagger),e.easing!=null&&(t.easing=e.easing),e.direction!=null&&(t.direction=e.direction),e.trigger!=null&&(t.trigger=e.trigger),e.once!=null&&(t.once=e.once),e.debug!=null&&(t.debug=e.debug),e.onProgress!=null&&(t.onProgress=e.onProgress),e.onStart!=null&&(t.onStart=e.onStart),e.onComplete!=null&&(t.onComplete=e.onComplete);let l=Ye(n.value,t);onUnmounted(()=>l.destroy());}),()=>h("div",{ref:n},r.default?.())}});function _t(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Ue(r.value,e);onUnmounted(()=>n.destroy());}),r}var tt=defineComponent({name:"ScrollAnimate",props:{options:{type:Object,required:true}},setup(e,{slots:r}){let n=ref(null);return onMounted(()=>{if(!n.value)return;let t=Ue(n.value,e.options);onUnmounted(()=>t.destroy());}),()=>h("div",{ref:n},r.default?.())}});function Bt(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Je(r.value,e);onUnmounted(()=>n.destroy());}),r}var nt=defineComponent({name:"ScrollCounter",props:{to:{type:Number,required:true},from:{type:Number},format:{type:Function},easing:{type:[String,Function]},trigger:{type:Object},once:{type:Boolean},decimals:{type:Number},onComplete:{type:Function}},setup(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n={to:e.to};e.from!=null&&(n.from=e.from),e.format!=null&&(n.format=e.format),e.easing!=null&&(n.easing=e.easing),e.trigger!=null&&(n.trigger=e.trigger),e.once!=null&&(n.once=e.once),e.decimals!=null&&(n.decimals=e.decimals),e.onComplete!=null&&(n.onComplete=e.onComplete);let t=Je(r.value,n);onUnmounted(()=>t.destroy());}),()=>h("span",{ref:r})}});function Gt(e={}){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Ke(r.value,e);onUnmounted(()=>n.destroy());}),r}var rt=defineComponent({name:"ScrollVideo",props:{src:{type:String,required:true},options:{type:Object},muted:{type:Boolean,default:true},playsInline:{type:Boolean,default:true},class:{type:String}},setup(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Ke(r.value,e.options??{});onUnmounted(()=>n.destroy());}),()=>h("video",{ref:r,src:e.src,muted:e.muted,playsinline:e.playsInline,preload:"auto",class:e.class})}});function jt(e={}){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Qe(r.value,e);onUnmounted(()=>n.destroy());}),r}var ot=defineComponent({name:"ScrollText",props:{options:{type:Object},tag:{type:String,default:"p"}},setup(e,{slots:r}){let n=ref(null);return onMounted(()=>{if(!n.value)return;let t=Qe(n.value,e.options??{});onUnmounted(()=>t.destroy());}),()=>h(e.tag,{ref:n},r.default?.())}});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);}}}export{tt as ScrollAnimate,nt as ScrollCounter,et as ScrollDraw,ot as ScrollText,rt as ScrollVideo,vn as createScrollDrawPlugin,_t as useScrollAnimate,Bt as useScrollCounter,Wt as useScrollDraw,jt as useScrollText,Gt as useScrollVideo};
3
+ <div style="position:absolute;${u?`left:${c}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${c}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(t),window.addEventListener("scroll",l,{passive:true}),l(),t}function Ke(e,r,n){let t=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),l=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,s=>{let m=parseFloat(s),c=t[l++]??m;return String(+(m+(c-m)*n).toFixed(4))})}function Qe(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:n,...t}=r,l=n?{...yt[n],...t}:t,s=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:m="path, polyline, line, polygon, rect, circle",speed:c=1,fade:u=false,easing:h="linear",trigger:P={},stagger:H=0,direction:S="forward",once:Y=false,debug:he=false,axis:V="y",scrollContainer:ee,autoReverse:U=false,delay:Z=0,strokeColor:E,strokeWidth:M,fillOpacity:C,waypoints:g,velocityScale:x=false,threshold:k=0,rootMargin:G="0px",repeat:O=0,repeatDelay:se=0,morphTo:L,clip:W,autoplay:_=false,duration:j=1e3,native:z=true,onProgress:p,onStart:T,onComplete:b,onEnter:y,onLeave:q,onEnterBack:Ae,onLeaveBack:Me}=l,be=W===true?"left":typeof W=="string"?W:false,we=typeof h=="function"?h:ae[h]??ae.linear,ke=le(P.start??"top bottom"),qe=le(P.end??"bottom top"),te=typeof ee=="string"?document.querySelector(ee):ee??null,pe=Array.isArray(E)?E[0]:null,J=Array.isArray(E)?E[1]:typeof E=="string"?E:null,K=Array.isArray(M)?M[0]:null,i=Array.isArray(M)?M[1]:typeof M=="number"?M:null,d=Array.isArray(C)?C[0]:null,F=Array.isArray(C)?C[1]:typeof C=="number"?C:null;function ne(o){let a=o*100;switch(be){case "right":return `inset(0 0 0 ${100-a}%)`;case "top":return `inset(0 0 ${100-a}% 0)`;case "bottom":return `inset(${100-a}% 0 0 0)`;case "center":return `circle(${o*150}% at 50% 50%)`;default:return `inset(0 ${100-a}% 0 0)`}}let $=be?[]:Array.from(e.querySelectorAll(m)),R=[],D=[],ie=0,ce=0,re=false,de=false,oe=0,Be=false,ve=-1,We=-1,ue=false,Fe=0,Ce=0,Le,Ue=null,$e=new Set,_e=-1,ut=performance.now(),Ie=NaN;function He(){return te?V==="x"?te.scrollLeft:te.scrollTop:V==="x"?window.scrollX:window.scrollY}function ft(){return te?V==="x"?te.clientWidth:te.clientHeight:V==="x"?window.innerWidth:window.innerHeight}function mt(){let o=e.getBoundingClientRect(),a,v,X;if(te){let me=te.getBoundingClientRect();a=V==="x"?o.left-me.left+te.scrollLeft:o.top-me.top+te.scrollTop,v=V==="x"?o.width:o.height,X=He();}else a=V==="x"?o.left:o.top,v=V==="x"?o.width:o.height,X=He();let fe=ye({top:a,height:v},X,ft(),ke,qe);ie=fe.tStart,ce=fe.tEnd,he&&process.env.NODE_ENV!=="production"&&(Ue?.remove(),Ue=Rt(ie,ce,V));}function Ct(o,a){if(e.style.setProperty("--scroll-draw-progress",String(o)),be){let v=a==="reverse"?1-o:o;e.style.clipPath=ne(v);return}$.forEach((v,X)=>{v.style.strokeDashoffset=a==="reverse"?`${R[X]*o}`:`${R[X]*(1-o)}`,u&&(v.style.opacity=a==="reverse"?`${1-o}`:`${o}`),pe&&J?v.style.stroke=Re(pe,J,o):J&&(v.style.stroke=J),K!==null&&i!==null?v.style.strokeWidth=`${K+(i-K)*o}`:i!==null&&(v.style.strokeWidth=`${i}`),d!==null&&F!==null?v.style.fillOpacity=`${d+(F-d)*o}`:F!==null&&(v.style.fillOpacity=`${F}`),L&&v.tagName.toLowerCase()==="path"&&D[X]&&v.setAttribute("d",Ke(D[X],L,o));});}function Ge(){if(e.style.setProperty("--scroll-draw-progress","0"),be){e.style.clipPath=ne(0);return}$.forEach((o,a)=>{o.style.strokeDasharray=`${R[a]}`,o.style.strokeDashoffset=S==="reverse"?"0":`${R[a]}`,u?o.style.opacity=S==="reverse"?"1":"0":o.style.opacity="",pe&&(o.style.stroke=pe),K!==null&&(o.style.strokeWidth=`${K}`),d!==null&&(o.style.fillOpacity=`${d}`),L&&o.tagName.toLowerCase()==="path"&&D[a]&&o.setAttribute("d",D[a]);});}if($.forEach(o=>{Nt(o);let a=Ye(o);R.push(a),o.tagName.toLowerCase()==="path"?D.push(o.getAttribute("d")??""):D.push(""),s?(o.style.strokeDasharray=`${a}`,o.style.strokeDashoffset=S==="reverse"?`${a}`:"0",u&&(o.style.opacity="1"),J&&(o.style.stroke=J),i!==null&&(o.style.strokeWidth=`${i}`),F!==null&&(o.style.fillOpacity=`${F}`),L&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",L)):(o.style.strokeDasharray=`${a}`,o.style.strokeDashoffset=S==="reverse"?"0":`${a}`,u?o.style.opacity=S==="reverse"?"1":"0":o.style.opacity="",pe&&(o.style.stroke=pe),K!==null&&(o.style.strokeWidth=`${K}`),d!==null&&(o.style.fillOpacity=`${d}`));}),be){if(s)return e.style.clipPath=ne(1),b?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ne(0);}else if(s)return b?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Lt(){return !(z===false||!It()||!$.length||typeof h!="string"||!(h in bt)||be||V!=="y"||te||c!==1||H!==0||Y||U||x!==false||L||g||O||Z>0||p||T||b||y||q||Ae||Me||E!=null||M!=null||C!=null||(P.start??"top bottom").trim()!=="top bottom"||(P.end??"bottom top").trim()!=="bottom top")}function $t(){let o=`svg-scroll-draw-${++Dt}`,a=S==="reverse"?"0":"var(--ssd-len)",v=S==="reverse"?"var(--ssd-len)":"0",X=`stroke-dashoffset:${a};`,fe=`stroke-dashoffset:${v};`;u&&(X+=`opacity:${S==="reverse"?1:0};`,fe+=`opacity:${S==="reverse"?0:1};`);let me=document.createElement("style");me.setAttribute("data-svg-scroll-draw",""),me.textContent=`@keyframes ${o}{from{${X}}to{${fe}}}.${o}{animation-name:${o};animation-duration:auto;animation-timing-function:${bt[h]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(me);function ge(f,A){f.style.setProperty("--ssd-len",String(R[A])),f.style.strokeDasharray=`${R[A]}`,f.style.strokeDashoffset="",f.style.opacity="",f.style.animationPlayState="",f.classList.add(o);}$.forEach(ge);let w=false,I=-1;function N(){if(I>=0)return I;let f=e.getBoundingClientRect(),{tStart:A,tEnd:B}=ye({top:f.top,height:f.height},He(),ft(),ke,qe);return we(Q(He(),A,B,c))}return {destroy(){$.forEach(f=>{f.classList.remove(o),f.style.removeProperty("--ssd-len"),f.style.animationPlayState="";}),me.remove();},replay(){w=false,I=-1,$.forEach(ge);},pause(){w=true,$.forEach(f=>{f.style.animationPlayState="paused";});},resume(){w&&(w=false,$.forEach(f=>{f.style.animationPlayState="running";}));},seek(f){let A=Math.min(1,Math.max(0,f));I=A,w=true,$.forEach((B,De)=>{B.classList.remove(o),B.style.strokeDashoffset=S==="reverse"?`${R[De]*A}`:`${R[De]*(1-A)}`,u&&(B.style.opacity=S==="reverse"?`${1-A}`:`${A}`);});},getProgress(){return N()}}}if(Lt())return $t();function Pt(){let o=Math.max(1,j),a=0,v=0;function X(N){let f=true;if(be){let A=Math.min(1,Math.max(0,N/o)),B=we(A);Fe=B,e.style.setProperty("--scroll-draw-progress",String(B)),e.style.clipPath=ne(S==="reverse"?1-B:B),p?.(B),A<1&&(f=false);}else $.forEach((A,B)=>{let De=B*H*o,Ne=Math.min(1,Math.max(0,(N-De)/o)),Se=we(Ne);A.style.strokeDashoffset=S==="reverse"?`${R[B]*Se}`:`${R[B]*(1-Se)}`,u&&(A.style.opacity=S==="reverse"?`${1-Se}`:`${Se}`),pe&&J?A.style.stroke=Re(pe,J,Se):J&&(A.style.stroke=J),K!==null&&i!==null?A.style.strokeWidth=`${K+(i-K)*Se}`:i!==null&&(A.style.strokeWidth=`${i}`),d!==null&&F!==null?A.style.fillOpacity=`${d+(F-d)*Se}`:F!==null&&(A.style.fillOpacity=`${F}`),L&&A.tagName.toLowerCase()==="path"&&D[B]&&A.setAttribute("d",Ke(D[B],L,Se)),B===0&&(p?.(Se),e.style.setProperty("--scroll-draw-progress",String(Se))),Ne<1&&(f=false);});if(g){let A=Math.min(1,Math.max(0,N/o)),B=we(A);for(let De in g){let Ne=parseFloat(De);B>=Ne&&!$e.has(Ne)&&($e.add(Ne),g[De]?.());}}return f}function fe(N){if(ue)return;let f=N-a;de||(de=true,T?.());let A=X(f);if(A&&!re){re=true,X(o*(1+Math.max(0,$.length-1)*H)),b?.(),Ce<(O==="infinite"?1/0:O??0)&&(Ce++,Le=setTimeout(()=>{a=performance.now(),de=false,re=false,$e.clear(),Ge(),oe=requestAnimationFrame(fe);},se));return}A||(oe=requestAnimationFrame(fe));}function me(){cancelAnimationFrame(oe),clearTimeout(Le),a=performance.now(),v=0,ue=false,de=false,re=false,Ce=0,$e.clear(),Ge(),oe=requestAnimationFrame(fe);}let ge=new IntersectionObserver(N=>{N.forEach(f=>{f.isIntersecting&&!(Y&&re)?me():!f.isIntersecting&&!Y&&!re&&(cancelAnimationFrame(oe),clearTimeout(Le),a=null);});},{root:te??null,threshold:k,rootMargin:G}),w;function I(){clearTimeout(w),w=setTimeout(()=>{$.forEach((N,f)=>{R[f]=Ye(N),N.style.strokeDasharray=`${R[f]}`;});},150);}return window.addEventListener("resize",I),window.addEventListener("orientationchange",I),Z>0?setTimeout(()=>ge.observe(e),Z):ge.observe(e),{destroy(){cancelAnimationFrame(oe),clearTimeout(Le),ge.disconnect(),window.removeEventListener("resize",I),window.removeEventListener("orientationchange",I),clearTimeout(w);},replay(){Ce=0,me();},pause(){ue||(ue=true,v=performance.now()-a,cancelAnimationFrame(oe));},resume(){ue&&(ue=false,a=performance.now()-v,oe=requestAnimationFrame(fe));},seek(N){let f=Math.min(1,Math.max(0,N));Fe=f,ue=true,v=f*o,a=performance.now()-v,cancelAnimationFrame(oe),X(v);},getProgress(){return Fe}}}if(_)return Pt();mt();function je(){if(!Be||ue)return;let o=performance.now(),a=He(),v=c;if(x!==false){let w=o-ut,I=w>0?Math.abs(a-(_e<0?a:_e))/w:0;v=c*Math.max(.2,1+I*(typeof x=="number"?x:1)*.04);}_e=a,ut=o;let X=U?We===-1||a>=We?"forward":"reverse":S;We=a;let fe=ce-ie,me=true,ge=fe===0?0:(a-ie)/fe;if(isNaN(Ie)||(Ie<=0&&ge>0?y?.():Ie>0&&ge<=0&&Me?.(),Ie<1&&ge>=1?q?.():Ie>=1&&ge<1&&Ae?.()),Ie=ge,be){let w=we(Q(a,ie,ce,v));Y&&!U&&(ve=Math.max(ve,w),w=ve),Fe=w,e.style.setProperty("--scroll-draw-progress",String(w));let I=X==="reverse"?1-w:w;e.style.clipPath=ne(I),p?.(w),!de&&Q(a,ie,ce,v)>0&&(de=true,T?.()),w>=1&&!re?(re=true,b?.(),Ce<(O==="infinite"?1/0:O??0)&&(Ce++,Le=setTimeout(()=>{ve=-1,de=false,re=false,e.style.clipPath=ne(0);},se))):w<1&&!Y&&(re=false),oe=requestAnimationFrame(je);return}if($.forEach((w,I)=>{let N=I*H*fe,f=we(Q(a,ie+N,ce+N,v));Y&&!U&&(ve=Math.max(ve,f),f=ve),Fe=f,w.style.strokeDashoffset=X==="reverse"?`${R[I]*f}`:`${R[I]*(1-f)}`,u&&(w.style.opacity=X==="reverse"?`${1-f}`:`${f}`),pe&&J?w.style.stroke=Re(pe,J,f):J&&(w.style.stroke=J),K!==null&&i!==null?w.style.strokeWidth=`${K+(i-K)*f}`:i!==null&&(w.style.strokeWidth=`${i}`),d!==null&&F!==null?w.style.fillOpacity=`${d+(F-d)*f}`:F!==null&&(w.style.fillOpacity=`${F}`),L&&w.tagName.toLowerCase()==="path"&&D[I]&&w.setAttribute("d",Ke(D[I],L,f)),I===0&&(p?.(f),e.style.setProperty("--scroll-draw-progress",String(f))),f<1&&(me=false);}),g){let w=we(Q(a,ie,ce,v));for(let I in g){let N=parseFloat(I);w>=N&&!$e.has(N)&&($e.add(N),g[I]?.());}}!de&&Q(a,ie,ce,v)>0&&(de=true,T?.()),me&&!re?(re=true,b?.(),Ce<(O==="infinite"?1/0:O??0)&&(Ce++,Le=setTimeout(()=>{ve=-1,de=false,re=false,$e.clear(),Ge();},se))):!me&&!Y&&(re=false),oe=requestAnimationFrame(je);}let Ze=new IntersectionObserver(o=>{o.forEach(a=>{Be=a.isIntersecting,Be&&!ue?oe=requestAnimationFrame(je):cancelAnimationFrame(oe);});},{root:te??null,threshold:k,rootMargin:G}),Je;function Xe(){clearTimeout(Je),Je=setTimeout(()=>{$.forEach((o,a)=>{R[a]=Ye(o),o.style.strokeDasharray=`${R[a]}`;}),mt();},150);}return window.addEventListener("resize",Xe),window.addEventListener("orientationchange",Xe),Z>0?setTimeout(()=>Ze.observe(e),Z):Ze.observe(e),{destroy(){cancelAnimationFrame(oe),clearTimeout(Le),Ze.disconnect(),window.removeEventListener("resize",Xe),window.removeEventListener("orientationchange",Xe),clearTimeout(Je),Ue?.remove();},replay(){ve=-1,We=-1,_e=-1,de=false,re=false,Ce=0,ue=false,$e.clear(),clearTimeout(Le),Ge();},pause(){ue=true,cancelAnimationFrame(oe);},resume(){ue&&(ue=false,Be&&(oe=requestAnimationFrame(je)));},seek(o){let a=Math.min(1,Math.max(0,o));Fe=a,ve=a,ue=true,cancelAnimationFrame(oe),Ct(a,S);},getProgress(){return Fe}}}var wt=new Map;function Pe(e,r){wt.set(e,r);}function Oe(e){wt.delete(e);}function Ht(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function vt(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 Vt(e,r,n){let t=vt(e),l=vt(r);return t.length===0||t.length!==l.length?n<1?e:r:t.map((s,m)=>{let c=l[m];return s.fn!==c.fn||s.nums.length!==c.nums.length?n<1?`${s.fn}(${s.nums.map((u,h)=>`${u}${s.units[h]}`).join(", ")})`:`${c.fn}(${c.nums.map((u,h)=>`${u}${c.units[h]}`).join(", ")})`:`${s.fn}(${s.nums.map((u,h)=>`${u+(c.nums[h]-u)*n}${s.units[h]}`).join(", ")})`}).join(" ")}function St(e,r,n){if(typeof e=="number"&&typeof r=="number")return String(e+(r-e)*n);let t=String(e),l=String(r);if(Ht(t))return Re(t,l,n);if(t.includes("("))return Vt(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 zt(e){return e.replace(/([A-Z])/g,r=>`-${r.toLowerCase()}`)}var Et={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},qt=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),Bt=0;function Wt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function et(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let{props:t,trigger:l={},easing:s="ease-out",speed:m=1,once:c=false,axis:u="y",scrollContainer:h,native:P=true,velocityScale:H=false,onProgress:S,onComplete:Y,onEnter:he,onLeave:V,onEnterBack:ee,onLeaveBack:U}=r,Z=window.matchMedia("(prefers-reduced-motion: reduce)").matches,E=typeof s=="function"?s:ae[s]??ae["ease-out"],M=le(l.start??"top bottom"),C=le(l.end??"bottom top"),g=typeof h=="string"?document.querySelector(h):h??null,x=Object.entries(t).map(([i,d])=>({prop:zt(i),from:Array.isArray(d)?d[0]:"",to:Array.isArray(d)?d[1]:d}));function k(){let i=window.getComputedStyle(e);for(let d of x)d.from===""&&(d.from=i.getPropertyValue(d.prop).trim()||"0");}function G(){for(let i of x)e.style.setProperty(i.prop,String(i.to));}if(Z)return G(),Y?.(),n;k();function O(){if(!P||!Wt()||typeof s!="string"||!(s in Et)||u!=="y"||g||c||m!==1||S||Y||he||V||ee||U||H!==false||(l.start??"top bottom").trim()!=="top bottom"||(l.end??"bottom top").trim()!=="bottom top")return false;for(let i of x)if(!qt.has(i.prop))return false;return true}function se(){let i=`ssd-a-${++Bt}`,d=x.map(D=>`${D.prop}:${D.from}`).join(";"),F=x.map(D=>`${D.prop}:${D.to}`).join(";"),ne=document.createElement("style");ne.setAttribute("data-ssd-animate",""),ne.textContent=`@keyframes ${i}{from{${d}}to{${F}}}.${i}{animation-name:${i};animation-duration:auto;animation-timing-function:${Et[s]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(ne),e.classList.add(i);let $=()=>u==="x"?window.scrollX:window.scrollY,R=()=>u==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(i),ne.remove();},replay(){e.classList.remove(i),e.offsetWidth,e.classList.add(i);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(D){let ie=Math.min(1,Math.max(0,D));e.classList.remove(i);for(let ce of x)e.style.setProperty(ce.prop,St(ce.from,ce.to,ie));},getProgress(){let D=e.getBoundingClientRect(),ie=$(),ce=R(),{tStart:re,tEnd:de}=ye({top:D.top,height:D.height},ie,ce,M,C);return E(Q(ie,re,de,m))}}}if(O())return se();let L=0,W=0,_=0,j=false,z=false,p=-1,T=0,b=false,y=NaN,q=-1,Ae=0,Me=()=>g?u==="x"?g.scrollLeft:g.scrollTop:u==="x"?window.scrollX:window.scrollY,be=()=>g?u==="x"?g.clientWidth:g.clientHeight:u==="x"?window.innerWidth:window.innerHeight;function we(){let i=e.getBoundingClientRect(),d,F;if(g){let $=g.getBoundingClientRect();d=u==="x"?i.left-$.left+g.scrollLeft:i.top-$.top+g.scrollTop,F=u==="x"?i.width:i.height;}else d=u==="x"?i.left:i.top,F=u==="x"?i.width:i.height;let ne=ye({top:d,height:F},Me(),be(),M,C);L=ne.tStart,W=ne.tEnd;}function ke(i){e.style.setProperty("--scroll-draw-progress",String(i));for(let d of x)e.style.setProperty(d.prop,St(d.from,d.to,i));S?.(i);}function qe(i){if(isNaN(y)){y=i;return}y<=0&&i>0?he?.():y>0&&i<=0&&U?.(),y<1&&i>=1?V?.():y>=1&&i<1&&ee?.(),y=i;}function te(){if(!j||z)return;let i=performance.now(),d=Me(),F=m;if(H!==false){let R=i-Ae,D=R>0?Math.abs(d-(q<0?d:q))/R:0;F=m*Math.max(.2,1+D*(typeof H=="number"?H:1)*.04);}q=d,Ae=i;let ne=W===L?0:(d-L)/(W-L);qe(ne);let $=E(Q(d,L,W,F));c&&(p=Math.max(p,$),$=p),T=$,ke($),$>=1&&!b?(b=true,Y?.()):$<1&&!c&&(b=false),_=requestAnimationFrame(te);}we();{let i=E(Q(Me(),L,W,m));c&&i>0&&(p=i),T=i,ke(i);}let pe=new IntersectionObserver(i=>{i.forEach(d=>{j=d.isIntersecting,j&&!z?_=requestAnimationFrame(te):cancelAnimationFrame(_);});},{root:g??null}),J;function K(){clearTimeout(J),J=setTimeout(we,150);}return window.addEventListener("resize",K),window.addEventListener("orientationchange",K),pe.observe(e),Pe(e,{type:"animate",getProgress:()=>T,getTrigger:()=>({tStart:L,tEnd:W})}),{destroy(){cancelAnimationFrame(_),pe.disconnect(),window.removeEventListener("resize",K),window.removeEventListener("orientationchange",K),clearTimeout(J),Oe(e);},replay(){p=-1,b=false,T=0,z=false,ke(0);},pause(){z=true,cancelAnimationFrame(_);},resume(){z&&(z=false,j&&(_=requestAnimationFrame(te)));},seek(i){let d=Math.min(1,Math.max(0,i));T=d,p=d,z=true,cancelAnimationFrame(_),ke(d);},getProgress(){return T}}}var tt={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function nt(e,r){if(typeof window>"u")return tt;let n=typeof e=="string"?document.querySelector(e):e;if(!n)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollCounter: element not found:",e),tt;let t=n,{from:l=0,to:s,format:m,easing:c="ease-out",trigger:u={},once:h=true,decimals:P,onComplete:H}=r,S=P!==void 0?p=>p.toFixed(P):m??(p=>String(Math.round(p))),Y=typeof c=="function"?c:ae[c]??ae["ease-out"],he=le(u.start??"top 80%"),V=le(u.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=S(s),H?.(),tt;t.textContent=S(l);let U=0,Z=0,E=0,M=false,C=false,g=-1,x=0,k=false,G=()=>window.scrollY,O=()=>window.innerHeight;function se(){let p=t.getBoundingClientRect(),T=ye({top:p.top,height:p.height},G(),O(),he,V);U=T.tStart,Z=T.tEnd;}function L(p){t.textContent=S(l+(s-l)*p),t.style.setProperty("--scroll-draw-progress",String(p));}function W(){if(!M||C)return;let p=Y(Q(G(),U,Z,1));h&&(g=Math.max(g,p),p=g),x=p,L(p),p>=1&&!k?(k=true,H?.()):p<1&&!h&&(k=false),E=requestAnimationFrame(W);}se();{let p=Y(Q(G(),U,Z,1));h&&p>0&&(g=p),x=p,L(p);}let _=new IntersectionObserver(p=>{p.forEach(T=>{M=T.isIntersecting,M&&!C?E=requestAnimationFrame(W):cancelAnimationFrame(E);});}),j;function z(){clearTimeout(j),j=setTimeout(se,150);}return window.addEventListener("resize",z),window.addEventListener("orientationchange",z),_.observe(t),Pe(t,{type:"counter",getProgress:()=>x,getTrigger:()=>({tStart:U,tEnd:Z})}),{destroy(){cancelAnimationFrame(E),_.disconnect(),window.removeEventListener("resize",z),window.removeEventListener("orientationchange",z),clearTimeout(j),Oe(t);},replay(){g=-1,k=false,x=0,C=false,L(0);},pause(){C=true,cancelAnimationFrame(E);},resume(){C&&(C=false,M&&(E=requestAnimationFrame(W)));},seek(p){let T=Math.min(1,Math.max(0,p));x=T,g=T,C=true,cancelAnimationFrame(E),L(T);},getProgress(){return x}}}var xt={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function rt(e,r={}){if(typeof window>"u")return xt;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),xt;let t=n,{trigger:l={},easing:s="linear",once:m=false,axis:c="y",preload:u="auto",onReady:h,onComplete:P,onProgress:H}=r,S=window.matchMedia("(prefers-reduced-motion: reduce)").matches,Y=typeof s=="function"?s:ae[s]??ae.linear,he=le(l.start??"top top"),V=le(l.end??"bottom top");t.pause(),t.hasAttribute("preload")||(t.preload=u);let ee=r.from??0,U=r.to,Z=0,E=0,M=0,C=false,g=false,x=-1,k=0,G=false,O=false,se=()=>c==="x"?window.scrollX:window.scrollY,L=()=>c==="x"?window.innerWidth:window.innerHeight;function W(){let y=t.getBoundingClientRect(),q=c==="x"?y.left:y.top,Ae=c==="x"?y.width:y.height,Me=ye({top:q,height:Ae},se(),L(),he,V);Z=Me.tStart,E=Me.tEnd;}function _(y){if(!O)return;let q=U??t.duration??0;t.currentTime=ee+(q-ee)*y,t.style.setProperty("--scroll-draw-progress",String(y)),H?.(y);}function j(){if(!C||g||!O)return;let y=Y(Q(se(),Z,E,1));m&&(x=Math.max(x,y),y=x),k=y,_(y),y>=1&&!G?(G=true,P?.()):y<1&&!m&&(G=false),M=requestAnimationFrame(j);}function z(){if(O=true,U===void 0&&(U=t.duration),S){_(1),h?.();return}W(),h?.(),C&&!g&&(M=requestAnimationFrame(j));}t.readyState>=1?z():t.addEventListener("loadedmetadata",z,{once:true}),O||W();let p=new IntersectionObserver(y=>{y.forEach(q=>{C=q.isIntersecting,C&&!g&&O?M=requestAnimationFrame(j):cancelAnimationFrame(M);});}),T;function b(){clearTimeout(T),T=setTimeout(W,150);}return window.addEventListener("resize",b),window.addEventListener("orientationchange",b),p.observe(t),Pe(t,{type:"video",getProgress:()=>k,getTrigger:()=>({tStart:Z,tEnd:E})}),{destroy(){cancelAnimationFrame(M),p.disconnect(),t.removeEventListener("loadedmetadata",z),window.removeEventListener("resize",b),window.removeEventListener("orientationchange",b),clearTimeout(T),Oe(t);},replay(){x=-1,G=false,k=0,g=false,_(0);},pause(){g=true,cancelAnimationFrame(M);},resume(){g&&(g=false,C&&O&&(M=requestAnimationFrame(j)));},seek(y){let q=Math.min(1,Math.max(0,y));k=q,x=q,g=true,cancelAnimationFrame(M),_(q);},getProgress(){return k}}}function Mt(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 _t(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 Tt(e){let r=Mt(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 Gt(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 jt(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 At={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function ot(e,r={}){if(typeof window>"u")return At;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),At;let t=n,{split:l="words",stagger:s=.04,easing:m="ease-out",from:c={opacity:0,y:24},trigger:u={},once:h=true,onComplete:P}=r,H=window.matchMedia("(prefers-reduced-motion: reduce)").matches,S=typeof m=="function"?m:ae[m]??ae["ease-out"],Y=le(u.start??"top 85%"),he=le(u.end??"top 40%"),V=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let ee;l==="chars"?ee=_t(t):l==="lines"?ee=Tt(t):ee=Mt(t);let U=ee.length;function Z(b,y){c?.opacity!==void 0&&(b.style.opacity=String(c.opacity+(1-c.opacity)*y));let q=jt(y,c);q&&(b.style.transform=q);}function E(b){t.style.setProperty("--scroll-draw-progress",String(b)),ee.forEach((y,q)=>{let Ae=S(Gt(b,q,U,s));Z(y,Ae);});}if(H)return E(1),P?.(),{destroy(){t.innerHTML=V,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};E(0);let M=0,C=0,g=0,x=false,k=false,G=-1,O=0,se=false,L=()=>window.scrollY,W=()=>window.innerHeight;function _(){let b=t.getBoundingClientRect(),y=ye({top:b.top,height:b.height},L(),W(),Y,he);M=y.tStart,C=y.tEnd;}function j(){if(!x||k)return;let b=Q(L(),M,C,1);h&&(G=Math.max(G,b),b=G),O=b,E(b),b>=1&&!se?(se=true,P?.()):b<1&&!h&&(se=false),g=requestAnimationFrame(j);}_();let z=new IntersectionObserver(b=>{b.forEach(y=>{x=y.isIntersecting,x&&!k?g=requestAnimationFrame(j):cancelAnimationFrame(g);});}),p;function T(){clearTimeout(p),p=setTimeout(()=>{if(l==="lines"){let b=O;t.innerHTML=V,t.setAttribute("aria-label",t.textContent??""),ee=Tt(t),E(b);}_();},150);}return window.addEventListener("resize",T),window.addEventListener("orientationchange",T),z.observe(t),Pe(t,{type:"text",getProgress:()=>O,getTrigger:()=>({tStart:M,tEnd:C})}),{destroy(){cancelAnimationFrame(g),z.disconnect(),window.removeEventListener("resize",T),window.removeEventListener("orientationchange",T),clearTimeout(p),t.innerHTML=V,t.removeAttribute("aria-label"),Oe(t);},replay(){G=-1,se=false,O=0,k=false,E(0);},pause(){k=true,cancelAnimationFrame(g);},resume(){k&&(k=false,x&&(g=requestAnimationFrame(j)));},seek(b){let y=Math.min(1,Math.max(0,b));O=y,G=y,k=true,cancelAnimationFrame(g),E(y);},getProgress(){return O}}}function Xt(e={}){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=Qe(r.value,e);onUnmounted(()=>n.destroy());}),r}var st=defineComponent({name:"ScrollDraw",props:{selector:{type:String},speed:{type:Number},fade:{type:Boolean},stagger:{type:Number},easing:{type:[String,Function]},direction:{type:String},trigger:{type:Object},onProgress:{type:Function},onStart:{type:Function},onComplete:{type:Function},once:{type:Boolean},debug:{type:Boolean}},setup(e,{slots:r}){let n=ref(null);return onMounted(()=>{if(!n.value)return;let t={};e.selector!=null&&(t.selector=e.selector),e.speed!=null&&(t.speed=e.speed),e.fade!=null&&(t.fade=e.fade),e.stagger!=null&&(t.stagger=e.stagger),e.easing!=null&&(t.easing=e.easing),e.direction!=null&&(t.direction=e.direction),e.trigger!=null&&(t.trigger=e.trigger),e.once!=null&&(t.once=e.once),e.debug!=null&&(t.debug=e.debug),e.onProgress!=null&&(t.onProgress=e.onProgress),e.onStart!=null&&(t.onStart=e.onStart),e.onComplete!=null&&(t.onComplete=e.onComplete);let l=Qe(n.value,t);onUnmounted(()=>l.destroy());}),()=>h("div",{ref:n},r.default?.())}});function Yt(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=et(r.value,e);onUnmounted(()=>n.destroy());}),r}var it=defineComponent({name:"ScrollAnimate",props:{options:{type:Object,required:true}},setup(e,{slots:r}){let n=ref(null);return onMounted(()=>{if(!n.value)return;let t=et(n.value,e.options);onUnmounted(()=>t.destroy());}),()=>h("div",{ref:n},r.default?.())}});function Ut(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=nt(r.value,e);onUnmounted(()=>n.destroy());}),r}var at=defineComponent({name:"ScrollCounter",props:{to:{type:Number,required:true},from:{type:Number},format:{type:Function},easing:{type:[String,Function]},trigger:{type:Object},once:{type:Boolean},decimals:{type:Number},onComplete:{type:Function}},setup(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n={to:e.to};e.from!=null&&(n.from=e.from),e.format!=null&&(n.format=e.format),e.easing!=null&&(n.easing=e.easing),e.trigger!=null&&(n.trigger=e.trigger),e.once!=null&&(n.once=e.once),e.decimals!=null&&(n.decimals=e.decimals),e.onComplete!=null&&(n.onComplete=e.onComplete);let t=nt(r.value,n);onUnmounted(()=>t.destroy());}),()=>h("span",{ref:r})}});function Zt(e={}){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=rt(r.value,e);onUnmounted(()=>n.destroy());}),r}var lt=defineComponent({name:"ScrollVideo",props:{src:{type:String,required:true},options:{type:Object},muted:{type:Boolean,default:true},playsInline:{type:Boolean,default:true},class:{type:String}},setup(e){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=rt(r.value,e.options??{});onUnmounted(()=>n.destroy());}),()=>h("video",{ref:r,src:e.src,muted:e.muted,playsinline:e.playsInline,preload:"auto",class:e.class})}});function Jt(e={}){let r=ref(null);return onMounted(()=>{if(!r.value)return;let n=ot(r.value,e);onUnmounted(()=>n.destroy());}),r}var ct=defineComponent({name:"ScrollText",props:{options:{type:Object},tag:{type:String,default:"p"}},setup(e,{slots:r}){let n=ref(null);return onMounted(()=>{if(!n.value)return;let t=ot(n.value,e.options??{});onUnmounted(()=>t.destroy());}),()=>h(e.tag,{ref:n},r.default?.())}});function An(){return {install(e){e.component("ScrollDraw",st),e.component("ScrollAnimate",it),e.component("ScrollCounter",at),e.component("ScrollVideo",lt),e.component("ScrollText",ct);}}}export{it as ScrollAnimate,at as ScrollCounter,st as ScrollDraw,ct as ScrollText,lt as ScrollVideo,An as createScrollDrawPlugin,Yt as useScrollAnimate,Ut as useScrollCounter,Xt as useScrollDraw,Jt as useScrollText,Zt as useScrollVideo};
@@ -0,0 +1 @@
1
+ 'use strict';function F({bounces:t=3,decay:a=.5}={}){let s=Math.max(1,Math.round(t)),e=Math.max(.01,Math.min(.99,a)),l=Math.sqrt(e),u=0,g=[];for(let r=0;r<s;r++){let i=Math.pow(l,r);g.push(i),u+=i;}let c=[0],y=0;for(let r=0;r<s;r++)y+=g[r]/u,c.push(y);return r=>{if(r<=0)return 0;if(r>=1)return 1;for(let i=0;i<s;i++)if(r<=c[i+1]){let d=(r-c[i])/(c[i+1]-c[i]);if(i===0)return d*(2-d);let n=1-Math.pow(e,i);return n+(1-n)*(2*d-1)*(2*d-1)}return 1}}function q({amplitude:t=1,period:a=.4}={}){let s=Math.max(1,t),e=Math.max(.1,a),l=s<=1?e/4:e/(2*Math.PI)*Math.asin(1/s);return u=>u<=0?0:u>=1?1:s*Math.pow(2,-10*u)*Math.sin((u-l)*(2*Math.PI)/e)+1}({bounce:F(),elastic:q()});function B(t,a,s){return Math.min(s,Math.max(a,t))}var A=new Map;function O(t,a){A.set(t,a);}function N(t){A.delete(t);}var _={destroy:()=>{},refresh:()=>{},getProgress:()=>0};function U(t,a={}){if(typeof window>"u")return _;let s=typeof t=="string"?document.querySelector(t):t;if(!s)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollPin: element not found:",t),_;let e=s,{top:l=0,scrollContainer:u,onEnter:g,onLeave:c,onEnterBack:y,onLeaveBack:r,onProgress:i}=a,d=typeof u=="string"?document.querySelector(u):u??null,n={position:e.style.position,top:e.style.top,bottom:e.style.bottom,left:e.style.left,width:e.style.width,boxSizing:e.style.boxSizing},o=document.createElement("div");o.setAttribute("data-ssd-pin-wrapper",""),o.style.cssText="position:relative;",e.parentNode?.insertBefore(o,e),o.appendChild(e);let R=0,x=0,E=0,M="before",P=0,z=0,S=false;function h(){R=o.offsetWidth,x=e.offsetHeight,E=a.pinDistance??window.innerHeight,o.style.height=`${x+E}px`;}function I(p){if(M===p)return;let m=M;if(M=p,p==="before")e.style.position=n.position,e.style.top=n.top,e.style.bottom=n.bottom,e.style.left=n.left,e.style.width=n.width,e.style.boxSizing=n.boxSizing,m==="pinned"&&r?.();else if(p==="pinned"){let T=o.getBoundingClientRect();e.style.position="fixed",e.style.top=`${l}px`,e.style.bottom="",e.style.left=`${T.left}px`,e.style.width=`${R}px`,e.style.boxSizing="border-box",m==="before"?g?.():m==="after"&&y?.();}else e.style.position="absolute",e.style.top="",e.style.bottom="0",e.style.left="0",e.style.width="100%",e.style.boxSizing="border-box",m==="pinned"&&c?.();}function C(){S=false;let p=o.getBoundingClientRect(),m=p.top,T=p.bottom,$=B((l-m)/E,0,1);P=$,i?.($),m>l?I("before"):T-x<=l?I("after"):I("pinned");}function f(){S||(S=true,z=requestAnimationFrame(()=>C()));}let L=d??window;L.addEventListener("scroll",f,{passive:true});let b;function w(){clearTimeout(b),b=setTimeout(()=>{h(),f();},150);}window.addEventListener("resize",w),window.addEventListener("orientationchange",w);let v=null;return typeof ResizeObserver<"u"&&(v=new ResizeObserver(()=>{clearTimeout(b),b=setTimeout(()=>{h(),f();},100);}),v.observe(o),v.observe(document.documentElement)),h(),f(),O(o,{type:"pin",getProgress:()=>P,getTrigger:()=>({tStart:0,tEnd:1})}),{destroy(){cancelAnimationFrame(z),clearTimeout(b),L.removeEventListener("scroll",f),window.removeEventListener("resize",w),window.removeEventListener("orientationchange",w),v?.disconnect(),e.style.position=n.position,e.style.top=n.top,e.style.bottom=n.bottom,e.style.left=n.left,e.style.width=n.width,e.style.boxSizing=n.boxSizing,o.parentNode?.insertBefore(e,o),o.remove(),N(o);},refresh(){h(),f();},getProgress(){return P}}}exports.scrollPin=U;
@@ -0,0 +1,29 @@
1
+ interface ScrollPinOptions {
2
+ /** Extra pixels of scroll to stay pinned after the element hits its viewport position. Default: viewport height. */
3
+ pinDistance?: number;
4
+ /** Viewport Y position (px) where the element pins. Default: 0 (top of viewport). */
5
+ top?: number;
6
+ /** Custom scroll container (CSS selector or Element). Default: window. */
7
+ scrollContainer?: string | Element;
8
+ /** Fires when the element begins being pinned (scrolling forward). */
9
+ onEnter?: () => void;
10
+ /** Fires when the element unpins at the end of the pin zone (scrolling forward). */
11
+ onLeave?: () => void;
12
+ /** Fires when the element re-pins after scrolling back into the pin zone. */
13
+ onEnterBack?: () => void;
14
+ /** Fires when the element unpins back before the pin zone (scrolling back). */
15
+ onLeaveBack?: () => void;
16
+ /** Progress through the pin zone (0 = start, 1 = end). */
17
+ onProgress?: (progress: number) => void;
18
+ }
19
+ interface ScrollPinInstance {
20
+ /** Remove pin behaviour and restore the element to its original state. */
21
+ destroy: () => void;
22
+ /** Recalculate pin dimensions after a layout change. */
23
+ refresh: () => void;
24
+ /** Returns progress through the pin zone (0–1). */
25
+ getProgress: () => number;
26
+ }
27
+ declare function scrollPin(target: string | Element, options?: ScrollPinOptions): ScrollPinInstance;
28
+
29
+ export { type ScrollPinInstance, type ScrollPinOptions, scrollPin };
@@ -0,0 +1,29 @@
1
+ interface ScrollPinOptions {
2
+ /** Extra pixels of scroll to stay pinned after the element hits its viewport position. Default: viewport height. */
3
+ pinDistance?: number;
4
+ /** Viewport Y position (px) where the element pins. Default: 0 (top of viewport). */
5
+ top?: number;
6
+ /** Custom scroll container (CSS selector or Element). Default: window. */
7
+ scrollContainer?: string | Element;
8
+ /** Fires when the element begins being pinned (scrolling forward). */
9
+ onEnter?: () => void;
10
+ /** Fires when the element unpins at the end of the pin zone (scrolling forward). */
11
+ onLeave?: () => void;
12
+ /** Fires when the element re-pins after scrolling back into the pin zone. */
13
+ onEnterBack?: () => void;
14
+ /** Fires when the element unpins back before the pin zone (scrolling back). */
15
+ onLeaveBack?: () => void;
16
+ /** Progress through the pin zone (0 = start, 1 = end). */
17
+ onProgress?: (progress: number) => void;
18
+ }
19
+ interface ScrollPinInstance {
20
+ /** Remove pin behaviour and restore the element to its original state. */
21
+ destroy: () => void;
22
+ /** Recalculate pin dimensions after a layout change. */
23
+ refresh: () => void;
24
+ /** Returns progress through the pin zone (0–1). */
25
+ getProgress: () => number;
26
+ }
27
+ declare function scrollPin(target: string | Element, options?: ScrollPinOptions): ScrollPinInstance;
28
+
29
+ export { type ScrollPinInstance, type ScrollPinOptions, scrollPin };
@@ -0,0 +1 @@
1
+ function F({bounces:t=3,decay:a=.5}={}){let s=Math.max(1,Math.round(t)),e=Math.max(.01,Math.min(.99,a)),l=Math.sqrt(e),u=0,g=[];for(let r=0;r<s;r++){let i=Math.pow(l,r);g.push(i),u+=i;}let c=[0],y=0;for(let r=0;r<s;r++)y+=g[r]/u,c.push(y);return r=>{if(r<=0)return 0;if(r>=1)return 1;for(let i=0;i<s;i++)if(r<=c[i+1]){let d=(r-c[i])/(c[i+1]-c[i]);if(i===0)return d*(2-d);let n=1-Math.pow(e,i);return n+(1-n)*(2*d-1)*(2*d-1)}return 1}}function q({amplitude:t=1,period:a=.4}={}){let s=Math.max(1,t),e=Math.max(.1,a),l=s<=1?e/4:e/(2*Math.PI)*Math.asin(1/s);return u=>u<=0?0:u>=1?1:s*Math.pow(2,-10*u)*Math.sin((u-l)*(2*Math.PI)/e)+1}({bounce:F(),elastic:q()});function B(t,a,s){return Math.min(s,Math.max(a,t))}var A=new Map;function O(t,a){A.set(t,a);}function N(t){A.delete(t);}var _={destroy:()=>{},refresh:()=>{},getProgress:()=>0};function U(t,a={}){if(typeof window>"u")return _;let s=typeof t=="string"?document.querySelector(t):t;if(!s)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollPin: element not found:",t),_;let e=s,{top:l=0,scrollContainer:u,onEnter:g,onLeave:c,onEnterBack:y,onLeaveBack:r,onProgress:i}=a,d=typeof u=="string"?document.querySelector(u):u??null,n={position:e.style.position,top:e.style.top,bottom:e.style.bottom,left:e.style.left,width:e.style.width,boxSizing:e.style.boxSizing},o=document.createElement("div");o.setAttribute("data-ssd-pin-wrapper",""),o.style.cssText="position:relative;",e.parentNode?.insertBefore(o,e),o.appendChild(e);let R=0,x=0,E=0,M="before",P=0,z=0,S=false;function h(){R=o.offsetWidth,x=e.offsetHeight,E=a.pinDistance??window.innerHeight,o.style.height=`${x+E}px`;}function I(p){if(M===p)return;let m=M;if(M=p,p==="before")e.style.position=n.position,e.style.top=n.top,e.style.bottom=n.bottom,e.style.left=n.left,e.style.width=n.width,e.style.boxSizing=n.boxSizing,m==="pinned"&&r?.();else if(p==="pinned"){let T=o.getBoundingClientRect();e.style.position="fixed",e.style.top=`${l}px`,e.style.bottom="",e.style.left=`${T.left}px`,e.style.width=`${R}px`,e.style.boxSizing="border-box",m==="before"?g?.():m==="after"&&y?.();}else e.style.position="absolute",e.style.top="",e.style.bottom="0",e.style.left="0",e.style.width="100%",e.style.boxSizing="border-box",m==="pinned"&&c?.();}function C(){S=false;let p=o.getBoundingClientRect(),m=p.top,T=p.bottom,$=B((l-m)/E,0,1);P=$,i?.($),m>l?I("before"):T-x<=l?I("after"):I("pinned");}function f(){S||(S=true,z=requestAnimationFrame(()=>C()));}let L=d??window;L.addEventListener("scroll",f,{passive:true});let b;function w(){clearTimeout(b),b=setTimeout(()=>{h(),f();},150);}window.addEventListener("resize",w),window.addEventListener("orientationchange",w);let v=null;return typeof ResizeObserver<"u"&&(v=new ResizeObserver(()=>{clearTimeout(b),b=setTimeout(()=>{h(),f();},100);}),v.observe(o),v.observe(document.documentElement)),h(),f(),O(o,{type:"pin",getProgress:()=>P,getTrigger:()=>({tStart:0,tEnd:1})}),{destroy(){cancelAnimationFrame(z),clearTimeout(b),L.removeEventListener("scroll",f),window.removeEventListener("resize",w),window.removeEventListener("orientationchange",w),v?.disconnect(),e.style.position=n.position,e.style.top=n.top,e.style.bottom=n.bottom,e.style.left=n.left,e.style.width=n.width,e.style.boxSizing=n.boxSizing,o.parentNode?.insertBefore(e,o),o.remove(),N(o);},refresh(){h(),f();},getProgress(){return P}}}export{U as scrollPin};
@@ -0,0 +1 @@
1
+ 'use strict';function X({bounces:e=3,decay:t=.5}={}){let r=Math.max(1,Math.round(e)),o=Math.max(.01,Math.min(.99,t)),m=Math.sqrt(o),a=0,p=[];for(let s=0;s<r;s++){let u=Math.pow(m,s);p.push(u),a+=u;}let l=[0],h=0;for(let s=0;s<r;s++)h+=p[s]/a,l.push(h);return s=>{if(s<=0)return 0;if(s>=1)return 1;for(let u=0;u<r;u++)if(s<=l[u+1]){let b=(s-l[u])/(l[u+1]-l[u]);if(u===0)return b*(2-b);let f=1-Math.pow(o,u);return f+(1-f)*(2*b-1)*(2*b-1)}return 1}}function j({amplitude:e=1,period:t=.4}={}){let r=Math.max(1,e),o=Math.max(.1,t),m=r<=1?o/4:o/(2*Math.PI)*Math.asin(1/r);return a=>a<=0?0:a>=1?1:r*Math.pow(2,-10*a)*Math.sin((a-m)*(2*Math.PI)/o)+1}var R={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:X(),elastic:j()};function F(e="top bottom"){let t=e.trim();if(/^\d+(\.\d+)?%$/.test(t))return {element:"top",viewport:t};let[r="top",o="bottom"]=t.split(/\s+/).filter(Boolean);return {element:r,viewport:o}}function q(e,t,r,o){switch(o){case "top":return e+r;case "center":return e+r+t/2;case "bottom":return e+r+t;default:return e+r}}function _(e,t){if(/^\d+(\.\d+)?%$/.test(e))return t*(parseFloat(e)/100);switch(e){case "top":return 0;case "center":return t/2;case "bottom":return t;default:return t}}function J(e,t,r){return Math.min(r,Math.max(t,e))}function L(e,t,r,o){return r===t?0:J((e-t)/(r-t)*o,0,1)}function z(e,t,r,o,m){let a=q(e.top,e.height,t,o.element)-_(o.viewport,r),p=q(e.top,e.height,t,m.element)-_(m.viewport,r);return {tStart:a,tEnd:p}}var O=new Map;function V(e,t){O.set(e,t);}function D(e){O.delete(e);}var G={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function H(e,t={}){if(typeof window>"u")return G;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollProgress: element not found:",e),G;let o=r,{variable:m="--scroll-progress",easedVariable:a="--scroll-progress-eased",trigger:p={},easing:l="linear",speed:h=1,axis:s="y",scrollContainer:u,onProgress:b}=t,f=typeof l=="function"?l:R[l]??R.linear,B=F(p.start??"top bottom"),W=F(p.end??"bottom top"),c=typeof u=="string"?document.querySelector(u):u??null,x=0,E=0,g=0,M=false,d=false,w=0,I=()=>c?s==="x"?c.scrollLeft:c.scrollTop:s==="x"?window.scrollX:window.scrollY,k=()=>c?s==="x"?c.clientWidth:c.clientHeight:s==="x"?window.innerWidth:window.innerHeight;function P(){let n=o.getBoundingClientRect(),i,y;if(c){let $=c.getBoundingClientRect();i=s==="x"?n.left-$.left+c.scrollLeft:n.top-$.top+c.scrollTop,y=s==="x"?n.width:n.height;}else i=s==="x"?n.left:n.top,y=s==="x"?n.width:n.height;let N=z({top:i,height:y},I(),k(),B,W);x=N.tStart,E=N.tEnd;}function T(n,i){o.style.setProperty(m,String(n)),a!=null&&o.style.setProperty(a,String(i)),b?.(n,i);}function S(){if(!M||d)return;let n=L(I(),x,E,h),i=f(n);w=n,T(n,i),g=requestAnimationFrame(S);}P();{let n=L(I(),x,E,h),i=f(n);w=n,T(n,i);}let C=new IntersectionObserver(n=>{n.forEach(i=>{M=i.isIntersecting,M&&!d?g=requestAnimationFrame(S):cancelAnimationFrame(g);});},{root:c??null}),A;function v(){clearTimeout(A),A=setTimeout(P,150);}return window.addEventListener("resize",v),window.addEventListener("orientationchange",v),C.observe(r),V(r,{type:"animate",getProgress:()=>w,getTrigger:()=>({tStart:x,tEnd:E})}),{destroy(){cancelAnimationFrame(g),C.disconnect(),window.removeEventListener("resize",v),window.removeEventListener("orientationchange",v),clearTimeout(A),o.style.removeProperty(m),a!=null&&o.style.removeProperty(a),D(r);},replay(){P();},pause(){d=true,cancelAnimationFrame(g);},resume(){d&&(d=false,M&&(g=requestAnimationFrame(S)));},seek(n){let i=Math.min(1,Math.max(0,n)),y=f(i);w=i,d=true,cancelAnimationFrame(g),T(i,y);},getProgress(){return w}}}exports.scrollProgress=H;
@@ -0,0 +1,59 @@
1
+ type EasingName = 'linear' | 'ease-in' | 'ease-out' | 'ease-in-out' | 'spring' | 'bounce' | 'elastic';
2
+ interface TriggerConfig {
3
+ start?: string;
4
+ end?: string;
5
+ }
6
+ interface ScrollDrawInstance {
7
+ destroy: () => void;
8
+ /** Reset and replay the animation from the beginning. */
9
+ replay: () => void;
10
+ /** Pause the animation at the current progress. */
11
+ pause: () => void;
12
+ /** Resume a paused animation. */
13
+ resume: () => void;
14
+ /** Jump to a specific progress value (0–1) and pause. */
15
+ seek: (progress: number) => void;
16
+ /** Returns current draw progress (0–1). */
17
+ getProgress: () => number;
18
+ }
19
+
20
+ interface ScrollProgressOptions {
21
+ /**
22
+ * CSS custom property to set on the target element (raw 0–1, unclamped on
23
+ * the eased side). Default: `'--scroll-progress'`.
24
+ */
25
+ variable?: string;
26
+ /**
27
+ * Second property name for the eased value. Default: `'--scroll-progress-eased'`.
28
+ * Set to `null` to skip writing the eased variable.
29
+ */
30
+ easedVariable?: string | null;
31
+ trigger?: TriggerConfig;
32
+ easing?: EasingName | ((t: number) => number);
33
+ speed?: number;
34
+ /** Scroll axis. Default: 'y'. */
35
+ axis?: 'x' | 'y';
36
+ /** Custom scroll container. Default: window. */
37
+ scrollContainer?: string | Element;
38
+ onProgress?: (raw: number, eased: number) => void;
39
+ }
40
+ /**
41
+ * Expose scroll progress as CSS custom properties on a target element.
42
+ *
43
+ * The raw (linear) value and eased value are written every frame so CSS
44
+ * transitions, `calc()` expressions, and `@property` animations can drive
45
+ * visual effects with zero per-frame JS work beyond the variable update.
46
+ *
47
+ * @example
48
+ * // JS
49
+ * scrollProgress('#hero', { easing: 'ease-in-out' });
50
+ *
51
+ * // CSS
52
+ * #hero {
53
+ * opacity: calc(var(--scroll-progress));
54
+ * transform: translateY(calc((1 - var(--scroll-progress-eased)) * 40px));
55
+ * }
56
+ */
57
+ declare function scrollProgress(target: string | Element, options?: ScrollProgressOptions): ScrollDrawInstance;
58
+
59
+ export { type ScrollProgressOptions, scrollProgress };
@@ -0,0 +1,59 @@
1
+ type EasingName = 'linear' | 'ease-in' | 'ease-out' | 'ease-in-out' | 'spring' | 'bounce' | 'elastic';
2
+ interface TriggerConfig {
3
+ start?: string;
4
+ end?: string;
5
+ }
6
+ interface ScrollDrawInstance {
7
+ destroy: () => void;
8
+ /** Reset and replay the animation from the beginning. */
9
+ replay: () => void;
10
+ /** Pause the animation at the current progress. */
11
+ pause: () => void;
12
+ /** Resume a paused animation. */
13
+ resume: () => void;
14
+ /** Jump to a specific progress value (0–1) and pause. */
15
+ seek: (progress: number) => void;
16
+ /** Returns current draw progress (0–1). */
17
+ getProgress: () => number;
18
+ }
19
+
20
+ interface ScrollProgressOptions {
21
+ /**
22
+ * CSS custom property to set on the target element (raw 0–1, unclamped on
23
+ * the eased side). Default: `'--scroll-progress'`.
24
+ */
25
+ variable?: string;
26
+ /**
27
+ * Second property name for the eased value. Default: `'--scroll-progress-eased'`.
28
+ * Set to `null` to skip writing the eased variable.
29
+ */
30
+ easedVariable?: string | null;
31
+ trigger?: TriggerConfig;
32
+ easing?: EasingName | ((t: number) => number);
33
+ speed?: number;
34
+ /** Scroll axis. Default: 'y'. */
35
+ axis?: 'x' | 'y';
36
+ /** Custom scroll container. Default: window. */
37
+ scrollContainer?: string | Element;
38
+ onProgress?: (raw: number, eased: number) => void;
39
+ }
40
+ /**
41
+ * Expose scroll progress as CSS custom properties on a target element.
42
+ *
43
+ * The raw (linear) value and eased value are written every frame so CSS
44
+ * transitions, `calc()` expressions, and `@property` animations can drive
45
+ * visual effects with zero per-frame JS work beyond the variable update.
46
+ *
47
+ * @example
48
+ * // JS
49
+ * scrollProgress('#hero', { easing: 'ease-in-out' });
50
+ *
51
+ * // CSS
52
+ * #hero {
53
+ * opacity: calc(var(--scroll-progress));
54
+ * transform: translateY(calc((1 - var(--scroll-progress-eased)) * 40px));
55
+ * }
56
+ */
57
+ declare function scrollProgress(target: string | Element, options?: ScrollProgressOptions): ScrollDrawInstance;
58
+
59
+ export { type ScrollProgressOptions, scrollProgress };
@@ -0,0 +1 @@
1
+ function X({bounces:e=3,decay:t=.5}={}){let r=Math.max(1,Math.round(e)),o=Math.max(.01,Math.min(.99,t)),m=Math.sqrt(o),a=0,p=[];for(let s=0;s<r;s++){let u=Math.pow(m,s);p.push(u),a+=u;}let l=[0],h=0;for(let s=0;s<r;s++)h+=p[s]/a,l.push(h);return s=>{if(s<=0)return 0;if(s>=1)return 1;for(let u=0;u<r;u++)if(s<=l[u+1]){let b=(s-l[u])/(l[u+1]-l[u]);if(u===0)return b*(2-b);let f=1-Math.pow(o,u);return f+(1-f)*(2*b-1)*(2*b-1)}return 1}}function j({amplitude:e=1,period:t=.4}={}){let r=Math.max(1,e),o=Math.max(.1,t),m=r<=1?o/4:o/(2*Math.PI)*Math.asin(1/r);return a=>a<=0?0:a>=1?1:r*Math.pow(2,-10*a)*Math.sin((a-m)*(2*Math.PI)/o)+1}var R={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:X(),elastic:j()};function F(e="top bottom"){let t=e.trim();if(/^\d+(\.\d+)?%$/.test(t))return {element:"top",viewport:t};let[r="top",o="bottom"]=t.split(/\s+/).filter(Boolean);return {element:r,viewport:o}}function q(e,t,r,o){switch(o){case "top":return e+r;case "center":return e+r+t/2;case "bottom":return e+r+t;default:return e+r}}function _(e,t){if(/^\d+(\.\d+)?%$/.test(e))return t*(parseFloat(e)/100);switch(e){case "top":return 0;case "center":return t/2;case "bottom":return t;default:return t}}function J(e,t,r){return Math.min(r,Math.max(t,e))}function L(e,t,r,o){return r===t?0:J((e-t)/(r-t)*o,0,1)}function z(e,t,r,o,m){let a=q(e.top,e.height,t,o.element)-_(o.viewport,r),p=q(e.top,e.height,t,m.element)-_(m.viewport,r);return {tStart:a,tEnd:p}}var O=new Map;function V(e,t){O.set(e,t);}function D(e){O.delete(e);}var G={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function H(e,t={}){if(typeof window>"u")return G;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollProgress: element not found:",e),G;let o=r,{variable:m="--scroll-progress",easedVariable:a="--scroll-progress-eased",trigger:p={},easing:l="linear",speed:h=1,axis:s="y",scrollContainer:u,onProgress:b}=t,f=typeof l=="function"?l:R[l]??R.linear,B=F(p.start??"top bottom"),W=F(p.end??"bottom top"),c=typeof u=="string"?document.querySelector(u):u??null,x=0,E=0,g=0,M=false,d=false,w=0,I=()=>c?s==="x"?c.scrollLeft:c.scrollTop:s==="x"?window.scrollX:window.scrollY,k=()=>c?s==="x"?c.clientWidth:c.clientHeight:s==="x"?window.innerWidth:window.innerHeight;function P(){let n=o.getBoundingClientRect(),i,y;if(c){let $=c.getBoundingClientRect();i=s==="x"?n.left-$.left+c.scrollLeft:n.top-$.top+c.scrollTop,y=s==="x"?n.width:n.height;}else i=s==="x"?n.left:n.top,y=s==="x"?n.width:n.height;let N=z({top:i,height:y},I(),k(),B,W);x=N.tStart,E=N.tEnd;}function T(n,i){o.style.setProperty(m,String(n)),a!=null&&o.style.setProperty(a,String(i)),b?.(n,i);}function S(){if(!M||d)return;let n=L(I(),x,E,h),i=f(n);w=n,T(n,i),g=requestAnimationFrame(S);}P();{let n=L(I(),x,E,h),i=f(n);w=n,T(n,i);}let C=new IntersectionObserver(n=>{n.forEach(i=>{M=i.isIntersecting,M&&!d?g=requestAnimationFrame(S):cancelAnimationFrame(g);});},{root:c??null}),A;function v(){clearTimeout(A),A=setTimeout(P,150);}return window.addEventListener("resize",v),window.addEventListener("orientationchange",v),C.observe(r),V(r,{type:"animate",getProgress:()=>w,getTrigger:()=>({tStart:x,tEnd:E})}),{destroy(){cancelAnimationFrame(g),C.disconnect(),window.removeEventListener("resize",v),window.removeEventListener("orientationchange",v),clearTimeout(A),o.style.removeProperty(m),a!=null&&o.style.removeProperty(a),D(r);},replay(){P();},pause(){d=true,cancelAnimationFrame(g);},resume(){d&&(d=false,M&&(g=requestAnimationFrame(S)));},seek(n){let i=Math.min(1,Math.max(0,n)),y=f(i);w=i,d=true,cancelAnimationFrame(g),T(i,y);},getProgress(){return w}}}export{H as scrollProgress};
@@ -1,3 +1,3 @@
1
- 'use strict';var zt=require('react'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var zt__default=/*#__PURE__*/_interopDefault(zt);function vt({bounces:e=3,decay:n=.5}={}){let r=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,n)),i=Math.sqrt(t),o=0,l=[];for(let p=0;p<r;p++){let I=Math.pow(i,p);l.push(I),o+=I;}let c=[0],a=0;for(let p=0;p<r;p++)a+=l[p]/o,c.push(a);return p=>{if(p<=0)return 0;if(p>=1)return 1;for(let I=0;I<r;I++)if(p<=c[I+1]){let k=(p-c[I])/(c[I+1]-c[I]);if(I===0)return k*(2-k);let E=1-Math.pow(t,I);return E+(1-E)*(2*k-1)*(2*k-1)}return 1}}function Et({amplitude:e=1,period:n=.4}={}){let r=Math.max(1,e),t=Math.max(.1,n),i=r<=1?t/4:t/(2*Math.PI)*Math.asin(1/r);return o=>o<=0?0:o>=1?1:r*Math.pow(2,-10*o)*Math.sin((o-i)*(2*Math.PI)/t)+1}var te={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:vt(),elastic:Et()};function re(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 Je(e,n,r,t){switch(t){case "top":return e+r;case "center":return e+r+n/2;case "bottom":return e+r+n;default:return e+r}}function Ze(e,n){if(/^\d+(\.\d+)?%$/.test(e))return n*(parseFloat(e)/100);switch(e){case "top":return 0;case "center":return n/2;case "bottom":return n;default:return n}}function Ve(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 St(e,n,r){return Math.min(r,Math.max(n,e))}function Y(e,n,r,t){return r===n?0:St((e-n)/(r-n)*t,0,1)}function fe(e,n,r,t,i){let o=Je(e.top,e.height,n,t.element)-Ze(t.viewport,r),l=Je(e.top,e.height,n,i.element)-Ze(i.viewport,r);return {tStart:o,tEnd:l}}function Ke(e){let n=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(n)return [parseInt(n[1]+n[1],16),parseInt(n[2]+n[2],16),parseInt(n[3]+n[3],16)];let r=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(r)return [parseInt(r[1],16),parseInt(r[2],16),parseInt(r[3],16)];let t=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return t?[parseInt(t[1]),parseInt(t[2]),parseInt(t[3])]:null}function Le(e,n,r){let t=Ke(e),i=Ke(n);return !t||!i?e:`rgb(${Math.round(t[0]+(i[0]-t[0])*r)},${Math.round(t[1]+(i[1]-t[1])*r)},${Math.round(t[2]+(i[2]-t[2])*r)})`}var Qe={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 et(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n);}var tt={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},xt=0;function Tt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function At(e){let n=e.getAttribute("stroke"),r=e.getAttribute("fill");!n||n==="none"?et("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&&et("Element has a fill \u2014 it may obscure the stroke animation.",e);}function Mt(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 i(){let o=r==="x"?window.scrollX:window.scrollY,l=e-o,c=n-o,a=r==="x";t.innerHTML=`
2
- <div style="position:absolute;${a?`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;${a?`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",i,{passive:true}),i(),t}function Ge(e,n,r){let t=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),i=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,o=>{let l=parseFloat(o),c=t[i++]??l;return String(+(l+(c-l)*r).toFixed(4))})}function rt(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...t}=n,i=r?{...Qe[r],...t}:t,o=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:l="path, polyline, line, polygon, rect, circle",speed:c=1,fade:a=false,easing:p="linear",trigger:I={},stagger:k=0,direction:E="forward",once:Z=false,debug:ce=false,axis:V="y",scrollContainer:B,autoReverse:S=false,delay:R=0,strokeColor:C,strokeWidth:$,fillOpacity:L,waypoints:h,velocityScale:A=false,threshold:M=0,rootMargin:w="0px",repeat:b=0,repeatDelay:D=0,morphTo:P,clip:z,autoplay:G=false,duration:K=1e3,native:ae=true,onProgress:d,onStart:N,onComplete:y}=i,f=z===true?"left":typeof z=="string"?z:false,H=typeof p=="function"?p:te[p]??te.linear,ge=re(I.start??"top bottom"),m=re(I.end??"bottom top"),g=typeof B=="string"?document.querySelector(B):B??null,se=Array.isArray(C)?C[0]:null,_=Array.isArray(C)?C[1]:typeof C=="string"?C:null,Q=Array.isArray($)?$[0]:null,ie=Array.isArray($)?$[1]:typeof $=="number"?$:null,q=Array.isArray(L)?L[0]:null,j=Array.isArray(L)?L[1]:typeof L=="number"?L:null;function pe(s){let u=s*100;switch(f){case "right":return `inset(0 0 0 ${100-u}%)`;case "top":return `inset(0 0 ${100-u}% 0)`;case "bottom":return `inset(${100-u}% 0 0 0)`;case "center":return `circle(${s*150}% at 50% 50%)`;default:return `inset(0 ${100-u}% 0 0)`}}let ne=f?[]:Array.from(e.querySelectorAll(l)),U=[],he=[],Ee=0,Se=0,le=false,ye=false,oe=0,ke=false,be=-1,Re=-1,ue=false,Pe=0,ve=0,xe,We=null,Te=new Set,Ne=-1,Ye=performance.now();function Ie(){return g?V==="x"?g.scrollLeft:g.scrollTop:V==="x"?window.scrollX:window.scrollY}function je(){return g?V==="x"?g.clientWidth:g.clientHeight:V==="x"?window.innerWidth:window.innerHeight}function Ue(){let s=e.getBoundingClientRect(),u,T,J;if(g){let me=g.getBoundingClientRect();u=V==="x"?s.left-me.left+g.scrollLeft:s.top-me.top+g.scrollTop,T=V==="x"?s.width:s.height,J=Ie();}else u=V==="x"?s.left:s.top,T=V==="x"?s.width:s.height,J=Ie();let de=fe({top:u,height:T},J,je(),ge,m);Ee=de.tStart,Se=de.tEnd,ce&&process.env.NODE_ENV!=="production"&&(We?.remove(),We=Mt(Ee,Se,V));}function yt(s,u){if(e.style.setProperty("--scroll-draw-progress",String(s)),f){let T=u==="reverse"?1-s:s;e.style.clipPath=pe(T);return}ne.forEach((T,J)=>{T.style.strokeDashoffset=u==="reverse"?`${U[J]*s}`:`${U[J]*(1-s)}`,a&&(T.style.opacity=u==="reverse"?`${1-s}`:`${s}`),se&&_?T.style.stroke=Le(se,_,s):_&&(T.style.stroke=_),Q!==null&&ie!==null?T.style.strokeWidth=`${Q+(ie-Q)*s}`:ie!==null&&(T.style.strokeWidth=`${ie}`),q!==null&&j!==null?T.style.fillOpacity=`${q+(j-q)*s}`:j!==null&&(T.style.fillOpacity=`${j}`),P&&T.tagName.toLowerCase()==="path"&&he[J]&&T.setAttribute("d",Ge(he[J],P,s));});}function De(){if(e.style.setProperty("--scroll-draw-progress","0"),f){e.style.clipPath=pe(0);return}ne.forEach((s,u)=>{s.style.strokeDasharray=`${U[u]}`,s.style.strokeDashoffset=E==="reverse"?"0":`${U[u]}`,a?s.style.opacity=E==="reverse"?"1":"0":s.style.opacity="",se&&(s.style.stroke=se),Q!==null&&(s.style.strokeWidth=`${Q}`),q!==null&&(s.style.fillOpacity=`${q}`),P&&s.tagName.toLowerCase()==="path"&&he[u]&&s.setAttribute("d",he[u]);});}if(ne.forEach(s=>{At(s);let u=Ve(s);U.push(u),s.tagName.toLowerCase()==="path"?he.push(s.getAttribute("d")??""):he.push(""),o?(s.style.strokeDasharray=`${u}`,s.style.strokeDashoffset=E==="reverse"?`${u}`:"0",a&&(s.style.opacity="1"),_&&(s.style.stroke=_),ie!==null&&(s.style.strokeWidth=`${ie}`),j!==null&&(s.style.fillOpacity=`${j}`),P&&s.tagName.toLowerCase()==="path"&&s.setAttribute("d",P)):(s.style.strokeDasharray=`${u}`,s.style.strokeDashoffset=E==="reverse"?"0":`${u}`,a?s.style.opacity=E==="reverse"?"1":"0":s.style.opacity="",se&&(s.style.stroke=se),Q!==null&&(s.style.strokeWidth=`${Q}`),q!==null&&(s.style.fillOpacity=`${q}`));}),f){if(o)return e.style.clipPath=pe(1),y?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=pe(0);}else if(o)return y?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function ht(){return !(ae===false||!Tt()||!ne.length||typeof p!="string"||!(p in tt)||f||V!=="y"||g||c!==1||k!==0||Z||S||A!==false||P||h||b||R>0||d||N||y||C!=null||$!=null||L!=null||(I.start??"top bottom").trim()!=="top bottom"||(I.end??"bottom top").trim()!=="bottom top")}function bt(){let s=`svg-scroll-draw-${++xt}`,u=E==="reverse"?"0":"var(--ssd-len)",T=E==="reverse"?"var(--ssd-len)":"0",J=`stroke-dashoffset:${u};`,de=`stroke-dashoffset:${T};`;a&&(J+=`opacity:${E==="reverse"?1:0};`,de+=`opacity:${E==="reverse"?0:1};`);let me=document.createElement("style");me.setAttribute("data-svg-scroll-draw",""),me.textContent=`@keyframes ${s}{from{${J}}to{${de}}}.${s}{animation-name:${s};animation-duration:auto;animation-timing-function:${tt[p]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(me);function x(v,F){v.style.setProperty("--ssd-len",String(U[F])),v.style.strokeDasharray=`${U[F]}`,v.style.strokeDashoffset="",v.style.opacity="",v.style.animationPlayState="",v.classList.add(s);}ne.forEach(x);let W=false,ee=-1;function O(){if(ee>=0)return ee;let v=e.getBoundingClientRect(),{tStart:F,tEnd:X}=fe({top:v.top,height:v.height},Ie(),je(),ge,m);return H(Y(Ie(),F,X,c))}return {destroy(){ne.forEach(v=>{v.classList.remove(s),v.style.removeProperty("--ssd-len"),v.style.animationPlayState="";}),me.remove();},replay(){W=false,ee=-1,ne.forEach(x);},pause(){W=true,ne.forEach(v=>{v.style.animationPlayState="paused";});},resume(){W&&(W=false,ne.forEach(v=>{v.style.animationPlayState="running";}));},seek(v){let F=Math.min(1,Math.max(0,v));ee=F,W=true,ne.forEach((X,Ce)=>{X.classList.remove(s),X.style.strokeDashoffset=E==="reverse"?`${U[Ce]*F}`:`${U[Ce]*(1-F)}`,a&&(X.style.opacity=E==="reverse"?`${1-F}`:`${F}`);});},getProgress(){return O()}}}if(ht())return bt();function wt(){let s=Math.max(1,K),u=0,T=0;function J(O){let v=true;if(f){let F=Math.min(1,Math.max(0,O/s)),X=H(F);Pe=X,e.style.setProperty("--scroll-draw-progress",String(X)),e.style.clipPath=pe(E==="reverse"?1-X:X),d?.(X),F<1&&(v=false);}else ne.forEach((F,X)=>{let Ce=X*k*s,$e=Math.min(1,Math.max(0,(O-Ce)/s)),we=H($e);F.style.strokeDashoffset=E==="reverse"?`${U[X]*we}`:`${U[X]*(1-we)}`,a&&(F.style.opacity=E==="reverse"?`${1-we}`:`${we}`),se&&_?F.style.stroke=Le(se,_,we):_&&(F.style.stroke=_),Q!==null&&ie!==null?F.style.strokeWidth=`${Q+(ie-Q)*we}`:ie!==null&&(F.style.strokeWidth=`${ie}`),q!==null&&j!==null?F.style.fillOpacity=`${q+(j-q)*we}`:j!==null&&(F.style.fillOpacity=`${j}`),P&&F.tagName.toLowerCase()==="path"&&he[X]&&F.setAttribute("d",Ge(he[X],P,we)),X===0&&(d?.(we),e.style.setProperty("--scroll-draw-progress",String(we))),$e<1&&(v=false);});if(h){let F=Math.min(1,Math.max(0,O/s)),X=H(F);for(let Ce in h){let $e=parseFloat(Ce);X>=$e&&!Te.has($e)&&(Te.add($e),h[Ce]?.());}}return v}function de(O){if(ue)return;let v=O-u;ye||(ye=true,N?.());let F=J(v);if(F&&!le){le=true,J(s*(1+Math.max(0,ne.length-1)*k)),y?.(),ve<(b==="infinite"?1/0:b??0)&&(ve++,xe=setTimeout(()=>{u=performance.now(),ye=false,le=false,Te.clear(),De(),oe=requestAnimationFrame(de);},D));return}F||(oe=requestAnimationFrame(de));}function me(){cancelAnimationFrame(oe),clearTimeout(xe),u=performance.now(),T=0,ue=false,ye=false,le=false,ve=0,Te.clear(),De(),oe=requestAnimationFrame(de);}let x=new IntersectionObserver(O=>{O.forEach(v=>{v.isIntersecting&&!(Z&&le)?me():!v.isIntersecting&&!Z&&!le&&(cancelAnimationFrame(oe),clearTimeout(xe),u=null);});},{root:g??null,threshold:M,rootMargin:w}),W;function ee(){clearTimeout(W),W=setTimeout(()=>{ne.forEach((O,v)=>{U[v]=Ve(O),O.style.strokeDasharray=`${U[v]}`;});},150);}return window.addEventListener("resize",ee),window.addEventListener("orientationchange",ee),R>0?setTimeout(()=>x.observe(e),R):x.observe(e),{destroy(){cancelAnimationFrame(oe),clearTimeout(xe),x.disconnect(),window.removeEventListener("resize",ee),window.removeEventListener("orientationchange",ee),clearTimeout(W);},replay(){ve=0,me();},pause(){ue||(ue=true,T=performance.now()-u,cancelAnimationFrame(oe));},resume(){ue&&(ue=false,u=performance.now()-T,oe=requestAnimationFrame(de));},seek(O){let v=Math.min(1,Math.max(0,O));Pe=v,ue=true,T=v*s,u=performance.now()-T,cancelAnimationFrame(oe),J(T);},getProgress(){return Pe}}}if(G)return wt();Ue();function He(){if(!ke||ue)return;let s=performance.now(),u=Ie(),T=c;if(A!==false){let x=s-Ye,W=x>0?Math.abs(u-(Ne<0?u:Ne))/x:0;T=c*Math.max(.2,1+W*(typeof A=="number"?A:1)*.04);}Ne=u,Ye=s;let J=S?Re===-1||u>=Re?"forward":"reverse":E;Re=u;let de=Se-Ee,me=true;if(f){let x=H(Y(u,Ee,Se,T));Z&&!S&&(be=Math.max(be,x),x=be),Pe=x,e.style.setProperty("--scroll-draw-progress",String(x));let W=J==="reverse"?1-x:x;e.style.clipPath=pe(W),d?.(x),!ye&&Y(u,Ee,Se,T)>0&&(ye=true,N?.()),x>=1&&!le?(le=true,y?.(),ve<(b==="infinite"?1/0:b??0)&&(ve++,xe=setTimeout(()=>{be=-1,ye=false,le=false,e.style.clipPath=pe(0);},D))):x<1&&!Z&&(le=false),oe=requestAnimationFrame(He);return}if(ne.forEach((x,W)=>{let ee=W*k*de,O=H(Y(u,Ee+ee,Se+ee,T));Z&&!S&&(be=Math.max(be,O),O=be),Pe=O,x.style.strokeDashoffset=J==="reverse"?`${U[W]*O}`:`${U[W]*(1-O)}`,a&&(x.style.opacity=J==="reverse"?`${1-O}`:`${O}`),se&&_?x.style.stroke=Le(se,_,O):_&&(x.style.stroke=_),Q!==null&&ie!==null?x.style.strokeWidth=`${Q+(ie-Q)*O}`:ie!==null&&(x.style.strokeWidth=`${ie}`),q!==null&&j!==null?x.style.fillOpacity=`${q+(j-q)*O}`:j!==null&&(x.style.fillOpacity=`${j}`),P&&x.tagName.toLowerCase()==="path"&&he[W]&&x.setAttribute("d",Ge(he[W],P,O)),W===0&&(d?.(O),e.style.setProperty("--scroll-draw-progress",String(O))),O<1&&(me=false);}),h){let x=H(Y(u,Ee,Se,T));for(let W in h){let ee=parseFloat(W);x>=ee&&!Te.has(ee)&&(Te.add(ee),h[W]?.());}}!ye&&Y(u,Ee,Se,T)>0&&(ye=true,N?.()),me&&!le?(le=true,y?.(),ve<(b==="infinite"?1/0:b??0)&&(ve++,xe=setTimeout(()=>{be=-1,ye=false,le=false,Te.clear(),De();},D))):!me&&!Z&&(le=false),oe=requestAnimationFrame(He);}let _e=new IntersectionObserver(s=>{s.forEach(u=>{ke=u.isIntersecting,ke&&!ue?oe=requestAnimationFrame(He):cancelAnimationFrame(oe);});},{root:g??null,threshold:M,rootMargin:w}),Be;function ze(){clearTimeout(Be),Be=setTimeout(()=>{ne.forEach((s,u)=>{U[u]=Ve(s),s.style.strokeDasharray=`${U[u]}`;}),Ue();},150);}return window.addEventListener("resize",ze),window.addEventListener("orientationchange",ze),R>0?setTimeout(()=>_e.observe(e),R):_e.observe(e),{destroy(){cancelAnimationFrame(oe),clearTimeout(xe),_e.disconnect(),window.removeEventListener("resize",ze),window.removeEventListener("orientationchange",ze),clearTimeout(Be),We?.remove();},replay(){be=-1,Re=-1,Ne=-1,ye=false,le=false,ve=0,ue=false,Te.clear(),clearTimeout(xe),De();},pause(){ue=true,cancelAnimationFrame(oe);},resume(){ue&&(ue=false,ke&&(oe=requestAnimationFrame(He)));},seek(s){let u=Math.min(1,Math.max(0,s));Pe=u,be=u,ue=true,cancelAnimationFrame(oe),yt(u,E);},getProgress(){return Pe}}}var nt=new Map;function Ae(e,n){nt.set(e,n);}function Me(e){nt.delete(e);}function Pt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function ot(e){let n=[],r=/([\w]+)\(([^)]*)\)/g,t;for(;(t=r.exec(e))!==null;){let i=[],o=[],l=t[2].trim();if(l)for(let c of l.split(/[\s,]+/)){let a=c.match(/^([-+]?[\d.eE]+)(.*)$/);i.push(a?parseFloat(a[1]):0),o.push(a?a[2]:"");}n.push({fn:t[1],nums:i,units:o});}return n}function Ct(e,n,r){let t=ot(e),i=ot(n);return t.length===0||t.length!==i.length?r<1?e:n:t.map((o,l)=>{let c=i[l];return o.fn!==c.fn||o.nums.length!==c.nums.length?r<1?`${o.fn}(${o.nums.map((a,p)=>`${a}${o.units[p]}`).join(", ")})`:`${c.fn}(${c.nums.map((a,p)=>`${a}${c.units[p]}`).join(", ")})`:`${o.fn}(${o.nums.map((a,p)=>`${a+(c.nums[p]-a)*r}${o.units[p]}`).join(", ")})`}).join(" ")}function st(e,n,r){if(typeof e=="number"&&typeof n=="number")return String(e+(n-e)*r);let t=String(e),i=String(n);if(Pt(t))return Le(t,i,r);if(t.includes("("))return Ct(t,i,r);let o=t.match(/^([-+]?[\d.]+)(.*)$/),l=i.match(/^([-+]?[\d.]+)(.*)$/);if(o&&l){let c=parseFloat(o[1]),a=parseFloat(l[1]);return `${c+(a-c)*r}${o[2]||l[2]}`}return r<1?t:i}function $t(e){return e.replace(/([A-Z])/g,n=>`-${n.toLowerCase()}`)}var it={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Lt=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),It=0;function Ot(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function at(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let{props:t,trigger:i={},easing:o="ease-out",speed:l=1,once:c=false,axis:a="y",scrollContainer:p,native:I=true,onProgress:k,onComplete:E}=n,Z=window.matchMedia("(prefers-reduced-motion: reduce)").matches,ce=typeof o=="function"?o:te[o]??te["ease-out"],V=re(i.start??"top bottom"),B=re(i.end??"bottom top"),S=typeof p=="string"?document.querySelector(p):p??null,R=Object.entries(t).map(([m,g])=>({prop:$t(m),from:Array.isArray(g)?g[0]:"",to:Array.isArray(g)?g[1]:g}));function C(){let m=window.getComputedStyle(e);for(let g of R)g.from===""&&(g.from=m.getPropertyValue(g.prop).trim()||"0");}function $(){for(let m of R)e.style.setProperty(m.prop,String(m.to));}if(Z)return $(),E?.(),r;C();function L(){if(!I||!Ot()||typeof o!="string"||!(o in it)||a!=="y"||S||c||l!==1||k||E||(i.start??"top bottom").trim()!=="top bottom"||(i.end??"bottom top").trim()!=="bottom top")return false;for(let m of R)if(!Lt.has(m.prop))return false;return true}function h(){let m=`ssd-a-${++It}`,g=R.map(q=>`${q.prop}:${q.from}`).join(";"),se=R.map(q=>`${q.prop}:${q.to}`).join(";"),_=document.createElement("style");_.setAttribute("data-ssd-animate",""),_.textContent=`@keyframes ${m}{from{${g}}to{${se}}}.${m}{animation-name:${m};animation-duration:auto;animation-timing-function:${it[o]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(_),e.classList.add(m);let Q=()=>a==="x"?window.scrollX:window.scrollY,ie=()=>a==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(m),_.remove();},replay(){e.classList.remove(m),e.offsetWidth,e.classList.add(m);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(q){let j=Math.min(1,Math.max(0,q));e.classList.remove(m);for(let pe of R)e.style.setProperty(pe.prop,st(pe.from,pe.to,j));},getProgress(){let q=e.getBoundingClientRect(),j=Q(),pe=ie(),{tStart:ne,tEnd:U}=fe({top:q.top,height:q.height},j,pe,V,B);return ce(Y(j,ne,U,l))}}}if(L())return h();let A=0,M=0,w=0,b=false,D=false,P=-1,z=0,G=false,K=()=>S?a==="x"?S.scrollLeft:S.scrollTop:a==="x"?window.scrollX:window.scrollY,ae=()=>S?a==="x"?S.clientWidth:S.clientHeight:a==="x"?window.innerWidth:window.innerHeight;function d(){let m=e.getBoundingClientRect(),g,se;if(S){let Q=S.getBoundingClientRect();g=a==="x"?m.left-Q.left+S.scrollLeft:m.top-Q.top+S.scrollTop,se=a==="x"?m.width:m.height;}else g=a==="x"?m.left:m.top,se=a==="x"?m.width:m.height;let _=fe({top:g,height:se},K(),ae(),V,B);A=_.tStart,M=_.tEnd;}function N(m){e.style.setProperty("--scroll-draw-progress",String(m));for(let g of R)e.style.setProperty(g.prop,st(g.from,g.to,m));k?.(m);}function y(){if(!b||D)return;let m=ce(Y(K(),A,M,l));c&&(P=Math.max(P,m),m=P),z=m,N(m),m>=1&&!G?(G=true,E?.()):m<1&&!c&&(G=false),w=requestAnimationFrame(y);}d();{let m=ce(Y(K(),A,M,l));c&&m>0&&(P=m),z=m,N(m);}let f=new IntersectionObserver(m=>{m.forEach(g=>{b=g.isIntersecting,b&&!D?w=requestAnimationFrame(y):cancelAnimationFrame(w);});},{root:S??null}),H;function ge(){clearTimeout(H),H=setTimeout(d,150);}return window.addEventListener("resize",ge),window.addEventListener("orientationchange",ge),f.observe(e),Ae(e,{type:"animate",getProgress:()=>z,getTrigger:()=>({tStart:A,tEnd:M})}),{destroy(){cancelAnimationFrame(w),f.disconnect(),window.removeEventListener("resize",ge),window.removeEventListener("orientationchange",ge),clearTimeout(H),Me(e);},replay(){P=-1,G=false,z=0,D=false,N(0);},pause(){D=true,cancelAnimationFrame(w);},resume(){D&&(D=false,b&&(w=requestAnimationFrame(y)));},seek(m){let g=Math.min(1,Math.max(0,m));z=g,P=g,D=true,cancelAnimationFrame(w),N(g);},getProgress(){return z}}}var Xe={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function lt(e,n){if(typeof window>"u")return Xe;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollCounter: element not found:",e),Xe;let t=r,{from:i=0,to:o,format:l,easing:c="ease-out",trigger:a={},once:p=true,decimals:I,onComplete:k}=n,E=I!==void 0?d=>d.toFixed(I):l??(d=>String(Math.round(d))),Z=typeof c=="function"?c:te[c]??te["ease-out"],ce=re(a.start??"top 80%"),V=re(a.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=E(o),k?.(),Xe;t.textContent=E(i);let S=0,R=0,C=0,$=false,L=false,h=-1,A=0,M=false,w=()=>window.scrollY,b=()=>window.innerHeight;function D(){let d=t.getBoundingClientRect(),N=fe({top:d.top,height:d.height},w(),b(),ce,V);S=N.tStart,R=N.tEnd;}function P(d){t.textContent=E(i+(o-i)*d),t.style.setProperty("--scroll-draw-progress",String(d));}function z(){if(!$||L)return;let d=Z(Y(w(),S,R,1));p&&(h=Math.max(h,d),d=h),A=d,P(d),d>=1&&!M?(M=true,k?.()):d<1&&!p&&(M=false),C=requestAnimationFrame(z);}D();{let d=Z(Y(w(),S,R,1));p&&d>0&&(h=d),A=d,P(d);}let G=new IntersectionObserver(d=>{d.forEach(N=>{$=N.isIntersecting,$&&!L?C=requestAnimationFrame(z):cancelAnimationFrame(C);});}),K;function ae(){clearTimeout(K),K=setTimeout(D,150);}return window.addEventListener("resize",ae),window.addEventListener("orientationchange",ae),G.observe(t),Ae(t,{type:"counter",getProgress:()=>A,getTrigger:()=>({tStart:S,tEnd:R})}),{destroy(){cancelAnimationFrame(C),G.disconnect(),window.removeEventListener("resize",ae),window.removeEventListener("orientationchange",ae),clearTimeout(K),Me(t);},replay(){h=-1,M=false,A=0,L=false,P(0);},pause(){L=true,cancelAnimationFrame(C);},resume(){L&&(L=false,$&&(C=requestAnimationFrame(z)));},seek(d){let N=Math.min(1,Math.max(0,d));A=N,h=N,L=true,cancelAnimationFrame(C),P(N);},getProgress(){return A}}}var ct={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function ut(e,n={}){if(typeof window>"u")return ct;let r=typeof e=="string"?document.querySelector(e):e;if(!r||r.tagName.toLowerCase()!=="video")return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollVideo: <video> element not found:",e),ct;let t=r,{trigger:i={},easing:o="linear",once:l=false,axis:c="y",preload:a="auto",onReady:p,onComplete:I,onProgress:k}=n,E=window.matchMedia("(prefers-reduced-motion: reduce)").matches,Z=typeof o=="function"?o:te[o]??te.linear,ce=re(i.start??"top top"),V=re(i.end??"bottom top");t.pause(),t.hasAttribute("preload")||(t.preload=a);let B=n.from??0,S=n.to,R=0,C=0,$=0,L=false,h=false,A=-1,M=0,w=false,b=false,D=()=>c==="x"?window.scrollX:window.scrollY,P=()=>c==="x"?window.innerWidth:window.innerHeight;function z(){let f=t.getBoundingClientRect(),H=c==="x"?f.left:f.top,ge=c==="x"?f.width:f.height,m=fe({top:H,height:ge},D(),P(),ce,V);R=m.tStart,C=m.tEnd;}function G(f){if(!b)return;let H=S??t.duration??0;t.currentTime=B+(H-B)*f,t.style.setProperty("--scroll-draw-progress",String(f)),k?.(f);}function K(){if(!L||h||!b)return;let f=Z(Y(D(),R,C,1));l&&(A=Math.max(A,f),f=A),M=f,G(f),f>=1&&!w?(w=true,I?.()):f<1&&!l&&(w=false),$=requestAnimationFrame(K);}function ae(){if(b=true,S===void 0&&(S=t.duration),E){G(1),p?.();return}z(),p?.(),L&&!h&&($=requestAnimationFrame(K));}t.readyState>=1?ae():t.addEventListener("loadedmetadata",ae,{once:true}),b||z();let d=new IntersectionObserver(f=>{f.forEach(H=>{L=H.isIntersecting,L&&!h&&b?$=requestAnimationFrame(K):cancelAnimationFrame($);});}),N;function y(){clearTimeout(N),N=setTimeout(z,150);}return window.addEventListener("resize",y),window.addEventListener("orientationchange",y),d.observe(t),Ae(t,{type:"video",getProgress:()=>M,getTrigger:()=>({tStart:R,tEnd:C})}),{destroy(){cancelAnimationFrame($),d.disconnect(),t.removeEventListener("loadedmetadata",ae),window.removeEventListener("resize",y),window.removeEventListener("orientationchange",y),clearTimeout(N),Me(t);},replay(){A=-1,w=false,M=0,h=false,G(0);},pause(){h=true,cancelAnimationFrame($);},resume(){h&&(h=false,L&&b&&($=requestAnimationFrame(K)));},seek(f){let H=Math.min(1,Math.max(0,f));M=H,A=H,h=true,cancelAnimationFrame($),G(H);},getProgress(){return M}}}function pt(e){let n=e.textContent??"";return e.textContent="",n.split(/(\s+)/).filter(Boolean).map(r=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),/^\s+$/.test(r)?(t.textContent=r,t.style.whiteSpace="pre"):(t.textContent=r,t.style.display="inline-block"),e.appendChild(t),/^\s+$/.test(r)?null:t}).filter(r=>r!==null)}function Ft(e){let n=e.textContent??"";return e.textContent="",n.split("").map(r=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),t.textContent=r,r===" "?t.style.whiteSpace="pre":t.style.display="inline-block",e.appendChild(t),r===" "?null:t}).filter(r=>r!==null)}function mt(e){let n=pt(e),r=new Map;for(let o of n){let l=o.offsetTop;r.has(l)||r.set(l,[]),r.get(l).push(o);}let t=[],i=Array.from(r.keys()).sort((o,l)=>o-l);for(let o of i){let l=r.get(o),c=document.createElement("span");c.setAttribute("aria-hidden","true"),c.style.display="inline-block";for(let a of l)c.appendChild(a);t.push(c);}e.textContent="";for(let o of t)e.appendChild(o),e.appendChild(document.createTextNode(" "));return t}function kt(e,n,r,t){if(r<=1||t===0)return e;let i=(r-1)*t,o=n*t,l=o+(1-i);return l<=o?e>=o?1:0:Math.min(1,Math.max(0,(e-o)/(l-o)))}function Rt(e,n){let r=[];if(n?.y!==void 0&&r.push(`translateY(${n.y*(1-e)}px)`),n?.x!==void 0&&r.push(`translateX(${n.x*(1-e)}px)`),n?.rotate!==void 0&&r.push(`rotate(${n.rotate*(1-e)}deg)`),n?.scale!==void 0){let t=n.scale+(1-n.scale)*e;r.push(`scale(${t})`);}return r.join(" ")||""}var ft={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function dt(e,n={}){if(typeof window>"u")return ft;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollText: element not found:",e),ft;let t=r,{split:i="words",stagger:o=.04,easing:l="ease-out",from:c={opacity:0,y:24},trigger:a={},once:p=true,onComplete:I}=n,k=window.matchMedia("(prefers-reduced-motion: reduce)").matches,E=typeof l=="function"?l:te[l]??te["ease-out"],Z=re(a.start??"top 85%"),ce=re(a.end??"top 40%"),V=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let B;i==="chars"?B=Ft(t):i==="lines"?B=mt(t):B=pt(t);let S=B.length;function R(y,f){c?.opacity!==void 0&&(y.style.opacity=String(c.opacity+(1-c.opacity)*f));let H=Rt(f,c);H&&(y.style.transform=H);}function C(y){t.style.setProperty("--scroll-draw-progress",String(y)),B.forEach((f,H)=>{let ge=E(kt(y,H,S,o));R(f,ge);});}if(k)return C(1),I?.(),{destroy(){t.innerHTML=V,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};C(0);let $=0,L=0,h=0,A=false,M=false,w=-1,b=0,D=false,P=()=>window.scrollY,z=()=>window.innerHeight;function G(){let y=t.getBoundingClientRect(),f=fe({top:y.top,height:y.height},P(),z(),Z,ce);$=f.tStart,L=f.tEnd;}function K(){if(!A||M)return;let y=Y(P(),$,L,1);p&&(w=Math.max(w,y),y=w),b=y,C(y),y>=1&&!D?(D=true,I?.()):y<1&&!p&&(D=false),h=requestAnimationFrame(K);}G();let ae=new IntersectionObserver(y=>{y.forEach(f=>{A=f.isIntersecting,A&&!M?h=requestAnimationFrame(K):cancelAnimationFrame(h);});}),d;function N(){clearTimeout(d),d=setTimeout(()=>{if(i==="lines"){let y=b;t.innerHTML=V,t.setAttribute("aria-label",t.textContent??""),B=mt(t),C(y);}G();},150);}return window.addEventListener("resize",N),window.addEventListener("orientationchange",N),ae.observe(t),Ae(t,{type:"text",getProgress:()=>b,getTrigger:()=>({tStart:$,tEnd:L})}),{destroy(){cancelAnimationFrame(h),ae.disconnect(),window.removeEventListener("resize",N),window.removeEventListener("orientationchange",N),clearTimeout(d),t.innerHTML=V,t.removeAttribute("aria-label"),Me(t);},replay(){w=-1,D=false,b=0,M=false,C(0);},pause(){M=true,cancelAnimationFrame(h);},resume(){M&&(M=false,A&&(h=requestAnimationFrame(K)));},seek(y){let f=Math.min(1,Math.max(0,y));b=f,w=f,M=true,cancelAnimationFrame(h),C(f);},getProgress(){return b}}}function Ht(e,n={}){let[r,t]=zt.useState(0),i=zt.useRef(n);i.current=n;let o=zt.useRef(-1);return zt.useEffect(()=>{if(typeof window>"u")return;if(window.matchMedia("(prefers-reduced-motion: reduce)").matches){t(1);return}let l=typeof e=="string"?document.querySelector(e):e.current;if(!l)return;let c=l,{axis:a="y",scrollContainer:p,trigger:I={}}=i.current,k=typeof p=="string"?document.querySelector(p):p??null,E=re(I.start??"top bottom"),Z=re(I.end??"bottom top"),ce=0,V=0,B=false,S=0;function R(){return k?a==="x"?k.scrollLeft:k.scrollTop:a==="x"?window.scrollX:window.scrollY}function C(){return k?a==="x"?k.clientWidth:k.clientHeight:a==="x"?window.innerWidth:window.innerHeight}function $(){let w=c.getBoundingClientRect(),b=R(),D=a==="x"?w.left:w.top,P=a==="x"?w.width:w.height,z=fe({top:D,height:P},b,C(),E,Z);ce=z.tStart,V=z.tEnd;}function L(){if(!B)return;let{speed:w=1,easing:b="linear",once:D=false}=i.current,P=typeof b=="function"?b:te[b]??te.linear,z=Y(R(),ce,V,w),G=P(z);D&&(o.current=Math.max(o.current,G),G=o.current),t(G),S=requestAnimationFrame(L);}let h=new IntersectionObserver(w=>{w.forEach(b=>{B=b.isIntersecting,B?S=requestAnimationFrame(L):cancelAnimationFrame(S);});},{root:k??null,threshold:0});$(),h.observe(c);let A;function M(){clearTimeout(A),A=setTimeout($,150);}return window.addEventListener("resize",M),window.addEventListener("orientationchange",M),()=>{cancelAnimationFrame(S),clearTimeout(A),h.disconnect(),window.removeEventListener("resize",M),window.removeEventListener("orientationchange",M);}},[]),r}function pr({children:e,className:n,style:r,...t}){let i=zt.useRef(null);return zt.useEffect(()=>{if(!i.current)return;let o=rt(i.current,t);return ()=>o.destroy()},[]),jsxRuntime.jsx("div",{ref:i,className:n,style:r,children:e})}function dr({children:e,className:n,style:r,...t}){let i=zt.useRef(null);return zt.useEffect(()=>{if(!i.current)return;let o=at(i.current,t);return ()=>o.destroy()},[]),jsxRuntime.jsx("div",{ref:i,className:n,style:r,children:e})}function gr({className:e,style:n,...r}){let t=zt.useRef(null);return zt.useEffect(()=>{if(!t.current)return;let i=lt(t.current,r);return ()=>i.destroy()},[]),jsxRuntime.jsx("span",{ref:t,className:e,style:n})}function yr({src:e,className:n,style:r,muted:t=true,playsInline:i=true,...o}){let l=zt.useRef(null);return zt.useEffect(()=>{if(!l.current)return;let c=ut(l.current,o);return ()=>c.destroy()},[]),jsxRuntime.jsx("video",{ref:l,src:e,className:n,style:r,muted:t,playsInline:i,preload:"auto"})}function hr({children:e,as:n="p",className:r,style:t,...i}){let o=zt.useRef(null);return zt.useEffect(()=>{if(!o.current)return;let l=dt(o.current,i);return ()=>l.destroy()},[]),zt__default.default.createElement(n,{ref:o,className:r,style:t},e)}exports.ScrollAnimate=dr;exports.ScrollCounter=gr;exports.ScrollDraw=pr;exports.ScrollText=hr;exports.ScrollVideo=yr;exports.useScrollDrawProgress=Ht;
1
+ 'use strict';var _t=require('react'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var _t__default=/*#__PURE__*/_interopDefault(_t);function At({bounces:e=3,decay:n=.5}={}){let r=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,n)),i=Math.sqrt(t),o=0,l=[];for(let y=0;y<r;y++){let L=Math.pow(i,y);l.push(L),o+=L;}let u=[0],c=0;for(let y=0;y<r;y++)c+=l[y]/o,u.push(c);return y=>{if(y<=0)return 0;if(y>=1)return 1;for(let L=0;L<r;L++)if(y<=u[L+1]){let C=(y-u[L])/(u[L+1]-u[L]);if(L===0)return C*(2-C);let S=1-Math.pow(t,L);return S+(1-S)*(2*C-1)*(2*C-1)}return 1}}function Mt({amplitude:e=1,period:n=.4}={}){let r=Math.max(1,e),t=Math.max(.1,n),i=r<=1?t/4:t/(2*Math.PI)*Math.asin(1/r);return o=>o<=0?0:o>=1?1:r*Math.pow(2,-10*o)*Math.sin((o-i)*(2*Math.PI)/t)+1}var re={linear:e=>e,"ease-in":e=>e*e,"ease-out":e=>e*(2-e),"ease-in-out":e=>e<.5?2*e*e:-1+(4-2*e)*e,spring:e=>1-Math.cos(e*Math.PI*2.5)*Math.pow(1-e,2.2),bounce:At(),elastic:Mt()};function ne(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 tt(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 rt(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 Ge(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 Pt(e,n,r){return Math.min(r,Math.max(n,e))}function Z(e,n,r,t){return r===n?0:Pt((e-n)/(r-n)*t,0,1)}function pe(e,n,r,t,i){let o=tt(e.top,e.height,n,t.element)-rt(t.viewport,r),l=tt(e.top,e.height,n,i.element)-rt(i.viewport,r);return {tStart:o,tEnd:l}}function nt(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 Oe(e,n,r){let t=nt(e),i=nt(n);return !t||!i?e:`rgb(${Math.round(t[0]+(i[0]-t[0])*r)},${Math.round(t[1]+(i[1]-t[1])*r)},${Math.round(t[2]+(i[2]-t[2])*r)})`}var ot={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 st(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n);}var it={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Lt=0;function Ct(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function $t(e){let n=e.getAttribute("stroke"),r=e.getAttribute("fill");!n||n==="none"?st("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&&st("Element has a fill \u2014 it may obscure the stroke animation.",e);}function kt(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 i(){let o=r==="x"?window.scrollX:window.scrollY,l=e-o,u=n-o,c=r==="x";t.innerHTML=`
2
+ <div style="position:absolute;${c?`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;${c?`left:${u}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${u}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(t),window.addEventListener("scroll",i,{passive:true}),i(),t}function Je(e,n,r){let t=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),i=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,o=>{let l=parseFloat(o),u=t[i++]??l;return String(+(l+(u-l)*r).toFixed(4))})}function at(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...t}=n,i=r?{...ot[r],...t}:t,o=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:l="path, polyline, line, polygon, rect, circle",speed:u=1,fade:c=false,easing:y="linear",trigger:L={},stagger:C=0,direction:S="forward",once:U=false,debug:de=false,axis:F="y",scrollContainer:_,autoReverse:H=false,delay:G=0,strokeColor:x,strokeWidth:M,fillOpacity:P,waypoints:p,velocityScale:v=false,threshold:N=0,rootMargin:I="0px",repeat:E=0,repeatDelay:J=0,morphTo:T,clip:R,autoplay:D=false,duration:K=1e3,native:X=true,onProgress:d,onStart:$,onComplete:b,onEnter:h,onLeave:Y,onEnterBack:Se,onLeaveBack:xe}=i,be=R===true?"left":typeof R=="string"?R:false,we=typeof y=="function"?y:re[y]??re.linear,Ce=ne(L.start??"top bottom"),He=ne(L.end??"bottom top"),oe=typeof _=="string"?document.querySelector(_):_??null,ge=Array.isArray(x)?x[0]:null,ee=Array.isArray(x)?x[1]:typeof x=="string"?x:null,te=Array.isArray(M)?M[0]:null,a=Array.isArray(M)?M[1]:typeof M=="number"?M:null,g=Array.isArray(P)?P[0]:null,z=Array.isArray(P)?P[1]:typeof P=="number"?P:null;function se(s){let m=s*100;switch(be){case "right":return `inset(0 0 0 ${100-m}%)`;case "top":return `inset(0 0 ${100-m}% 0)`;case "bottom":return `inset(${100-m}% 0 0 0)`;case "center":return `circle(${s*150}% at 50% 50%)`;default:return `inset(0 ${100-m}% 0 0)`}}let O=be?[]:Array.from(e.querySelectorAll(l)),B=[],V=[],le=0,ce=0,ie=false,ye=false,ae=0,ze=false,ve=-1,Ve=-1,ue=false,$e=0,Te=0,Ae,Ye=null,Me=new Set,qe=-1,Ke=performance.now(),Ne=NaN;function Re(){return oe?F==="x"?oe.scrollLeft:oe.scrollTop:F==="x"?window.scrollX:window.scrollY}function Qe(){return oe?F==="x"?oe.clientWidth:oe.clientHeight:F==="x"?window.innerWidth:window.innerHeight}function et(){let s=e.getBoundingClientRect(),m,A,Q;if(oe){let fe=oe.getBoundingClientRect();m=F==="x"?s.left-fe.left+oe.scrollLeft:s.top-fe.top+oe.scrollTop,A=F==="x"?s.width:s.height,Q=Re();}else m=F==="x"?s.left:s.top,A=F==="x"?s.width:s.height,Q=Re();let me=pe({top:m,height:A},Q,Qe(),Ce,He);le=me.tStart,ce=me.tEnd,de&&process.env.NODE_ENV!=="production"&&(Ye?.remove(),Ye=kt(le,ce,F));}function Et(s,m){if(e.style.setProperty("--scroll-draw-progress",String(s)),be){let A=m==="reverse"?1-s:s;e.style.clipPath=se(A);return}O.forEach((A,Q)=>{A.style.strokeDashoffset=m==="reverse"?`${B[Q]*s}`:`${B[Q]*(1-s)}`,c&&(A.style.opacity=m==="reverse"?`${1-s}`:`${s}`),ge&&ee?A.style.stroke=Oe(ge,ee,s):ee&&(A.style.stroke=ee),te!==null&&a!==null?A.style.strokeWidth=`${te+(a-te)*s}`:a!==null&&(A.style.strokeWidth=`${a}`),g!==null&&z!==null?A.style.fillOpacity=`${g+(z-g)*s}`:z!==null&&(A.style.fillOpacity=`${z}`),T&&A.tagName.toLowerCase()==="path"&&V[Q]&&A.setAttribute("d",Je(V[Q],T,s));});}function We(){if(e.style.setProperty("--scroll-draw-progress","0"),be){e.style.clipPath=se(0);return}O.forEach((s,m)=>{s.style.strokeDasharray=`${B[m]}`,s.style.strokeDashoffset=S==="reverse"?"0":`${B[m]}`,c?s.style.opacity=S==="reverse"?"1":"0":s.style.opacity="",ge&&(s.style.stroke=ge),te!==null&&(s.style.strokeWidth=`${te}`),g!==null&&(s.style.fillOpacity=`${g}`),T&&s.tagName.toLowerCase()==="path"&&V[m]&&s.setAttribute("d",V[m]);});}if(O.forEach(s=>{$t(s);let m=Ge(s);B.push(m),s.tagName.toLowerCase()==="path"?V.push(s.getAttribute("d")??""):V.push(""),o?(s.style.strokeDasharray=`${m}`,s.style.strokeDashoffset=S==="reverse"?`${m}`:"0",c&&(s.style.opacity="1"),ee&&(s.style.stroke=ee),a!==null&&(s.style.strokeWidth=`${a}`),z!==null&&(s.style.fillOpacity=`${z}`),T&&s.tagName.toLowerCase()==="path"&&s.setAttribute("d",T)):(s.style.strokeDasharray=`${m}`,s.style.strokeDashoffset=S==="reverse"?"0":`${m}`,c?s.style.opacity=S==="reverse"?"1":"0":s.style.opacity="",ge&&(s.style.stroke=ge),te!==null&&(s.style.strokeWidth=`${te}`),g!==null&&(s.style.fillOpacity=`${g}`));}),be){if(o)return e.style.clipPath=se(1),b?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=se(0);}else if(o)return b?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function St(){return !(X===false||!Ct()||!O.length||typeof y!="string"||!(y in it)||be||F!=="y"||oe||u!==1||C!==0||U||H||v!==false||T||p||E||G>0||d||$||b||h||Y||Se||xe||x!=null||M!=null||P!=null||(L.start??"top bottom").trim()!=="top bottom"||(L.end??"bottom top").trim()!=="bottom top")}function xt(){let s=`svg-scroll-draw-${++Lt}`,m=S==="reverse"?"0":"var(--ssd-len)",A=S==="reverse"?"var(--ssd-len)":"0",Q=`stroke-dashoffset:${m};`,me=`stroke-dashoffset:${A};`;c&&(Q+=`opacity:${S==="reverse"?1:0};`,me+=`opacity:${S==="reverse"?0:1};`);let fe=document.createElement("style");fe.setAttribute("data-svg-scroll-draw",""),fe.textContent=`@keyframes ${s}{from{${Q}}to{${me}}}.${s}{animation-name:${s};animation-duration:auto;animation-timing-function:${it[y]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(fe);function he(f,k){f.style.setProperty("--ssd-len",String(B[k])),f.style.strokeDasharray=`${B[k]}`,f.style.strokeDashoffset="",f.style.opacity="",f.style.animationPlayState="",f.classList.add(s);}O.forEach(he);let w=false,q=-1;function W(){if(q>=0)return q;let f=e.getBoundingClientRect(),{tStart:k,tEnd:j}=pe({top:f.top,height:f.height},Re(),Qe(),Ce,He);return we(Z(Re(),k,j,u))}return {destroy(){O.forEach(f=>{f.classList.remove(s),f.style.removeProperty("--ssd-len"),f.style.animationPlayState="";}),fe.remove();},replay(){w=false,q=-1,O.forEach(he);},pause(){w=true,O.forEach(f=>{f.style.animationPlayState="paused";});},resume(){w&&(w=false,O.forEach(f=>{f.style.animationPlayState="running";}));},seek(f){let k=Math.min(1,Math.max(0,f));q=k,w=true,O.forEach((j,ke)=>{j.classList.remove(s),j.style.strokeDashoffset=S==="reverse"?`${B[ke]*k}`:`${B[ke]*(1-k)}`,c&&(j.style.opacity=S==="reverse"?`${1-k}`:`${k}`);});},getProgress(){return W()}}}if(St())return xt();function Tt(){let s=Math.max(1,K),m=0,A=0;function Q(W){let f=true;if(be){let k=Math.min(1,Math.max(0,W/s)),j=we(k);$e=j,e.style.setProperty("--scroll-draw-progress",String(j)),e.style.clipPath=se(S==="reverse"?1-j:j),d?.(j),k<1&&(f=false);}else O.forEach((k,j)=>{let ke=j*C*s,Ie=Math.min(1,Math.max(0,(W-ke)/s)),Ee=we(Ie);k.style.strokeDashoffset=S==="reverse"?`${B[j]*Ee}`:`${B[j]*(1-Ee)}`,c&&(k.style.opacity=S==="reverse"?`${1-Ee}`:`${Ee}`),ge&&ee?k.style.stroke=Oe(ge,ee,Ee):ee&&(k.style.stroke=ee),te!==null&&a!==null?k.style.strokeWidth=`${te+(a-te)*Ee}`:a!==null&&(k.style.strokeWidth=`${a}`),g!==null&&z!==null?k.style.fillOpacity=`${g+(z-g)*Ee}`:z!==null&&(k.style.fillOpacity=`${z}`),T&&k.tagName.toLowerCase()==="path"&&V[j]&&k.setAttribute("d",Je(V[j],T,Ee)),j===0&&(d?.(Ee),e.style.setProperty("--scroll-draw-progress",String(Ee))),Ie<1&&(f=false);});if(p){let k=Math.min(1,Math.max(0,W/s)),j=we(k);for(let ke in p){let Ie=parseFloat(ke);j>=Ie&&!Me.has(Ie)&&(Me.add(Ie),p[ke]?.());}}return f}function me(W){if(ue)return;let f=W-m;ye||(ye=true,$?.());let k=Q(f);if(k&&!ie){ie=true,Q(s*(1+Math.max(0,O.length-1)*C)),b?.(),Te<(E==="infinite"?1/0:E??0)&&(Te++,Ae=setTimeout(()=>{m=performance.now(),ye=false,ie=false,Me.clear(),We(),ae=requestAnimationFrame(me);},J));return}k||(ae=requestAnimationFrame(me));}function fe(){cancelAnimationFrame(ae),clearTimeout(Ae),m=performance.now(),A=0,ue=false,ye=false,ie=false,Te=0,Me.clear(),We(),ae=requestAnimationFrame(me);}let he=new IntersectionObserver(W=>{W.forEach(f=>{f.isIntersecting&&!(U&&ie)?fe():!f.isIntersecting&&!U&&!ie&&(cancelAnimationFrame(ae),clearTimeout(Ae),m=null);});},{root:oe??null,threshold:N,rootMargin:I}),w;function q(){clearTimeout(w),w=setTimeout(()=>{O.forEach((W,f)=>{B[f]=Ge(W),W.style.strokeDasharray=`${B[f]}`;});},150);}return window.addEventListener("resize",q),window.addEventListener("orientationchange",q),G>0?setTimeout(()=>he.observe(e),G):he.observe(e),{destroy(){cancelAnimationFrame(ae),clearTimeout(Ae),he.disconnect(),window.removeEventListener("resize",q),window.removeEventListener("orientationchange",q),clearTimeout(w);},replay(){Te=0,fe();},pause(){ue||(ue=true,A=performance.now()-m,cancelAnimationFrame(ae));},resume(){ue&&(ue=false,m=performance.now()-A,ae=requestAnimationFrame(me));},seek(W){let f=Math.min(1,Math.max(0,W));$e=f,ue=true,A=f*s,m=performance.now()-A,cancelAnimationFrame(ae),Q(A);},getProgress(){return $e}}}if(D)return Tt();et();function Be(){if(!ze||ue)return;let s=performance.now(),m=Re(),A=u;if(v!==false){let w=s-Ke,q=w>0?Math.abs(m-(qe<0?m:qe))/w:0;A=u*Math.max(.2,1+q*(typeof v=="number"?v:1)*.04);}qe=m,Ke=s;let Q=H?Ve===-1||m>=Ve?"forward":"reverse":S;Ve=m;let me=ce-le,fe=true,he=me===0?0:(m-le)/me;if(isNaN(Ne)||(Ne<=0&&he>0?h?.():Ne>0&&he<=0&&xe?.(),Ne<1&&he>=1?Y?.():Ne>=1&&he<1&&Se?.()),Ne=he,be){let w=we(Z(m,le,ce,A));U&&!H&&(ve=Math.max(ve,w),w=ve),$e=w,e.style.setProperty("--scroll-draw-progress",String(w));let q=Q==="reverse"?1-w:w;e.style.clipPath=se(q),d?.(w),!ye&&Z(m,le,ce,A)>0&&(ye=true,$?.()),w>=1&&!ie?(ie=true,b?.(),Te<(E==="infinite"?1/0:E??0)&&(Te++,Ae=setTimeout(()=>{ve=-1,ye=false,ie=false,e.style.clipPath=se(0);},J))):w<1&&!U&&(ie=false),ae=requestAnimationFrame(Be);return}if(O.forEach((w,q)=>{let W=q*C*me,f=we(Z(m,le+W,ce+W,A));U&&!H&&(ve=Math.max(ve,f),f=ve),$e=f,w.style.strokeDashoffset=Q==="reverse"?`${B[q]*f}`:`${B[q]*(1-f)}`,c&&(w.style.opacity=Q==="reverse"?`${1-f}`:`${f}`),ge&&ee?w.style.stroke=Oe(ge,ee,f):ee&&(w.style.stroke=ee),te!==null&&a!==null?w.style.strokeWidth=`${te+(a-te)*f}`:a!==null&&(w.style.strokeWidth=`${a}`),g!==null&&z!==null?w.style.fillOpacity=`${g+(z-g)*f}`:z!==null&&(w.style.fillOpacity=`${z}`),T&&w.tagName.toLowerCase()==="path"&&V[q]&&w.setAttribute("d",Je(V[q],T,f)),q===0&&(d?.(f),e.style.setProperty("--scroll-draw-progress",String(f))),f<1&&(fe=false);}),p){let w=we(Z(m,le,ce,A));for(let q in p){let W=parseFloat(q);w>=W&&!Me.has(W)&&(Me.add(W),p[q]?.());}}!ye&&Z(m,le,ce,A)>0&&(ye=true,$?.()),fe&&!ie?(ie=true,b?.(),Te<(E==="infinite"?1/0:E??0)&&(Te++,Ae=setTimeout(()=>{ve=-1,ye=false,ie=false,Me.clear(),We();},J))):!fe&&!U&&(ie=false),ae=requestAnimationFrame(Be);}let je=new IntersectionObserver(s=>{s.forEach(m=>{ze=m.isIntersecting,ze&&!ue?ae=requestAnimationFrame(Be):cancelAnimationFrame(ae);});},{root:oe??null,threshold:N,rootMargin:I}),Ue;function _e(){clearTimeout(Ue),Ue=setTimeout(()=>{O.forEach((s,m)=>{B[m]=Ge(s),s.style.strokeDasharray=`${B[m]}`;}),et();},150);}return window.addEventListener("resize",_e),window.addEventListener("orientationchange",_e),G>0?setTimeout(()=>je.observe(e),G):je.observe(e),{destroy(){cancelAnimationFrame(ae),clearTimeout(Ae),je.disconnect(),window.removeEventListener("resize",_e),window.removeEventListener("orientationchange",_e),clearTimeout(Ue),Ye?.remove();},replay(){ve=-1,Ve=-1,qe=-1,ye=false,ie=false,Te=0,ue=false,Me.clear(),clearTimeout(Ae),We();},pause(){ue=true,cancelAnimationFrame(ae);},resume(){ue&&(ue=false,ze&&(ae=requestAnimationFrame(Be)));},seek(s){let m=Math.min(1,Math.max(0,s));$e=m,ve=m,ue=true,cancelAnimationFrame(ae),Et(m,S);},getProgress(){return $e}}}var lt=new Map;function Pe(e,n){lt.set(e,n);}function Le(e){lt.delete(e);}function Nt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function ct(e){let n=[],r=/([\w]+)\(([^)]*)\)/g,t;for(;(t=r.exec(e))!==null;){let i=[],o=[],l=t[2].trim();if(l)for(let u of l.split(/[\s,]+/)){let c=u.match(/^([-+]?[\d.eE]+)(.*)$/);i.push(c?parseFloat(c[1]):0),o.push(c?c[2]:"");}n.push({fn:t[1],nums:i,units:o});}return n}function It(e,n,r){let t=ct(e),i=ct(n);return t.length===0||t.length!==i.length?r<1?e:n:t.map((o,l)=>{let u=i[l];return o.fn!==u.fn||o.nums.length!==u.nums.length?r<1?`${o.fn}(${o.nums.map((c,y)=>`${c}${o.units[y]}`).join(", ")})`:`${u.fn}(${u.nums.map((c,y)=>`${c}${u.units[y]}`).join(", ")})`:`${o.fn}(${o.nums.map((c,y)=>`${c+(u.nums[y]-c)*r}${o.units[y]}`).join(", ")})`}).join(" ")}function ut(e,n,r){if(typeof e=="number"&&typeof n=="number")return String(e+(n-e)*r);let t=String(e),i=String(n);if(Nt(t))return Oe(t,i,r);if(t.includes("("))return It(t,i,r);let o=t.match(/^([-+]?[\d.]+)(.*)$/),l=i.match(/^([-+]?[\d.]+)(.*)$/);if(o&&l){let u=parseFloat(o[1]),c=parseFloat(l[1]);return `${u+(c-u)*r}${o[2]||l[2]}`}return r<1?t:i}function Ot(e){return e.replace(/([A-Z])/g,n=>`-${n.toLowerCase()}`)}var mt={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"]),Ft=0;function Dt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function ft(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let{props:t,trigger:i={},easing:o="ease-out",speed:l=1,once:u=false,axis:c="y",scrollContainer:y,native:L=true,velocityScale:C=false,onProgress:S,onComplete:U,onEnter:de,onLeave:F,onEnterBack:_,onLeaveBack:H}=n,G=window.matchMedia("(prefers-reduced-motion: reduce)").matches,x=typeof o=="function"?o:re[o]??re["ease-out"],M=ne(i.start??"top bottom"),P=ne(i.end??"bottom top"),p=typeof y=="string"?document.querySelector(y):y??null,v=Object.entries(t).map(([a,g])=>({prop:Ot(a),from:Array.isArray(g)?g[0]:"",to:Array.isArray(g)?g[1]:g}));function N(){let a=window.getComputedStyle(e);for(let g of v)g.from===""&&(g.from=a.getPropertyValue(g.prop).trim()||"0");}function I(){for(let a of v)e.style.setProperty(a.prop,String(a.to));}if(G)return I(),U?.(),r;N();function E(){if(!L||!Dt()||typeof o!="string"||!(o in mt)||c!=="y"||p||u||l!==1||S||U||de||F||_||H||C!==false||(i.start??"top bottom").trim()!=="top bottom"||(i.end??"bottom top").trim()!=="bottom top")return false;for(let a of v)if(!Rt.has(a.prop))return false;return true}function J(){let a=`ssd-a-${++Ft}`,g=v.map(V=>`${V.prop}:${V.from}`).join(";"),z=v.map(V=>`${V.prop}:${V.to}`).join(";"),se=document.createElement("style");se.setAttribute("data-ssd-animate",""),se.textContent=`@keyframes ${a}{from{${g}}to{${z}}}.${a}{animation-name:${a};animation-duration:auto;animation-timing-function:${mt[o]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(se),e.classList.add(a);let O=()=>c==="x"?window.scrollX:window.scrollY,B=()=>c==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(a),se.remove();},replay(){e.classList.remove(a),e.offsetWidth,e.classList.add(a);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(V){let le=Math.min(1,Math.max(0,V));e.classList.remove(a);for(let ce of v)e.style.setProperty(ce.prop,ut(ce.from,ce.to,le));},getProgress(){let V=e.getBoundingClientRect(),le=O(),ce=B(),{tStart:ie,tEnd:ye}=pe({top:V.top,height:V.height},le,ce,M,P);return x(Z(le,ie,ye,l))}}}if(E())return J();let T=0,R=0,D=0,K=false,X=false,d=-1,$=0,b=false,h=NaN,Y=-1,Se=0,xe=()=>p?c==="x"?p.scrollLeft:p.scrollTop:c==="x"?window.scrollX:window.scrollY,be=()=>p?c==="x"?p.clientWidth:p.clientHeight:c==="x"?window.innerWidth:window.innerHeight;function we(){let a=e.getBoundingClientRect(),g,z;if(p){let O=p.getBoundingClientRect();g=c==="x"?a.left-O.left+p.scrollLeft:a.top-O.top+p.scrollTop,z=c==="x"?a.width:a.height;}else g=c==="x"?a.left:a.top,z=c==="x"?a.width:a.height;let se=pe({top:g,height:z},xe(),be(),M,P);T=se.tStart,R=se.tEnd;}function Ce(a){e.style.setProperty("--scroll-draw-progress",String(a));for(let g of v)e.style.setProperty(g.prop,ut(g.from,g.to,a));S?.(a);}function He(a){if(isNaN(h)){h=a;return}h<=0&&a>0?de?.():h>0&&a<=0&&H?.(),h<1&&a>=1?F?.():h>=1&&a<1&&_?.(),h=a;}function oe(){if(!K||X)return;let a=performance.now(),g=xe(),z=l;if(C!==false){let B=a-Se,V=B>0?Math.abs(g-(Y<0?g:Y))/B:0;z=l*Math.max(.2,1+V*(typeof C=="number"?C:1)*.04);}Y=g,Se=a;let se=R===T?0:(g-T)/(R-T);He(se);let O=x(Z(g,T,R,z));u&&(d=Math.max(d,O),O=d),$=O,Ce(O),O>=1&&!b?(b=true,U?.()):O<1&&!u&&(b=false),D=requestAnimationFrame(oe);}we();{let a=x(Z(xe(),T,R,l));u&&a>0&&(d=a),$=a,Ce(a);}let ge=new IntersectionObserver(a=>{a.forEach(g=>{K=g.isIntersecting,K&&!X?D=requestAnimationFrame(oe):cancelAnimationFrame(D);});},{root:p??null}),ee;function te(){clearTimeout(ee),ee=setTimeout(we,150);}return window.addEventListener("resize",te),window.addEventListener("orientationchange",te),ge.observe(e),Pe(e,{type:"animate",getProgress:()=>$,getTrigger:()=>({tStart:T,tEnd:R})}),{destroy(){cancelAnimationFrame(D),ge.disconnect(),window.removeEventListener("resize",te),window.removeEventListener("orientationchange",te),clearTimeout(ee),Le(e);},replay(){d=-1,b=false,$=0,X=false,Ce(0);},pause(){X=true,cancelAnimationFrame(D);},resume(){X&&(X=false,K&&(D=requestAnimationFrame(oe)));},seek(a){let g=Math.min(1,Math.max(0,a));$=g,d=g,X=true,cancelAnimationFrame(D),Ce(g);},getProgress(){return $}}}var Ze={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function pt(e,n){if(typeof window>"u")return Ze;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollCounter: element not found:",e),Ze;let t=r,{from:i=0,to:o,format:l,easing:u="ease-out",trigger:c={},once:y=true,decimals:L,onComplete:C}=n,S=L!==void 0?d=>d.toFixed(L):l??(d=>String(Math.round(d))),U=typeof u=="function"?u:re[u]??re["ease-out"],de=ne(c.start??"top 80%"),F=ne(c.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=S(o),C?.(),Ze;t.textContent=S(i);let H=0,G=0,x=0,M=false,P=false,p=-1,v=0,N=false,I=()=>window.scrollY,E=()=>window.innerHeight;function J(){let d=t.getBoundingClientRect(),$=pe({top:d.top,height:d.height},I(),E(),de,F);H=$.tStart,G=$.tEnd;}function T(d){t.textContent=S(i+(o-i)*d),t.style.setProperty("--scroll-draw-progress",String(d));}function R(){if(!M||P)return;let d=U(Z(I(),H,G,1));y&&(p=Math.max(p,d),d=p),v=d,T(d),d>=1&&!N?(N=true,C?.()):d<1&&!y&&(N=false),x=requestAnimationFrame(R);}J();{let d=U(Z(I(),H,G,1));y&&d>0&&(p=d),v=d,T(d);}let D=new IntersectionObserver(d=>{d.forEach($=>{M=$.isIntersecting,M&&!P?x=requestAnimationFrame(R):cancelAnimationFrame(x);});}),K;function X(){clearTimeout(K),K=setTimeout(J,150);}return window.addEventListener("resize",X),window.addEventListener("orientationchange",X),D.observe(t),Pe(t,{type:"counter",getProgress:()=>v,getTrigger:()=>({tStart:H,tEnd:G})}),{destroy(){cancelAnimationFrame(x),D.disconnect(),window.removeEventListener("resize",X),window.removeEventListener("orientationchange",X),clearTimeout(K),Le(t);},replay(){p=-1,N=false,v=0,P=false,T(0);},pause(){P=true,cancelAnimationFrame(x);},resume(){P&&(P=false,M&&(x=requestAnimationFrame(R)));},seek(d){let $=Math.min(1,Math.max(0,d));v=$,p=$,P=true,cancelAnimationFrame(x),T($);},getProgress(){return v}}}var dt={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function gt(e,n={}){if(typeof window>"u")return dt;let r=typeof e=="string"?document.querySelector(e):e;if(!r||r.tagName.toLowerCase()!=="video")return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollVideo: <video> element not found:",e),dt;let t=r,{trigger:i={},easing:o="linear",once:l=false,axis:u="y",preload:c="auto",onReady:y,onComplete:L,onProgress:C}=n,S=window.matchMedia("(prefers-reduced-motion: reduce)").matches,U=typeof o=="function"?o:re[o]??re.linear,de=ne(i.start??"top top"),F=ne(i.end??"bottom top");t.pause(),t.hasAttribute("preload")||(t.preload=c);let _=n.from??0,H=n.to,G=0,x=0,M=0,P=false,p=false,v=-1,N=0,I=false,E=false,J=()=>u==="x"?window.scrollX:window.scrollY,T=()=>u==="x"?window.innerWidth:window.innerHeight;function R(){let h=t.getBoundingClientRect(),Y=u==="x"?h.left:h.top,Se=u==="x"?h.width:h.height,xe=pe({top:Y,height:Se},J(),T(),de,F);G=xe.tStart,x=xe.tEnd;}function D(h){if(!E)return;let Y=H??t.duration??0;t.currentTime=_+(Y-_)*h,t.style.setProperty("--scroll-draw-progress",String(h)),C?.(h);}function K(){if(!P||p||!E)return;let h=U(Z(J(),G,x,1));l&&(v=Math.max(v,h),h=v),N=h,D(h),h>=1&&!I?(I=true,L?.()):h<1&&!l&&(I=false),M=requestAnimationFrame(K);}function X(){if(E=true,H===void 0&&(H=t.duration),S){D(1),y?.();return}R(),y?.(),P&&!p&&(M=requestAnimationFrame(K));}t.readyState>=1?X():t.addEventListener("loadedmetadata",X,{once:true}),E||R();let d=new IntersectionObserver(h=>{h.forEach(Y=>{P=Y.isIntersecting,P&&!p&&E?M=requestAnimationFrame(K):cancelAnimationFrame(M);});}),$;function b(){clearTimeout($),$=setTimeout(R,150);}return window.addEventListener("resize",b),window.addEventListener("orientationchange",b),d.observe(t),Pe(t,{type:"video",getProgress:()=>N,getTrigger:()=>({tStart:G,tEnd:x})}),{destroy(){cancelAnimationFrame(M),d.disconnect(),t.removeEventListener("loadedmetadata",X),window.removeEventListener("resize",b),window.removeEventListener("orientationchange",b),clearTimeout($),Le(t);},replay(){v=-1,I=false,N=0,p=false,D(0);},pause(){p=true,cancelAnimationFrame(M);},resume(){p&&(p=false,P&&E&&(M=requestAnimationFrame(K)));},seek(h){let Y=Math.min(1,Math.max(0,h));N=Y,v=Y,p=true,cancelAnimationFrame(M),D(Y);},getProgress(){return N}}}function bt(e){let n=e.textContent??"";return e.textContent="",n.split(/(\s+)/).filter(Boolean).map(r=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),/^\s+$/.test(r)?(t.textContent=r,t.style.whiteSpace="pre"):(t.textContent=r,t.style.display="inline-block"),e.appendChild(t),/^\s+$/.test(r)?null:t}).filter(r=>r!==null)}function Ht(e){let n=e.textContent??"";return e.textContent="",n.split("").map(r=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),t.textContent=r,r===" "?t.style.whiteSpace="pre":t.style.display="inline-block",e.appendChild(t),r===" "?null:t}).filter(r=>r!==null)}function yt(e){let n=bt(e),r=new Map;for(let o of n){let l=o.offsetTop;r.has(l)||r.set(l,[]),r.get(l).push(o);}let t=[],i=Array.from(r.keys()).sort((o,l)=>o-l);for(let o of i){let l=r.get(o),u=document.createElement("span");u.setAttribute("aria-hidden","true"),u.style.display="inline-block";for(let c of l)u.appendChild(c);t.push(u);}e.textContent="";for(let o of t)e.appendChild(o),e.appendChild(document.createTextNode(" "));return t}function zt(e,n,r,t){if(r<=1||t===0)return e;let i=(r-1)*t,o=n*t,l=o+(1-i);return l<=o?e>=o?1:0:Math.min(1,Math.max(0,(e-o)/(l-o)))}function Vt(e,n){let r=[];if(n?.y!==void 0&&r.push(`translateY(${n.y*(1-e)}px)`),n?.x!==void 0&&r.push(`translateX(${n.x*(1-e)}px)`),n?.rotate!==void 0&&r.push(`rotate(${n.rotate*(1-e)}deg)`),n?.scale!==void 0){let t=n.scale+(1-n.scale)*e;r.push(`scale(${t})`);}return r.join(" ")||""}var ht={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function wt(e,n={}){if(typeof window>"u")return ht;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollText: element not found:",e),ht;let t=r,{split:i="words",stagger:o=.04,easing:l="ease-out",from:u={opacity:0,y:24},trigger:c={},once:y=true,onComplete:L}=n,C=window.matchMedia("(prefers-reduced-motion: reduce)").matches,S=typeof l=="function"?l:re[l]??re["ease-out"],U=ne(c.start??"top 85%"),de=ne(c.end??"top 40%"),F=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let _;i==="chars"?_=Ht(t):i==="lines"?_=yt(t):_=bt(t);let H=_.length;function G(b,h){u?.opacity!==void 0&&(b.style.opacity=String(u.opacity+(1-u.opacity)*h));let Y=Vt(h,u);Y&&(b.style.transform=Y);}function x(b){t.style.setProperty("--scroll-draw-progress",String(b)),_.forEach((h,Y)=>{let Se=S(zt(b,Y,H,o));G(h,Se);});}if(C)return x(1),L?.(),{destroy(){t.innerHTML=F,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};x(0);let M=0,P=0,p=0,v=false,N=false,I=-1,E=0,J=false,T=()=>window.scrollY,R=()=>window.innerHeight;function D(){let b=t.getBoundingClientRect(),h=pe({top:b.top,height:b.height},T(),R(),U,de);M=h.tStart,P=h.tEnd;}function K(){if(!v||N)return;let b=Z(T(),M,P,1);y&&(I=Math.max(I,b),b=I),E=b,x(b),b>=1&&!J?(J=true,L?.()):b<1&&!y&&(J=false),p=requestAnimationFrame(K);}D();let X=new IntersectionObserver(b=>{b.forEach(h=>{v=h.isIntersecting,v&&!N?p=requestAnimationFrame(K):cancelAnimationFrame(p);});}),d;function $(){clearTimeout(d),d=setTimeout(()=>{if(i==="lines"){let b=E;t.innerHTML=F,t.setAttribute("aria-label",t.textContent??""),_=yt(t),x(b);}D();},150);}return window.addEventListener("resize",$),window.addEventListener("orientationchange",$),X.observe(t),Pe(t,{type:"text",getProgress:()=>E,getTrigger:()=>({tStart:M,tEnd:P})}),{destroy(){cancelAnimationFrame(p),X.disconnect(),window.removeEventListener("resize",$),window.removeEventListener("orientationchange",$),clearTimeout(d),t.innerHTML=F,t.removeAttribute("aria-label"),Le(t);},replay(){I=-1,J=false,E=0,N=false,x(0);},pause(){N=true,cancelAnimationFrame(p);},resume(){N&&(N=false,v&&(p=requestAnimationFrame(K)));},seek(b){let h=Math.min(1,Math.max(0,b));E=h,I=h,N=true,cancelAnimationFrame(p),x(h);},getProgress(){return E}}}function Bt(e,n={}){let[r,t]=_t.useState(0),i=_t.useRef(n);i.current=n;let o=_t.useRef(-1);return _t.useEffect(()=>{if(typeof window>"u")return;if(window.matchMedia("(prefers-reduced-motion: reduce)").matches){t(1);return}let l=typeof e=="string"?document.querySelector(e):e.current;if(!l)return;let u=l,{axis:c="y",scrollContainer:y,trigger:L={}}=i.current,C=typeof y=="string"?document.querySelector(y):y??null,S=ne(L.start??"top bottom"),U=ne(L.end??"bottom top"),de=0,F=0,_=false,H=0;function G(){return C?c==="x"?C.scrollLeft:C.scrollTop:c==="x"?window.scrollX:window.scrollY}function x(){return C?c==="x"?C.clientWidth:C.clientHeight:c==="x"?window.innerWidth:window.innerHeight}function M(){let I=u.getBoundingClientRect(),E=G(),J=c==="x"?I.left:I.top,T=c==="x"?I.width:I.height,R=pe({top:J,height:T},E,x(),S,U);de=R.tStart,F=R.tEnd;}function P(){if(!_)return;let{speed:I=1,easing:E="linear",once:J=false}=i.current,T=typeof E=="function"?E:re[E]??re.linear,R=Z(G(),de,F,I),D=T(R);J&&(o.current=Math.max(o.current,D),D=o.current),t(D),H=requestAnimationFrame(P);}let p=new IntersectionObserver(I=>{I.forEach(E=>{_=E.isIntersecting,_?H=requestAnimationFrame(P):cancelAnimationFrame(H);});},{root:C??null,threshold:0});M(),p.observe(u);let v;function N(){clearTimeout(v),v=setTimeout(M,150);}return window.addEventListener("resize",N),window.addEventListener("orientationchange",N),()=>{cancelAnimationFrame(H),clearTimeout(v),p.disconnect(),window.removeEventListener("resize",N),window.removeEventListener("orientationchange",N);}},[]),r}function br({children:e,className:n,style:r,...t}){let i=_t.useRef(null);return _t.useEffect(()=>{if(!i.current)return;let o=at(i.current,t);return ()=>o.destroy()},[]),jsxRuntime.jsx("div",{ref:i,className:n,style:r,children:e})}function wr({children:e,className:n,style:r,...t}){let i=_t.useRef(null);return _t.useEffect(()=>{if(!i.current)return;let o=ft(i.current,t);return ()=>o.destroy()},[]),jsxRuntime.jsx("div",{ref:i,className:n,style:r,children:e})}function vr({className:e,style:n,...r}){let t=_t.useRef(null);return _t.useEffect(()=>{if(!t.current)return;let i=pt(t.current,r);return ()=>i.destroy()},[]),jsxRuntime.jsx("span",{ref:t,className:e,style:n})}function Er({src:e,className:n,style:r,muted:t=true,playsInline:i=true,...o}){let l=_t.useRef(null);return _t.useEffect(()=>{if(!l.current)return;let u=gt(l.current,o);return ()=>u.destroy()},[]),jsxRuntime.jsx("video",{ref:l,src:e,className:n,style:r,muted:t,playsInline:i,preload:"auto"})}function Sr({children:e,as:n="p",className:r,style:t,...i}){let o=_t.useRef(null);return _t.useEffect(()=>{if(!o.current)return;let l=wt(o.current,i);return ()=>l.destroy()},[]),_t__default.default.createElement(n,{ref:o,className:r,style:t},e)}exports.ScrollAnimate=wr;exports.ScrollCounter=vr;exports.ScrollDraw=br;exports.ScrollText=Sr;exports.ScrollVideo=Er;exports.useScrollDrawProgress=Bt;