svg-scroll-draw 2.7.0 → 2.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/angular/index.cjs +2 -2
- package/dist/angular/index.d.mts +6 -0
- package/dist/angular/index.d.ts +6 -0
- package/dist/angular/index.mjs +2 -2
- package/dist/astro/index.cjs +3 -3
- package/dist/astro/index.mjs +3 -3
- package/dist/cdn/svg-scroll-draw.global.js +3 -3
- package/dist/group/index.cjs +3 -3
- package/dist/group/index.d.mts +6 -0
- package/dist/group/index.d.ts +6 -0
- package/dist/group/index.mjs +3 -3
- package/dist/horizontal/index.cjs +1 -0
- package/dist/horizontal/index.d.mts +61 -0
- package/dist/horizontal/index.d.ts +61 -0
- package/dist/horizontal/index.mjs +1 -0
- package/dist/index.cjs +2 -2
- package/dist/index.d.mts +6 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.mjs +2 -2
- package/dist/nuxt/index.cjs +3 -3
- package/dist/nuxt/index.d.mts +6 -0
- package/dist/nuxt/index.d.ts +6 -0
- package/dist/nuxt/index.mjs +3 -3
- package/dist/pin/index.cjs +1 -1
- package/dist/pin/index.mjs +1 -1
- package/dist/progress/index.cjs +1 -0
- package/dist/progress/index.d.mts +59 -0
- package/dist/progress/index.d.ts +59 -0
- package/dist/progress/index.mjs +1 -0
- package/dist/react/index.cjs +3 -3
- package/dist/react/index.d.mts +6 -0
- package/dist/react/index.d.ts +6 -0
- package/dist/react/index.mjs +3 -3
- package/dist/reveal/index.cjs +1 -0
- package/dist/reveal/index.d.mts +80 -0
- package/dist/reveal/index.d.ts +80 -0
- package/dist/reveal/index.mjs +1 -0
- package/dist/solid/index.cjs +2 -2
- package/dist/solid/index.d.mts +6 -0
- package/dist/solid/index.d.ts +6 -0
- package/dist/solid/index.mjs +2 -2
- package/dist/svelte/index.cjs +2 -2
- package/dist/svelte/index.d.mts +6 -0
- package/dist/svelte/index.d.ts +6 -0
- package/dist/svelte/index.mjs +2 -2
- package/dist/vue/index.cjs +2 -2
- package/dist/vue/index.d.mts +6 -0
- package/dist/vue/index.d.ts +6 -0
- package/dist/vue/index.mjs +2 -2
- package/package.json +16 -1
package/dist/index.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
function Et({tension:e=2.5,friction:t=2.2}={}){return r=>1-Math.cos(r*Math.PI*e)*Math.pow(1-r,t)}function it({bounces:e=3,decay:t=.5}={}){let r=Math.max(1,Math.round(e)),n=Math.max(.01,Math.min(.99,t)),
|
|
1
|
+
function Et({tension:e=2.5,friction:t=2.2}={}){return r=>1-Math.cos(r*Math.PI*e)*Math.pow(1-r,t)}function it({bounces:e=3,decay:t=.5}={}){let r=Math.max(1,Math.round(e)),n=Math.max(.01,Math.min(.99,t)),u=Math.sqrt(n),a=0,h=[];for(let p=0;p<r;p++){let x=Math.pow(u,p);h.push(x),a+=x;}let f=[0],l=0;for(let p=0;p<r;p++)l+=h[p]/a,f.push(l);return p=>{if(p<=0)return 0;if(p>=1)return 1;for(let x=0;x<r;x++)if(p<=f[x+1]){let F=(p-f[x])/(f[x+1]-f[x]);if(x===0)return F*(2-F);let E=1-Math.pow(n,x);return E+(1-E)*(2*F-1)*(2*F-1)}return 1}}function at({amplitude:e=1,period:t=.4}={}){let r=Math.max(1,e),n=Math.max(.1,t),u=r<=1?n/4:n/(2*Math.PI)*Math.asin(1/r);return a=>a<=0?0:a>=1?1:r*Math.pow(2,-10*a)*Math.sin((a-u)*(2*Math.PI)/n)+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:it(),elastic:at()};function be(e="top bottom"){let t=e.trim();if(/^\d+(\.\d+)?%$/.test(t))return {element:"top",viewport:t};let[r="top",n="bottom"]=t.split(/\s+/).filter(Boolean);return {element:r,viewport:n}}function nt(e,t,r,n){switch(n){case "top":return e+r;case "center":return e+r+t/2;case "bottom":return e+r+t;default:return e+r}}function ot(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 Ve(e){let t=e.tagName.toLowerCase();if(t==="rect"){let r=parseFloat(e.getAttribute("width")??"0"),n=parseFloat(e.getAttribute("height")??"0");return 2*(r+n)}if(t==="circle"){let r=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*r}return e.getTotalLength()}function St(e,t,r){return Math.min(r,Math.max(t,e))}function re(e,t,r,n){return r===t?0:St((e-t)/(r-t)*n,0,1)}function xe(e,t,r,n,u){let a=nt(e.top,e.height,t,n.element)-ot(n.viewport,r),h=nt(e.top,e.height,t,u.element)-ot(u.viewport,r);return {tStart:a,tEnd:h}}function st(e){let t=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(t)return [parseInt(t[1]+t[1],16),parseInt(t[2]+t[2],16),parseInt(t[3]+t[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 n=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return n?[parseInt(n[1]),parseInt(n[2]),parseInt(n[3])]:null}function Le(e,t,r){let n=st(e),u=st(t);return !n||!u?e:`rgb(${Math.round(n[0]+(u[0]-n[0])*r)},${Math.round(n[1]+(u[1]-n[1])*r)},${Math.round(n[2]+(u[2]-n[2])*r)})`}var Ue={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 lt(e,t){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,t);}var ct={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},xt=0;function At(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Tt(e){let t=e.getAttribute("stroke"),r=e.getAttribute("fill");!t||t==="none"?lt("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&<("Element has a fill \u2014 it may obscure the stroke animation.",e);}function $t(e,t,r){let n=document.createElement("div");n.setAttribute("data-svg-scroll-draw-debug",""),n.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function u(){let a=r==="x"?window.scrollX:window.scrollY,h=e-a,f=t-a,l=r==="x";n.innerHTML=`
|
|
2
2
|
<div style="position:absolute;${l?`left:${h}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${h}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
|
|
3
|
-
<div style="position:absolute;${l?`left:${f}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${f}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(n),window.addEventListener("scroll",m,{passive:true}),m(),n}function Ze(e,t,r){let n=(t.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),m=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,a=>{let h=parseFloat(a),f=n[m++]??h;return String(+(h+(f-h)*r).toFixed(4))})}function ut(e,t={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...n}=t,m=r?{...Ue[r],...n}:n,a=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:h="path, polyline, line, polygon, rect, circle",speed:f=1,fade:l=false,easing:p="linear",trigger:T={},stagger:H=0,direction:v="forward",once:_=false,debug:pe=false,axis:x="y",scrollContainer:$,autoReverse:g=false,delay:E=0,strokeColor:b,strokeWidth:F,fillOpacity:A,waypoints:C,velocityScale:te=false,threshold:de=0,rootMargin:be="0px",repeat:ie=0,repeatDelay:Y=0,morphTo:L,clip:j,autoplay:ge=false,duration:re=1e3,native:ne=true,onProgress:d,onStart:q,onComplete:U,onEnter:xe,onLeave:Oe,onEnterBack:Le,onLeaveBack:Ae}=m,ue=j===true?"left":typeof j=="string"?j:false,ae=typeof p=="function"?p:Q[p]??Q.linear,Ie=he(T.start??"top bottom"),Me=he(T.end??"bottom top"),z=typeof $=="string"?document.querySelector($):$??null,s=Array.isArray(b)?b[0]:null,u=Array.isArray(b)?b[1]:typeof b=="string"?b:null,N=Array.isArray(F)?F[0]:null,I=Array.isArray(F)?F[1]:typeof F=="number"?F:null,V=Array.isArray(A)?A[0]:null,G=Array.isArray(A)?A[1]:typeof A=="number"?A:null;function B(o){let i=o*100;switch(ue){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 O=ue?[]:Array.from(e.querySelectorAll(h)),M=[],oe=[],le=0,we=0,X=false,ce=false,W=0,Fe=false,me=-1,Ne=-1,Z=false,Te=0,ye=0,ve,je=null,Ee=new Set,Re=-1,et=performance.now(),Pe=NaN;function De(){return z?x==="x"?z.scrollLeft:z.scrollTop:x==="x"?window.scrollX:window.scrollY}function tt(){return z?x==="x"?z.clientWidth:z.clientHeight:x==="x"?window.innerWidth:window.innerHeight}function rt(){let o=e.getBoundingClientRect(),i,w,R;if(z){let K=z.getBoundingClientRect();i=x==="x"?o.left-K.left+z.scrollLeft:o.top-K.top+z.scrollTop,w=x==="x"?o.width:o.height,R=De();}else i=x==="x"?o.left:o.top,w=x==="x"?o.width:o.height,R=De();let J=Se({top:i,height:w},R,tt(),Ie,Me);le=J.tStart,we=J.tEnd,pe&&process.env.NODE_ENV!=="production"&&(je?.remove(),je=$t(le,we,x));}function ht(o,i){if(e.style.setProperty("--scroll-draw-progress",String(o)),ue){let w=i==="reverse"?1-o:o;e.style.clipPath=B(w);return}O.forEach((w,R)=>{w.style.strokeDashoffset=i==="reverse"?`${M[R]*o}`:`${M[R]*(1-o)}`,l&&(w.style.opacity=i==="reverse"?`${1-o}`:`${o}`),s&&u?w.style.stroke=Ce(s,u,o):u&&(w.style.stroke=u),N!==null&&I!==null?w.style.strokeWidth=`${N+(I-N)*o}`:I!==null&&(w.style.strokeWidth=`${I}`),V!==null&&G!==null?w.style.fillOpacity=`${V+(G-V)*o}`:G!==null&&(w.style.fillOpacity=`${G}`),L&&w.tagName.toLowerCase()==="path"&&oe[R]&&w.setAttribute("d",Ze(oe[R],L,o));});}function He(){if(e.style.setProperty("--scroll-draw-progress","0"),ue){e.style.clipPath=B(0);return}O.forEach((o,i)=>{o.style.strokeDasharray=`${M[i]}`,o.style.strokeDashoffset=v==="reverse"?"0":`${M[i]}`,l?o.style.opacity=v==="reverse"?"1":"0":o.style.opacity="",s&&(o.style.stroke=s),N!==null&&(o.style.strokeWidth=`${N}`),V!==null&&(o.style.fillOpacity=`${V}`),L&&o.tagName.toLowerCase()==="path"&&oe[i]&&o.setAttribute("d",oe[i]);});}if(O.forEach(o=>{Tt(o);let i=Ve(o);M.push(i),o.tagName.toLowerCase()==="path"?oe.push(o.getAttribute("d")??""):oe.push(""),a?(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=v==="reverse"?`${i}`:"0",l&&(o.style.opacity="1"),u&&(o.style.stroke=u),I!==null&&(o.style.strokeWidth=`${I}`),G!==null&&(o.style.fillOpacity=`${G}`),L&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",L)):(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=v==="reverse"?"0":`${i}`,l?o.style.opacity=v==="reverse"?"1":"0":o.style.opacity="",s&&(o.style.stroke=s),N!==null&&(o.style.strokeWidth=`${N}`),V!==null&&(o.style.fillOpacity=`${V}`));}),ue){if(a)return e.style.clipPath=B(1),U?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=B(0);}else if(a)return U?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function bt(){return !(ne===false||!At()||!O.length||typeof p!="string"||!(p in ct)||ue||x!=="y"||z||f!==1||H!==0||_||g||te!==false||L||C||ie||E>0||d||q||U||xe||Oe||Le||Ae||b!=null||F!=null||A!=null||(T.start??"top bottom").trim()!=="top bottom"||(T.end??"bottom top").trim()!=="bottom top")}function wt(){let o=`svg-scroll-draw-${++xt}`,i=v==="reverse"?"0":"var(--ssd-len)",w=v==="reverse"?"var(--ssd-len)":"0",R=`stroke-dashoffset:${i};`,J=`stroke-dashoffset:${w};`;l&&(R+=`opacity:${v==="reverse"?1:0};`,J+=`opacity:${v==="reverse"?0:1};`);let K=document.createElement("style");K.setAttribute("data-svg-scroll-draw",""),K.textContent=`@keyframes ${o}{from{${R}}to{${J}}}.${o}{animation-name:${o};animation-duration:auto;animation-timing-function:${ct[p]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(K);function se(c,S){c.style.setProperty("--ssd-len",String(M[S])),c.style.strokeDasharray=`${M[S]}`,c.style.strokeDashoffset="",c.style.opacity="",c.style.animationPlayState="",c.classList.add(o);}O.forEach(se);let y=false,P=-1;function k(){if(P>=0)return P;let c=e.getBoundingClientRect(),{tStart:S,tEnd:D}=Se({top:c.top,height:c.height},De(),tt(),Ie,Me);return ae(ee(De(),S,D,f))}return {destroy(){O.forEach(c=>{c.classList.remove(o),c.style.removeProperty("--ssd-len"),c.style.animationPlayState="";}),K.remove();},replay(){y=false,P=-1,O.forEach(se);},pause(){y=true,O.forEach(c=>{c.style.animationPlayState="paused";});},resume(){y&&(y=false,O.forEach(c=>{c.style.animationPlayState="running";}));},seek(c){let S=Math.min(1,Math.max(0,c));P=S,y=true,O.forEach((D,$e)=>{D.classList.remove(o),D.style.strokeDashoffset=v==="reverse"?`${M[$e]*S}`:`${M[$e]*(1-S)}`,l&&(D.style.opacity=v==="reverse"?`${1-S}`:`${S}`);});},getProgress(){return k()}}}if(bt())return wt();function vt(){let o=Math.max(1,re),i=0,w=0;function R(k){let c=true;if(ue){let S=Math.min(1,Math.max(0,k/o)),D=ae(S);Te=D,e.style.setProperty("--scroll-draw-progress",String(D)),e.style.clipPath=B(v==="reverse"?1-D:D),d?.(D),S<1&&(c=false);}else O.forEach((S,D)=>{let $e=D*H*o,ke=Math.min(1,Math.max(0,(k-$e)/o)),fe=ae(ke);S.style.strokeDashoffset=v==="reverse"?`${M[D]*fe}`:`${M[D]*(1-fe)}`,l&&(S.style.opacity=v==="reverse"?`${1-fe}`:`${fe}`),s&&u?S.style.stroke=Ce(s,u,fe):u&&(S.style.stroke=u),N!==null&&I!==null?S.style.strokeWidth=`${N+(I-N)*fe}`:I!==null&&(S.style.strokeWidth=`${I}`),V!==null&&G!==null?S.style.fillOpacity=`${V+(G-V)*fe}`:G!==null&&(S.style.fillOpacity=`${G}`),L&&S.tagName.toLowerCase()==="path"&&oe[D]&&S.setAttribute("d",Ze(oe[D],L,fe)),D===0&&(d?.(fe),e.style.setProperty("--scroll-draw-progress",String(fe))),ke<1&&(c=false);});if(C){let S=Math.min(1,Math.max(0,k/o)),D=ae(S);for(let $e in C){let ke=parseFloat($e);D>=ke&&!Ee.has(ke)&&(Ee.add(ke),C[$e]?.());}}return c}function J(k){if(Z)return;let c=k-i;ce||(ce=true,q?.());let S=R(c);if(S&&!X){X=true,R(o*(1+Math.max(0,O.length-1)*H)),U?.(),ye<(ie==="infinite"?1/0:ie??0)&&(ye++,ve=setTimeout(()=>{i=performance.now(),ce=false,X=false,Ee.clear(),He(),W=requestAnimationFrame(J);},Y));return}S||(W=requestAnimationFrame(J));}function K(){cancelAnimationFrame(W),clearTimeout(ve),i=performance.now(),w=0,Z=false,ce=false,X=false,ye=0,Ee.clear(),He(),W=requestAnimationFrame(J);}let se=new IntersectionObserver(k=>{k.forEach(c=>{c.isIntersecting&&!(_&&X)?K():!c.isIntersecting&&!_&&!X&&(cancelAnimationFrame(W),clearTimeout(ve),i=null);});},{root:z??null,threshold:de,rootMargin:be}),y;function P(){clearTimeout(y),y=setTimeout(()=>{O.forEach((k,c)=>{M[c]=Ve(k),k.style.strokeDasharray=`${M[c]}`;});},150);}return window.addEventListener("resize",P),window.addEventListener("orientationchange",P),E>0?setTimeout(()=>se.observe(e),E):se.observe(e),{destroy(){cancelAnimationFrame(W),clearTimeout(ve),se.disconnect(),window.removeEventListener("resize",P),window.removeEventListener("orientationchange",P),clearTimeout(y);},replay(){ye=0,K();},pause(){Z||(Z=true,w=performance.now()-i,cancelAnimationFrame(W));},resume(){Z&&(Z=false,i=performance.now()-w,W=requestAnimationFrame(J));},seek(k){let c=Math.min(1,Math.max(0,k));Te=c,Z=true,w=c*o,i=performance.now()-w,cancelAnimationFrame(W),R(w);},getProgress(){return Te}}}if(ge)return vt();rt();function qe(){if(!Fe||Z)return;let o=performance.now(),i=De(),w=f;if(te!==false){let y=o-et,P=y>0?Math.abs(i-(Re<0?i:Re))/y:0;w=f*Math.max(.2,1+P*(typeof te=="number"?te:1)*.04);}Re=i,et=o;let R=g?Ne===-1||i>=Ne?"forward":"reverse":v;Ne=i;let J=we-le,K=true,se=J===0?0:(i-le)/J;if(isNaN(Pe)||(Pe<=0&&se>0?xe?.():Pe>0&&se<=0&&Ae?.(),Pe<1&&se>=1?Oe?.():Pe>=1&&se<1&&Le?.()),Pe=se,ue){let y=ae(ee(i,le,we,w));_&&!g&&(me=Math.max(me,y),y=me),Te=y,e.style.setProperty("--scroll-draw-progress",String(y));let P=R==="reverse"?1-y:y;e.style.clipPath=B(P),d?.(y),!ce&&ee(i,le,we,w)>0&&(ce=true,q?.()),y>=1&&!X?(X=true,U?.(),ye<(ie==="infinite"?1/0:ie??0)&&(ye++,ve=setTimeout(()=>{me=-1,ce=false,X=false,e.style.clipPath=B(0);},Y))):y<1&&!_&&(X=false),W=requestAnimationFrame(qe);return}if(O.forEach((y,P)=>{let k=P*H*J,c=ae(ee(i,le+k,we+k,w));_&&!g&&(me=Math.max(me,c),c=me),Te=c,y.style.strokeDashoffset=R==="reverse"?`${M[P]*c}`:`${M[P]*(1-c)}`,l&&(y.style.opacity=R==="reverse"?`${1-c}`:`${c}`),s&&u?y.style.stroke=Ce(s,u,c):u&&(y.style.stroke=u),N!==null&&I!==null?y.style.strokeWidth=`${N+(I-N)*c}`:I!==null&&(y.style.strokeWidth=`${I}`),V!==null&&G!==null?y.style.fillOpacity=`${V+(G-V)*c}`:G!==null&&(y.style.fillOpacity=`${G}`),L&&y.tagName.toLowerCase()==="path"&&oe[P]&&y.setAttribute("d",Ze(oe[P],L,c)),P===0&&(d?.(c),e.style.setProperty("--scroll-draw-progress",String(c))),c<1&&(K=false);}),C){let y=ae(ee(i,le,we,w));for(let P in C){let k=parseFloat(P);y>=k&&!Ee.has(k)&&(Ee.add(k),C[P]?.());}}!ce&&ee(i,le,we,w)>0&&(ce=true,q?.()),K&&!X?(X=true,U?.(),ye<(ie==="infinite"?1/0:ie??0)&&(ye++,ve=setTimeout(()=>{me=-1,ce=false,X=false,Ee.clear(),He();},Y))):!K&&!_&&(X=false),W=requestAnimationFrame(qe);}let Xe=new IntersectionObserver(o=>{o.forEach(i=>{Fe=i.isIntersecting,Fe&&!Z?W=requestAnimationFrame(qe):cancelAnimationFrame(W);});},{root:z??null,threshold:de,rootMargin:be}),Ye;function ze(){clearTimeout(Ye),Ye=setTimeout(()=>{O.forEach((o,i)=>{M[i]=Ve(o),o.style.strokeDasharray=`${M[i]}`;}),rt();},150);}return window.addEventListener("resize",ze),window.addEventListener("orientationchange",ze),E>0?setTimeout(()=>Xe.observe(e),E):Xe.observe(e),{destroy(){cancelAnimationFrame(W),clearTimeout(ve),Xe.disconnect(),window.removeEventListener("resize",ze),window.removeEventListener("orientationchange",ze),clearTimeout(Ye),je?.remove();},replay(){me=-1,Ne=-1,Re=-1,ce=false,X=false,ye=0,Z=false,Ee.clear(),clearTimeout(ve),He();},pause(){Z=true,cancelAnimationFrame(W);},resume(){Z&&(Z=false,Fe&&(W=requestAnimationFrame(qe)));},seek(o){let i=Math.min(1,Math.max(0,o));Te=i,me=i,Z=true,cancelAnimationFrame(W),ht(i,v);},getProgress(){return Te}}}var mt=new Map;function Be(e,t){mt.set(e,t);}function We(e){mt.delete(e);}function Mt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function ft(e){let t=[],r=/([\w]+)\(([^)]*)\)/g,n;for(;(n=r.exec(e))!==null;){let m=[],a=[],h=n[2].trim();if(h)for(let f of h.split(/[\s,]+/)){let l=f.match(/^([-+]?[\d.eE]+)(.*)$/);m.push(l?parseFloat(l[1]):0),a.push(l?l[2]:"");}t.push({fn:n[1],nums:m,units:a});}return t}function Pt(e,t,r){let n=ft(e),m=ft(t);return n.length===0||n.length!==m.length?r<1?e:t:n.map((a,h)=>{let f=m[h];return a.fn!==f.fn||a.nums.length!==f.nums.length?r<1?`${a.fn}(${a.nums.map((l,p)=>`${l}${a.units[p]}`).join(", ")})`:`${f.fn}(${f.nums.map((l,p)=>`${l}${f.units[p]}`).join(", ")})`:`${a.fn}(${a.nums.map((l,p)=>`${l+(f.nums[p]-l)*r}${a.units[p]}`).join(", ")})`}).join(" ")}function pt(e,t,r){if(typeof e=="number"&&typeof t=="number")return String(e+(t-e)*r);let n=String(e),m=String(t);if(Mt(n))return Ce(n,m,r);if(n.includes("("))return Pt(n,m,r);let a=n.match(/^([-+]?[\d.]+)(.*)$/),h=m.match(/^([-+]?[\d.]+)(.*)$/);if(a&&h){let f=parseFloat(a[1]),l=parseFloat(h[1]);return `${f+(l-f)*r}${a[2]||h[2]}`}return r<1?n:m}function kt(e){return e.replace(/([A-Z])/g,t=>`-${t.toLowerCase()}`)}var dt={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Ct=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),Lt=0;function It(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function gt(e,t){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let{props:n,trigger:m={},easing:a="ease-out",speed:h=1,once:f=false,axis:l="y",scrollContainer:p,native:T=true,onProgress:H,onComplete:v,onEnter:_,onLeave:pe,onEnterBack:x,onLeaveBack:$}=t,g=window.matchMedia("(prefers-reduced-motion: reduce)").matches,E=typeof a=="function"?a:Q[a]??Q["ease-out"],b=he(m.start??"top bottom"),F=he(m.end??"bottom top"),A=typeof p=="string"?document.querySelector(p):p??null,C=Object.entries(n).map(([s,u])=>({prop:kt(s),from:Array.isArray(u)?u[0]:"",to:Array.isArray(u)?u[1]:u}));function te(){let s=window.getComputedStyle(e);for(let u of C)u.from===""&&(u.from=s.getPropertyValue(u.prop).trim()||"0");}function de(){for(let s of C)e.style.setProperty(s.prop,String(s.to));}if(g)return de(),v?.(),r;te();function be(){if(!T||!It()||typeof a!="string"||!(a in dt)||l!=="y"||A||f||h!==1||H||v||_||pe||x||$||(m.start??"top bottom").trim()!=="top bottom"||(m.end??"bottom top").trim()!=="bottom top")return false;for(let s of C)if(!Ct.has(s.prop))return false;return true}function ie(){let s=`ssd-a-${++Lt}`,u=C.map(B=>`${B.prop}:${B.from}`).join(";"),N=C.map(B=>`${B.prop}:${B.to}`).join(";"),I=document.createElement("style");I.setAttribute("data-ssd-animate",""),I.textContent=`@keyframes ${s}{from{${u}}to{${N}}}.${s}{animation-name:${s};animation-duration:auto;animation-timing-function:${dt[a]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(I),e.classList.add(s);let V=()=>l==="x"?window.scrollX:window.scrollY,G=()=>l==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(s),I.remove();},replay(){e.classList.remove(s),e.offsetWidth,e.classList.add(s);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(B){let O=Math.min(1,Math.max(0,B));e.classList.remove(s);for(let M of C)e.style.setProperty(M.prop,pt(M.from,M.to,O));},getProgress(){let B=e.getBoundingClientRect(),O=V(),M=G(),{tStart:oe,tEnd:le}=Se({top:B.top,height:B.height},O,M,b,F);return E(ee(O,oe,le,h))}}}if(be())return ie();let Y=0,L=0,j=0,ge=false,re=false,ne=-1,d=0,q=false,U=NaN,xe=()=>A?l==="x"?A.scrollLeft:A.scrollTop:l==="x"?window.scrollX:window.scrollY,Oe=()=>A?l==="x"?A.clientWidth:A.clientHeight:l==="x"?window.innerWidth:window.innerHeight;function Le(){let s=e.getBoundingClientRect(),u,N;if(A){let V=A.getBoundingClientRect();u=l==="x"?s.left-V.left+A.scrollLeft:s.top-V.top+A.scrollTop,N=l==="x"?s.width:s.height;}else u=l==="x"?s.left:s.top,N=l==="x"?s.width:s.height;let I=Se({top:u,height:N},xe(),Oe(),b,F);Y=I.tStart,L=I.tEnd;}function Ae(s){e.style.setProperty("--scroll-draw-progress",String(s));for(let u of C)e.style.setProperty(u.prop,pt(u.from,u.to,s));H?.(s);}function ue(s){if(isNaN(U)){U=s;return}U<=0&&s>0?_?.():U>0&&s<=0&&$?.(),U<1&&s>=1?pe?.():U>=1&&s<1&&x?.(),U=s;}function ae(){if(!ge||re)return;let s=L===Y?0:(xe()-Y)/(L-Y);ue(s);let u=E(ee(xe(),Y,L,h));f&&(ne=Math.max(ne,u),u=ne),d=u,Ae(u),u>=1&&!q?(q=true,v?.()):u<1&&!f&&(q=false),j=requestAnimationFrame(ae);}Le();{let s=E(ee(xe(),Y,L,h));f&&s>0&&(ne=s),d=s,Ae(s);}let Ie=new IntersectionObserver(s=>{s.forEach(u=>{ge=u.isIntersecting,ge&&!re?j=requestAnimationFrame(ae):cancelAnimationFrame(j);});},{root:A??null}),Me;function z(){clearTimeout(Me),Me=setTimeout(Le,150);}return window.addEventListener("resize",z),window.addEventListener("orientationchange",z),Ie.observe(e),Be(e,{type:"animate",getProgress:()=>d,getTrigger:()=>({tStart:Y,tEnd:L})}),{destroy(){cancelAnimationFrame(j),Ie.disconnect(),window.removeEventListener("resize",z),window.removeEventListener("orientationchange",z),clearTimeout(Me),We(e);},replay(){ne=-1,q=false,d=0,re=false,Ae(0);},pause(){re=true,cancelAnimationFrame(j);},resume(){re&&(re=false,ge&&(j=requestAnimationFrame(ae)));},seek(s){let u=Math.min(1,Math.max(0,s));d=u,ne=u,re=true,cancelAnimationFrame(j),Ae(u);},getProgress(){return d}}}var _e={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Dt(e,t){if(typeof window>"u")return _e;let r=typeof e=="string"?document.querySelector(e):e;return r?gt(r,t):(process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollAnimate: element not found:",e),_e)}function Ot(e,t={}){if(typeof window>"u")return _e;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollParallax: element not found:",e),_e;let{speed:n=.3,axis:m="y",easing:a="linear",trigger:h,onProgress:f}=t,l=r.getBoundingClientRect(),p=m==="x"?l.width:l.height,T=n*p;return gt(r,{props:m==="x"?{transform:["translateX(0px)",`translateX(${-T}px)`]}:{transform:["translateY(0px)",`translateY(${-T}px)`]},trigger:h??{start:"top bottom",end:"bottom top"},easing:a,native:false,onProgress:f})}var Je={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Ft(e,t){if(typeof window>"u")return Je;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),Je;let n=r,{from:m=0,to:a,format:h,easing:f="ease-out",trigger:l={},once:p=true,decimals:T,onComplete:H}=t,v=T!==void 0?d=>d.toFixed(T):h??(d=>String(Math.round(d))),_=typeof f=="function"?f:Q[f]??Q["ease-out"],pe=he(l.start??"top 80%"),x=he(l.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return n.textContent=v(a),H?.(),Je;n.textContent=v(m);let g=0,E=0,b=0,F=false,A=false,C=-1,te=0,de=false,be=()=>window.scrollY,ie=()=>window.innerHeight;function Y(){let d=n.getBoundingClientRect(),q=Se({top:d.top,height:d.height},be(),ie(),pe,x);g=q.tStart,E=q.tEnd;}function L(d){n.textContent=v(m+(a-m)*d),n.style.setProperty("--scroll-draw-progress",String(d));}function j(){if(!F||A)return;let d=_(ee(be(),g,E,1));p&&(C=Math.max(C,d),d=C),te=d,L(d),d>=1&&!de?(de=true,H?.()):d<1&&!p&&(de=false),b=requestAnimationFrame(j);}Y();{let d=_(ee(be(),g,E,1));p&&d>0&&(C=d),te=d,L(d);}let ge=new IntersectionObserver(d=>{d.forEach(q=>{F=q.isIntersecting,F&&!A?b=requestAnimationFrame(j):cancelAnimationFrame(b);});}),re;function ne(){clearTimeout(re),re=setTimeout(Y,150);}return window.addEventListener("resize",ne),window.addEventListener("orientationchange",ne),ge.observe(n),Be(n,{type:"counter",getProgress:()=>te,getTrigger:()=>({tStart:g,tEnd:E})}),{destroy(){cancelAnimationFrame(b),ge.disconnect(),window.removeEventListener("resize",ne),window.removeEventListener("orientationchange",ne),clearTimeout(re),We(n);},replay(){C=-1,de=false,te=0,A=false,L(0);},pause(){A=true,cancelAnimationFrame(b);},resume(){A&&(A=false,F&&(b=requestAnimationFrame(j)));},seek(d){let q=Math.min(1,Math.max(0,d));te=q,C=q,A=true,cancelAnimationFrame(b),L(q);},getProgress(){return te}}}var yt="http://www.w3.org/2000/svg",Nt="cinematic-photo",Ke=e=>e<0?0:e>1?1:e;function Ge(e){let t=parseFloat(e);return Number.isFinite(t)?Ke(t/100):0}function Rt(e){return Q[e]??Q.linear}var Ht={destroy:()=>{},getProgress:()=>0},Qe=class{constructor(t){if(typeof document>"u"){this.mount=null;return}this.mount=typeof t.wrapper=="string"?document.querySelector(t.wrapper):t.wrapper,!this.mount&&process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] Cinematic: wrapper not found:",t.wrapper);}loadStory(t){let r=this.mount;if(typeof window>"u"||!r)return Ht;r.style.position="relative",r.style.height=t.totalHeight,r.style.display="block";let n=document.createElement("div");n.setAttribute("data-cinematic-stage",""),n.style.cssText="position:sticky;top:0;height:100vh;width:100%;overflow:hidden;display:block;",r.appendChild(n);let m=[];for(let x of t.scenes){if(x.background){let g=document.createElement("img");g.id=Nt,g.src=x.background,g.alt="",g.style.cssText="position:absolute;inset:0;width:100%;height:100%;object-fit:contain;opacity:0;pointer-events:none;",n.appendChild(g);}let $=x.animations.filter(g=>g.type==="draw");if($.length){let g=document.createElementNS(yt,"svg");g.setAttribute("viewBox",`0 0 ${t.canvas.width} ${t.canvas.height}`),g.setAttribute("preserveAspectRatio","xMidYMid meet"),g.style.cssText="position:absolute;inset:0;width:100%;height:100%;overflow:visible;",n.appendChild(g);for(let E of $){let b=document.createElementNS(yt,"path");b.id=E.target.replace(/^#/,""),b.setAttribute("d",E.d),b.setAttribute("fill","none"),b.setAttribute("stroke",E.stroke),b.setAttribute("stroke-width",String(E.strokeWidth)),b.setAttribute("stroke-linecap","round"),b.setAttribute("stroke-linejoin","round");let F=E.length||b.getTotalLength?.()||0;b.style.strokeDasharray=String(F),b.style.strokeDashoffset=String(F),g.appendChild(b),m.push({kind:"draw",el:b,start:Ge(E.start),end:Ge(E.end),ease:Rt(E.easing),length:F});}}for(let g of x.animations){if(g.type!=="fade")continue;let E=n.querySelector(g.target)??document.querySelector(g.target);E&&(E.style.opacity=String(g.from),m.push({kind:"fade",el:E,start:Ge(g.start),end:Ge(g.end),ease:Q["ease-in-out"]??Q.linear,from:g.from,to:g.to}));}}let a=0,h=()=>{let x=r.offsetHeight-window.innerHeight;return x<=0?r.getBoundingClientRect().top<=0?1:0:Ke(-r.getBoundingClientRect().top/x)},f=x=>{for(let $ of m){let g=$.end-$.start,E=g<=0?x>=$.end?1:0:Ke((x-$.start)/g),b=$.ease(E);$.kind==="draw"?$.el.style.strokeDashoffset=String($.length*(1-b)):$.el.style.opacity=String($.from+($.to-$.from)*b);}};if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return f(1),{destroy:()=>{},getProgress:()=>1};let l=0,p=false,T=false,H=()=>{a=h(),f(a),p&&(l=requestAnimationFrame(H));},v=()=>{p||(p=true,l=requestAnimationFrame(H));},_=()=>{p=false,cancelAnimationFrame(l);},pe=new IntersectionObserver(x=>{for(let $ of x)T=$.isIntersecting,T?v():_();},{threshold:0});return pe.observe(n),a=h(),f(a),{destroy(){_(),pe.disconnect();},getProgress:()=>a}}};function er(e,t){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let n=typeof e=="string"?document.querySelector(e):e;return n?ut(n,t):(console.warn("[svg-scroll-draw] Container not found:",e),r)}
|
|
3
|
+
<div style="position:absolute;${l?`left:${f}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${f}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(n),window.addEventListener("scroll",u,{passive:true}),u(),n}function Ze(e,t,r){let n=(t.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),u=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,a=>{let h=parseFloat(a),f=n[u++]??h;return String(+(h+(f-h)*r).toFixed(4))})}function ut(e,t={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...n}=t,u=r?{...Ue[r],...n}:n,a=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:h="path, polyline, line, polygon, rect, circle",speed:f=1,fade:l=false,easing:p="linear",trigger:x={},stagger:F=0,direction:E="forward",once:W=false,debug:ge=false,axis:S="y",scrollContainer:M,autoReverse:d=false,delay:A=0,strokeColor:b,strokeWidth:R,fillOpacity:z,waypoints:T,velocityScale:H=false,threshold:ye=0,rootMargin:we="0px",repeat:ae=0,repeatDelay:ve=0,morphTo:P,clip:U,autoplay:se=false,duration:ce=1e3,native:Z=true,onProgress:g,onStart:N,onComplete:le,onEnter:ue,onLeave:Me,onEnterBack:Ie,onLeaveBack:Pe}=u,me=U===true?"left":typeof U=="string"?U:false,fe=typeof p=="function"?p:te[p]??te.linear,Ae=be(x.start??"top bottom"),Oe=be(x.end??"bottom top"),_=typeof M=="string"?document.querySelector(M):M??null,ne=Array.isArray(b)?b[0]:null,V=Array.isArray(b)?b[1]:typeof b=="string"?b:null,B=Array.isArray(R)?R[0]:null,s=Array.isArray(R)?R[1]:typeof R=="number"?R:null,m=Array.isArray(z)?z[0]:null,k=Array.isArray(z)?z[1]:typeof z=="number"?z:null;function G(o){let i=o*100;switch(me){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 $=me?[]:Array.from(e.querySelectorAll(h)),D=[],C=[],Y=0,J=0,j=false,oe=false,X=0,Fe=false,pe=-1,Ne=-1,K=false,Te=0,he=0,Ee,je=null,Se=new Set,Re=-1,et=performance.now(),ke=NaN;function De(){return _?S==="x"?_.scrollLeft:_.scrollTop:S==="x"?window.scrollX:window.scrollY}function tt(){return _?S==="x"?_.clientWidth:_.clientHeight:S==="x"?window.innerWidth:window.innerHeight}function rt(){let o=e.getBoundingClientRect(),i,w,q;if(_){let ee=_.getBoundingClientRect();i=S==="x"?o.left-ee.left+_.scrollLeft:o.top-ee.top+_.scrollTop,w=S==="x"?o.width:o.height,q=De();}else i=S==="x"?o.left:o.top,w=S==="x"?o.width:o.height,q=De();let Q=xe({top:i,height:w},q,tt(),Ae,Oe);Y=Q.tStart,J=Q.tEnd,ge&&process.env.NODE_ENV!=="production"&&(je?.remove(),je=$t(Y,J,S));}function ht(o,i){if(e.style.setProperty("--scroll-draw-progress",String(o)),me){let w=i==="reverse"?1-o:o;e.style.clipPath=G(w);return}$.forEach((w,q)=>{w.style.strokeDashoffset=i==="reverse"?`${D[q]*o}`:`${D[q]*(1-o)}`,l&&(w.style.opacity=i==="reverse"?`${1-o}`:`${o}`),ne&&V?w.style.stroke=Le(ne,V,o):V&&(w.style.stroke=V),B!==null&&s!==null?w.style.strokeWidth=`${B+(s-B)*o}`:s!==null&&(w.style.strokeWidth=`${s}`),m!==null&&k!==null?w.style.fillOpacity=`${m+(k-m)*o}`:k!==null&&(w.style.fillOpacity=`${k}`),P&&w.tagName.toLowerCase()==="path"&&C[q]&&w.setAttribute("d",Ze(C[q],P,o));});}function He(){if(e.style.setProperty("--scroll-draw-progress","0"),me){e.style.clipPath=G(0);return}$.forEach((o,i)=>{o.style.strokeDasharray=`${D[i]}`,o.style.strokeDashoffset=E==="reverse"?"0":`${D[i]}`,l?o.style.opacity=E==="reverse"?"1":"0":o.style.opacity="",ne&&(o.style.stroke=ne),B!==null&&(o.style.strokeWidth=`${B}`),m!==null&&(o.style.fillOpacity=`${m}`),P&&o.tagName.toLowerCase()==="path"&&C[i]&&o.setAttribute("d",C[i]);});}if($.forEach(o=>{Tt(o);let i=Ve(o);D.push(i),o.tagName.toLowerCase()==="path"?C.push(o.getAttribute("d")??""):C.push(""),a?(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=E==="reverse"?`${i}`:"0",l&&(o.style.opacity="1"),V&&(o.style.stroke=V),s!==null&&(o.style.strokeWidth=`${s}`),k!==null&&(o.style.fillOpacity=`${k}`),P&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",P)):(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=E==="reverse"?"0":`${i}`,l?o.style.opacity=E==="reverse"?"1":"0":o.style.opacity="",ne&&(o.style.stroke=ne),B!==null&&(o.style.strokeWidth=`${B}`),m!==null&&(o.style.fillOpacity=`${m}`));}),me){if(a)return e.style.clipPath=G(1),le?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=G(0);}else if(a)return le?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function bt(){return !(Z===false||!At()||!$.length||typeof p!="string"||!(p in ct)||me||S!=="y"||_||f!==1||F!==0||W||d||H!==false||P||T||ae||A>0||g||N||le||ue||Me||Ie||Pe||b!=null||R!=null||z!=null||(x.start??"top bottom").trim()!=="top bottom"||(x.end??"bottom top").trim()!=="bottom top")}function wt(){let o=`svg-scroll-draw-${++xt}`,i=E==="reverse"?"0":"var(--ssd-len)",w=E==="reverse"?"var(--ssd-len)":"0",q=`stroke-dashoffset:${i};`,Q=`stroke-dashoffset:${w};`;l&&(q+=`opacity:${E==="reverse"?1:0};`,Q+=`opacity:${E==="reverse"?0:1};`);let ee=document.createElement("style");ee.setAttribute("data-svg-scroll-draw",""),ee.textContent=`@keyframes ${o}{from{${q}}to{${Q}}}.${o}{animation-name:${o};animation-duration:auto;animation-timing-function:${ct[p]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(ee);function ie(c,v){c.style.setProperty("--ssd-len",String(D[v])),c.style.strokeDasharray=`${D[v]}`,c.style.strokeDashoffset="",c.style.opacity="",c.style.animationPlayState="",c.classList.add(o);}$.forEach(ie);let y=false,L=-1;function I(){if(L>=0)return L;let c=e.getBoundingClientRect(),{tStart:v,tEnd:O}=xe({top:c.top,height:c.height},De(),tt(),Ae,Oe);return fe(re(De(),v,O,f))}return {destroy(){$.forEach(c=>{c.classList.remove(o),c.style.removeProperty("--ssd-len"),c.style.animationPlayState="";}),ee.remove();},replay(){y=false,L=-1,$.forEach(ie);},pause(){y=true,$.forEach(c=>{c.style.animationPlayState="paused";});},resume(){y&&(y=false,$.forEach(c=>{c.style.animationPlayState="running";}));},seek(c){let v=Math.min(1,Math.max(0,c));L=v,y=true,$.forEach((O,$e)=>{O.classList.remove(o),O.style.strokeDashoffset=E==="reverse"?`${D[$e]*v}`:`${D[$e]*(1-v)}`,l&&(O.style.opacity=E==="reverse"?`${1-v}`:`${v}`);});},getProgress(){return I()}}}if(bt())return wt();function vt(){let o=Math.max(1,ce),i=0,w=0;function q(I){let c=true;if(me){let v=Math.min(1,Math.max(0,I/o)),O=fe(v);Te=O,e.style.setProperty("--scroll-draw-progress",String(O)),e.style.clipPath=G(E==="reverse"?1-O:O),g?.(O),v<1&&(c=false);}else $.forEach((v,O)=>{let $e=O*F*o,Ce=Math.min(1,Math.max(0,(I-$e)/o)),de=fe(Ce);v.style.strokeDashoffset=E==="reverse"?`${D[O]*de}`:`${D[O]*(1-de)}`,l&&(v.style.opacity=E==="reverse"?`${1-de}`:`${de}`),ne&&V?v.style.stroke=Le(ne,V,de):V&&(v.style.stroke=V),B!==null&&s!==null?v.style.strokeWidth=`${B+(s-B)*de}`:s!==null&&(v.style.strokeWidth=`${s}`),m!==null&&k!==null?v.style.fillOpacity=`${m+(k-m)*de}`:k!==null&&(v.style.fillOpacity=`${k}`),P&&v.tagName.toLowerCase()==="path"&&C[O]&&v.setAttribute("d",Ze(C[O],P,de)),O===0&&(g?.(de),e.style.setProperty("--scroll-draw-progress",String(de))),Ce<1&&(c=false);});if(T){let v=Math.min(1,Math.max(0,I/o)),O=fe(v);for(let $e in T){let Ce=parseFloat($e);O>=Ce&&!Se.has(Ce)&&(Se.add(Ce),T[$e]?.());}}return c}function Q(I){if(K)return;let c=I-i;oe||(oe=true,N?.());let v=q(c);if(v&&!j){j=true,q(o*(1+Math.max(0,$.length-1)*F)),le?.(),he<(ae==="infinite"?1/0:ae??0)&&(he++,Ee=setTimeout(()=>{i=performance.now(),oe=false,j=false,Se.clear(),He(),X=requestAnimationFrame(Q);},ve));return}v||(X=requestAnimationFrame(Q));}function ee(){cancelAnimationFrame(X),clearTimeout(Ee),i=performance.now(),w=0,K=false,oe=false,j=false,he=0,Se.clear(),He(),X=requestAnimationFrame(Q);}let ie=new IntersectionObserver(I=>{I.forEach(c=>{c.isIntersecting&&!(W&&j)?ee():!c.isIntersecting&&!W&&!j&&(cancelAnimationFrame(X),clearTimeout(Ee),i=null);});},{root:_??null,threshold:ye,rootMargin:we}),y;function L(){clearTimeout(y),y=setTimeout(()=>{$.forEach((I,c)=>{D[c]=Ve(I),I.style.strokeDasharray=`${D[c]}`;});},150);}return window.addEventListener("resize",L),window.addEventListener("orientationchange",L),A>0?setTimeout(()=>ie.observe(e),A):ie.observe(e),{destroy(){cancelAnimationFrame(X),clearTimeout(Ee),ie.disconnect(),window.removeEventListener("resize",L),window.removeEventListener("orientationchange",L),clearTimeout(y);},replay(){he=0,ee();},pause(){K||(K=true,w=performance.now()-i,cancelAnimationFrame(X));},resume(){K&&(K=false,i=performance.now()-w,X=requestAnimationFrame(Q));},seek(I){let c=Math.min(1,Math.max(0,I));Te=c,K=true,w=c*o,i=performance.now()-w,cancelAnimationFrame(X),q(w);},getProgress(){return Te}}}if(se)return vt();rt();function qe(){if(!Fe||K)return;let o=performance.now(),i=De(),w=f;if(H!==false){let y=o-et,L=y>0?Math.abs(i-(Re<0?i:Re))/y:0;w=f*Math.max(.2,1+L*(typeof H=="number"?H:1)*.04);}Re=i,et=o;let q=d?Ne===-1||i>=Ne?"forward":"reverse":E;Ne=i;let Q=J-Y,ee=true,ie=Q===0?0:(i-Y)/Q;if(isNaN(ke)||(ke<=0&&ie>0?ue?.():ke>0&&ie<=0&&Pe?.(),ke<1&&ie>=1?Me?.():ke>=1&&ie<1&&Ie?.()),ke=ie,me){let y=fe(re(i,Y,J,w));W&&!d&&(pe=Math.max(pe,y),y=pe),Te=y,e.style.setProperty("--scroll-draw-progress",String(y));let L=q==="reverse"?1-y:y;e.style.clipPath=G(L),g?.(y),!oe&&re(i,Y,J,w)>0&&(oe=true,N?.()),y>=1&&!j?(j=true,le?.(),he<(ae==="infinite"?1/0:ae??0)&&(he++,Ee=setTimeout(()=>{pe=-1,oe=false,j=false,e.style.clipPath=G(0);},ve))):y<1&&!W&&(j=false),X=requestAnimationFrame(qe);return}if($.forEach((y,L)=>{let I=L*F*Q,c=fe(re(i,Y+I,J+I,w));W&&!d&&(pe=Math.max(pe,c),c=pe),Te=c,y.style.strokeDashoffset=q==="reverse"?`${D[L]*c}`:`${D[L]*(1-c)}`,l&&(y.style.opacity=q==="reverse"?`${1-c}`:`${c}`),ne&&V?y.style.stroke=Le(ne,V,c):V&&(y.style.stroke=V),B!==null&&s!==null?y.style.strokeWidth=`${B+(s-B)*c}`:s!==null&&(y.style.strokeWidth=`${s}`),m!==null&&k!==null?y.style.fillOpacity=`${m+(k-m)*c}`:k!==null&&(y.style.fillOpacity=`${k}`),P&&y.tagName.toLowerCase()==="path"&&C[L]&&y.setAttribute("d",Ze(C[L],P,c)),L===0&&(g?.(c),e.style.setProperty("--scroll-draw-progress",String(c))),c<1&&(ee=false);}),T){let y=fe(re(i,Y,J,w));for(let L in T){let I=parseFloat(L);y>=I&&!Se.has(I)&&(Se.add(I),T[L]?.());}}!oe&&re(i,Y,J,w)>0&&(oe=true,N?.()),ee&&!j?(j=true,le?.(),he<(ae==="infinite"?1/0:ae??0)&&(he++,Ee=setTimeout(()=>{pe=-1,oe=false,j=false,Se.clear(),He();},ve))):!ee&&!W&&(j=false),X=requestAnimationFrame(qe);}let Xe=new IntersectionObserver(o=>{o.forEach(i=>{Fe=i.isIntersecting,Fe&&!K?X=requestAnimationFrame(qe):cancelAnimationFrame(X);});},{root:_??null,threshold:ye,rootMargin:we}),Ye;function ze(){clearTimeout(Ye),Ye=setTimeout(()=>{$.forEach((o,i)=>{D[i]=Ve(o),o.style.strokeDasharray=`${D[i]}`;}),rt();},150);}return window.addEventListener("resize",ze),window.addEventListener("orientationchange",ze),A>0?setTimeout(()=>Xe.observe(e),A):Xe.observe(e),{destroy(){cancelAnimationFrame(X),clearTimeout(Ee),Xe.disconnect(),window.removeEventListener("resize",ze),window.removeEventListener("orientationchange",ze),clearTimeout(Ye),je?.remove();},replay(){pe=-1,Ne=-1,Re=-1,oe=false,j=false,he=0,K=false,Se.clear(),clearTimeout(Ee),He();},pause(){K=true,cancelAnimationFrame(X);},resume(){K&&(K=false,Fe&&(X=requestAnimationFrame(qe)));},seek(o){let i=Math.min(1,Math.max(0,o));Te=i,pe=i,K=true,cancelAnimationFrame(X),ht(i,E);},getProgress(){return Te}}}var mt=new Map;function Be(e,t){mt.set(e,t);}function We(e){mt.delete(e);}function Mt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function ft(e){let t=[],r=/([\w]+)\(([^)]*)\)/g,n;for(;(n=r.exec(e))!==null;){let u=[],a=[],h=n[2].trim();if(h)for(let f of h.split(/[\s,]+/)){let l=f.match(/^([-+]?[\d.eE]+)(.*)$/);u.push(l?parseFloat(l[1]):0),a.push(l?l[2]:"");}t.push({fn:n[1],nums:u,units:a});}return t}function Pt(e,t,r){let n=ft(e),u=ft(t);return n.length===0||n.length!==u.length?r<1?e:t:n.map((a,h)=>{let f=u[h];return a.fn!==f.fn||a.nums.length!==f.nums.length?r<1?`${a.fn}(${a.nums.map((l,p)=>`${l}${a.units[p]}`).join(", ")})`:`${f.fn}(${f.nums.map((l,p)=>`${l}${f.units[p]}`).join(", ")})`:`${a.fn}(${a.nums.map((l,p)=>`${l+(f.nums[p]-l)*r}${a.units[p]}`).join(", ")})`}).join(" ")}function pt(e,t,r){if(typeof e=="number"&&typeof t=="number")return String(e+(t-e)*r);let n=String(e),u=String(t);if(Mt(n))return Le(n,u,r);if(n.includes("("))return Pt(n,u,r);let a=n.match(/^([-+]?[\d.]+)(.*)$/),h=u.match(/^([-+]?[\d.]+)(.*)$/);if(a&&h){let f=parseFloat(a[1]),l=parseFloat(h[1]);return `${f+(l-f)*r}${a[2]||h[2]}`}return r<1?n:u}function kt(e){return e.replace(/([A-Z])/g,t=>`-${t.toLowerCase()}`)}var dt={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Ct=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),Lt=0;function It(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function gt(e,t){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let{props:n,trigger:u={},easing:a="ease-out",speed:h=1,once:f=false,axis:l="y",scrollContainer:p,native:x=true,velocityScale:F=false,onProgress:E,onComplete:W,onEnter:ge,onLeave:S,onEnterBack:M,onLeaveBack:d}=t,A=window.matchMedia("(prefers-reduced-motion: reduce)").matches,b=typeof a=="function"?a:te[a]??te["ease-out"],R=be(u.start??"top bottom"),z=be(u.end??"bottom top"),T=typeof p=="string"?document.querySelector(p):p??null,H=Object.entries(n).map(([s,m])=>({prop:kt(s),from:Array.isArray(m)?m[0]:"",to:Array.isArray(m)?m[1]:m}));function ye(){let s=window.getComputedStyle(e);for(let m of H)m.from===""&&(m.from=s.getPropertyValue(m.prop).trim()||"0");}function we(){for(let s of H)e.style.setProperty(s.prop,String(s.to));}if(A)return we(),W?.(),r;ye();function ae(){if(!x||!It()||typeof a!="string"||!(a in dt)||l!=="y"||T||f||h!==1||E||W||ge||S||M||d||F!==false||(u.start??"top bottom").trim()!=="top bottom"||(u.end??"bottom top").trim()!=="bottom top")return false;for(let s of H)if(!Ct.has(s.prop))return false;return true}function ve(){let s=`ssd-a-${++Lt}`,m=H.map(C=>`${C.prop}:${C.from}`).join(";"),k=H.map(C=>`${C.prop}:${C.to}`).join(";"),G=document.createElement("style");G.setAttribute("data-ssd-animate",""),G.textContent=`@keyframes ${s}{from{${m}}to{${k}}}.${s}{animation-name:${s};animation-duration:auto;animation-timing-function:${dt[a]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(G),e.classList.add(s);let $=()=>l==="x"?window.scrollX:window.scrollY,D=()=>l==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(s),G.remove();},replay(){e.classList.remove(s),e.offsetWidth,e.classList.add(s);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(C){let Y=Math.min(1,Math.max(0,C));e.classList.remove(s);for(let J of H)e.style.setProperty(J.prop,pt(J.from,J.to,Y));},getProgress(){let C=e.getBoundingClientRect(),Y=$(),J=D(),{tStart:j,tEnd:oe}=xe({top:C.top,height:C.height},Y,J,R,z);return b(re(Y,j,oe,h))}}}if(ae())return ve();let P=0,U=0,se=0,ce=false,Z=false,g=-1,N=0,le=false,ue=NaN,Me=-1,Ie=0,Pe=()=>T?l==="x"?T.scrollLeft:T.scrollTop:l==="x"?window.scrollX:window.scrollY,me=()=>T?l==="x"?T.clientWidth:T.clientHeight:l==="x"?window.innerWidth:window.innerHeight;function fe(){let s=e.getBoundingClientRect(),m,k;if(T){let $=T.getBoundingClientRect();m=l==="x"?s.left-$.left+T.scrollLeft:s.top-$.top+T.scrollTop,k=l==="x"?s.width:s.height;}else m=l==="x"?s.left:s.top,k=l==="x"?s.width:s.height;let G=xe({top:m,height:k},Pe(),me(),R,z);P=G.tStart,U=G.tEnd;}function Ae(s){e.style.setProperty("--scroll-draw-progress",String(s));for(let m of H)e.style.setProperty(m.prop,pt(m.from,m.to,s));E?.(s);}function Oe(s){if(isNaN(ue)){ue=s;return}ue<=0&&s>0?ge?.():ue>0&&s<=0&&d?.(),ue<1&&s>=1?S?.():ue>=1&&s<1&&M?.(),ue=s;}function _(){if(!ce||Z)return;let s=performance.now(),m=Pe(),k=h;if(F!==false){let D=s-Ie,C=D>0?Math.abs(m-(Me<0?m:Me))/D:0;k=h*Math.max(.2,1+C*(typeof F=="number"?F:1)*.04);}Me=m,Ie=s;let G=U===P?0:(m-P)/(U-P);Oe(G);let $=b(re(m,P,U,k));f&&(g=Math.max(g,$),$=g),N=$,Ae($),$>=1&&!le?(le=true,W?.()):$<1&&!f&&(le=false),se=requestAnimationFrame(_);}fe();{let s=b(re(Pe(),P,U,h));f&&s>0&&(g=s),N=s,Ae(s);}let ne=new IntersectionObserver(s=>{s.forEach(m=>{ce=m.isIntersecting,ce&&!Z?se=requestAnimationFrame(_):cancelAnimationFrame(se);});},{root:T??null}),V;function B(){clearTimeout(V),V=setTimeout(fe,150);}return window.addEventListener("resize",B),window.addEventListener("orientationchange",B),ne.observe(e),Be(e,{type:"animate",getProgress:()=>N,getTrigger:()=>({tStart:P,tEnd:U})}),{destroy(){cancelAnimationFrame(se),ne.disconnect(),window.removeEventListener("resize",B),window.removeEventListener("orientationchange",B),clearTimeout(V),We(e);},replay(){g=-1,le=false,N=0,Z=false,Ae(0);},pause(){Z=true,cancelAnimationFrame(se);},resume(){Z&&(Z=false,ce&&(se=requestAnimationFrame(_)));},seek(s){let m=Math.min(1,Math.max(0,s));N=m,g=m,Z=true,cancelAnimationFrame(se),Ae(m);},getProgress(){return N}}}var _e={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Dt(e,t){if(typeof window>"u")return _e;let r=typeof e=="string"?document.querySelector(e):e;return r?gt(r,t):(process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollAnimate: element not found:",e),_e)}function Ot(e,t={}){if(typeof window>"u")return _e;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollParallax: element not found:",e),_e;let{speed:n=.3,axis:u="y",easing:a="linear",trigger:h,onProgress:f}=t,l=r.getBoundingClientRect(),p=u==="x"?l.width:l.height,x=n*p;return gt(r,{props:u==="x"?{transform:["translateX(0px)",`translateX(${-x}px)`]}:{transform:["translateY(0px)",`translateY(${-x}px)`]},trigger:h??{start:"top bottom",end:"bottom top"},easing:a,native:false,onProgress:f})}var Je={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Ft(e,t){if(typeof window>"u")return Je;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),Je;let n=r,{from:u=0,to:a,format:h,easing:f="ease-out",trigger:l={},once:p=true,decimals:x,onComplete:F}=t,E=x!==void 0?g=>g.toFixed(x):h??(g=>String(Math.round(g))),W=typeof f=="function"?f:te[f]??te["ease-out"],ge=be(l.start??"top 80%"),S=be(l.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return n.textContent=E(a),F?.(),Je;n.textContent=E(u);let d=0,A=0,b=0,R=false,z=false,T=-1,H=0,ye=false,we=()=>window.scrollY,ae=()=>window.innerHeight;function ve(){let g=n.getBoundingClientRect(),N=xe({top:g.top,height:g.height},we(),ae(),ge,S);d=N.tStart,A=N.tEnd;}function P(g){n.textContent=E(u+(a-u)*g),n.style.setProperty("--scroll-draw-progress",String(g));}function U(){if(!R||z)return;let g=W(re(we(),d,A,1));p&&(T=Math.max(T,g),g=T),H=g,P(g),g>=1&&!ye?(ye=true,F?.()):g<1&&!p&&(ye=false),b=requestAnimationFrame(U);}ve();{let g=W(re(we(),d,A,1));p&&g>0&&(T=g),H=g,P(g);}let se=new IntersectionObserver(g=>{g.forEach(N=>{R=N.isIntersecting,R&&!z?b=requestAnimationFrame(U):cancelAnimationFrame(b);});}),ce;function Z(){clearTimeout(ce),ce=setTimeout(ve,150);}return window.addEventListener("resize",Z),window.addEventListener("orientationchange",Z),se.observe(n),Be(n,{type:"counter",getProgress:()=>H,getTrigger:()=>({tStart:d,tEnd:A})}),{destroy(){cancelAnimationFrame(b),se.disconnect(),window.removeEventListener("resize",Z),window.removeEventListener("orientationchange",Z),clearTimeout(ce),We(n);},replay(){T=-1,ye=false,H=0,z=false,P(0);},pause(){z=true,cancelAnimationFrame(b);},resume(){z&&(z=false,R&&(b=requestAnimationFrame(U)));},seek(g){let N=Math.min(1,Math.max(0,g));H=N,T=N,z=true,cancelAnimationFrame(b),P(N);},getProgress(){return H}}}var yt="http://www.w3.org/2000/svg",Nt="cinematic-photo",Ke=e=>e<0?0:e>1?1:e;function Ge(e){let t=parseFloat(e);return Number.isFinite(t)?Ke(t/100):0}function Rt(e){return te[e]??te.linear}var Ht={destroy:()=>{},getProgress:()=>0},Qe=class{constructor(t){if(typeof document>"u"){this.mount=null;return}this.mount=typeof t.wrapper=="string"?document.querySelector(t.wrapper):t.wrapper,!this.mount&&process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] Cinematic: wrapper not found:",t.wrapper);}loadStory(t){let r=this.mount;if(typeof window>"u"||!r)return Ht;r.style.position="relative",r.style.height=t.totalHeight,r.style.display="block";let n=document.createElement("div");n.setAttribute("data-cinematic-stage",""),n.style.cssText="position:sticky;top:0;height:100vh;width:100%;overflow:hidden;display:block;",r.appendChild(n);let u=[];for(let S of t.scenes){if(S.background){let d=document.createElement("img");d.id=Nt,d.src=S.background,d.alt="",d.style.cssText="position:absolute;inset:0;width:100%;height:100%;object-fit:contain;opacity:0;pointer-events:none;",n.appendChild(d);}let M=S.animations.filter(d=>d.type==="draw");if(M.length){let d=document.createElementNS(yt,"svg");d.setAttribute("viewBox",`0 0 ${t.canvas.width} ${t.canvas.height}`),d.setAttribute("preserveAspectRatio","xMidYMid meet"),d.style.cssText="position:absolute;inset:0;width:100%;height:100%;overflow:visible;",n.appendChild(d);for(let A of M){let b=document.createElementNS(yt,"path");b.id=A.target.replace(/^#/,""),b.setAttribute("d",A.d),b.setAttribute("fill","none"),b.setAttribute("stroke",A.stroke),b.setAttribute("stroke-width",String(A.strokeWidth)),b.setAttribute("stroke-linecap","round"),b.setAttribute("stroke-linejoin","round");let R=A.length||b.getTotalLength?.()||0;b.style.strokeDasharray=String(R),b.style.strokeDashoffset=String(R),d.appendChild(b),u.push({kind:"draw",el:b,start:Ge(A.start),end:Ge(A.end),ease:Rt(A.easing),length:R});}}for(let d of S.animations){if(d.type!=="fade")continue;let A=n.querySelector(d.target)??document.querySelector(d.target);A&&(A.style.opacity=String(d.from),u.push({kind:"fade",el:A,start:Ge(d.start),end:Ge(d.end),ease:te["ease-in-out"]??te.linear,from:d.from,to:d.to}));}}let a=0,h=()=>{let S=r.offsetHeight-window.innerHeight;return S<=0?r.getBoundingClientRect().top<=0?1:0:Ke(-r.getBoundingClientRect().top/S)},f=S=>{for(let M of u){let d=M.end-M.start,A=d<=0?S>=M.end?1:0:Ke((S-M.start)/d),b=M.ease(A);M.kind==="draw"?M.el.style.strokeDashoffset=String(M.length*(1-b)):M.el.style.opacity=String(M.from+(M.to-M.from)*b);}};if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return f(1),{destroy:()=>{},getProgress:()=>1};let l=0,p=false,x=false,F=()=>{a=h(),f(a),p&&(l=requestAnimationFrame(F));},E=()=>{p||(p=true,l=requestAnimationFrame(F));},W=()=>{p=false,cancelAnimationFrame(l);},ge=new IntersectionObserver(S=>{for(let M of S)x=M.isIntersecting,x?E():W();},{threshold:0});return ge.observe(n),a=h(),f(a),{destroy(){W(),ge.disconnect();},getProgress:()=>a}}};function er(e,t){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let n=typeof e=="string"?document.querySelector(e):e;return n?ut(n,t):(console.warn("[svg-scroll-draw] Container not found:",e),r)}
|
|
4
4
|
export{Qe as Cinematic,Ue as PRESETS,it as createBounce,at as createElastic,Et as createSpring,Dt as scrollAnimate,Ft as scrollCounter,er as scrollDraw,Ot as scrollParallax};
|
package/dist/nuxt/index.cjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';var vue=require('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,
|
|
2
|
-
<div style="position:absolute;${u?`left:${
|
|
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 f=parseFloat(s),c=t[l++]??f;return String(+(f+(c-f)*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:f="path, polyline, line, polygon, rect, circle",speed:c=1,fade:u=false,easing:h="linear",trigger:L={},stagger:_=0,direction:E="forward",once:Q=false,debug:he=false,axis:H="y",scrollContainer:ee,autoReverse:te=false,delay:q=0,strokeColor:x,strokeWidth:A,fillOpacity:w,waypoints:b,velocityScale:P=false,threshold:O=0,rootMargin:G="0px",repeat:$=0,repeatDelay:I=0,morphTo:M,clip:V,autoplay:ne=false,duration:N=1e3,native:B=true,onProgress:d,onStart:C,onComplete:g,onEnter:y,onLeave:j,onEnterBack:Ae,onLeaveBack:be}=l,we=V===true?"left":typeof V=="string"?V:false,de=typeof h=="function"?h:ie[h]??ie.linear,He=ae(L.start??"top bottom"),De=ae(L.end??"bottom top"),U=typeof ee=="string"?document.querySelector(ee):ee??null,i=Array.isArray(x)?x[0]:null,p=Array.isArray(x)?x[1]:typeof x=="string"?x:null,X=Array.isArray(A)?A[0]:null,R=Array.isArray(A)?A[1]:typeof A=="number"?A:null,Z=Array.isArray(w)?w[0]:null,oe=Array.isArray(w)?w[1]:typeof w=="number"?w:null;function J(o){let a=o*100;switch(we){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 W=we?[]:Array.from(e.querySelectorAll(f)),k=[],me=[],ge=0,Ce=0,se=false,ye=false,re=0,Be=false,ve=-1,We=-1,le=false,ke=0,Me=0,Le,Ue=null,$e=new Set,_e=-1,ut=performance.now(),Ie=NaN;function Ve(){return U?H==="x"?U.scrollLeft:U.scrollTop:H==="x"?window.scrollX:window.scrollY}function mt(){return U?H==="x"?U.clientWidth:U.clientHeight:H==="x"?window.innerWidth:window.innerHeight}function ft(){let o=e.getBoundingClientRect(),a,S,Y;if(U){let ue=U.getBoundingClientRect();a=H==="x"?o.left-ue.left+U.scrollLeft:o.top-ue.top+U.scrollTop,S=H==="x"?o.width:o.height,Y=Ve();}else a=H==="x"?o.left:o.top,S=H==="x"?o.width:o.height,Y=Ve();let ce=pe({top:a,height:S},Y,mt(),He,De);ge=ce.tStart,Ce=ce.tEnd,he&&process.env.NODE_ENV!=="production"&&(Ue?.remove(),Ue=Rt(ge,Ce,H));}function Ct(o,a){if(e.style.setProperty("--scroll-draw-progress",String(o)),we){let S=a==="reverse"?1-o:o;e.style.clipPath=J(S);return}W.forEach((S,Y)=>{S.style.strokeDashoffset=a==="reverse"?`${k[Y]*o}`:`${k[Y]*(1-o)}`,u&&(S.style.opacity=a==="reverse"?`${1-o}`:`${o}`),i&&p?S.style.stroke=Re(i,p,o):p&&(S.style.stroke=p),X!==null&&R!==null?S.style.strokeWidth=`${X+(R-X)*o}`:R!==null&&(S.style.strokeWidth=`${R}`),Z!==null&&oe!==null?S.style.fillOpacity=`${Z+(oe-Z)*o}`:oe!==null&&(S.style.fillOpacity=`${oe}`),M&&S.tagName.toLowerCase()==="path"&&me[Y]&&S.setAttribute("d",Ke(me[Y],M,o));});}function Ge(){if(e.style.setProperty("--scroll-draw-progress","0"),we){e.style.clipPath=J(0);return}W.forEach((o,a)=>{o.style.strokeDasharray=`${k[a]}`,o.style.strokeDashoffset=E==="reverse"?"0":`${k[a]}`,u?o.style.opacity=E==="reverse"?"1":"0":o.style.opacity="",i&&(o.style.stroke=i),X!==null&&(o.style.strokeWidth=`${X}`),Z!==null&&(o.style.fillOpacity=`${Z}`),M&&o.tagName.toLowerCase()==="path"&&me[a]&&o.setAttribute("d",me[a]);});}if(W.forEach(o=>{Nt(o);let a=Ye(o);k.push(a),o.tagName.toLowerCase()==="path"?me.push(o.getAttribute("d")??""):me.push(""),s?(o.style.strokeDasharray=`${a}`,o.style.strokeDashoffset=E==="reverse"?`${a}`:"0",u&&(o.style.opacity="1"),p&&(o.style.stroke=p),R!==null&&(o.style.strokeWidth=`${R}`),oe!==null&&(o.style.fillOpacity=`${oe}`),M&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",M)):(o.style.strokeDasharray=`${a}`,o.style.strokeDashoffset=E==="reverse"?"0":`${a}`,u?o.style.opacity=E==="reverse"?"1":"0":o.style.opacity="",i&&(o.style.stroke=i),X!==null&&(o.style.strokeWidth=`${X}`),Z!==null&&(o.style.fillOpacity=`${Z}`));}),we){if(s)return e.style.clipPath=J(1),g?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=J(0);}else if(s)return g?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Lt(){return !(B===false||!It()||!W.length||typeof h!="string"||!(h in bt)||we||H!=="y"||U||c!==1||_!==0||Q||te||P!==false||M||b||$||q>0||d||C||g||y||j||Ae||be||x!=null||A!=null||w!=null||(L.start??"top bottom").trim()!=="top bottom"||(L.end??"bottom top").trim()!=="bottom top")}function $t(){let o=`svg-scroll-draw-${++Dt}`,a=E==="reverse"?"0":"var(--ssd-len)",S=E==="reverse"?"var(--ssd-len)":"0",Y=`stroke-dashoffset:${a};`,ce=`stroke-dashoffset:${S};`;u&&(Y+=`opacity:${E==="reverse"?1:0};`,ce+=`opacity:${E==="reverse"?0:1};`);let ue=document.createElement("style");ue.setAttribute("data-svg-scroll-draw",""),ue.textContent=`@keyframes ${o}{from{${Y}}to{${ce}}}.${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(ue);function fe(m,T){m.style.setProperty("--ssd-len",String(k[T])),m.style.strokeDasharray=`${k[T]}`,m.style.strokeDashoffset="",m.style.opacity="",m.style.animationPlayState="",m.classList.add(o);}W.forEach(fe);let v=false,F=-1;function D(){if(F>=0)return F;let m=e.getBoundingClientRect(),{tStart:T,tEnd:z}=pe({top:m.top,height:m.height},Ve(),mt(),He,De);return de(K(Ve(),T,z,c))}return {destroy(){W.forEach(m=>{m.classList.remove(o),m.style.removeProperty("--ssd-len"),m.style.animationPlayState="";}),ue.remove();},replay(){v=false,F=-1,W.forEach(fe);},pause(){v=true,W.forEach(m=>{m.style.animationPlayState="paused";});},resume(){v&&(v=false,W.forEach(m=>{m.style.animationPlayState="running";}));},seek(m){let T=Math.min(1,Math.max(0,m));F=T,v=true,W.forEach((z,Fe)=>{z.classList.remove(o),z.style.strokeDashoffset=E==="reverse"?`${k[Fe]*T}`:`${k[Fe]*(1-T)}`,u&&(z.style.opacity=E==="reverse"?`${1-T}`:`${T}`);});},getProgress(){return D()}}}if(Lt())return $t();function Pt(){let o=Math.max(1,N),a=0,S=0;function Y(D){let m=true;if(we){let T=Math.min(1,Math.max(0,D/o)),z=de(T);ke=z,e.style.setProperty("--scroll-draw-progress",String(z)),e.style.clipPath=J(E==="reverse"?1-z:z),d?.(z),T<1&&(m=false);}else W.forEach((T,z)=>{let Fe=z*_*o,Ne=Math.min(1,Math.max(0,(D-Fe)/o)),Se=de(Ne);T.style.strokeDashoffset=E==="reverse"?`${k[z]*Se}`:`${k[z]*(1-Se)}`,u&&(T.style.opacity=E==="reverse"?`${1-Se}`:`${Se}`),i&&p?T.style.stroke=Re(i,p,Se):p&&(T.style.stroke=p),X!==null&&R!==null?T.style.strokeWidth=`${X+(R-X)*Se}`:R!==null&&(T.style.strokeWidth=`${R}`),Z!==null&&oe!==null?T.style.fillOpacity=`${Z+(oe-Z)*Se}`:oe!==null&&(T.style.fillOpacity=`${oe}`),M&&T.tagName.toLowerCase()==="path"&&me[z]&&T.setAttribute("d",Ke(me[z],M,Se)),z===0&&(d?.(Se),e.style.setProperty("--scroll-draw-progress",String(Se))),Ne<1&&(m=false);});if(b){let T=Math.min(1,Math.max(0,D/o)),z=de(T);for(let Fe in b){let Ne=parseFloat(Fe);z>=Ne&&!$e.has(Ne)&&($e.add(Ne),b[Fe]?.());}}return m}function ce(D){if(le)return;let m=D-a;ye||(ye=true,C?.());let T=Y(m);if(T&&!se){se=true,Y(o*(1+Math.max(0,W.length-1)*_)),g?.(),Me<($==="infinite"?1/0:$??0)&&(Me++,Le=setTimeout(()=>{a=performance.now(),ye=false,se=false,$e.clear(),Ge(),re=requestAnimationFrame(ce);},I));return}T||(re=requestAnimationFrame(ce));}function ue(){cancelAnimationFrame(re),clearTimeout(Le),a=performance.now(),S=0,le=false,ye=false,se=false,Me=0,$e.clear(),Ge(),re=requestAnimationFrame(ce);}let fe=new IntersectionObserver(D=>{D.forEach(m=>{m.isIntersecting&&!(Q&&se)?ue():!m.isIntersecting&&!Q&&!se&&(cancelAnimationFrame(re),clearTimeout(Le),a=null);});},{root:U??null,threshold:O,rootMargin:G}),v;function F(){clearTimeout(v),v=setTimeout(()=>{W.forEach((D,m)=>{k[m]=Ye(D),D.style.strokeDasharray=`${k[m]}`;});},150);}return window.addEventListener("resize",F),window.addEventListener("orientationchange",F),q>0?setTimeout(()=>fe.observe(e),q):fe.observe(e),{destroy(){cancelAnimationFrame(re),clearTimeout(Le),fe.disconnect(),window.removeEventListener("resize",F),window.removeEventListener("orientationchange",F),clearTimeout(v);},replay(){Me=0,ue();},pause(){le||(le=true,S=performance.now()-a,cancelAnimationFrame(re));},resume(){le&&(le=false,a=performance.now()-S,re=requestAnimationFrame(ce));},seek(D){let m=Math.min(1,Math.max(0,D));ke=m,le=true,S=m*o,a=performance.now()-S,cancelAnimationFrame(re),Y(S);},getProgress(){return ke}}}if(ne)return Pt();ft();function je(){if(!Be||le)return;let o=performance.now(),a=Ve(),S=c;if(P!==false){let v=o-ut,F=v>0?Math.abs(a-(_e<0?a:_e))/v:0;S=c*Math.max(.2,1+F*(typeof P=="number"?P:1)*.04);}_e=a,ut=o;let Y=te?We===-1||a>=We?"forward":"reverse":E;We=a;let ce=Ce-ge,ue=true,fe=ce===0?0:(a-ge)/ce;if(isNaN(Ie)||(Ie<=0&&fe>0?y?.():Ie>0&&fe<=0&&be?.(),Ie<1&&fe>=1?j?.():Ie>=1&&fe<1&&Ae?.()),Ie=fe,we){let v=de(K(a,ge,Ce,S));Q&&!te&&(ve=Math.max(ve,v),v=ve),ke=v,e.style.setProperty("--scroll-draw-progress",String(v));let F=Y==="reverse"?1-v:v;e.style.clipPath=J(F),d?.(v),!ye&&K(a,ge,Ce,S)>0&&(ye=true,C?.()),v>=1&&!se?(se=true,g?.(),Me<($==="infinite"?1/0:$??0)&&(Me++,Le=setTimeout(()=>{ve=-1,ye=false,se=false,e.style.clipPath=J(0);},I))):v<1&&!Q&&(se=false),re=requestAnimationFrame(je);return}if(W.forEach((v,F)=>{let D=F*_*ce,m=de(K(a,ge+D,Ce+D,S));Q&&!te&&(ve=Math.max(ve,m),m=ve),ke=m,v.style.strokeDashoffset=Y==="reverse"?`${k[F]*m}`:`${k[F]*(1-m)}`,u&&(v.style.opacity=Y==="reverse"?`${1-m}`:`${m}`),i&&p?v.style.stroke=Re(i,p,m):p&&(v.style.stroke=p),X!==null&&R!==null?v.style.strokeWidth=`${X+(R-X)*m}`:R!==null&&(v.style.strokeWidth=`${R}`),Z!==null&&oe!==null?v.style.fillOpacity=`${Z+(oe-Z)*m}`:oe!==null&&(v.style.fillOpacity=`${oe}`),M&&v.tagName.toLowerCase()==="path"&&me[F]&&v.setAttribute("d",Ke(me[F],M,m)),F===0&&(d?.(m),e.style.setProperty("--scroll-draw-progress",String(m))),m<1&&(ue=false);}),b){let v=de(K(a,ge,Ce,S));for(let F in b){let D=parseFloat(F);v>=D&&!$e.has(D)&&($e.add(D),b[F]?.());}}!ye&&K(a,ge,Ce,S)>0&&(ye=true,C?.()),ue&&!se?(se=true,g?.(),Me<($==="infinite"?1/0:$??0)&&(Me++,Le=setTimeout(()=>{ve=-1,ye=false,se=false,$e.clear(),Ge();},I))):!ue&&!Q&&(se=false),re=requestAnimationFrame(je);}let Ze=new IntersectionObserver(o=>{o.forEach(a=>{Be=a.isIntersecting,Be&&!le?re=requestAnimationFrame(je):cancelAnimationFrame(re);});},{root:U??null,threshold:O,rootMargin:G}),Je;function Xe(){clearTimeout(Je),Je=setTimeout(()=>{W.forEach((o,a)=>{k[a]=Ye(o),o.style.strokeDasharray=`${k[a]}`;}),ft();},150);}return window.addEventListener("resize",Xe),window.addEventListener("orientationchange",Xe),q>0?setTimeout(()=>Ze.observe(e),q):Ze.observe(e),{destroy(){cancelAnimationFrame(re),clearTimeout(Le),Ze.disconnect(),window.removeEventListener("resize",Xe),window.removeEventListener("orientationchange",Xe),clearTimeout(Je),Ue?.remove();},replay(){ve=-1,We=-1,_e=-1,ye=false,se=false,Me=0,le=false,$e.clear(),clearTimeout(Le),Ge();},pause(){le=true,cancelAnimationFrame(re);},resume(){le&&(le=false,Be&&(re=requestAnimationFrame(je)));},seek(o){let a=Math.min(1,Math.max(0,o));ke=a,ve=a,le=true,cancelAnimationFrame(re),Ct(a,E);},getProgress(){return ke}}}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=[],f=t[2].trim();if(f)for(let c of f.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,f)=>{let c=l[f];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.]+)(.*)$/),f=l.match(/^([-+]?[\d.]+)(.*)$/);if(s&&f){let c=parseFloat(s[1]),u=parseFloat(f[1]);return `${c+(u-c)*n}${s[2]||f[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:f=1,once:c=false,axis:u="y",scrollContainer:h,native:L=true,onProgress:_,onComplete:E,onEnter:Q,onLeave:he,onEnterBack:H,onLeaveBack:ee}=r,te=window.matchMedia("(prefers-reduced-motion: reduce)").matches,q=typeof s=="function"?s:ie[s]??ie["ease-out"],x=ae(l.start??"top bottom"),A=ae(l.end??"bottom top"),w=typeof h=="string"?document.querySelector(h):h??null,b=Object.entries(t).map(([i,p])=>({prop:zt(i),from:Array.isArray(p)?p[0]:"",to:Array.isArray(p)?p[1]:p}));function P(){let i=window.getComputedStyle(e);for(let p of b)p.from===""&&(p.from=i.getPropertyValue(p.prop).trim()||"0");}function O(){for(let i of b)e.style.setProperty(i.prop,String(i.to));}if(te)return O(),E?.(),n;P();function G(){if(!L||!Wt()||typeof s!="string"||!(s in Et)||u!=="y"||w||c||f!==1||_||E||Q||he||H||ee||(l.start??"top bottom").trim()!=="top bottom"||(l.end??"bottom top").trim()!=="bottom top")return false;for(let i of b)if(!qt.has(i.prop))return false;return true}function $(){let i=`ssd-a-${++Bt}`,p=b.map(J=>`${J.prop}:${J.from}`).join(";"),X=b.map(J=>`${J.prop}:${J.to}`).join(";"),R=document.createElement("style");R.setAttribute("data-ssd-animate",""),R.textContent=`@keyframes ${i}{from{${p}}to{${X}}}.${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(R),e.classList.add(i);let Z=()=>u==="x"?window.scrollX:window.scrollY,oe=()=>u==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(i),R.remove();},replay(){e.classList.remove(i),e.offsetWidth,e.classList.add(i);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(J){let W=Math.min(1,Math.max(0,J));e.classList.remove(i);for(let k of b)e.style.setProperty(k.prop,St(k.from,k.to,W));},getProgress(){let J=e.getBoundingClientRect(),W=Z(),k=oe(),{tStart:me,tEnd:ge}=pe({top:J.top,height:J.height},W,k,x,A);return q(K(W,me,ge,f))}}}if(G())return $();let I=0,M=0,V=0,ne=false,N=false,B=-1,d=0,C=false,g=NaN,y=()=>w?u==="x"?w.scrollLeft:w.scrollTop:u==="x"?window.scrollX:window.scrollY,j=()=>w?u==="x"?w.clientWidth:w.clientHeight:u==="x"?window.innerWidth:window.innerHeight;function Ae(){let i=e.getBoundingClientRect(),p,X;if(w){let Z=w.getBoundingClientRect();p=u==="x"?i.left-Z.left+w.scrollLeft:i.top-Z.top+w.scrollTop,X=u==="x"?i.width:i.height;}else p=u==="x"?i.left:i.top,X=u==="x"?i.width:i.height;let R=pe({top:p,height:X},y(),j(),x,A);I=R.tStart,M=R.tEnd;}function be(i){e.style.setProperty("--scroll-draw-progress",String(i));for(let p of b)e.style.setProperty(p.prop,St(p.from,p.to,i));_?.(i);}function we(i){if(isNaN(g)){g=i;return}g<=0&&i>0?Q?.():g>0&&i<=0&&ee?.(),g<1&&i>=1?he?.():g>=1&&i<1&&H?.(),g=i;}function de(){if(!ne||N)return;let i=M===I?0:(y()-I)/(M-I);we(i);let p=q(K(y(),I,M,f));c&&(B=Math.max(B,p),p=B),d=p,be(p),p>=1&&!C?(C=true,E?.()):p<1&&!c&&(C=false),V=requestAnimationFrame(de);}Ae();{let i=q(K(y(),I,M,f));c&&i>0&&(B=i),d=i,be(i);}let He=new IntersectionObserver(i=>{i.forEach(p=>{ne=p.isIntersecting,ne&&!N?V=requestAnimationFrame(de):cancelAnimationFrame(V);});},{root:w??null}),De;function U(){clearTimeout(De),De=setTimeout(Ae,150);}return window.addEventListener("resize",U),window.addEventListener("orientationchange",U),He.observe(e),Pe(e,{type:"animate",getProgress:()=>d,getTrigger:()=>({tStart:I,tEnd:M})}),{destroy(){cancelAnimationFrame(V),He.disconnect(),window.removeEventListener("resize",U),window.removeEventListener("orientationchange",U),clearTimeout(De),Oe(e);},replay(){B=-1,C=false,d=0,N=false,be(0);},pause(){N=true,cancelAnimationFrame(V);},resume(){N&&(N=false,ne&&(V=requestAnimationFrame(de)));},seek(i){let p=Math.min(1,Math.max(0,i));d=p,B=p,N=true,cancelAnimationFrame(V),be(p);},getProgress(){return d}}}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:f,easing:c="ease-out",trigger:u={},once:h=true,decimals:L,onComplete:_}=r,E=L!==void 0?d=>d.toFixed(L):f??(d=>String(Math.round(d))),Q=typeof c=="function"?c:ie[c]??ie["ease-out"],he=ae(u.start??"top 80%"),H=ae(u.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=E(s),_?.(),tt;t.textContent=E(l);let te=0,q=0,x=0,A=false,w=false,b=-1,P=0,O=false,G=()=>window.scrollY,$=()=>window.innerHeight;function I(){let d=t.getBoundingClientRect(),C=pe({top:d.top,height:d.height},G(),$(),he,H);te=C.tStart,q=C.tEnd;}function M(d){t.textContent=E(l+(s-l)*d),t.style.setProperty("--scroll-draw-progress",String(d));}function V(){if(!A||w)return;let d=Q(K(G(),te,q,1));h&&(b=Math.max(b,d),d=b),P=d,M(d),d>=1&&!O?(O=true,_?.()):d<1&&!h&&(O=false),x=requestAnimationFrame(V);}I();{let d=Q(K(G(),te,q,1));h&&d>0&&(b=d),P=d,M(d);}let ne=new IntersectionObserver(d=>{d.forEach(C=>{A=C.isIntersecting,A&&!w?x=requestAnimationFrame(V):cancelAnimationFrame(x);});}),N;function B(){clearTimeout(N),N=setTimeout(I,150);}return window.addEventListener("resize",B),window.addEventListener("orientationchange",B),ne.observe(t),Pe(t,{type:"counter",getProgress:()=>P,getTrigger:()=>({tStart:te,tEnd:q})}),{destroy(){cancelAnimationFrame(x),ne.disconnect(),window.removeEventListener("resize",B),window.removeEventListener("orientationchange",B),clearTimeout(N),Oe(t);},replay(){b=-1,O=false,P=0,w=false,M(0);},pause(){w=true,cancelAnimationFrame(x);},resume(){w&&(w=false,A&&(x=requestAnimationFrame(V)));},seek(d){let C=Math.min(1,Math.max(0,d));P=C,b=C,w=true,cancelAnimationFrame(x),M(C);},getProgress(){return P}}}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:f=false,axis:c="y",preload:u="auto",onReady:h,onComplete:L,onProgress:_}=r,E=window.matchMedia("(prefers-reduced-motion: reduce)").matches,Q=typeof s=="function"?s:ie[s]??ie.linear,he=ae(l.start??"top top"),H=ae(l.end??"bottom top");t.pause(),t.hasAttribute("preload")||(t.preload=u);let ee=r.from??0,te=r.to,q=0,x=0,A=0,w=false,b=false,P=-1,O=0,G=false,$=false,I=()=>c==="x"?window.scrollX:window.scrollY,M=()=>c==="x"?window.innerWidth:window.innerHeight;function V(){let y=t.getBoundingClientRect(),j=c==="x"?y.left:y.top,Ae=c==="x"?y.width:y.height,be=pe({top:j,height:Ae},I(),M(),he,H);q=be.tStart,x=be.tEnd;}function ne(y){if(!$)return;let j=te??t.duration??0;t.currentTime=ee+(j-ee)*y,t.style.setProperty("--scroll-draw-progress",String(y)),_?.(y);}function N(){if(!w||b||!$)return;let y=Q(K(I(),q,x,1));f&&(P=Math.max(P,y),y=P),O=y,ne(y),y>=1&&!G?(G=true,L?.()):y<1&&!f&&(G=false),A=requestAnimationFrame(N);}function B(){if($=true,te===void 0&&(te=t.duration),E){ne(1),h?.();return}V(),h?.(),w&&!b&&(A=requestAnimationFrame(N));}t.readyState>=1?B():t.addEventListener("loadedmetadata",B,{once:true}),$||V();let d=new IntersectionObserver(y=>{y.forEach(j=>{w=j.isIntersecting,w&&!b&&$?A=requestAnimationFrame(N):cancelAnimationFrame(A);});}),C;function g(){clearTimeout(C),C=setTimeout(V,150);}return window.addEventListener("resize",g),window.addEventListener("orientationchange",g),d.observe(t),Pe(t,{type:"video",getProgress:()=>O,getTrigger:()=>({tStart:q,tEnd:x})}),{destroy(){cancelAnimationFrame(A),d.disconnect(),t.removeEventListener("loadedmetadata",B),window.removeEventListener("resize",g),window.removeEventListener("orientationchange",g),clearTimeout(C),Oe(t);},replay(){P=-1,G=false,O=0,b=false,ne(0);},pause(){b=true,cancelAnimationFrame(A);},resume(){b&&(b=false,w&&$&&(A=requestAnimationFrame(N)));},seek(y){let j=Math.min(1,Math.max(0,y));O=j,P=j,b=true,cancelAnimationFrame(A),ne(j);},getProgress(){return O}}}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 f=s.offsetTop;n.has(f)||n.set(f,[]),n.get(f).push(s);}let t=[],l=Array.from(n.keys()).sort((s,f)=>s-f);for(let s of l){let f=n.get(s),c=document.createElement("span");c.setAttribute("aria-hidden","true"),c.style.display="inline-block";for(let u of f)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,f=s+(1-l);return f<=s?e>=s?1:0:Math.min(1,Math.max(0,(e-s)/(f-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:f="ease-out",from:c={opacity:0,y:24},trigger:u={},once:h=true,onComplete:L}=r,_=window.matchMedia("(prefers-reduced-motion: reduce)").matches,E=typeof f=="function"?f:ie[f]??ie["ease-out"],Q=ae(u.start??"top 85%"),he=ae(u.end??"top 40%"),H=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let ee;l==="chars"?ee=_t(t):l==="lines"?ee=Tt(t):ee=Mt(t);let te=ee.length;function q(g,y){c?.opacity!==void 0&&(g.style.opacity=String(c.opacity+(1-c.opacity)*y));let j=jt(y,c);j&&(g.style.transform=j);}function x(g){t.style.setProperty("--scroll-draw-progress",String(g)),ee.forEach((y,j)=>{let Ae=E(Gt(g,j,te,s));q(y,Ae);});}if(_)return x(1),L?.(),{destroy(){t.innerHTML=H,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};x(0);let A=0,w=0,b=0,P=false,O=false,G=-1,$=0,I=false,M=()=>window.scrollY,V=()=>window.innerHeight;function ne(){let g=t.getBoundingClientRect(),y=pe({top:g.top,height:g.height},M(),V(),Q,he);A=y.tStart,w=y.tEnd;}function N(){if(!P||O)return;let g=K(M(),A,w,1);h&&(G=Math.max(G,g),g=G),$=g,x(g),g>=1&&!I?(I=true,L?.()):g<1&&!h&&(I=false),b=requestAnimationFrame(N);}ne();let B=new IntersectionObserver(g=>{g.forEach(y=>{P=y.isIntersecting,P&&!O?b=requestAnimationFrame(N):cancelAnimationFrame(b);});}),d;function C(){clearTimeout(d),d=setTimeout(()=>{if(l==="lines"){let g=$;t.innerHTML=H,t.setAttribute("aria-label",t.textContent??""),ee=Tt(t),x(g);}ne();},150);}return window.addEventListener("resize",C),window.addEventListener("orientationchange",C),B.observe(t),Pe(t,{type:"text",getProgress:()=>$,getTrigger:()=>({tStart:A,tEnd:w})}),{destroy(){cancelAnimationFrame(b),B.disconnect(),window.removeEventListener("resize",C),window.removeEventListener("orientationchange",C),clearTimeout(d),t.innerHTML=H,t.removeAttribute("aria-label"),Oe(t);},replay(){G=-1,I=false,$=0,O=false,x(0);},pause(){O=true,cancelAnimationFrame(b);},resume(){O&&(O=false,P&&(b=requestAnimationFrame(N)));},seek(g){let y=Math.min(1,Math.max(0,g));$=y,G=y,O=true,cancelAnimationFrame(b),x(y);},getProgress(){return $}}}function Xt(e={}){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=Qe(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var st=vue.defineComponent({name:"ScrollDraw",props:{selector:{type:String},speed:{type:Number},fade:{type:Boolean},stagger:{type:Number},easing:{type:[String,Function]},direction:{type:String},trigger:{type:Object},onProgress:{type:Function},onStart:{type:Function},onComplete:{type:Function},once:{type:Boolean},debug:{type:Boolean}},setup(e,{slots:r}){let n=vue.ref(null);return vue.onMounted(()=>{if(!n.value)return;let t={};e.selector!=null&&(t.selector=e.selector),e.speed!=null&&(t.speed=e.speed),e.fade!=null&&(t.fade=e.fade),e.stagger!=null&&(t.stagger=e.stagger),e.easing!=null&&(t.easing=e.easing),e.direction!=null&&(t.direction=e.direction),e.trigger!=null&&(t.trigger=e.trigger),e.once!=null&&(t.once=e.once),e.debug!=null&&(t.debug=e.debug),e.onProgress!=null&&(t.onProgress=e.onProgress),e.onStart!=null&&(t.onStart=e.onStart),e.onComplete!=null&&(t.onComplete=e.onComplete);let l=Qe(n.value,t);vue.onUnmounted(()=>l.destroy());}),()=>vue.h("div",{ref:n},r.default?.())}});function Yt(e){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=et(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var it=vue.defineComponent({name:"ScrollAnimate",props:{options:{type:Object,required:true}},setup(e,{slots:r}){let n=vue.ref(null);return vue.onMounted(()=>{if(!n.value)return;let t=et(n.value,e.options);vue.onUnmounted(()=>t.destroy());}),()=>vue.h("div",{ref:n},r.default?.())}});function Ut(e){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=nt(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var at=vue.defineComponent({name:"ScrollCounter",props:{to:{type:Number,required:true},from:{type:Number},format:{type:Function},easing:{type:[String,Function]},trigger:{type:Object},once:{type:Boolean},decimals:{type:Number},onComplete:{type:Function}},setup(e){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n={to:e.to};e.from!=null&&(n.from=e.from),e.format!=null&&(n.format=e.format),e.easing!=null&&(n.easing=e.easing),e.trigger!=null&&(n.trigger=e.trigger),e.once!=null&&(n.once=e.once),e.decimals!=null&&(n.decimals=e.decimals),e.onComplete!=null&&(n.onComplete=e.onComplete);let t=nt(r.value,n);vue.onUnmounted(()=>t.destroy());}),()=>vue.h("span",{ref:r})}});function Zt(e={}){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=rt(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var lt=vue.defineComponent({name:"ScrollVideo",props:{src:{type:String,required:true},options:{type:Object},muted:{type:Boolean,default:true},playsInline:{type:Boolean,default:true},class:{type:String}},setup(e){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=rt(r.value,e.options??{});vue.onUnmounted(()=>n.destroy());}),()=>vue.h("video",{ref:r,src:e.src,muted:e.muted,playsinline:e.playsInline,preload:"auto",class:e.class})}});function Jt(e={}){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=ot(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var ct=vue.defineComponent({name:"ScrollText",props:{options:{type:Object},tag:{type:String,default:"p"}},setup(e,{slots:r}){let n=vue.ref(null);return vue.onMounted(()=>{if(!n.value)return;let t=ot(n.value,e.options??{});vue.onUnmounted(()=>t.destroy());}),()=>vue.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);}}}exports.ScrollAnimate=it;exports.ScrollCounter=at;exports.ScrollDraw=st;exports.ScrollText=ct;exports.ScrollVideo=lt;exports.createScrollDrawPlugin=An;exports.useScrollAnimate=Yt;exports.useScrollCounter=Ut;exports.useScrollDraw=Xt;exports.useScrollText=Jt;exports.useScrollVideo=Zt;
|
|
1
|
+
'use strict';var vue=require('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
|
+
<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 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=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=Qe(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var st=vue.defineComponent({name:"ScrollDraw",props:{selector:{type:String},speed:{type:Number},fade:{type:Boolean},stagger:{type:Number},easing:{type:[String,Function]},direction:{type:String},trigger:{type:Object},onProgress:{type:Function},onStart:{type:Function},onComplete:{type:Function},once:{type:Boolean},debug:{type:Boolean}},setup(e,{slots:r}){let n=vue.ref(null);return vue.onMounted(()=>{if(!n.value)return;let t={};e.selector!=null&&(t.selector=e.selector),e.speed!=null&&(t.speed=e.speed),e.fade!=null&&(t.fade=e.fade),e.stagger!=null&&(t.stagger=e.stagger),e.easing!=null&&(t.easing=e.easing),e.direction!=null&&(t.direction=e.direction),e.trigger!=null&&(t.trigger=e.trigger),e.once!=null&&(t.once=e.once),e.debug!=null&&(t.debug=e.debug),e.onProgress!=null&&(t.onProgress=e.onProgress),e.onStart!=null&&(t.onStart=e.onStart),e.onComplete!=null&&(t.onComplete=e.onComplete);let l=Qe(n.value,t);vue.onUnmounted(()=>l.destroy());}),()=>vue.h("div",{ref:n},r.default?.())}});function Yt(e){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=et(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var it=vue.defineComponent({name:"ScrollAnimate",props:{options:{type:Object,required:true}},setup(e,{slots:r}){let n=vue.ref(null);return vue.onMounted(()=>{if(!n.value)return;let t=et(n.value,e.options);vue.onUnmounted(()=>t.destroy());}),()=>vue.h("div",{ref:n},r.default?.())}});function Ut(e){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=nt(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var at=vue.defineComponent({name:"ScrollCounter",props:{to:{type:Number,required:true},from:{type:Number},format:{type:Function},easing:{type:[String,Function]},trigger:{type:Object},once:{type:Boolean},decimals:{type:Number},onComplete:{type:Function}},setup(e){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n={to:e.to};e.from!=null&&(n.from=e.from),e.format!=null&&(n.format=e.format),e.easing!=null&&(n.easing=e.easing),e.trigger!=null&&(n.trigger=e.trigger),e.once!=null&&(n.once=e.once),e.decimals!=null&&(n.decimals=e.decimals),e.onComplete!=null&&(n.onComplete=e.onComplete);let t=nt(r.value,n);vue.onUnmounted(()=>t.destroy());}),()=>vue.h("span",{ref:r})}});function Zt(e={}){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=rt(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var lt=vue.defineComponent({name:"ScrollVideo",props:{src:{type:String,required:true},options:{type:Object},muted:{type:Boolean,default:true},playsInline:{type:Boolean,default:true},class:{type:String}},setup(e){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=rt(r.value,e.options??{});vue.onUnmounted(()=>n.destroy());}),()=>vue.h("video",{ref:r,src:e.src,muted:e.muted,playsinline:e.playsInline,preload:"auto",class:e.class})}});function Jt(e={}){let r=vue.ref(null);return vue.onMounted(()=>{if(!r.value)return;let n=ot(r.value,e);vue.onUnmounted(()=>n.destroy());}),r}var ct=vue.defineComponent({name:"ScrollText",props:{options:{type:Object},tag:{type:String,default:"p"}},setup(e,{slots:r}){let n=vue.ref(null);return vue.onMounted(()=>{if(!n.value)return;let t=ot(n.value,e.options??{});vue.onUnmounted(()=>t.destroy());}),()=>vue.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);}}}exports.ScrollAnimate=it;exports.ScrollCounter=at;exports.ScrollDraw=st;exports.ScrollText=ct;exports.ScrollVideo=lt;exports.createScrollDrawPlugin=An;exports.useScrollAnimate=Yt;exports.useScrollCounter=Ut;exports.useScrollDraw=Xt;exports.useScrollText=Jt;exports.useScrollVideo=Zt;
|
package/dist/nuxt/index.d.mts
CHANGED
|
@@ -126,6 +126,12 @@ interface ScrollAnimateOptions {
|
|
|
126
126
|
axis?: 'x' | 'y';
|
|
127
127
|
scrollContainer?: string | Element;
|
|
128
128
|
native?: boolean;
|
|
129
|
+
/**
|
|
130
|
+
* Scale animation speed by scroll velocity — faster scrolling = faster animation.
|
|
131
|
+
* Pass `true` for default sensitivity (1) or a number to control it.
|
|
132
|
+
* Higher values = more dramatic speed-up. Default sensitivity: 1.
|
|
133
|
+
*/
|
|
134
|
+
velocityScale?: boolean | number;
|
|
129
135
|
onProgress?: (alpha: number) => void;
|
|
130
136
|
onComplete?: () => void;
|
|
131
137
|
/** Fires when scroll enters the trigger zone (scrolling forward). */
|
package/dist/nuxt/index.d.ts
CHANGED
|
@@ -126,6 +126,12 @@ interface ScrollAnimateOptions {
|
|
|
126
126
|
axis?: 'x' | 'y';
|
|
127
127
|
scrollContainer?: string | Element;
|
|
128
128
|
native?: boolean;
|
|
129
|
+
/**
|
|
130
|
+
* Scale animation speed by scroll velocity — faster scrolling = faster animation.
|
|
131
|
+
* Pass `true` for default sensitivity (1) or a number to control it.
|
|
132
|
+
* Higher values = more dramatic speed-up. Default sensitivity: 1.
|
|
133
|
+
*/
|
|
134
|
+
velocityScale?: boolean | number;
|
|
129
135
|
onProgress?: (alpha: number) => void;
|
|
130
136
|
onComplete?: () => void;
|
|
131
137
|
/** Fires when scroll enters the trigger zone (scrolling forward). */
|
package/dist/nuxt/index.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
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,
|
|
2
|
-
<div style="position:absolute;${u?`left:${
|
|
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 f=parseFloat(s),c=t[l++]??f;return String(+(f+(c-f)*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:f="path, polyline, line, polygon, rect, circle",speed:c=1,fade:u=false,easing:h="linear",trigger:L={},stagger:_=0,direction:E="forward",once:Q=false,debug:he=false,axis:H="y",scrollContainer:ee,autoReverse:te=false,delay:q=0,strokeColor:x,strokeWidth:A,fillOpacity:w,waypoints:b,velocityScale:P=false,threshold:O=0,rootMargin:G="0px",repeat:$=0,repeatDelay:I=0,morphTo:M,clip:V,autoplay:ne=false,duration:N=1e3,native:B=true,onProgress:d,onStart:C,onComplete:g,onEnter:y,onLeave:j,onEnterBack:Ae,onLeaveBack:be}=l,we=V===true?"left":typeof V=="string"?V:false,de=typeof h=="function"?h:ie[h]??ie.linear,He=ae(L.start??"top bottom"),De=ae(L.end??"bottom top"),U=typeof ee=="string"?document.querySelector(ee):ee??null,i=Array.isArray(x)?x[0]:null,p=Array.isArray(x)?x[1]:typeof x=="string"?x:null,X=Array.isArray(A)?A[0]:null,R=Array.isArray(A)?A[1]:typeof A=="number"?A:null,Z=Array.isArray(w)?w[0]:null,oe=Array.isArray(w)?w[1]:typeof w=="number"?w:null;function J(o){let a=o*100;switch(we){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 W=we?[]:Array.from(e.querySelectorAll(f)),k=[],me=[],ge=0,Ce=0,se=false,ye=false,re=0,Be=false,ve=-1,We=-1,le=false,ke=0,Me=0,Le,Ue=null,$e=new Set,_e=-1,ut=performance.now(),Ie=NaN;function Ve(){return U?H==="x"?U.scrollLeft:U.scrollTop:H==="x"?window.scrollX:window.scrollY}function mt(){return U?H==="x"?U.clientWidth:U.clientHeight:H==="x"?window.innerWidth:window.innerHeight}function ft(){let o=e.getBoundingClientRect(),a,S,Y;if(U){let ue=U.getBoundingClientRect();a=H==="x"?o.left-ue.left+U.scrollLeft:o.top-ue.top+U.scrollTop,S=H==="x"?o.width:o.height,Y=Ve();}else a=H==="x"?o.left:o.top,S=H==="x"?o.width:o.height,Y=Ve();let ce=pe({top:a,height:S},Y,mt(),He,De);ge=ce.tStart,Ce=ce.tEnd,he&&process.env.NODE_ENV!=="production"&&(Ue?.remove(),Ue=Rt(ge,Ce,H));}function Ct(o,a){if(e.style.setProperty("--scroll-draw-progress",String(o)),we){let S=a==="reverse"?1-o:o;e.style.clipPath=J(S);return}W.forEach((S,Y)=>{S.style.strokeDashoffset=a==="reverse"?`${k[Y]*o}`:`${k[Y]*(1-o)}`,u&&(S.style.opacity=a==="reverse"?`${1-o}`:`${o}`),i&&p?S.style.stroke=Re(i,p,o):p&&(S.style.stroke=p),X!==null&&R!==null?S.style.strokeWidth=`${X+(R-X)*o}`:R!==null&&(S.style.strokeWidth=`${R}`),Z!==null&&oe!==null?S.style.fillOpacity=`${Z+(oe-Z)*o}`:oe!==null&&(S.style.fillOpacity=`${oe}`),M&&S.tagName.toLowerCase()==="path"&&me[Y]&&S.setAttribute("d",Ke(me[Y],M,o));});}function Ge(){if(e.style.setProperty("--scroll-draw-progress","0"),we){e.style.clipPath=J(0);return}W.forEach((o,a)=>{o.style.strokeDasharray=`${k[a]}`,o.style.strokeDashoffset=E==="reverse"?"0":`${k[a]}`,u?o.style.opacity=E==="reverse"?"1":"0":o.style.opacity="",i&&(o.style.stroke=i),X!==null&&(o.style.strokeWidth=`${X}`),Z!==null&&(o.style.fillOpacity=`${Z}`),M&&o.tagName.toLowerCase()==="path"&&me[a]&&o.setAttribute("d",me[a]);});}if(W.forEach(o=>{Nt(o);let a=Ye(o);k.push(a),o.tagName.toLowerCase()==="path"?me.push(o.getAttribute("d")??""):me.push(""),s?(o.style.strokeDasharray=`${a}`,o.style.strokeDashoffset=E==="reverse"?`${a}`:"0",u&&(o.style.opacity="1"),p&&(o.style.stroke=p),R!==null&&(o.style.strokeWidth=`${R}`),oe!==null&&(o.style.fillOpacity=`${oe}`),M&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",M)):(o.style.strokeDasharray=`${a}`,o.style.strokeDashoffset=E==="reverse"?"0":`${a}`,u?o.style.opacity=E==="reverse"?"1":"0":o.style.opacity="",i&&(o.style.stroke=i),X!==null&&(o.style.strokeWidth=`${X}`),Z!==null&&(o.style.fillOpacity=`${Z}`));}),we){if(s)return e.style.clipPath=J(1),g?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=J(0);}else if(s)return g?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Lt(){return !(B===false||!It()||!W.length||typeof h!="string"||!(h in bt)||we||H!=="y"||U||c!==1||_!==0||Q||te||P!==false||M||b||$||q>0||d||C||g||y||j||Ae||be||x!=null||A!=null||w!=null||(L.start??"top bottom").trim()!=="top bottom"||(L.end??"bottom top").trim()!=="bottom top")}function $t(){let o=`svg-scroll-draw-${++Dt}`,a=E==="reverse"?"0":"var(--ssd-len)",S=E==="reverse"?"var(--ssd-len)":"0",Y=`stroke-dashoffset:${a};`,ce=`stroke-dashoffset:${S};`;u&&(Y+=`opacity:${E==="reverse"?1:0};`,ce+=`opacity:${E==="reverse"?0:1};`);let ue=document.createElement("style");ue.setAttribute("data-svg-scroll-draw",""),ue.textContent=`@keyframes ${o}{from{${Y}}to{${ce}}}.${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(ue);function fe(m,T){m.style.setProperty("--ssd-len",String(k[T])),m.style.strokeDasharray=`${k[T]}`,m.style.strokeDashoffset="",m.style.opacity="",m.style.animationPlayState="",m.classList.add(o);}W.forEach(fe);let v=false,F=-1;function D(){if(F>=0)return F;let m=e.getBoundingClientRect(),{tStart:T,tEnd:z}=pe({top:m.top,height:m.height},Ve(),mt(),He,De);return de(K(Ve(),T,z,c))}return {destroy(){W.forEach(m=>{m.classList.remove(o),m.style.removeProperty("--ssd-len"),m.style.animationPlayState="";}),ue.remove();},replay(){v=false,F=-1,W.forEach(fe);},pause(){v=true,W.forEach(m=>{m.style.animationPlayState="paused";});},resume(){v&&(v=false,W.forEach(m=>{m.style.animationPlayState="running";}));},seek(m){let T=Math.min(1,Math.max(0,m));F=T,v=true,W.forEach((z,Fe)=>{z.classList.remove(o),z.style.strokeDashoffset=E==="reverse"?`${k[Fe]*T}`:`${k[Fe]*(1-T)}`,u&&(z.style.opacity=E==="reverse"?`${1-T}`:`${T}`);});},getProgress(){return D()}}}if(Lt())return $t();function Pt(){let o=Math.max(1,N),a=0,S=0;function Y(D){let m=true;if(we){let T=Math.min(1,Math.max(0,D/o)),z=de(T);ke=z,e.style.setProperty("--scroll-draw-progress",String(z)),e.style.clipPath=J(E==="reverse"?1-z:z),d?.(z),T<1&&(m=false);}else W.forEach((T,z)=>{let Fe=z*_*o,Ne=Math.min(1,Math.max(0,(D-Fe)/o)),Se=de(Ne);T.style.strokeDashoffset=E==="reverse"?`${k[z]*Se}`:`${k[z]*(1-Se)}`,u&&(T.style.opacity=E==="reverse"?`${1-Se}`:`${Se}`),i&&p?T.style.stroke=Re(i,p,Se):p&&(T.style.stroke=p),X!==null&&R!==null?T.style.strokeWidth=`${X+(R-X)*Se}`:R!==null&&(T.style.strokeWidth=`${R}`),Z!==null&&oe!==null?T.style.fillOpacity=`${Z+(oe-Z)*Se}`:oe!==null&&(T.style.fillOpacity=`${oe}`),M&&T.tagName.toLowerCase()==="path"&&me[z]&&T.setAttribute("d",Ke(me[z],M,Se)),z===0&&(d?.(Se),e.style.setProperty("--scroll-draw-progress",String(Se))),Ne<1&&(m=false);});if(b){let T=Math.min(1,Math.max(0,D/o)),z=de(T);for(let Fe in b){let Ne=parseFloat(Fe);z>=Ne&&!$e.has(Ne)&&($e.add(Ne),b[Fe]?.());}}return m}function ce(D){if(le)return;let m=D-a;ye||(ye=true,C?.());let T=Y(m);if(T&&!se){se=true,Y(o*(1+Math.max(0,W.length-1)*_)),g?.(),Me<($==="infinite"?1/0:$??0)&&(Me++,Le=setTimeout(()=>{a=performance.now(),ye=false,se=false,$e.clear(),Ge(),re=requestAnimationFrame(ce);},I));return}T||(re=requestAnimationFrame(ce));}function ue(){cancelAnimationFrame(re),clearTimeout(Le),a=performance.now(),S=0,le=false,ye=false,se=false,Me=0,$e.clear(),Ge(),re=requestAnimationFrame(ce);}let fe=new IntersectionObserver(D=>{D.forEach(m=>{m.isIntersecting&&!(Q&&se)?ue():!m.isIntersecting&&!Q&&!se&&(cancelAnimationFrame(re),clearTimeout(Le),a=null);});},{root:U??null,threshold:O,rootMargin:G}),v;function F(){clearTimeout(v),v=setTimeout(()=>{W.forEach((D,m)=>{k[m]=Ye(D),D.style.strokeDasharray=`${k[m]}`;});},150);}return window.addEventListener("resize",F),window.addEventListener("orientationchange",F),q>0?setTimeout(()=>fe.observe(e),q):fe.observe(e),{destroy(){cancelAnimationFrame(re),clearTimeout(Le),fe.disconnect(),window.removeEventListener("resize",F),window.removeEventListener("orientationchange",F),clearTimeout(v);},replay(){Me=0,ue();},pause(){le||(le=true,S=performance.now()-a,cancelAnimationFrame(re));},resume(){le&&(le=false,a=performance.now()-S,re=requestAnimationFrame(ce));},seek(D){let m=Math.min(1,Math.max(0,D));ke=m,le=true,S=m*o,a=performance.now()-S,cancelAnimationFrame(re),Y(S);},getProgress(){return ke}}}if(ne)return Pt();ft();function je(){if(!Be||le)return;let o=performance.now(),a=Ve(),S=c;if(P!==false){let v=o-ut,F=v>0?Math.abs(a-(_e<0?a:_e))/v:0;S=c*Math.max(.2,1+F*(typeof P=="number"?P:1)*.04);}_e=a,ut=o;let Y=te?We===-1||a>=We?"forward":"reverse":E;We=a;let ce=Ce-ge,ue=true,fe=ce===0?0:(a-ge)/ce;if(isNaN(Ie)||(Ie<=0&&fe>0?y?.():Ie>0&&fe<=0&&be?.(),Ie<1&&fe>=1?j?.():Ie>=1&&fe<1&&Ae?.()),Ie=fe,we){let v=de(K(a,ge,Ce,S));Q&&!te&&(ve=Math.max(ve,v),v=ve),ke=v,e.style.setProperty("--scroll-draw-progress",String(v));let F=Y==="reverse"?1-v:v;e.style.clipPath=J(F),d?.(v),!ye&&K(a,ge,Ce,S)>0&&(ye=true,C?.()),v>=1&&!se?(se=true,g?.(),Me<($==="infinite"?1/0:$??0)&&(Me++,Le=setTimeout(()=>{ve=-1,ye=false,se=false,e.style.clipPath=J(0);},I))):v<1&&!Q&&(se=false),re=requestAnimationFrame(je);return}if(W.forEach((v,F)=>{let D=F*_*ce,m=de(K(a,ge+D,Ce+D,S));Q&&!te&&(ve=Math.max(ve,m),m=ve),ke=m,v.style.strokeDashoffset=Y==="reverse"?`${k[F]*m}`:`${k[F]*(1-m)}`,u&&(v.style.opacity=Y==="reverse"?`${1-m}`:`${m}`),i&&p?v.style.stroke=Re(i,p,m):p&&(v.style.stroke=p),X!==null&&R!==null?v.style.strokeWidth=`${X+(R-X)*m}`:R!==null&&(v.style.strokeWidth=`${R}`),Z!==null&&oe!==null?v.style.fillOpacity=`${Z+(oe-Z)*m}`:oe!==null&&(v.style.fillOpacity=`${oe}`),M&&v.tagName.toLowerCase()==="path"&&me[F]&&v.setAttribute("d",Ke(me[F],M,m)),F===0&&(d?.(m),e.style.setProperty("--scroll-draw-progress",String(m))),m<1&&(ue=false);}),b){let v=de(K(a,ge,Ce,S));for(let F in b){let D=parseFloat(F);v>=D&&!$e.has(D)&&($e.add(D),b[F]?.());}}!ye&&K(a,ge,Ce,S)>0&&(ye=true,C?.()),ue&&!se?(se=true,g?.(),Me<($==="infinite"?1/0:$??0)&&(Me++,Le=setTimeout(()=>{ve=-1,ye=false,se=false,$e.clear(),Ge();},I))):!ue&&!Q&&(se=false),re=requestAnimationFrame(je);}let Ze=new IntersectionObserver(o=>{o.forEach(a=>{Be=a.isIntersecting,Be&&!le?re=requestAnimationFrame(je):cancelAnimationFrame(re);});},{root:U??null,threshold:O,rootMargin:G}),Je;function Xe(){clearTimeout(Je),Je=setTimeout(()=>{W.forEach((o,a)=>{k[a]=Ye(o),o.style.strokeDasharray=`${k[a]}`;}),ft();},150);}return window.addEventListener("resize",Xe),window.addEventListener("orientationchange",Xe),q>0?setTimeout(()=>Ze.observe(e),q):Ze.observe(e),{destroy(){cancelAnimationFrame(re),clearTimeout(Le),Ze.disconnect(),window.removeEventListener("resize",Xe),window.removeEventListener("orientationchange",Xe),clearTimeout(Je),Ue?.remove();},replay(){ve=-1,We=-1,_e=-1,ye=false,se=false,Me=0,le=false,$e.clear(),clearTimeout(Le),Ge();},pause(){le=true,cancelAnimationFrame(re);},resume(){le&&(le=false,Be&&(re=requestAnimationFrame(je)));},seek(o){let a=Math.min(1,Math.max(0,o));ke=a,ve=a,le=true,cancelAnimationFrame(re),Ct(a,E);},getProgress(){return ke}}}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=[],f=t[2].trim();if(f)for(let c of f.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,f)=>{let c=l[f];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.]+)(.*)$/),f=l.match(/^([-+]?[\d.]+)(.*)$/);if(s&&f){let c=parseFloat(s[1]),u=parseFloat(f[1]);return `${c+(u-c)*n}${s[2]||f[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:f=1,once:c=false,axis:u="y",scrollContainer:h,native:L=true,onProgress:_,onComplete:E,onEnter:Q,onLeave:he,onEnterBack:H,onLeaveBack:ee}=r,te=window.matchMedia("(prefers-reduced-motion: reduce)").matches,q=typeof s=="function"?s:ie[s]??ie["ease-out"],x=ae(l.start??"top bottom"),A=ae(l.end??"bottom top"),w=typeof h=="string"?document.querySelector(h):h??null,b=Object.entries(t).map(([i,p])=>({prop:zt(i),from:Array.isArray(p)?p[0]:"",to:Array.isArray(p)?p[1]:p}));function P(){let i=window.getComputedStyle(e);for(let p of b)p.from===""&&(p.from=i.getPropertyValue(p.prop).trim()||"0");}function O(){for(let i of b)e.style.setProperty(i.prop,String(i.to));}if(te)return O(),E?.(),n;P();function G(){if(!L||!Wt()||typeof s!="string"||!(s in Et)||u!=="y"||w||c||f!==1||_||E||Q||he||H||ee||(l.start??"top bottom").trim()!=="top bottom"||(l.end??"bottom top").trim()!=="bottom top")return false;for(let i of b)if(!qt.has(i.prop))return false;return true}function $(){let i=`ssd-a-${++Bt}`,p=b.map(J=>`${J.prop}:${J.from}`).join(";"),X=b.map(J=>`${J.prop}:${J.to}`).join(";"),R=document.createElement("style");R.setAttribute("data-ssd-animate",""),R.textContent=`@keyframes ${i}{from{${p}}to{${X}}}.${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(R),e.classList.add(i);let Z=()=>u==="x"?window.scrollX:window.scrollY,oe=()=>u==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(i),R.remove();},replay(){e.classList.remove(i),e.offsetWidth,e.classList.add(i);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(J){let W=Math.min(1,Math.max(0,J));e.classList.remove(i);for(let k of b)e.style.setProperty(k.prop,St(k.from,k.to,W));},getProgress(){let J=e.getBoundingClientRect(),W=Z(),k=oe(),{tStart:me,tEnd:ge}=pe({top:J.top,height:J.height},W,k,x,A);return q(K(W,me,ge,f))}}}if(G())return $();let I=0,M=0,V=0,ne=false,N=false,B=-1,d=0,C=false,g=NaN,y=()=>w?u==="x"?w.scrollLeft:w.scrollTop:u==="x"?window.scrollX:window.scrollY,j=()=>w?u==="x"?w.clientWidth:w.clientHeight:u==="x"?window.innerWidth:window.innerHeight;function Ae(){let i=e.getBoundingClientRect(),p,X;if(w){let Z=w.getBoundingClientRect();p=u==="x"?i.left-Z.left+w.scrollLeft:i.top-Z.top+w.scrollTop,X=u==="x"?i.width:i.height;}else p=u==="x"?i.left:i.top,X=u==="x"?i.width:i.height;let R=pe({top:p,height:X},y(),j(),x,A);I=R.tStart,M=R.tEnd;}function be(i){e.style.setProperty("--scroll-draw-progress",String(i));for(let p of b)e.style.setProperty(p.prop,St(p.from,p.to,i));_?.(i);}function we(i){if(isNaN(g)){g=i;return}g<=0&&i>0?Q?.():g>0&&i<=0&&ee?.(),g<1&&i>=1?he?.():g>=1&&i<1&&H?.(),g=i;}function de(){if(!ne||N)return;let i=M===I?0:(y()-I)/(M-I);we(i);let p=q(K(y(),I,M,f));c&&(B=Math.max(B,p),p=B),d=p,be(p),p>=1&&!C?(C=true,E?.()):p<1&&!c&&(C=false),V=requestAnimationFrame(de);}Ae();{let i=q(K(y(),I,M,f));c&&i>0&&(B=i),d=i,be(i);}let He=new IntersectionObserver(i=>{i.forEach(p=>{ne=p.isIntersecting,ne&&!N?V=requestAnimationFrame(de):cancelAnimationFrame(V);});},{root:w??null}),De;function U(){clearTimeout(De),De=setTimeout(Ae,150);}return window.addEventListener("resize",U),window.addEventListener("orientationchange",U),He.observe(e),Pe(e,{type:"animate",getProgress:()=>d,getTrigger:()=>({tStart:I,tEnd:M})}),{destroy(){cancelAnimationFrame(V),He.disconnect(),window.removeEventListener("resize",U),window.removeEventListener("orientationchange",U),clearTimeout(De),Oe(e);},replay(){B=-1,C=false,d=0,N=false,be(0);},pause(){N=true,cancelAnimationFrame(V);},resume(){N&&(N=false,ne&&(V=requestAnimationFrame(de)));},seek(i){let p=Math.min(1,Math.max(0,i));d=p,B=p,N=true,cancelAnimationFrame(V),be(p);},getProgress(){return d}}}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:f,easing:c="ease-out",trigger:u={},once:h=true,decimals:L,onComplete:_}=r,E=L!==void 0?d=>d.toFixed(L):f??(d=>String(Math.round(d))),Q=typeof c=="function"?c:ie[c]??ie["ease-out"],he=ae(u.start??"top 80%"),H=ae(u.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=E(s),_?.(),tt;t.textContent=E(l);let te=0,q=0,x=0,A=false,w=false,b=-1,P=0,O=false,G=()=>window.scrollY,$=()=>window.innerHeight;function I(){let d=t.getBoundingClientRect(),C=pe({top:d.top,height:d.height},G(),$(),he,H);te=C.tStart,q=C.tEnd;}function M(d){t.textContent=E(l+(s-l)*d),t.style.setProperty("--scroll-draw-progress",String(d));}function V(){if(!A||w)return;let d=Q(K(G(),te,q,1));h&&(b=Math.max(b,d),d=b),P=d,M(d),d>=1&&!O?(O=true,_?.()):d<1&&!h&&(O=false),x=requestAnimationFrame(V);}I();{let d=Q(K(G(),te,q,1));h&&d>0&&(b=d),P=d,M(d);}let ne=new IntersectionObserver(d=>{d.forEach(C=>{A=C.isIntersecting,A&&!w?x=requestAnimationFrame(V):cancelAnimationFrame(x);});}),N;function B(){clearTimeout(N),N=setTimeout(I,150);}return window.addEventListener("resize",B),window.addEventListener("orientationchange",B),ne.observe(t),Pe(t,{type:"counter",getProgress:()=>P,getTrigger:()=>({tStart:te,tEnd:q})}),{destroy(){cancelAnimationFrame(x),ne.disconnect(),window.removeEventListener("resize",B),window.removeEventListener("orientationchange",B),clearTimeout(N),Oe(t);},replay(){b=-1,O=false,P=0,w=false,M(0);},pause(){w=true,cancelAnimationFrame(x);},resume(){w&&(w=false,A&&(x=requestAnimationFrame(V)));},seek(d){let C=Math.min(1,Math.max(0,d));P=C,b=C,w=true,cancelAnimationFrame(x),M(C);},getProgress(){return P}}}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:f=false,axis:c="y",preload:u="auto",onReady:h,onComplete:L,onProgress:_}=r,E=window.matchMedia("(prefers-reduced-motion: reduce)").matches,Q=typeof s=="function"?s:ie[s]??ie.linear,he=ae(l.start??"top top"),H=ae(l.end??"bottom top");t.pause(),t.hasAttribute("preload")||(t.preload=u);let ee=r.from??0,te=r.to,q=0,x=0,A=0,w=false,b=false,P=-1,O=0,G=false,$=false,I=()=>c==="x"?window.scrollX:window.scrollY,M=()=>c==="x"?window.innerWidth:window.innerHeight;function V(){let y=t.getBoundingClientRect(),j=c==="x"?y.left:y.top,Ae=c==="x"?y.width:y.height,be=pe({top:j,height:Ae},I(),M(),he,H);q=be.tStart,x=be.tEnd;}function ne(y){if(!$)return;let j=te??t.duration??0;t.currentTime=ee+(j-ee)*y,t.style.setProperty("--scroll-draw-progress",String(y)),_?.(y);}function N(){if(!w||b||!$)return;let y=Q(K(I(),q,x,1));f&&(P=Math.max(P,y),y=P),O=y,ne(y),y>=1&&!G?(G=true,L?.()):y<1&&!f&&(G=false),A=requestAnimationFrame(N);}function B(){if($=true,te===void 0&&(te=t.duration),E){ne(1),h?.();return}V(),h?.(),w&&!b&&(A=requestAnimationFrame(N));}t.readyState>=1?B():t.addEventListener("loadedmetadata",B,{once:true}),$||V();let d=new IntersectionObserver(y=>{y.forEach(j=>{w=j.isIntersecting,w&&!b&&$?A=requestAnimationFrame(N):cancelAnimationFrame(A);});}),C;function g(){clearTimeout(C),C=setTimeout(V,150);}return window.addEventListener("resize",g),window.addEventListener("orientationchange",g),d.observe(t),Pe(t,{type:"video",getProgress:()=>O,getTrigger:()=>({tStart:q,tEnd:x})}),{destroy(){cancelAnimationFrame(A),d.disconnect(),t.removeEventListener("loadedmetadata",B),window.removeEventListener("resize",g),window.removeEventListener("orientationchange",g),clearTimeout(C),Oe(t);},replay(){P=-1,G=false,O=0,b=false,ne(0);},pause(){b=true,cancelAnimationFrame(A);},resume(){b&&(b=false,w&&$&&(A=requestAnimationFrame(N)));},seek(y){let j=Math.min(1,Math.max(0,y));O=j,P=j,b=true,cancelAnimationFrame(A),ne(j);},getProgress(){return O}}}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 f=s.offsetTop;n.has(f)||n.set(f,[]),n.get(f).push(s);}let t=[],l=Array.from(n.keys()).sort((s,f)=>s-f);for(let s of l){let f=n.get(s),c=document.createElement("span");c.setAttribute("aria-hidden","true"),c.style.display="inline-block";for(let u of f)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,f=s+(1-l);return f<=s?e>=s?1:0:Math.min(1,Math.max(0,(e-s)/(f-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:f="ease-out",from:c={opacity:0,y:24},trigger:u={},once:h=true,onComplete:L}=r,_=window.matchMedia("(prefers-reduced-motion: reduce)").matches,E=typeof f=="function"?f:ie[f]??ie["ease-out"],Q=ae(u.start??"top 85%"),he=ae(u.end??"top 40%"),H=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let ee;l==="chars"?ee=_t(t):l==="lines"?ee=Tt(t):ee=Mt(t);let te=ee.length;function q(g,y){c?.opacity!==void 0&&(g.style.opacity=String(c.opacity+(1-c.opacity)*y));let j=jt(y,c);j&&(g.style.transform=j);}function x(g){t.style.setProperty("--scroll-draw-progress",String(g)),ee.forEach((y,j)=>{let Ae=E(Gt(g,j,te,s));q(y,Ae);});}if(_)return x(1),L?.(),{destroy(){t.innerHTML=H,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};x(0);let A=0,w=0,b=0,P=false,O=false,G=-1,$=0,I=false,M=()=>window.scrollY,V=()=>window.innerHeight;function ne(){let g=t.getBoundingClientRect(),y=pe({top:g.top,height:g.height},M(),V(),Q,he);A=y.tStart,w=y.tEnd;}function N(){if(!P||O)return;let g=K(M(),A,w,1);h&&(G=Math.max(G,g),g=G),$=g,x(g),g>=1&&!I?(I=true,L?.()):g<1&&!h&&(I=false),b=requestAnimationFrame(N);}ne();let B=new IntersectionObserver(g=>{g.forEach(y=>{P=y.isIntersecting,P&&!O?b=requestAnimationFrame(N):cancelAnimationFrame(b);});}),d;function C(){clearTimeout(d),d=setTimeout(()=>{if(l==="lines"){let g=$;t.innerHTML=H,t.setAttribute("aria-label",t.textContent??""),ee=Tt(t),x(g);}ne();},150);}return window.addEventListener("resize",C),window.addEventListener("orientationchange",C),B.observe(t),Pe(t,{type:"text",getProgress:()=>$,getTrigger:()=>({tStart:A,tEnd:w})}),{destroy(){cancelAnimationFrame(b),B.disconnect(),window.removeEventListener("resize",C),window.removeEventListener("orientationchange",C),clearTimeout(d),t.innerHTML=H,t.removeAttribute("aria-label"),Oe(t);},replay(){G=-1,I=false,$=0,O=false,x(0);},pause(){O=true,cancelAnimationFrame(b);},resume(){O&&(O=false,P&&(b=requestAnimationFrame(N)));},seek(g){let y=Math.min(1,Math.max(0,g));$=y,G=y,O=true,cancelAnimationFrame(b),x(y);},getProgress(){return $}}}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};
|
|
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
|
+
<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 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};
|
package/dist/pin/index.cjs
CHANGED
|
@@ -1 +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,
|
|
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;
|