svg-scroll-draw 2.6.0 → 2.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/angular/index.cjs +3 -3
- package/dist/angular/index.d.mts +22 -0
- package/dist/angular/index.d.ts +22 -0
- package/dist/angular/index.mjs +3 -3
- package/dist/astro/index.cjs +3 -3
- package/dist/astro/index.d.mts +8 -0
- package/dist/astro/index.d.ts +8 -0
- package/dist/astro/index.mjs +3 -3
- package/dist/cdn/svg-scroll-draw.global.js +3 -3
- package/dist/devtools/index.cjs +1 -1
- package/dist/devtools/index.mjs +1 -1
- package/dist/group/index.cjs +3 -3
- package/dist/group/index.d.mts +22 -0
- package/dist/group/index.d.ts +22 -0
- package/dist/group/index.mjs +3 -3
- package/dist/horizontal/index.cjs +1 -0
- package/dist/horizontal/index.d.mts +61 -0
- package/dist/horizontal/index.d.ts +61 -0
- package/dist/horizontal/index.mjs +1 -0
- package/dist/index.cjs +4 -4
- package/dist/index.d.mts +22 -0
- package/dist/index.d.ts +22 -0
- package/dist/index.mjs +4 -4
- package/dist/lenis/index.cjs +1 -0
- package/dist/lenis/index.d.mts +51 -0
- package/dist/lenis/index.d.ts +51 -0
- package/dist/lenis/index.mjs +1 -0
- package/dist/nuxt/index.cjs +2 -2
- package/dist/nuxt/index.d.mts +22 -0
- package/dist/nuxt/index.d.ts +22 -0
- package/dist/nuxt/index.mjs +2 -2
- package/dist/pin/index.cjs +1 -0
- package/dist/pin/index.d.mts +29 -0
- package/dist/pin/index.d.ts +29 -0
- package/dist/pin/index.mjs +1 -0
- package/dist/progress/index.cjs +1 -0
- package/dist/progress/index.d.mts +59 -0
- package/dist/progress/index.d.ts +59 -0
- package/dist/progress/index.mjs +1 -0
- package/dist/react/index.cjs +3 -3
- package/dist/react/index.d.mts +22 -0
- package/dist/react/index.d.ts +22 -0
- package/dist/react/index.mjs +3 -3
- package/dist/reveal/index.cjs +1 -0
- package/dist/reveal/index.d.mts +80 -0
- package/dist/reveal/index.d.ts +80 -0
- package/dist/reveal/index.mjs +1 -0
- package/dist/snap/index.cjs +1 -0
- package/dist/snap/index.d.mts +30 -0
- package/dist/snap/index.d.ts +30 -0
- package/dist/snap/index.mjs +1 -0
- package/dist/solid/index.cjs +3 -3
- package/dist/solid/index.d.mts +22 -0
- package/dist/solid/index.d.ts +22 -0
- package/dist/solid/index.mjs +3 -3
- package/dist/svelte/index.cjs +3 -3
- package/dist/svelte/index.d.mts +22 -0
- package/dist/svelte/index.d.ts +22 -0
- package/dist/svelte/index.mjs +3 -3
- package/dist/vue/index.cjs +2 -2
- package/dist/vue/index.d.mts +22 -0
- package/dist/vue/index.d.ts +22 -0
- package/dist/vue/index.mjs +2 -2
- package/dist/web-component/index.cjs +3 -3
- package/dist/web-component/index.mjs +3 -3
- package/package.json +31 -1
package/dist/astro/index.d.mts
CHANGED
|
@@ -71,6 +71,14 @@ interface ScrollDrawOptions {
|
|
|
71
71
|
onProgress?: (alpha: number) => void;
|
|
72
72
|
onStart?: () => void;
|
|
73
73
|
onComplete?: () => void;
|
|
74
|
+
/** Fires when scroll position enters the trigger zone (scrolling forward). */
|
|
75
|
+
onEnter?: () => void;
|
|
76
|
+
/** Fires when scroll position exits the trigger zone at the end (scrolling forward). */
|
|
77
|
+
onLeave?: () => void;
|
|
78
|
+
/** Fires when scroll position re-enters the trigger zone from the end (scrolling back). */
|
|
79
|
+
onEnterBack?: () => void;
|
|
80
|
+
/** Fires when scroll position exits the trigger zone at the start (scrolling back). */
|
|
81
|
+
onLeaveBack?: () => void;
|
|
74
82
|
/**
|
|
75
83
|
* Trigger the animation when the element enters the viewport instead of
|
|
76
84
|
* tying it to scroll position. The draw runs over `duration` milliseconds,
|
package/dist/astro/index.d.ts
CHANGED
|
@@ -71,6 +71,14 @@ interface ScrollDrawOptions {
|
|
|
71
71
|
onProgress?: (alpha: number) => void;
|
|
72
72
|
onStart?: () => void;
|
|
73
73
|
onComplete?: () => void;
|
|
74
|
+
/** Fires when scroll position enters the trigger zone (scrolling forward). */
|
|
75
|
+
onEnter?: () => void;
|
|
76
|
+
/** Fires when scroll position exits the trigger zone at the end (scrolling forward). */
|
|
77
|
+
onLeave?: () => void;
|
|
78
|
+
/** Fires when scroll position re-enters the trigger zone from the end (scrolling back). */
|
|
79
|
+
onEnterBack?: () => void;
|
|
80
|
+
/** Fires when scroll position exits the trigger zone at the start (scrolling back). */
|
|
81
|
+
onLeaveBack?: () => void;
|
|
74
82
|
/**
|
|
75
83
|
* Trigger the animation when the element enters the viewport instead of
|
|
76
84
|
* tying it to scroll position. The draw runs over `duration` milliseconds,
|
package/dist/astro/index.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
function
|
|
2
|
-
<div style="position:absolute;${
|
|
3
|
-
<div style="position:absolute;${l?`left:${u}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${u}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(t),window.addEventListener("scroll",c,{passive:true}),c(),t}function Be(e,n,r){let t=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),c=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,s=>{let m=parseFloat(s),u=t[c++]??m;return String(+(m+(u-m)*r).toFixed(4))})}function qe(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...t}=n,c=r?{..._e[r],...t}:t,s=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:m="path, polyline, line, polygon, rect, circle",speed:u=1,fade:l=false,easing:d="linear",trigger:T={},stagger:Y=0,direction:b="forward",once:re=false,debug:we=false,axis:q="y",scrollContainer:ne,autoReverse:A=false,delay:N=0,strokeColor:M,strokeWidth:B,fillOpacity:O,waypoints:$,velocityScale:D=false,threshold:H=0,rootMargin:R="0px",repeat:I=0,repeatDelay:z=0,morphTo:E,clip:U,autoplay:ce=false,duration:ie=1e3,native:pe=true,onProgress:f,onStart:P,onComplete:h}=c,x=U===true?"left":typeof U=="string"?U:false,Z=typeof d=="function"?d:le[d]??le.linear,be=me(T.start??"top bottom"),a=me(T.end??"bottom top"),p=typeof ne=="string"?document.querySelector(ne):ne??null,K=Array.isArray(M)?M[0]:null,k=Array.isArray(M)?M[1]:typeof M=="string"?M:null,G=Array.isArray(B)?B[0]:null,Q=Array.isArray(B)?B[1]:typeof B=="number"?B:null,C=Array.isArray(O)?O[0]:null,V=Array.isArray(O)?O[1]:typeof O=="number"?O:null;function ae(o){let i=o*100;switch(x){case "right":return `inset(0 0 0 ${100-i}%)`;case "top":return `inset(0 0 ${100-i}% 0)`;case "bottom":return `inset(${100-i}% 0 0 0)`;case "center":return `circle(${o*150}% at 50% 50%)`;default:return `inset(0 ${100-i}% 0 0)`}}let X=x?[]:Array.from(e.querySelectorAll(m)),W=[],de=[],ve=0,Ee=0,te=false,fe=false,J=0,Oe=false,ge=-1,De=-1,oe=false,Ae=0,Se=0,xe,ze=null,Te=new Set,Ie=-1,Ye=performance.now();function ke(){return p?q==="x"?p.scrollLeft:p.scrollTop:q==="x"?window.scrollX:window.scrollY}function Xe(){return p?q==="x"?p.clientWidth:p.clientHeight:q==="x"?window.innerWidth:window.innerHeight}function Je(){let o=e.getBoundingClientRect(),i,w,_;if(p){let se=p.getBoundingClientRect();i=q==="x"?o.left-se.left+p.scrollLeft:o.top-se.top+p.scrollTop,w=q==="x"?o.width:o.height,_=ke();}else i=q==="x"?o.left:o.top,w=q==="x"?o.width:o.height,_=ke();let ue=he({top:i,height:w},_,Xe(),be,a);ve=ue.tStart,Ee=ue.tEnd,we&&process.env.NODE_ENV!=="production"&&(ze?.remove(),ze=St(ve,Ee,q));}function pt(o,i){if(e.style.setProperty("--scroll-draw-progress",String(o)),x){let w=i==="reverse"?1-o:o;e.style.clipPath=ae(w);return}X.forEach((w,_)=>{w.style.strokeDashoffset=i==="reverse"?`${W[_]*o}`:`${W[_]*(1-o)}`,l&&(w.style.opacity=i==="reverse"?`${1-o}`:`${o}`),K&&k?w.style.stroke=Ce(K,k,o):k&&(w.style.stroke=k),G!==null&&Q!==null?w.style.strokeWidth=`${G+(Q-G)*o}`:Q!==null&&(w.style.strokeWidth=`${Q}`),C!==null&&V!==null?w.style.fillOpacity=`${C+(V-C)*o}`:V!==null&&(w.style.fillOpacity=`${V}`),E&&w.tagName.toLowerCase()==="path"&&de[_]&&w.setAttribute("d",Be(de[_],E,o));});}function Fe(){if(e.style.setProperty("--scroll-draw-progress","0"),x){e.style.clipPath=ae(0);return}X.forEach((o,i)=>{o.style.strokeDasharray=`${W[i]}`,o.style.strokeDashoffset=b==="reverse"?"0":`${W[i]}`,l?o.style.opacity=b==="reverse"?"1":"0":o.style.opacity="",K&&(o.style.stroke=K),G!==null&&(o.style.strokeWidth=`${G}`),C!==null&&(o.style.fillOpacity=`${C}`),E&&o.tagName.toLowerCase()==="path"&&de[i]&&o.setAttribute("d",de[i]);});}if(X.forEach(o=>{bt(o);let i=Re(o);W.push(i),o.tagName.toLowerCase()==="path"?de.push(o.getAttribute("d")??""):de.push(""),s?(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=b==="reverse"?`${i}`:"0",l&&(o.style.opacity="1"),k&&(o.style.stroke=k),Q!==null&&(o.style.strokeWidth=`${Q}`),V!==null&&(o.style.fillOpacity=`${V}`),E&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",E)):(o.style.strokeDasharray=`${i}`,o.style.strokeDashoffset=b==="reverse"?"0":`${i}`,l?o.style.opacity=b==="reverse"?"1":"0":o.style.opacity="",K&&(o.style.stroke=K),G!==null&&(o.style.strokeWidth=`${G}`),C!==null&&(o.style.fillOpacity=`${C}`));}),x){if(s)return e.style.clipPath=ae(1),h?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ae(0);}else if(s)return h?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function ft(){return !(pe===false||!wt()||!X.length||typeof d!="string"||!(d in rt)||x||q!=="y"||p||u!==1||Y!==0||re||A||D!==false||E||$||I||N>0||f||P||h||M!=null||B!=null||O!=null||(T.start??"top bottom").trim()!=="top bottom"||(T.end??"bottom top").trim()!=="bottom top")}function dt(){let o=`svg-scroll-draw-${++ht}`,i=b==="reverse"?"0":"var(--ssd-len)",w=b==="reverse"?"var(--ssd-len)":"0",_=`stroke-dashoffset:${i};`,ue=`stroke-dashoffset:${w};`;l&&(_+=`opacity:${b==="reverse"?1:0};`,ue+=`opacity:${b==="reverse"?0:1};`);let se=document.createElement("style");se.setAttribute("data-svg-scroll-draw",""),se.textContent=`@keyframes ${o}{from{${_}}to{${ue}}}.${o}{animation-name:${o};animation-duration:auto;animation-timing-function:${rt[d]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(se);function y(g,v){g.style.setProperty("--ssd-len",String(W[v])),g.style.strokeDasharray=`${W[v]}`,g.style.strokeDashoffset="",g.style.opacity="",g.style.animationPlayState="",g.classList.add(o);}X.forEach(y);let L=false,j=-1;function S(){if(j>=0)return j;let g=e.getBoundingClientRect(),{tStart:v,tEnd:F}=he({top:g.top,height:g.height},ke(),Xe(),be,a);return Z(ee(ke(),v,F,u))}return {destroy(){X.forEach(g=>{g.classList.remove(o),g.style.removeProperty("--ssd-len"),g.style.animationPlayState="";}),se.remove();},replay(){L=false,j=-1,X.forEach(y);},pause(){L=true,X.forEach(g=>{g.style.animationPlayState="paused";});},resume(){L&&(L=false,X.forEach(g=>{g.style.animationPlayState="running";}));},seek(g){let v=Math.min(1,Math.max(0,g));j=v,L=true,X.forEach((F,Me)=>{F.classList.remove(o),F.style.strokeDashoffset=b==="reverse"?`${W[Me]*v}`:`${W[Me]*(1-v)}`,l&&(F.style.opacity=b==="reverse"?`${1-v}`:`${v}`);});},getProgress(){return S()}}}if(ft())return dt();function gt(){let o=Math.max(1,ie),i=0,w=0;function _(S){let g=true;if(x){let v=Math.min(1,Math.max(0,S/o)),F=Z(v);Ae=F,e.style.setProperty("--scroll-draw-progress",String(F)),e.style.clipPath=ae(b==="reverse"?1-F:F),f?.(F),v<1&&(g=false);}else X.forEach((v,F)=>{let Me=F*Y*o,$e=Math.min(1,Math.max(0,(S-Me)/o)),ye=Z($e);v.style.strokeDashoffset=b==="reverse"?`${W[F]*ye}`:`${W[F]*(1-ye)}`,l&&(v.style.opacity=b==="reverse"?`${1-ye}`:`${ye}`),K&&k?v.style.stroke=Ce(K,k,ye):k&&(v.style.stroke=k),G!==null&&Q!==null?v.style.strokeWidth=`${G+(Q-G)*ye}`:Q!==null&&(v.style.strokeWidth=`${Q}`),C!==null&&V!==null?v.style.fillOpacity=`${C+(V-C)*ye}`:V!==null&&(v.style.fillOpacity=`${V}`),E&&v.tagName.toLowerCase()==="path"&&de[F]&&v.setAttribute("d",Be(de[F],E,ye)),F===0&&(f?.(ye),e.style.setProperty("--scroll-draw-progress",String(ye))),$e<1&&(g=false);});if($){let v=Math.min(1,Math.max(0,S/o)),F=Z(v);for(let Me in $){let $e=parseFloat(Me);F>=$e&&!Te.has($e)&&(Te.add($e),$[Me]?.());}}return g}function ue(S){if(oe)return;let g=S-i;fe||(fe=true,P?.());let v=_(g);if(v&&!te){te=true,_(o*(1+Math.max(0,X.length-1)*Y)),h?.(),Se<(I==="infinite"?1/0:I??0)&&(Se++,xe=setTimeout(()=>{i=performance.now(),fe=false,te=false,Te.clear(),Fe(),J=requestAnimationFrame(ue);},z));return}v||(J=requestAnimationFrame(ue));}function se(){cancelAnimationFrame(J),clearTimeout(xe),i=performance.now(),w=0,oe=false,fe=false,te=false,Se=0,Te.clear(),Fe(),J=requestAnimationFrame(ue);}let y=new IntersectionObserver(S=>{S.forEach(g=>{g.isIntersecting&&!(re&&te)?se():!g.isIntersecting&&!re&&!te&&(cancelAnimationFrame(J),clearTimeout(xe),i=null);});},{root:p??null,threshold:H,rootMargin:R}),L;function j(){clearTimeout(L),L=setTimeout(()=>{X.forEach((S,g)=>{W[g]=Re(S),S.style.strokeDasharray=`${W[g]}`;});},150);}return window.addEventListener("resize",j),window.addEventListener("orientationchange",j),N>0?setTimeout(()=>y.observe(e),N):y.observe(e),{destroy(){cancelAnimationFrame(J),clearTimeout(xe),y.disconnect(),window.removeEventListener("resize",j),window.removeEventListener("orientationchange",j),clearTimeout(L);},replay(){Se=0,se();},pause(){oe||(oe=true,w=performance.now()-i,cancelAnimationFrame(J));},resume(){oe&&(oe=false,i=performance.now()-w,J=requestAnimationFrame(ue));},seek(S){let g=Math.min(1,Math.max(0,S));Ae=g,oe=true,w=g*o,i=performance.now()-w,cancelAnimationFrame(J),_(w);},getProgress(){return Ae}}}if(ce)return gt();Je();function Ne(){if(!Oe||oe)return;let o=performance.now(),i=ke(),w=u;if(D!==false){let y=o-Ye,L=y>0?Math.abs(i-(Ie<0?i:Ie))/y:0;w=u*Math.max(.2,1+L*(typeof D=="number"?D:1)*.04);}Ie=i,Ye=o;let _=A?De===-1||i>=De?"forward":"reverse":b;De=i;let ue=Ee-ve,se=true;if(x){let y=Z(ee(i,ve,Ee,w));re&&!A&&(ge=Math.max(ge,y),y=ge),Ae=y,e.style.setProperty("--scroll-draw-progress",String(y));let L=_==="reverse"?1-y:y;e.style.clipPath=ae(L),f?.(y),!fe&&ee(i,ve,Ee,w)>0&&(fe=true,P?.()),y>=1&&!te?(te=true,h?.(),Se<(I==="infinite"?1/0:I??0)&&(Se++,xe=setTimeout(()=>{ge=-1,fe=false,te=false,e.style.clipPath=ae(0);},z))):y<1&&!re&&(te=false),J=requestAnimationFrame(Ne);return}if(X.forEach((y,L)=>{let j=L*Y*ue,S=Z(ee(i,ve+j,Ee+j,w));re&&!A&&(ge=Math.max(ge,S),S=ge),Ae=S,y.style.strokeDashoffset=_==="reverse"?`${W[L]*S}`:`${W[L]*(1-S)}`,l&&(y.style.opacity=_==="reverse"?`${1-S}`:`${S}`),K&&k?y.style.stroke=Ce(K,k,S):k&&(y.style.stroke=k),G!==null&&Q!==null?y.style.strokeWidth=`${G+(Q-G)*S}`:Q!==null&&(y.style.strokeWidth=`${Q}`),C!==null&&V!==null?y.style.fillOpacity=`${C+(V-C)*S}`:V!==null&&(y.style.fillOpacity=`${V}`),E&&y.tagName.toLowerCase()==="path"&&de[L]&&y.setAttribute("d",Be(de[L],E,S)),L===0&&(f?.(S),e.style.setProperty("--scroll-draw-progress",String(S))),S<1&&(se=false);}),$){let y=Z(ee(i,ve,Ee,w));for(let L in $){let j=parseFloat(L);y>=j&&!Te.has(j)&&(Te.add(j),$[L]?.());}}!fe&&ee(i,ve,Ee,w)>0&&(fe=true,P?.()),se&&!te?(te=true,h?.(),Se<(I==="infinite"?1/0:I??0)&&(Se++,xe=setTimeout(()=>{ge=-1,fe=false,te=false,Te.clear(),Fe();},z))):!se&&!re&&(te=false),J=requestAnimationFrame(Ne);}let Ve=new IntersectionObserver(o=>{o.forEach(i=>{Oe=i.isIntersecting,Oe&&!oe?J=requestAnimationFrame(Ne):cancelAnimationFrame(J);});},{root:p??null,threshold:H,rootMargin:R}),We;function He(){clearTimeout(We),We=setTimeout(()=>{X.forEach((o,i)=>{W[i]=Re(o),o.style.strokeDasharray=`${W[i]}`;}),Je();},150);}return window.addEventListener("resize",He),window.addEventListener("orientationchange",He),N>0?setTimeout(()=>Ve.observe(e),N):Ve.observe(e),{destroy(){cancelAnimationFrame(J),clearTimeout(xe),Ve.disconnect(),window.removeEventListener("resize",He),window.removeEventListener("orientationchange",He),clearTimeout(We),ze?.remove();},replay(){ge=-1,De=-1,Ie=-1,fe=false,te=false,Se=0,oe=false,Te.clear(),clearTimeout(xe),Fe();},pause(){oe=true,cancelAnimationFrame(J);},resume(){oe&&(oe=false,Oe&&(J=requestAnimationFrame(Ne)));},seek(o){let i=Math.min(1,Math.max(0,o));Ae=i,ge=i,oe=true,cancelAnimationFrame(J),pt(i,b);},getProgress(){return Ae}}}var nt=new Map;function Pe(e,n){nt.set(e,n);}function Le(e){nt.delete(e);}function vt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function ot(e){let n=[],r=/([\w]+)\(([^)]*)\)/g,t;for(;(t=r.exec(e))!==null;){let c=[],s=[],m=t[2].trim();if(m)for(let u of m.split(/[\s,]+/)){let l=u.match(/^([-+]?[\d.eE]+)(.*)$/);c.push(l?parseFloat(l[1]):0),s.push(l?l[2]:"");}n.push({fn:t[1],nums:c,units:s});}return n}function Et(e,n,r){let t=ot(e),c=ot(n);return t.length===0||t.length!==c.length?r<1?e:n:t.map((s,m)=>{let u=c[m];return s.fn!==u.fn||s.nums.length!==u.nums.length?r<1?`${s.fn}(${s.nums.map((l,d)=>`${l}${s.units[d]}`).join(", ")})`:`${u.fn}(${u.nums.map((l,d)=>`${l}${u.units[d]}`).join(", ")})`:`${s.fn}(${s.nums.map((l,d)=>`${l+(u.nums[d]-l)*r}${s.units[d]}`).join(", ")})`}).join(" ")}function st(e,n,r){if(typeof e=="number"&&typeof n=="number")return String(e+(n-e)*r);let t=String(e),c=String(n);if(vt(t))return Ce(t,c,r);if(t.includes("("))return Et(t,c,r);let s=t.match(/^([-+]?[\d.]+)(.*)$/),m=c.match(/^([-+]?[\d.]+)(.*)$/);if(s&&m){let u=parseFloat(s[1]),l=parseFloat(m[1]);return `${u+(l-u)*r}${s[2]||m[2]}`}return r<1?t:c}function xt(e){return e.replace(/([A-Z])/g,n=>`-${n.toLowerCase()}`)}var it={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Tt=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),At=0;function Mt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function at(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let{props:t,trigger:c={},easing:s="ease-out",speed:m=1,once:u=false,axis:l="y",scrollContainer:d,native:T=true,onProgress:Y,onComplete:b}=n,re=window.matchMedia("(prefers-reduced-motion: reduce)").matches,we=typeof s=="function"?s:le[s]??le["ease-out"],q=me(c.start??"top bottom"),ne=me(c.end??"bottom top"),A=typeof d=="string"?document.querySelector(d):d??null,N=Object.entries(t).map(([a,p])=>({prop:xt(a),from:Array.isArray(p)?p[0]:"",to:Array.isArray(p)?p[1]:p}));function M(){let a=window.getComputedStyle(e);for(let p of N)p.from===""&&(p.from=a.getPropertyValue(p.prop).trim()||"0");}function B(){for(let a of N)e.style.setProperty(a.prop,String(a.to));}if(re)return B(),b?.(),r;M();function O(){if(!T||!Mt()||typeof s!="string"||!(s in it)||l!=="y"||A||u||m!==1||Y||b||(c.start??"top bottom").trim()!=="top bottom"||(c.end??"bottom top").trim()!=="bottom top")return false;for(let a of N)if(!Tt.has(a.prop))return false;return true}function $(){let a=`ssd-a-${++At}`,p=N.map(C=>`${C.prop}:${C.from}`).join(";"),K=N.map(C=>`${C.prop}:${C.to}`).join(";"),k=document.createElement("style");k.setAttribute("data-ssd-animate",""),k.textContent=`@keyframes ${a}{from{${p}}to{${K}}}.${a}{animation-name:${a};animation-duration:auto;animation-timing-function:${it[s]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(k),e.classList.add(a);let G=()=>l==="x"?window.scrollX:window.scrollY,Q=()=>l==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(a),k.remove();},replay(){e.classList.remove(a),e.offsetWidth,e.classList.add(a);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(C){let V=Math.min(1,Math.max(0,C));e.classList.remove(a);for(let ae of N)e.style.setProperty(ae.prop,st(ae.from,ae.to,V));},getProgress(){let C=e.getBoundingClientRect(),V=G(),ae=Q(),{tStart:X,tEnd:W}=he({top:C.top,height:C.height},V,ae,q,ne);return we(ee(V,X,W,m))}}}if(O())return $();let D=0,H=0,R=0,I=false,z=false,E=-1,U=0,ce=false,ie=()=>A?l==="x"?A.scrollLeft:A.scrollTop:l==="x"?window.scrollX:window.scrollY,pe=()=>A?l==="x"?A.clientWidth:A.clientHeight:l==="x"?window.innerWidth:window.innerHeight;function f(){let a=e.getBoundingClientRect(),p,K;if(A){let G=A.getBoundingClientRect();p=l==="x"?a.left-G.left+A.scrollLeft:a.top-G.top+A.scrollTop,K=l==="x"?a.width:a.height;}else p=l==="x"?a.left:a.top,K=l==="x"?a.width:a.height;let k=he({top:p,height:K},ie(),pe(),q,ne);D=k.tStart,H=k.tEnd;}function P(a){e.style.setProperty("--scroll-draw-progress",String(a));for(let p of N)e.style.setProperty(p.prop,st(p.from,p.to,a));Y?.(a);}function h(){if(!I||z)return;let a=we(ee(ie(),D,H,m));u&&(E=Math.max(E,a),a=E),U=a,P(a),a>=1&&!ce?(ce=true,b?.()):a<1&&!u&&(ce=false),R=requestAnimationFrame(h);}f();{let a=we(ee(ie(),D,H,m));u&&a>0&&(E=a),U=a,P(a);}let x=new IntersectionObserver(a=>{a.forEach(p=>{I=p.isIntersecting,I&&!z?R=requestAnimationFrame(h):cancelAnimationFrame(R);});},{root:A??null}),Z;function be(){clearTimeout(Z),Z=setTimeout(f,150);}return window.addEventListener("resize",be),window.addEventListener("orientationchange",be),x.observe(e),Pe(e,{type:"animate",getProgress:()=>U,getTrigger:()=>({tStart:D,tEnd:H})}),{destroy(){cancelAnimationFrame(R),x.disconnect(),window.removeEventListener("resize",be),window.removeEventListener("orientationchange",be),clearTimeout(Z),Le(e);},replay(){E=-1,ce=false,U=0,z=false,P(0);},pause(){z=true,cancelAnimationFrame(R);},resume(){z&&(z=false,I&&(R=requestAnimationFrame(h)));},seek(a){let p=Math.min(1,Math.max(0,a));U=p,E=p,z=true,cancelAnimationFrame(R),P(p);},getProgress(){return U}}}var Ge={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function je(e,n){if(typeof window>"u")return Ge;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollCounter: element not found:",e),Ge;let t=r,{from:c=0,to:s,format:m,easing:u="ease-out",trigger:l={},once:d=true,decimals:T,onComplete:Y}=n,b=T!==void 0?f=>f.toFixed(T):m??(f=>String(Math.round(f))),re=typeof u=="function"?u:le[u]??le["ease-out"],we=me(l.start??"top 80%"),q=me(l.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=b(s),Y?.(),Ge;t.textContent=b(c);let A=0,N=0,M=0,B=false,O=false,$=-1,D=0,H=false,R=()=>window.scrollY,I=()=>window.innerHeight;function z(){let f=t.getBoundingClientRect(),P=he({top:f.top,height:f.height},R(),I(),we,q);A=P.tStart,N=P.tEnd;}function E(f){t.textContent=b(c+(s-c)*f),t.style.setProperty("--scroll-draw-progress",String(f));}function U(){if(!B||O)return;let f=re(ee(R(),A,N,1));d&&($=Math.max($,f),f=$),D=f,E(f),f>=1&&!H?(H=true,Y?.()):f<1&&!d&&(H=false),M=requestAnimationFrame(U);}z();{let f=re(ee(R(),A,N,1));d&&f>0&&($=f),D=f,E(f);}let ce=new IntersectionObserver(f=>{f.forEach(P=>{B=P.isIntersecting,B&&!O?M=requestAnimationFrame(U):cancelAnimationFrame(M);});}),ie;function pe(){clearTimeout(ie),ie=setTimeout(z,150);}return window.addEventListener("resize",pe),window.addEventListener("orientationchange",pe),ce.observe(t),Pe(t,{type:"counter",getProgress:()=>D,getTrigger:()=>({tStart:A,tEnd:N})}),{destroy(){cancelAnimationFrame(M),ce.disconnect(),window.removeEventListener("resize",pe),window.removeEventListener("orientationchange",pe),clearTimeout(ie),Le(t);},replay(){$=-1,H=false,D=0,O=false,E(0);},pause(){O=true,cancelAnimationFrame(M);},resume(){O&&(O=false,B&&(M=requestAnimationFrame(U)));},seek(f){let P=Math.min(1,Math.max(0,f));D=P,$=P,O=true,cancelAnimationFrame(M),E(P);},getProgress(){return D}}}function ut(e){let n=e.textContent??"";return e.textContent="",n.split(/(\s+)/).filter(Boolean).map(r=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),/^\s+$/.test(r)?(t.textContent=r,t.style.whiteSpace="pre"):(t.textContent=r,t.style.display="inline-block"),e.appendChild(t),/^\s+$/.test(r)?null:t}).filter(r=>r!==null)}function $t(e){let n=e.textContent??"";return e.textContent="",n.split("").map(r=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),t.textContent=r,r===" "?t.style.whiteSpace="pre":t.style.display="inline-block",e.appendChild(t),r===" "?null:t}).filter(r=>r!==null)}function lt(e){let n=ut(e),r=new Map;for(let s of n){let m=s.offsetTop;r.has(m)||r.set(m,[]),r.get(m).push(s);}let t=[],c=Array.from(r.keys()).sort((s,m)=>s-m);for(let s of c){let m=r.get(s),u=document.createElement("span");u.setAttribute("aria-hidden","true"),u.style.display="inline-block";for(let l of m)u.appendChild(l);t.push(u);}e.textContent="";for(let s of t)e.appendChild(s),e.appendChild(document.createTextNode(" "));return t}function Ct(e,n,r,t){if(r<=1||t===0)return e;let c=(r-1)*t,s=n*t,m=s+(1-c);return m<=s?e>=s?1:0:Math.min(1,Math.max(0,(e-s)/(m-s)))}function Pt(e,n){let r=[];if(n?.y!==void 0&&r.push(`translateY(${n.y*(1-e)}px)`),n?.x!==void 0&&r.push(`translateX(${n.x*(1-e)}px)`),n?.rotate!==void 0&&r.push(`rotate(${n.rotate*(1-e)}deg)`),n?.scale!==void 0){let t=n.scale+(1-n.scale)*e;r.push(`scale(${t})`);}return r.join(" ")||""}var ct={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function mt(e,n={}){if(typeof window>"u")return ct;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollText: element not found:",e),ct;let t=r,{split:c="words",stagger:s=.04,easing:m="ease-out",from:u={opacity:0,y:24},trigger:l={},once:d=true,onComplete:T}=n,Y=window.matchMedia("(prefers-reduced-motion: reduce)").matches,b=typeof m=="function"?m:le[m]??le["ease-out"],re=me(l.start??"top 85%"),we=me(l.end??"top 40%"),q=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let ne;c==="chars"?ne=$t(t):c==="lines"?ne=lt(t):ne=ut(t);let A=ne.length;function N(h,x){u?.opacity!==void 0&&(h.style.opacity=String(u.opacity+(1-u.opacity)*x));let Z=Pt(x,u);Z&&(h.style.transform=Z);}function M(h){t.style.setProperty("--scroll-draw-progress",String(h)),ne.forEach((x,Z)=>{let be=b(Ct(h,Z,A,s));N(x,be);});}if(Y)return M(1),T?.(),{destroy(){t.innerHTML=q,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};M(0);let B=0,O=0,$=0,D=false,H=false,R=-1,I=0,z=false,E=()=>window.scrollY,U=()=>window.innerHeight;function ce(){let h=t.getBoundingClientRect(),x=he({top:h.top,height:h.height},E(),U(),re,we);B=x.tStart,O=x.tEnd;}function ie(){if(!D||H)return;let h=ee(E(),B,O,1);d&&(R=Math.max(R,h),h=R),I=h,M(h),h>=1&&!z?(z=true,T?.()):h<1&&!d&&(z=false),$=requestAnimationFrame(ie);}ce();let pe=new IntersectionObserver(h=>{h.forEach(x=>{D=x.isIntersecting,D&&!H?$=requestAnimationFrame(ie):cancelAnimationFrame($);});}),f;function P(){clearTimeout(f),f=setTimeout(()=>{if(c==="lines"){let h=I;t.innerHTML=q,t.setAttribute("aria-label",t.textContent??""),ne=lt(t),M(h);}ce();},150);}return window.addEventListener("resize",P),window.addEventListener("orientationchange",P),pe.observe(t),Pe(t,{type:"text",getProgress:()=>I,getTrigger:()=>({tStart:B,tEnd:O})}),{destroy(){cancelAnimationFrame($),pe.disconnect(),window.removeEventListener("resize",P),window.removeEventListener("orientationchange",P),clearTimeout(f),t.innerHTML=q,t.removeAttribute("aria-label"),Le(t);},replay(){R=-1,z=false,I=0,H=false,M(0);},pause(){H=true,cancelAnimationFrame($);},resume(){H&&(H=false,D&&($=requestAnimationFrame(ie)));},seek(h){let x=Math.min(1,Math.max(0,h));I=x,R=x,H=true,cancelAnimationFrame($),M(x);},getProgress(){return I}}}function Lt(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let t=typeof e=="string"?document.querySelector(e):e;return t?qe(t,n):(console.warn("[svg-scroll-draw] Container not found:",e),r)}function kt(e=document){return Array.from(e.querySelectorAll("[data-scroll-draw]")).map(n=>{let r={};try{let t=n.dataset.scrollDrawOptions??n.dataset.scrollDrawoptions??"";t&&(r=JSON.parse(t));}catch{}return qe(n,r)})}function Ot(e=document){return Array.from(e.querySelectorAll("[data-scroll-animate]")).map(n=>{let r={props:{}};try{let t=n.dataset.scrollAnimateOptions??"";t&&(r=JSON.parse(t));}catch{}return at(n,r)})}function Dt(e=document){return Array.from(e.querySelectorAll("[data-scroll-counter]")).map(n=>{let r={};try{let t=n.dataset.scrollCounterOptions??"";t&&(r=JSON.parse(t));}catch{}return !r.to&&r.to!==0&&(process.env.NODE_ENV!=="production"&&console.warn('[svg-scroll-draw] initScrollCounter: element missing "to" in options JSON:',n),r.to=0),je(n,r)})}function It(e=document){return Array.from(e.querySelectorAll("[data-scroll-text]")).map(n=>{let r={};try{let t=n.dataset.scrollTextOptions??"";t&&(r=JSON.parse(t));}catch{}return mt(n,r)})}function fr(e=document){return {draw:kt(e),animate:Ot(e),counter:Dt(e),text:It(e)}}export{fr as initAll,Ot as initScrollAnimate,Dt as initScrollCounter,kt as initScrollDraw,It as initScrollText,Lt as scrollDraw};
|
|
1
|
+
function ot({bounces:e=3,decay:n=.5}={}){let r=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,n)),u=Math.sqrt(t),i=0,p=[];for(let g=0;g<r;g++){let M=Math.pow(u,g);p.push(M),i+=M;}let m=[0],c=0;for(let g=0;g<r;g++)c+=p[g]/i,m.push(c);return g=>{if(g<=0)return 0;if(g>=1)return 1;for(let M=0;M<r;M++)if(g<=m[M+1]){let F=(g-m[M])/(m[M+1]-m[M]);if(M===0)return F*(2-F);let S=1-Math.pow(t,M);return S+(1-S)*(2*F-1)*(2*F-1)}return 1}}function st({amplitude:e=1,period:n=.4}={}){let r=Math.max(1,e),t=Math.max(.1,n),u=r<=1?t/4:t/(2*Math.PI)*Math.asin(1/r);return i=>i<=0?0:i>=1?1:r*Math.pow(2,-10*i)*Math.sin((i-u)*(2*Math.PI)/t)+1}var pe={linear:e=>e,"ease-in":e=>e*e,"ease-out":e=>e*(2-e),"ease-in-out":e=>e<.5?2*e*e:-1+(4-2*e)*e,spring:e=>1-Math.cos(e*Math.PI*2.5)*Math.pow(1-e,2.2),bounce:ot(),elastic:st()};function de(e="top bottom"){let n=e.trim();if(/^\d+(\.\d+)?%$/.test(n))return {element:"top",viewport:n};let[r="top",t="bottom"]=n.split(/\s+/).filter(Boolean);return {element:r,viewport:t}}function tt(e,n,r,t){switch(t){case "top":return e+r;case "center":return e+r+n/2;case "bottom":return e+r+n;default:return e+r}}function rt(e,n){if(/^\d+(\.\d+)?%$/.test(e))return n*(parseFloat(e)/100);switch(e){case "top":return 0;case "center":return n/2;case "bottom":return n;default:return n}}function We(e){let n=e.tagName.toLowerCase();if(n==="rect"){let r=parseFloat(e.getAttribute("width")??"0"),t=parseFloat(e.getAttribute("height")??"0");return 2*(r+t)}if(n==="circle"){let r=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*r}return e.getTotalLength()}function St(e,n,r){return Math.min(r,Math.max(n,e))}function Z(e,n,r,t){return r===n?0:St((e-n)/(r-n)*t,0,1)}function ve(e,n,r,t,u){let i=tt(e.top,e.height,n,t.element)-rt(t.viewport,r),p=tt(e.top,e.height,n,u.element)-rt(u.viewport,r);return {tStart:i,tEnd:p}}function nt(e){let n=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(n)return [parseInt(n[1]+n[1],16),parseInt(n[2]+n[2],16),parseInt(n[3]+n[3],16)];let r=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(r)return [parseInt(r[1],16),parseInt(r[2],16),parseInt(r[3],16)];let t=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return t?[parseInt(t[1]),parseInt(t[2]),parseInt(t[3])]:null}function Oe(e,n,r){let t=nt(e),u=nt(n);return !t||!u?e:`rgb(${Math.round(t[0]+(u[0]-t[0])*r)},${Math.round(t[1]+(u[1]-t[1])*r)},${Math.round(t[2]+(u[2]-t[2])*r)})`}var Xe={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 it(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n);}var at={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Et=0;function xt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Tt(e){let n=e.getAttribute("stroke"),r=e.getAttribute("fill");!n||n==="none"?it("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&&it("Element has a fill \u2014 it may obscure the stroke animation.",e);}function At(e,n,r){let t=document.createElement("div");t.setAttribute("data-svg-scroll-draw-debug",""),t.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function u(){let i=r==="x"?window.scrollX:window.scrollY,p=e-i,m=n-i,c=r==="x";t.innerHTML=`
|
|
2
|
+
<div style="position:absolute;${c?`left:${p}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${p}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
|
|
3
|
+
<div style="position:absolute;${c?`left:${m}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${m}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(t),window.addEventListener("scroll",u,{passive:true}),u(),t}function Je(e,n,r){let t=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),u=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,i=>{let p=parseFloat(i),m=t[u++]??p;return String(+(p+(m-p)*r).toFixed(4))})}function _e(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...t}=n,u=r?{...Xe[r],...t}:t,i=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:p="path, polyline, line, polygon, rect, circle",speed:m=1,fade:c=false,easing:g="linear",trigger:M={},stagger:F=0,direction:S="forward",once:J=false,debug:Ee=false,axis:H="y",scrollContainer:ee,autoReverse:te=false,delay:re=0,strokeColor:x,strokeWidth:R,fillOpacity:D,waypoints:h,velocityScale:C=false,threshold:W=0,rootMargin:ne="0px",repeat:z=0,repeatDelay:ce=0,morphTo:T,clip:U,autoplay:K=false,duration:oe=1e3,native:_=true,onProgress:d,onStart:A,onComplete:b,onEnter:$,onLeave:ge,onEnterBack:Ae,onLeaveBack:Le}=u,ye=U===true?"left":typeof U=="string"?U:false,he=typeof g=="function"?g:pe[g]??pe.linear,Me=de(M.start??"top bottom"),Fe=de(M.end??"bottom top"),G=typeof ee=="string"?document.querySelector(ee):ee??null,ue=Array.isArray(x)?x[0]:null,V=Array.isArray(x)?x[1]:typeof x=="string"?x:null,B=Array.isArray(R)?R[0]:null,s=Array.isArray(R)?R[1]:typeof R=="number"?R:null,f=Array.isArray(D)?D[0]:null,L=Array.isArray(D)?D[1]:typeof D=="number"?D:null;function j(o){let a=o*100;switch(ye){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 E=ye?[]:Array.from(e.querySelectorAll(p)),I=[],P=[],Q=0,se=0,Y=false,me=false,X=0,He=false,be=-1,Re=-1,ie=false,Ce=0,Se=0,xe,Ge=null,Te=new Set,qe=-1,Ke=performance.now(),Pe=NaN;function Ne(){return G?H==="x"?G.scrollLeft:G.scrollTop:H==="x"?window.scrollX:window.scrollY}function Qe(){return G?H==="x"?G.clientWidth:G.clientHeight:H==="x"?window.innerWidth:window.innerHeight}function et(){let o=e.getBoundingClientRect(),a,w,q;if(G){let le=G.getBoundingClientRect();a=H==="x"?o.left-le.left+G.scrollLeft:o.top-le.top+G.scrollTop,w=H==="x"?o.width:o.height,q=Ne();}else a=H==="x"?o.left:o.top,w=H==="x"?o.width:o.height,q=Ne();let ae=ve({top:a,height:w},q,Qe(),Me,Fe);Q=ae.tStart,se=ae.tEnd,Ee&&process.env.NODE_ENV!=="production"&&(Ge?.remove(),Ge=At(Q,se,H));}function ht(o,a){if(e.style.setProperty("--scroll-draw-progress",String(o)),ye){let w=a==="reverse"?1-o:o;e.style.clipPath=j(w);return}E.forEach((w,q)=>{w.style.strokeDashoffset=a==="reverse"?`${I[q]*o}`:`${I[q]*(1-o)}`,c&&(w.style.opacity=a==="reverse"?`${1-o}`:`${o}`),ue&&V?w.style.stroke=Oe(ue,V,o):V&&(w.style.stroke=V),B!==null&&s!==null?w.style.strokeWidth=`${B+(s-B)*o}`:s!==null&&(w.style.strokeWidth=`${s}`),f!==null&&L!==null?w.style.fillOpacity=`${f+(L-f)*o}`:L!==null&&(w.style.fillOpacity=`${L}`),T&&w.tagName.toLowerCase()==="path"&&P[q]&&w.setAttribute("d",Je(P[q],T,o));});}function ze(){if(e.style.setProperty("--scroll-draw-progress","0"),ye){e.style.clipPath=j(0);return}E.forEach((o,a)=>{o.style.strokeDasharray=`${I[a]}`,o.style.strokeDashoffset=S==="reverse"?"0":`${I[a]}`,c?o.style.opacity=S==="reverse"?"1":"0":o.style.opacity="",ue&&(o.style.stroke=ue),B!==null&&(o.style.strokeWidth=`${B}`),f!==null&&(o.style.fillOpacity=`${f}`),T&&o.tagName.toLowerCase()==="path"&&P[a]&&o.setAttribute("d",P[a]);});}if(E.forEach(o=>{Tt(o);let a=We(o);I.push(a),o.tagName.toLowerCase()==="path"?P.push(o.getAttribute("d")??""):P.push(""),i?(o.style.strokeDasharray=`${a}`,o.style.strokeDashoffset=S==="reverse"?`${a}`:"0",c&&(o.style.opacity="1"),V&&(o.style.stroke=V),s!==null&&(o.style.strokeWidth=`${s}`),L!==null&&(o.style.fillOpacity=`${L}`),T&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",T)):(o.style.strokeDasharray=`${a}`,o.style.strokeDashoffset=S==="reverse"?"0":`${a}`,c?o.style.opacity=S==="reverse"?"1":"0":o.style.opacity="",ue&&(o.style.stroke=ue),B!==null&&(o.style.strokeWidth=`${B}`),f!==null&&(o.style.fillOpacity=`${f}`));}),ye){if(i)return e.style.clipPath=j(1),b?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=j(0);}else if(i)return b?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function bt(){return !(_===false||!xt()||!E.length||typeof g!="string"||!(g in at)||ye||H!=="y"||G||m!==1||F!==0||J||te||C!==false||T||h||z||re>0||d||A||b||$||ge||Ae||Le||x!=null||R!=null||D!=null||(M.start??"top bottom").trim()!=="top bottom"||(M.end??"bottom top").trim()!=="bottom top")}function wt(){let o=`svg-scroll-draw-${++Et}`,a=S==="reverse"?"0":"var(--ssd-len)",w=S==="reverse"?"var(--ssd-len)":"0",q=`stroke-dashoffset:${a};`,ae=`stroke-dashoffset:${w};`;c&&(q+=`opacity:${S==="reverse"?1:0};`,ae+=`opacity:${S==="reverse"?0:1};`);let le=document.createElement("style");le.setAttribute("data-svg-scroll-draw",""),le.textContent=`@keyframes ${o}{from{${q}}to{${ae}}}.${o}{animation-name:${o};animation-duration:auto;animation-timing-function:${at[g]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(le);function fe(l,v){l.style.setProperty("--ssd-len",String(I[v])),l.style.strokeDasharray=`${I[v]}`,l.style.strokeDashoffset="",l.style.opacity="",l.style.animationPlayState="",l.classList.add(o);}E.forEach(fe);let y=false,k=-1;function O(){if(k>=0)return k;let l=e.getBoundingClientRect(),{tStart:v,tEnd:N}=ve({top:l.top,height:l.height},Ne(),Qe(),Me,Fe);return he(Z(Ne(),v,N,m))}return {destroy(){E.forEach(l=>{l.classList.remove(o),l.style.removeProperty("--ssd-len"),l.style.animationPlayState="";}),le.remove();},replay(){y=false,k=-1,E.forEach(fe);},pause(){y=true,E.forEach(l=>{l.style.animationPlayState="paused";});},resume(){y&&(y=false,E.forEach(l=>{l.style.animationPlayState="running";}));},seek(l){let v=Math.min(1,Math.max(0,l));k=v,y=true,E.forEach((N,$e)=>{N.classList.remove(o),N.style.strokeDashoffset=S==="reverse"?`${I[$e]*v}`:`${I[$e]*(1-v)}`,c&&(N.style.opacity=S==="reverse"?`${1-v}`:`${v}`);});},getProgress(){return O()}}}if(bt())return wt();function vt(){let o=Math.max(1,oe),a=0,w=0;function q(O){let l=true;if(ye){let v=Math.min(1,Math.max(0,O/o)),N=he(v);Ce=N,e.style.setProperty("--scroll-draw-progress",String(N)),e.style.clipPath=j(S==="reverse"?1-N:N),d?.(N),v<1&&(l=false);}else E.forEach((v,N)=>{let $e=N*F*o,ke=Math.min(1,Math.max(0,(O-$e)/o)),we=he(ke);v.style.strokeDashoffset=S==="reverse"?`${I[N]*we}`:`${I[N]*(1-we)}`,c&&(v.style.opacity=S==="reverse"?`${1-we}`:`${we}`),ue&&V?v.style.stroke=Oe(ue,V,we):V&&(v.style.stroke=V),B!==null&&s!==null?v.style.strokeWidth=`${B+(s-B)*we}`:s!==null&&(v.style.strokeWidth=`${s}`),f!==null&&L!==null?v.style.fillOpacity=`${f+(L-f)*we}`:L!==null&&(v.style.fillOpacity=`${L}`),T&&v.tagName.toLowerCase()==="path"&&P[N]&&v.setAttribute("d",Je(P[N],T,we)),N===0&&(d?.(we),e.style.setProperty("--scroll-draw-progress",String(we))),ke<1&&(l=false);});if(h){let v=Math.min(1,Math.max(0,O/o)),N=he(v);for(let $e in h){let ke=parseFloat($e);N>=ke&&!Te.has(ke)&&(Te.add(ke),h[$e]?.());}}return l}function ae(O){if(ie)return;let l=O-a;me||(me=true,A?.());let v=q(l);if(v&&!Y){Y=true,q(o*(1+Math.max(0,E.length-1)*F)),b?.(),Se<(z==="infinite"?1/0:z??0)&&(Se++,xe=setTimeout(()=>{a=performance.now(),me=false,Y=false,Te.clear(),ze(),X=requestAnimationFrame(ae);},ce));return}v||(X=requestAnimationFrame(ae));}function le(){cancelAnimationFrame(X),clearTimeout(xe),a=performance.now(),w=0,ie=false,me=false,Y=false,Se=0,Te.clear(),ze(),X=requestAnimationFrame(ae);}let fe=new IntersectionObserver(O=>{O.forEach(l=>{l.isIntersecting&&!(J&&Y)?le():!l.isIntersecting&&!J&&!Y&&(cancelAnimationFrame(X),clearTimeout(xe),a=null);});},{root:G??null,threshold:W,rootMargin:ne}),y;function k(){clearTimeout(y),y=setTimeout(()=>{E.forEach((O,l)=>{I[l]=We(O),O.style.strokeDasharray=`${I[l]}`;});},150);}return window.addEventListener("resize",k),window.addEventListener("orientationchange",k),re>0?setTimeout(()=>fe.observe(e),re):fe.observe(e),{destroy(){cancelAnimationFrame(X),clearTimeout(xe),fe.disconnect(),window.removeEventListener("resize",k),window.removeEventListener("orientationchange",k),clearTimeout(y);},replay(){Se=0,le();},pause(){ie||(ie=true,w=performance.now()-a,cancelAnimationFrame(X));},resume(){ie&&(ie=false,a=performance.now()-w,X=requestAnimationFrame(ae));},seek(O){let l=Math.min(1,Math.max(0,O));Ce=l,ie=true,w=l*o,a=performance.now()-w,cancelAnimationFrame(X),q(w);},getProgress(){return Ce}}}if(K)return vt();et();function Ve(){if(!He||ie)return;let o=performance.now(),a=Ne(),w=m;if(C!==false){let y=o-Ke,k=y>0?Math.abs(a-(qe<0?a:qe))/y:0;w=m*Math.max(.2,1+k*(typeof C=="number"?C:1)*.04);}qe=a,Ke=o;let q=te?Re===-1||a>=Re?"forward":"reverse":S;Re=a;let ae=se-Q,le=true,fe=ae===0?0:(a-Q)/ae;if(isNaN(Pe)||(Pe<=0&&fe>0?$?.():Pe>0&&fe<=0&&Le?.(),Pe<1&&fe>=1?ge?.():Pe>=1&&fe<1&&Ae?.()),Pe=fe,ye){let y=he(Z(a,Q,se,w));J&&!te&&(be=Math.max(be,y),y=be),Ce=y,e.style.setProperty("--scroll-draw-progress",String(y));let k=q==="reverse"?1-y:y;e.style.clipPath=j(k),d?.(y),!me&&Z(a,Q,se,w)>0&&(me=true,A?.()),y>=1&&!Y?(Y=true,b?.(),Se<(z==="infinite"?1/0:z??0)&&(Se++,xe=setTimeout(()=>{be=-1,me=false,Y=false,e.style.clipPath=j(0);},ce))):y<1&&!J&&(Y=false),X=requestAnimationFrame(Ve);return}if(E.forEach((y,k)=>{let O=k*F*ae,l=he(Z(a,Q+O,se+O,w));J&&!te&&(be=Math.max(be,l),l=be),Ce=l,y.style.strokeDashoffset=q==="reverse"?`${I[k]*l}`:`${I[k]*(1-l)}`,c&&(y.style.opacity=q==="reverse"?`${1-l}`:`${l}`),ue&&V?y.style.stroke=Oe(ue,V,l):V&&(y.style.stroke=V),B!==null&&s!==null?y.style.strokeWidth=`${B+(s-B)*l}`:s!==null&&(y.style.strokeWidth=`${s}`),f!==null&&L!==null?y.style.fillOpacity=`${f+(L-f)*l}`:L!==null&&(y.style.fillOpacity=`${L}`),T&&y.tagName.toLowerCase()==="path"&&P[k]&&y.setAttribute("d",Je(P[k],T,l)),k===0&&(d?.(l),e.style.setProperty("--scroll-draw-progress",String(l))),l<1&&(le=false);}),h){let y=he(Z(a,Q,se,w));for(let k in h){let O=parseFloat(k);y>=O&&!Te.has(O)&&(Te.add(O),h[k]?.());}}!me&&Z(a,Q,se,w)>0&&(me=true,A?.()),le&&!Y?(Y=true,b?.(),Se<(z==="infinite"?1/0:z??0)&&(Se++,xe=setTimeout(()=>{be=-1,me=false,Y=false,Te.clear(),ze();},ce))):!le&&!J&&(Y=false),X=requestAnimationFrame(Ve);}let je=new IntersectionObserver(o=>{o.forEach(a=>{He=a.isIntersecting,He&&!ie?X=requestAnimationFrame(Ve):cancelAnimationFrame(X);});},{root:G??null,threshold:W,rootMargin:ne}),Ye;function Be(){clearTimeout(Ye),Ye=setTimeout(()=>{E.forEach((o,a)=>{I[a]=We(o),o.style.strokeDasharray=`${I[a]}`;}),et();},150);}return window.addEventListener("resize",Be),window.addEventListener("orientationchange",Be),re>0?setTimeout(()=>je.observe(e),re):je.observe(e),{destroy(){cancelAnimationFrame(X),clearTimeout(xe),je.disconnect(),window.removeEventListener("resize",Be),window.removeEventListener("orientationchange",Be),clearTimeout(Ye),Ge?.remove();},replay(){be=-1,Re=-1,qe=-1,me=false,Y=false,Se=0,ie=false,Te.clear(),clearTimeout(xe),ze();},pause(){ie=true,cancelAnimationFrame(X);},resume(){ie&&(ie=false,He&&(X=requestAnimationFrame(Ve)));},seek(o){let a=Math.min(1,Math.max(0,o));Ce=a,be=a,ie=true,cancelAnimationFrame(X),ht(a,S);},getProgress(){return Ce}}}var lt=new Map;function De(e,n){lt.set(e,n);}function Ie(e){lt.delete(e);}function Mt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function ct(e){let n=[],r=/([\w]+)\(([^)]*)\)/g,t;for(;(t=r.exec(e))!==null;){let u=[],i=[],p=t[2].trim();if(p)for(let m of p.split(/[\s,]+/)){let c=m.match(/^([-+]?[\d.eE]+)(.*)$/);u.push(c?parseFloat(c[1]):0),i.push(c?c[2]:"");}n.push({fn:t[1],nums:u,units:i});}return n}function Ct(e,n,r){let t=ct(e),u=ct(n);return t.length===0||t.length!==u.length?r<1?e:n:t.map((i,p)=>{let m=u[p];return i.fn!==m.fn||i.nums.length!==m.nums.length?r<1?`${i.fn}(${i.nums.map((c,g)=>`${c}${i.units[g]}`).join(", ")})`:`${m.fn}(${m.nums.map((c,g)=>`${c}${m.units[g]}`).join(", ")})`:`${i.fn}(${i.nums.map((c,g)=>`${c+(m.nums[g]-c)*r}${i.units[g]}`).join(", ")})`}).join(" ")}function ut(e,n,r){if(typeof e=="number"&&typeof n=="number")return String(e+(n-e)*r);let t=String(e),u=String(n);if(Mt(t))return Oe(t,u,r);if(t.includes("("))return Ct(t,u,r);let i=t.match(/^([-+]?[\d.]+)(.*)$/),p=u.match(/^([-+]?[\d.]+)(.*)$/);if(i&&p){let m=parseFloat(i[1]),c=parseFloat(p[1]);return `${m+(c-m)*r}${i[2]||p[2]}`}return r<1?t:u}function $t(e){return e.replace(/([A-Z])/g,n=>`-${n.toLowerCase()}`)}var mt={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Lt=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),Pt=0;function kt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function pt(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let{props:t,trigger:u={},easing:i="ease-out",speed:p=1,once:m=false,axis:c="y",scrollContainer:g,native:M=true,velocityScale:F=false,onProgress:S,onComplete:J,onEnter:Ee,onLeave:H,onEnterBack:ee,onLeaveBack:te}=n,re=window.matchMedia("(prefers-reduced-motion: reduce)").matches,x=typeof i=="function"?i:pe[i]??pe["ease-out"],R=de(u.start??"top bottom"),D=de(u.end??"bottom top"),h=typeof g=="string"?document.querySelector(g):g??null,C=Object.entries(t).map(([s,f])=>({prop:$t(s),from:Array.isArray(f)?f[0]:"",to:Array.isArray(f)?f[1]:f}));function W(){let s=window.getComputedStyle(e);for(let f of C)f.from===""&&(f.from=s.getPropertyValue(f.prop).trim()||"0");}function ne(){for(let s of C)e.style.setProperty(s.prop,String(s.to));}if(re)return ne(),J?.(),r;W();function z(){if(!M||!kt()||typeof i!="string"||!(i in mt)||c!=="y"||h||m||p!==1||S||J||Ee||H||ee||te||F!==false||(u.start??"top bottom").trim()!=="top bottom"||(u.end??"bottom top").trim()!=="bottom top")return false;for(let s of C)if(!Lt.has(s.prop))return false;return true}function ce(){let s=`ssd-a-${++Pt}`,f=C.map(P=>`${P.prop}:${P.from}`).join(";"),L=C.map(P=>`${P.prop}:${P.to}`).join(";"),j=document.createElement("style");j.setAttribute("data-ssd-animate",""),j.textContent=`@keyframes ${s}{from{${f}}to{${L}}}.${s}{animation-name:${s};animation-duration:auto;animation-timing-function:${mt[i]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(j),e.classList.add(s);let E=()=>c==="x"?window.scrollX:window.scrollY,I=()=>c==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(s),j.remove();},replay(){e.classList.remove(s),e.offsetWidth,e.classList.add(s);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(P){let Q=Math.min(1,Math.max(0,P));e.classList.remove(s);for(let se of C)e.style.setProperty(se.prop,ut(se.from,se.to,Q));},getProgress(){let P=e.getBoundingClientRect(),Q=E(),se=I(),{tStart:Y,tEnd:me}=ve({top:P.top,height:P.height},Q,se,R,D);return x(Z(Q,Y,me,p))}}}if(z())return ce();let T=0,U=0,K=0,oe=false,_=false,d=-1,A=0,b=false,$=NaN,ge=-1,Ae=0,Le=()=>h?c==="x"?h.scrollLeft:h.scrollTop:c==="x"?window.scrollX:window.scrollY,ye=()=>h?c==="x"?h.clientWidth:h.clientHeight:c==="x"?window.innerWidth:window.innerHeight;function he(){let s=e.getBoundingClientRect(),f,L;if(h){let E=h.getBoundingClientRect();f=c==="x"?s.left-E.left+h.scrollLeft:s.top-E.top+h.scrollTop,L=c==="x"?s.width:s.height;}else f=c==="x"?s.left:s.top,L=c==="x"?s.width:s.height;let j=ve({top:f,height:L},Le(),ye(),R,D);T=j.tStart,U=j.tEnd;}function Me(s){e.style.setProperty("--scroll-draw-progress",String(s));for(let f of C)e.style.setProperty(f.prop,ut(f.from,f.to,s));S?.(s);}function Fe(s){if(isNaN($)){$=s;return}$<=0&&s>0?Ee?.():$>0&&s<=0&&te?.(),$<1&&s>=1?H?.():$>=1&&s<1&&ee?.(),$=s;}function G(){if(!oe||_)return;let s=performance.now(),f=Le(),L=p;if(F!==false){let I=s-Ae,P=I>0?Math.abs(f-(ge<0?f:ge))/I:0;L=p*Math.max(.2,1+P*(typeof F=="number"?F:1)*.04);}ge=f,Ae=s;let j=U===T?0:(f-T)/(U-T);Fe(j);let E=x(Z(f,T,U,L));m&&(d=Math.max(d,E),E=d),A=E,Me(E),E>=1&&!b?(b=true,J?.()):E<1&&!m&&(b=false),K=requestAnimationFrame(G);}he();{let s=x(Z(Le(),T,U,p));m&&s>0&&(d=s),A=s,Me(s);}let ue=new IntersectionObserver(s=>{s.forEach(f=>{oe=f.isIntersecting,oe&&!_?K=requestAnimationFrame(G):cancelAnimationFrame(K);});},{root:h??null}),V;function B(){clearTimeout(V),V=setTimeout(he,150);}return window.addEventListener("resize",B),window.addEventListener("orientationchange",B),ue.observe(e),De(e,{type:"animate",getProgress:()=>A,getTrigger:()=>({tStart:T,tEnd:U})}),{destroy(){cancelAnimationFrame(K),ue.disconnect(),window.removeEventListener("resize",B),window.removeEventListener("orientationchange",B),clearTimeout(V),Ie(e);},replay(){d=-1,b=false,A=0,_=false,Me(0);},pause(){_=true,cancelAnimationFrame(K);},resume(){_&&(_=false,oe&&(K=requestAnimationFrame(G)));},seek(s){let f=Math.min(1,Math.max(0,s));A=f,d=f,_=true,cancelAnimationFrame(K),Me(f);},getProgress(){return A}}}var Ue={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Ze(e,n){if(typeof window>"u")return Ue;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),Ue;let t=r,{from:u=0,to:i,format:p,easing:m="ease-out",trigger:c={},once:g=true,decimals:M,onComplete:F}=n,S=M!==void 0?d=>d.toFixed(M):p??(d=>String(Math.round(d))),J=typeof m=="function"?m:pe[m]??pe["ease-out"],Ee=de(c.start??"top 80%"),H=de(c.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return t.textContent=S(i),F?.(),Ue;t.textContent=S(u);let te=0,re=0,x=0,R=false,D=false,h=-1,C=0,W=false,ne=()=>window.scrollY,z=()=>window.innerHeight;function ce(){let d=t.getBoundingClientRect(),A=ve({top:d.top,height:d.height},ne(),z(),Ee,H);te=A.tStart,re=A.tEnd;}function T(d){t.textContent=S(u+(i-u)*d),t.style.setProperty("--scroll-draw-progress",String(d));}function U(){if(!R||D)return;let d=J(Z(ne(),te,re,1));g&&(h=Math.max(h,d),d=h),C=d,T(d),d>=1&&!W?(W=true,F?.()):d<1&&!g&&(W=false),x=requestAnimationFrame(U);}ce();{let d=J(Z(ne(),te,re,1));g&&d>0&&(h=d),C=d,T(d);}let K=new IntersectionObserver(d=>{d.forEach(A=>{R=A.isIntersecting,R&&!D?x=requestAnimationFrame(U):cancelAnimationFrame(x);});}),oe;function _(){clearTimeout(oe),oe=setTimeout(ce,150);}return window.addEventListener("resize",_),window.addEventListener("orientationchange",_),K.observe(t),De(t,{type:"counter",getProgress:()=>C,getTrigger:()=>({tStart:te,tEnd:re})}),{destroy(){cancelAnimationFrame(x),K.disconnect(),window.removeEventListener("resize",_),window.removeEventListener("orientationchange",_),clearTimeout(oe),Ie(t);},replay(){h=-1,W=false,C=0,D=false,T(0);},pause(){D=true,cancelAnimationFrame(x);},resume(){D&&(D=false,R&&(x=requestAnimationFrame(U)));},seek(d){let A=Math.min(1,Math.max(0,d));C=A,h=A,D=true,cancelAnimationFrame(x),T(A);},getProgress(){return C}}}function gt(e){let n=e.textContent??"";return e.textContent="",n.split(/(\s+)/).filter(Boolean).map(r=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),/^\s+$/.test(r)?(t.textContent=r,t.style.whiteSpace="pre"):(t.textContent=r,t.style.display="inline-block"),e.appendChild(t),/^\s+$/.test(r)?null:t}).filter(r=>r!==null)}function Ot(e){let n=e.textContent??"";return e.textContent="",n.split("").map(r=>{let t=document.createElement("span");return t.setAttribute("aria-hidden","true"),t.textContent=r,r===" "?t.style.whiteSpace="pre":t.style.display="inline-block",e.appendChild(t),r===" "?null:t}).filter(r=>r!==null)}function ft(e){let n=gt(e),r=new Map;for(let i of n){let p=i.offsetTop;r.has(p)||r.set(p,[]),r.get(p).push(i);}let t=[],u=Array.from(r.keys()).sort((i,p)=>i-p);for(let i of u){let p=r.get(i),m=document.createElement("span");m.setAttribute("aria-hidden","true"),m.style.display="inline-block";for(let c of p)m.appendChild(c);t.push(m);}e.textContent="";for(let i of t)e.appendChild(i),e.appendChild(document.createTextNode(" "));return t}function Dt(e,n,r,t){if(r<=1||t===0)return e;let u=(r-1)*t,i=n*t,p=i+(1-u);return p<=i?e>=i?1:0:Math.min(1,Math.max(0,(e-i)/(p-i)))}function It(e,n){let r=[];if(n?.y!==void 0&&r.push(`translateY(${n.y*(1-e)}px)`),n?.x!==void 0&&r.push(`translateX(${n.x*(1-e)}px)`),n?.rotate!==void 0&&r.push(`rotate(${n.rotate*(1-e)}deg)`),n?.scale!==void 0){let t=n.scale+(1-n.scale)*e;r.push(`scale(${t})`);}return r.join(" ")||""}var dt={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function yt(e,n={}){if(typeof window>"u")return dt;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollText: element not found:",e),dt;let t=r,{split:u="words",stagger:i=.04,easing:p="ease-out",from:m={opacity:0,y:24},trigger:c={},once:g=true,onComplete:M}=n,F=window.matchMedia("(prefers-reduced-motion: reduce)").matches,S=typeof p=="function"?p:pe[p]??pe["ease-out"],J=de(c.start??"top 85%"),Ee=de(c.end??"top 40%"),H=t.innerHTML;t.setAttribute("aria-label",t.textContent??"");let ee;u==="chars"?ee=Ot(t):u==="lines"?ee=ft(t):ee=gt(t);let te=ee.length;function re(b,$){m?.opacity!==void 0&&(b.style.opacity=String(m.opacity+(1-m.opacity)*$));let ge=It($,m);ge&&(b.style.transform=ge);}function x(b){t.style.setProperty("--scroll-draw-progress",String(b)),ee.forEach(($,ge)=>{let Ae=S(Dt(b,ge,te,i));re($,Ae);});}if(F)return x(1),M?.(),{destroy(){t.innerHTML=H,t.removeAttribute("aria-label");},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};x(0);let R=0,D=0,h=0,C=false,W=false,ne=-1,z=0,ce=false,T=()=>window.scrollY,U=()=>window.innerHeight;function K(){let b=t.getBoundingClientRect(),$=ve({top:b.top,height:b.height},T(),U(),J,Ee);R=$.tStart,D=$.tEnd;}function oe(){if(!C||W)return;let b=Z(T(),R,D,1);g&&(ne=Math.max(ne,b),b=ne),z=b,x(b),b>=1&&!ce?(ce=true,M?.()):b<1&&!g&&(ce=false),h=requestAnimationFrame(oe);}K();let _=new IntersectionObserver(b=>{b.forEach($=>{C=$.isIntersecting,C&&!W?h=requestAnimationFrame(oe):cancelAnimationFrame(h);});}),d;function A(){clearTimeout(d),d=setTimeout(()=>{if(u==="lines"){let b=z;t.innerHTML=H,t.setAttribute("aria-label",t.textContent??""),ee=ft(t),x(b);}K();},150);}return window.addEventListener("resize",A),window.addEventListener("orientationchange",A),_.observe(t),De(t,{type:"text",getProgress:()=>z,getTrigger:()=>({tStart:R,tEnd:D})}),{destroy(){cancelAnimationFrame(h),_.disconnect(),window.removeEventListener("resize",A),window.removeEventListener("orientationchange",A),clearTimeout(d),t.innerHTML=H,t.removeAttribute("aria-label"),Ie(t);},replay(){ne=-1,ce=false,z=0,W=false,x(0);},pause(){W=true,cancelAnimationFrame(h);},resume(){W&&(W=false,C&&(h=requestAnimationFrame(oe)));},seek(b){let $=Math.min(1,Math.max(0,b));z=$,ne=$,W=true,cancelAnimationFrame(h),x($);},getProgress(){return z}}}function Nt(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let t=typeof e=="string"?document.querySelector(e):e;return t?_e(t,n):(console.warn("[svg-scroll-draw] Container not found:",e),r)}function Ft(e=document){return Array.from(e.querySelectorAll("[data-scroll-draw]")).map(n=>{let r={};try{let t=n.dataset.scrollDrawOptions??n.dataset.scrollDrawoptions??"";t&&(r=JSON.parse(t));}catch{}return _e(n,r)})}function Ht(e=document){return Array.from(e.querySelectorAll("[data-scroll-animate]")).map(n=>{let r={props:{}};try{let t=n.dataset.scrollAnimateOptions??"";t&&(r=JSON.parse(t));}catch{}return pt(n,r)})}function Rt(e=document){return Array.from(e.querySelectorAll("[data-scroll-counter]")).map(n=>{let r={};try{let t=n.dataset.scrollCounterOptions??"";t&&(r=JSON.parse(t));}catch{}return !r.to&&r.to!==0&&(process.env.NODE_ENV!=="production"&&console.warn('[svg-scroll-draw] initScrollCounter: element missing "to" in options JSON:',n),r.to=0),Ze(n,r)})}function qt(e=document){return Array.from(e.querySelectorAll("[data-scroll-text]")).map(n=>{let r={};try{let t=n.dataset.scrollTextOptions??"";t&&(r=JSON.parse(t));}catch{}return yt(n,r)})}function br(e=document){return {draw:Ft(e),animate:Ht(e),counter:Rt(e),text:qt(e)}}export{br as initAll,Ht as initScrollAnimate,Rt as initScrollCounter,Ft as initScrollDraw,qt as initScrollText,Nt as scrollDraw};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";var SvgScrollDraw=(()=>{var
|
|
2
|
-
<div style="position:absolute;${
|
|
3
|
-
<div style="position:absolute;${l?`left:${m}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${m}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",i,{passive:!0}),i(),n}function Ze(e,r,t){let n=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),i=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,s=>{let d=parseFloat(s),m=n[i++]??d;return String(+(d+(m-d)*t).toFixed(4))})}function He(e,r={}){if(typeof window>"u")return{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:t,...n}=r,i=t?{...Re[t],...n}:n,s=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:d="path, polyline, line, polygon, rect, circle",speed:m=1,fade:l=!1,easing:f="linear",trigger:T={},stagger:F=0,direction:E="forward",once:X=!1,debug:ce=!1,axis:A="y",scrollContainer:$,autoReverse:u=!1,delay:h=0,strokeColor:b,strokeWidth:N,fillOpacity:z,waypoints:_,velocityScale:B=!1,threshold:oe=0,rootMargin:U="0px",repeat:Z=0,repeatDelay:J=0,morphTo:k,clip:K,autoplay:de=!1,duration:ge=1e3,native:be=!0,onProgress:g,onStart:R,onComplete:ue}=i,ie=K===!0?"left":typeof K=="string"?K:!1,ae=typeof f=="function"?f:te[f]??te.linear,Ae=he(T.start??"top bottom"),c=he(T.end??"bottom top"),p=typeof $=="string"?document.querySelector($):$??null,G=Array.isArray(b)?b[0]:null,C=Array.isArray(b)?b[1]:typeof b=="string"?b:null,H=Array.isArray(N)?N[0]:null,j=Array.isArray(N)?N[1]:typeof N=="number"?N:null,M=Array.isArray(z)?z[0]:null,I=Array.isArray(z)?z[1]:typeof z=="number"?z:null;function ne(o){let a=o*100;switch(ie){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 V=ie?[]:Array.from(e.querySelectorAll(d)),D=[],me=[],we=0,ve=0,Y=!1,le=!1,W=0,Ce=!1,fe=-1,Le=-1,Q=!1,Te=0,ye=0,Ee,Be=null,Se=new Set,Ie=-1,et=performance.now();function ke(){return p?A==="x"?p.scrollLeft:p.scrollTop:A==="x"?window.scrollX:window.scrollY}function tt(){return p?A==="x"?p.clientWidth:p.clientHeight:A==="x"?window.innerWidth:window.innerHeight}function rt(){let o=e.getBoundingClientRect(),a,v,O;if(p){let ee=p.getBoundingClientRect();a=A==="x"?o.left-ee.left+p.scrollLeft:o.top-ee.top+p.scrollTop,v=A==="x"?o.width:o.height,O=ke()}else a=A==="x"?o.left:o.top,v=A==="x"?o.width:o.height,O=ke();let se=xe({top:a,height:v},O,tt(),Ae,c);we=se.tStart,ve=se.tEnd,ce&&process.env.NODE_ENV!=="production"&&(Be?.remove(),Be=It(we,ve,A))}function bt(o,a){if(e.style.setProperty("--scroll-draw-progress",String(o)),ie){let v=a==="reverse"?1-o:o;e.style.clipPath=ne(v);return}V.forEach((v,O)=>{v.style.strokeDashoffset=a==="reverse"?`${D[O]*o}`:`${D[O]*(1-o)}`,l&&(v.style.opacity=a==="reverse"?`${1-o}`:`${o}`),G&&C?v.style.stroke=Pe(G,C,o):C&&(v.style.stroke=C),H!==null&&j!==null?v.style.strokeWidth=`${H+(j-H)*o}`:j!==null&&(v.style.strokeWidth=`${j}`),M!==null&&I!==null?v.style.fillOpacity=`${M+(I-M)*o}`:I!==null&&(v.style.fillOpacity=`${I}`),k&&v.tagName.toLowerCase()==="path"&&me[O]&&v.setAttribute("d",Ze(me[O],k,o))})}function De(){if(e.style.setProperty("--scroll-draw-progress","0"),ie){e.style.clipPath=ne(0);return}V.forEach((o,a)=>{o.style.strokeDasharray=`${D[a]}`,o.style.strokeDashoffset=E==="reverse"?"0":`${D[a]}`,l?o.style.opacity=E==="reverse"?"1":"0":o.style.opacity="",G&&(o.style.stroke=G),H!==null&&(o.style.strokeWidth=`${H}`),M!==null&&(o.style.fillOpacity=`${M}`),k&&o.tagName.toLowerCase()==="path"&&me[a]&&o.setAttribute("d",me[a])})}if(V.forEach(o=>{Lt(o);let a=Ne(o);D.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",l&&(o.style.opacity="1"),C&&(o.style.stroke=C),j!==null&&(o.style.strokeWidth=`${j}`),I!==null&&(o.style.fillOpacity=`${I}`),k&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",k)):(o.style.strokeDasharray=`${a}`,o.style.strokeDashoffset=E==="reverse"?"0":`${a}`,l?o.style.opacity=E==="reverse"?"1":"0":o.style.opacity="",G&&(o.style.stroke=G),H!==null&&(o.style.strokeWidth=`${H}`),M!==null&&(o.style.fillOpacity=`${M}`))}),ie){if(s)return e.style.clipPath=ne(1),ue?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ne(0)}else if(s)return ue?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function wt(){return!(be===!1||!Ct()||!V.length||typeof f!="string"||!(f in lt)||ie||A!=="y"||p||m!==1||F!==0||X||u||B!==!1||k||_||Z||h>0||g||R||ue||b!=null||N!=null||z!=null||(T.start??"top bottom").trim()!=="top bottom"||(T.end??"bottom top").trim()!=="bottom top")}function vt(){let o=`svg-scroll-draw-${++kt}`,a=E==="reverse"?"0":"var(--ssd-len)",v=E==="reverse"?"var(--ssd-len)":"0",O=`stroke-dashoffset:${a};`,se=`stroke-dashoffset:${v};`;l&&(O+=`opacity:${E==="reverse"?1:0};`,se+=`opacity:${E==="reverse"?0:1};`);let ee=document.createElement("style");ee.setAttribute("data-svg-scroll-draw",""),ee.textContent=`@keyframes ${o}{from{${O}}to{${se}}}.${o}{animation-name:${o};animation-duration:auto;animation-timing-function:${lt[f]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(ee);function w(y,x){y.style.setProperty("--ssd-len",String(D[x])),y.style.strokeDasharray=`${D[x]}`,y.style.strokeDashoffset="",y.style.opacity="",y.style.animationPlayState="",y.classList.add(o)}V.forEach(w);let P=!1,q=-1;function S(){if(q>=0)return q;let y=e.getBoundingClientRect(),{tStart:x,tEnd:L}=xe({top:y.top,height:y.height},ke(),tt(),Ae,c);return ae(re(ke(),x,L,m))}return{destroy(){V.forEach(y=>{y.classList.remove(o),y.style.removeProperty("--ssd-len"),y.style.animationPlayState=""}),ee.remove()},replay(){P=!1,q=-1,V.forEach(w)},pause(){P=!0,V.forEach(y=>{y.style.animationPlayState="paused"})},resume(){P&&(P=!1,V.forEach(y=>{y.style.animationPlayState="running"}))},seek(y){let x=Math.min(1,Math.max(0,y));q=x,P=!0,V.forEach((L,$e)=>{L.classList.remove(o),L.style.strokeDashoffset=E==="reverse"?`${D[$e]*x}`:`${D[$e]*(1-x)}`,l&&(L.style.opacity=E==="reverse"?`${1-x}`:`${x}`)})},getProgress(){return S()}}}if(wt())return vt();function Et(){let o=Math.max(1,ge),a=0,v=0;function O(S){let y=!0;if(ie){let x=Math.min(1,Math.max(0,S/o)),L=ae(x);Te=L,e.style.setProperty("--scroll-draw-progress",String(L)),e.style.clipPath=ne(E==="reverse"?1-L:L),g?.(L),x<1&&(y=!1)}else V.forEach((x,L)=>{let $e=L*F*o,Me=Math.min(1,Math.max(0,(S-$e)/o)),pe=ae(Me);x.style.strokeDashoffset=E==="reverse"?`${D[L]*pe}`:`${D[L]*(1-pe)}`,l&&(x.style.opacity=E==="reverse"?`${1-pe}`:`${pe}`),G&&C?x.style.stroke=Pe(G,C,pe):C&&(x.style.stroke=C),H!==null&&j!==null?x.style.strokeWidth=`${H+(j-H)*pe}`:j!==null&&(x.style.strokeWidth=`${j}`),M!==null&&I!==null?x.style.fillOpacity=`${M+(I-M)*pe}`:I!==null&&(x.style.fillOpacity=`${I}`),k&&x.tagName.toLowerCase()==="path"&&me[L]&&x.setAttribute("d",Ze(me[L],k,pe)),L===0&&(g?.(pe),e.style.setProperty("--scroll-draw-progress",String(pe))),Me<1&&(y=!1)});if(_){let x=Math.min(1,Math.max(0,S/o)),L=ae(x);for(let $e in _){let Me=parseFloat($e);L>=Me&&!Se.has(Me)&&(Se.add(Me),_[$e]?.())}}return y}function se(S){if(Q)return;let y=S-a;le||(le=!0,R?.());let x=O(y);if(x&&!Y){Y=!0,O(o*(1+Math.max(0,V.length-1)*F)),ue?.(),ye<(Z==="infinite"?1/0:Z??0)&&(ye++,Ee=setTimeout(()=>{a=performance.now(),le=!1,Y=!1,Se.clear(),De(),W=requestAnimationFrame(se)},J));return}x||(W=requestAnimationFrame(se))}function ee(){cancelAnimationFrame(W),clearTimeout(Ee),a=performance.now(),v=0,Q=!1,le=!1,Y=!1,ye=0,Se.clear(),De(),W=requestAnimationFrame(se)}let w=new IntersectionObserver(S=>{S.forEach(y=>{y.isIntersecting&&!(X&&Y)?ee():!y.isIntersecting&&!X&&!Y&&(cancelAnimationFrame(W),clearTimeout(Ee),a=null)})},{root:p??null,threshold:oe,rootMargin:U}),P;function q(){clearTimeout(P),P=setTimeout(()=>{V.forEach((S,y)=>{D[y]=Ne(S),S.style.strokeDasharray=`${D[y]}`})},150)}return window.addEventListener("resize",q),window.addEventListener("orientationchange",q),h>0?setTimeout(()=>w.observe(e),h):w.observe(e),{destroy(){cancelAnimationFrame(W),clearTimeout(Ee),w.disconnect(),window.removeEventListener("resize",q),window.removeEventListener("orientationchange",q),clearTimeout(P)},replay(){ye=0,ee()},pause(){Q||(Q=!0,v=performance.now()-a,cancelAnimationFrame(W))},resume(){Q&&(Q=!1,a=performance.now()-v,W=requestAnimationFrame(se))},seek(S){let y=Math.min(1,Math.max(0,S));Te=y,Q=!0,v=y*o,a=performance.now()-v,cancelAnimationFrame(W),O(v)},getProgress(){return Te}}}if(de)return Et();rt();function Oe(){if(!Ce||Q)return;let o=performance.now(),a=ke(),v=m;if(B!==!1){let w=o-et,P=w>0?Math.abs(a-(Ie<0?a:Ie))/w:0;v=m*Math.max(.2,1+P*(typeof B=="number"?B:1)*.04)}Ie=a,et=o;let O=u?Le===-1||a>=Le?"forward":"reverse":E;Le=a;let se=ve-we,ee=!0;if(ie){let w=ae(re(a,we,ve,v));X&&!u&&(fe=Math.max(fe,w),w=fe),Te=w,e.style.setProperty("--scroll-draw-progress",String(w));let P=O==="reverse"?1-w:w;e.style.clipPath=ne(P),g?.(w),!le&&re(a,we,ve,v)>0&&(le=!0,R?.()),w>=1&&!Y?(Y=!0,ue?.(),ye<(Z==="infinite"?1/0:Z??0)&&(ye++,Ee=setTimeout(()=>{fe=-1,le=!1,Y=!1,e.style.clipPath=ne(0)},J))):w<1&&!X&&(Y=!1),W=requestAnimationFrame(Oe);return}if(V.forEach((w,P)=>{let q=P*F*se,S=ae(re(a,we+q,ve+q,v));X&&!u&&(fe=Math.max(fe,S),S=fe),Te=S,w.style.strokeDashoffset=O==="reverse"?`${D[P]*S}`:`${D[P]*(1-S)}`,l&&(w.style.opacity=O==="reverse"?`${1-S}`:`${S}`),G&&C?w.style.stroke=Pe(G,C,S):C&&(w.style.stroke=C),H!==null&&j!==null?w.style.strokeWidth=`${H+(j-H)*S}`:j!==null&&(w.style.strokeWidth=`${j}`),M!==null&&I!==null?w.style.fillOpacity=`${M+(I-M)*S}`:I!==null&&(w.style.fillOpacity=`${I}`),k&&w.tagName.toLowerCase()==="path"&&me[P]&&w.setAttribute("d",Ze(me[P],k,S)),P===0&&(g?.(S),e.style.setProperty("--scroll-draw-progress",String(S))),S<1&&(ee=!1)}),_){let w=ae(re(a,we,ve,v));for(let P in _){let q=parseFloat(P);w>=q&&!Se.has(q)&&(Se.add(q),_[P]?.())}}!le&&re(a,we,ve,v)>0&&(le=!0,R?.()),ee&&!Y?(Y=!0,ue?.(),ye<(Z==="infinite"?1/0:Z??0)&&(ye++,Ee=setTimeout(()=>{fe=-1,le=!1,Y=!1,Se.clear(),De()},J))):!ee&&!X&&(Y=!1),W=requestAnimationFrame(Oe)}let Ge=new IntersectionObserver(o=>{o.forEach(a=>{Ce=a.isIntersecting,Ce&&!Q?W=requestAnimationFrame(Oe):cancelAnimationFrame(W)})},{root:p??null,threshold:oe,rootMargin:U}),je;function Fe(){clearTimeout(je),je=setTimeout(()=>{V.forEach((o,a)=>{D[a]=Ne(o),o.style.strokeDasharray=`${D[a]}`}),rt()},150)}return window.addEventListener("resize",Fe),window.addEventListener("orientationchange",Fe),h>0?setTimeout(()=>Ge.observe(e),h):Ge.observe(e),{destroy(){cancelAnimationFrame(W),clearTimeout(Ee),Ge.disconnect(),window.removeEventListener("resize",Fe),window.removeEventListener("orientationchange",Fe),clearTimeout(je),Be?.remove()},replay(){fe=-1,Le=-1,Ie=-1,le=!1,Y=!1,ye=0,Q=!1,Se.clear(),clearTimeout(Ee),De()},pause(){Q=!0,cancelAnimationFrame(W)},resume(){Q&&(Q=!1,Ce&&(W=requestAnimationFrame(Oe)))},seek(o){let a=Math.min(1,Math.max(0,o));Te=a,fe=a,Q=!0,cancelAnimationFrame(W),bt(a,E)},getProgress(){return Te}}}var ct=new Map;function qe(e,r){ct.set(e,r)}function ze(e){ct.delete(e)}function Dt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function ut(e){let r=[],t=/([\w]+)\(([^)]*)\)/g,n;for(;(n=t.exec(e))!==null;){let i=[],s=[],d=n[2].trim();if(d)for(let m of d.split(/[\s,]+/)){let l=m.match(/^([-+]?[\d.eE]+)(.*)$/);i.push(l?parseFloat(l[1]):0),s.push(l?l[2]:"")}r.push({fn:n[1],nums:i,units:s})}return r}function Ot(e,r,t){let n=ut(e),i=ut(r);return n.length===0||n.length!==i.length?t<1?e:r:n.map((s,d)=>{let m=i[d];return s.fn!==m.fn||s.nums.length!==m.nums.length?t<1?`${s.fn}(${s.nums.map((l,f)=>`${l}${s.units[f]}`).join(", ")})`:`${m.fn}(${m.nums.map((l,f)=>`${l}${m.units[f]}`).join(", ")})`:`${s.fn}(${s.nums.map((l,f)=>`${l+(m.nums[f]-l)*t}${s.units[f]}`).join(", ")})`}).join(" ")}function mt(e,r,t){if(typeof e=="number"&&typeof r=="number")return String(e+(r-e)*t);let n=String(e),i=String(r);if(Dt(n))return Pe(n,i,t);if(n.includes("("))return Ot(n,i,t);let s=n.match(/^([-+]?[\d.]+)(.*)$/),d=i.match(/^([-+]?[\d.]+)(.*)$/);if(s&&d){let m=parseFloat(s[1]),l=parseFloat(d[1]);return`${m+(l-m)*t}${s[2]||d[2]}`}return t<1?n:i}function Ft(e){return e.replace(/([A-Z])/g,r=>`-${r.toLowerCase()}`)}var ft={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Nt=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),Rt=0;function Ht(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function pt(e,r){let t={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return t;let{props:n,trigger:i={},easing:s="ease-out",speed:d=1,once:m=!1,axis:l="y",scrollContainer:f,native:T=!0,onProgress:F,onComplete:E}=r,X=window.matchMedia("(prefers-reduced-motion: reduce)").matches,ce=typeof s=="function"?s:te[s]??te["ease-out"],A=he(i.start??"top bottom"),$=he(i.end??"bottom top"),u=typeof f=="string"?document.querySelector(f):f??null,h=Object.entries(n).map(([c,p])=>({prop:Ft(c),from:Array.isArray(p)?p[0]:"",to:Array.isArray(p)?p[1]:p}));function b(){let c=window.getComputedStyle(e);for(let p of h)p.from===""&&(p.from=c.getPropertyValue(p.prop).trim()||"0")}function N(){for(let c of h)e.style.setProperty(c.prop,String(c.to))}if(X)return N(),E?.(),t;b();function z(){if(!T||!Ht()||typeof s!="string"||!(s in ft)||l!=="y"||u||m||d!==1||F||E||(i.start??"top bottom").trim()!=="top bottom"||(i.end??"bottom top").trim()!=="bottom top")return!1;for(let c of h)if(!Nt.has(c.prop))return!1;return!0}function _(){let c=`ssd-a-${++Rt}`,p=h.map(M=>`${M.prop}:${M.from}`).join(";"),G=h.map(M=>`${M.prop}:${M.to}`).join(";"),C=document.createElement("style");C.setAttribute("data-ssd-animate",""),C.textContent=`@keyframes ${c}{from{${p}}to{${G}}}.${c}{animation-name:${c};animation-duration:auto;animation-timing-function:${ft[s]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(C),e.classList.add(c);let H=()=>l==="x"?window.scrollX:window.scrollY,j=()=>l==="x"?window.innerWidth:window.innerHeight;return{destroy(){e.classList.remove(c),C.remove()},replay(){e.classList.remove(c),e.offsetWidth,e.classList.add(c)},pause(){e.style.animationPlayState="paused"},resume(){e.style.animationPlayState=""},seek(M){let I=Math.min(1,Math.max(0,M));e.classList.remove(c);for(let ne of h)e.style.setProperty(ne.prop,mt(ne.from,ne.to,I))},getProgress(){let M=e.getBoundingClientRect(),I=H(),ne=j(),{tStart:V,tEnd:D}=xe({top:M.top,height:M.height},I,ne,A,$);return ce(re(I,V,D,d))}}}if(z())return _();let B=0,oe=0,U=0,Z=!1,J=!1,k=-1,K=0,de=!1,ge=()=>u?l==="x"?u.scrollLeft:u.scrollTop:l==="x"?window.scrollX:window.scrollY,be=()=>u?l==="x"?u.clientWidth:u.clientHeight:l==="x"?window.innerWidth:window.innerHeight;function g(){let c=e.getBoundingClientRect(),p,G;if(u){let H=u.getBoundingClientRect();p=l==="x"?c.left-H.left+u.scrollLeft:c.top-H.top+u.scrollTop,G=l==="x"?c.width:c.height}else p=l==="x"?c.left:c.top,G=l==="x"?c.width:c.height;let C=xe({top:p,height:G},ge(),be(),A,$);B=C.tStart,oe=C.tEnd}function R(c){e.style.setProperty("--scroll-draw-progress",String(c));for(let p of h)e.style.setProperty(p.prop,mt(p.from,p.to,c));F?.(c)}function ue(){if(!Z||J)return;let c=ce(re(ge(),B,oe,d));m&&(k=Math.max(k,c),c=k),K=c,R(c),c>=1&&!de?(de=!0,E?.()):c<1&&!m&&(de=!1),U=requestAnimationFrame(ue)}g();{let c=ce(re(ge(),B,oe,d));m&&c>0&&(k=c),K=c,R(c)}let ie=new IntersectionObserver(c=>{c.forEach(p=>{Z=p.isIntersecting,Z&&!J?U=requestAnimationFrame(ue):cancelAnimationFrame(U)})},{root:u??null}),ae;function Ae(){clearTimeout(ae),ae=setTimeout(g,150)}return window.addEventListener("resize",Ae),window.addEventListener("orientationchange",Ae),ie.observe(e),qe(e,{type:"animate",getProgress:()=>K,getTrigger:()=>({tStart:B,tEnd:oe})}),{destroy(){cancelAnimationFrame(U),ie.disconnect(),window.removeEventListener("resize",Ae),window.removeEventListener("orientationchange",Ae),clearTimeout(ae),ze(e)},replay(){k=-1,de=!1,K=0,J=!1,R(0)},pause(){J=!0,cancelAnimationFrame(U)},resume(){J&&(J=!1,Z&&(U=requestAnimationFrame(ue)))},seek(c){let p=Math.min(1,Math.max(0,c));K=p,k=p,J=!0,cancelAnimationFrame(U),R(p)},getProgress(){return K}}}var Ve={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function dt(e,r){if(typeof window>"u")return Ve;let t=typeof e=="string"?document.querySelector(e):e;return t?pt(t,r):(process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollAnimate: element not found:",e),Ve)}function gt(e,r={}){if(typeof window>"u")return Ve;let t=typeof e=="string"?document.querySelector(e):e;if(!t)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollParallax: element not found:",e),Ve;let{speed:n=.3,axis:i="y",easing:s="linear",trigger:d,onProgress:m}=r,l=t.getBoundingClientRect(),f=i==="x"?l.width:l.height,T=n*f;return pt(t,{props:i==="x"?{transform:["translateX(0px)",`translateX(${-T}px)`]}:{transform:["translateY(0px)",`translateY(${-T}px)`]},trigger:d??{start:"top bottom",end:"bottom top"},easing:s,native:!1,onProgress:m})}var Je={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function yt(e,r){if(typeof window>"u")return Je;let t=typeof e=="string"?document.querySelector(e):e;if(!t)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollCounter: element not found:",e),Je;let n=t,{from:i=0,to:s,format:d,easing:m="ease-out",trigger:l={},once:f=!0,decimals:T,onComplete:F}=r,E=T!==void 0?g=>g.toFixed(T):d??(g=>String(Math.round(g))),X=typeof m=="function"?m:te[m]??te["ease-out"],ce=he(l.start??"top 80%"),A=he(l.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return n.textContent=E(s),F?.(),Je;n.textContent=E(i);let u=0,h=0,b=0,N=!1,z=!1,_=-1,B=0,oe=!1,U=()=>window.scrollY,Z=()=>window.innerHeight;function J(){let g=n.getBoundingClientRect(),R=xe({top:g.top,height:g.height},U(),Z(),ce,A);u=R.tStart,h=R.tEnd}function k(g){n.textContent=E(i+(s-i)*g),n.style.setProperty("--scroll-draw-progress",String(g))}function K(){if(!N||z)return;let g=X(re(U(),u,h,1));f&&(_=Math.max(_,g),g=_),B=g,k(g),g>=1&&!oe?(oe=!0,F?.()):g<1&&!f&&(oe=!1),b=requestAnimationFrame(K)}J();{let g=X(re(U(),u,h,1));f&&g>0&&(_=g),B=g,k(g)}let de=new IntersectionObserver(g=>{g.forEach(R=>{N=R.isIntersecting,N&&!z?b=requestAnimationFrame(K):cancelAnimationFrame(b)})}),ge;function be(){clearTimeout(ge),ge=setTimeout(J,150)}return window.addEventListener("resize",be),window.addEventListener("orientationchange",be),de.observe(n),qe(n,{type:"counter",getProgress:()=>B,getTrigger:()=>({tStart:u,tEnd:h})}),{destroy(){cancelAnimationFrame(b),de.disconnect(),window.removeEventListener("resize",be),window.removeEventListener("orientationchange",be),clearTimeout(ge),ze(n)},replay(){_=-1,oe=!1,B=0,z=!1,k(0)},pause(){z=!0,cancelAnimationFrame(b)},resume(){z&&(z=!1,N&&(b=requestAnimationFrame(K)))},seek(g){let R=Math.min(1,Math.max(0,g));B=R,_=R,z=!0,cancelAnimationFrame(b),k(R)},getProgress(){return B}}}var ht="http://www.w3.org/2000/svg",qt="cinematic-photo",Ke=e=>e<0?0:e>1?1:e;function We(e){let r=parseFloat(e);return Number.isFinite(r)?Ke(r/100):0}function zt(e){return te[e]??te.linear}var Vt={destroy:()=>{},getProgress:()=>0},_e=class{constructor(r){if(typeof document>"u"){this.mount=null;return}this.mount=typeof r.wrapper=="string"?document.querySelector(r.wrapper):r.wrapper,!this.mount&&process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] Cinematic: wrapper not found:",r.wrapper)}loadStory(r){let t=this.mount;if(typeof window>"u"||!t)return Vt;t.style.position="relative",t.style.height=r.totalHeight,t.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;",t.appendChild(n);let i=[];for(let A of r.scenes){if(A.background){let u=document.createElement("img");u.id=qt,u.src=A.background,u.alt="",u.style.cssText="position:absolute;inset:0;width:100%;height:100%;object-fit:contain;opacity:0;pointer-events:none;",n.appendChild(u)}let $=A.animations.filter(u=>u.type==="draw");if($.length){let u=document.createElementNS(ht,"svg");u.setAttribute("viewBox",`0 0 ${r.canvas.width} ${r.canvas.height}`),u.setAttribute("preserveAspectRatio","xMidYMid meet"),u.style.cssText="position:absolute;inset:0;width:100%;height:100%;overflow:visible;",n.appendChild(u);for(let h of $){let b=document.createElementNS(ht,"path");b.id=h.target.replace(/^#/,""),b.setAttribute("d",h.d),b.setAttribute("fill","none"),b.setAttribute("stroke",h.stroke),b.setAttribute("stroke-width",String(h.strokeWidth)),b.setAttribute("stroke-linecap","round"),b.setAttribute("stroke-linejoin","round");let N=h.length||b.getTotalLength?.()||0;b.style.strokeDasharray=String(N),b.style.strokeDashoffset=String(N),u.appendChild(b),i.push({kind:"draw",el:b,start:We(h.start),end:We(h.end),ease:zt(h.easing),length:N})}}for(let u of A.animations){if(u.type!=="fade")continue;let h=n.querySelector(u.target)??document.querySelector(u.target);h&&(h.style.opacity=String(u.from),i.push({kind:"fade",el:h,start:We(u.start),end:We(u.end),ease:te["ease-in-out"]??te.linear,from:u.from,to:u.to}))}}let s=0,d=()=>{let A=t.offsetHeight-window.innerHeight;return A<=0?t.getBoundingClientRect().top<=0?1:0:Ke(-t.getBoundingClientRect().top/A)},m=A=>{for(let $ of i){let u=$.end-$.start,h=u<=0?A>=$.end?1:0:Ke((A-$.start)/u),b=$.ease(h);$.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 m(1),{destroy:()=>{},getProgress:()=>1};let l=0,f=!1,T=!1,F=()=>{s=d(),m(s),f&&(l=requestAnimationFrame(F))},E=()=>{f||(f=!0,l=requestAnimationFrame(F))},X=()=>{f=!1,cancelAnimationFrame(l)},ce=new IntersectionObserver(A=>{for(let $ of A)T=$.isIntersecting,T?E():X()},{threshold:0});return ce.observe(n),s=d(),m(s),{destroy(){X(),ce.disconnect()},getProgress:()=>s}}};function Wt(e,r){let t={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return t;let n=typeof e=="string"?document.querySelector(e):e;return n?He(n,r):(console.warn("[svg-scroll-draw] Container not found:",e),t)}var Qe=class extends HTMLElement{constructor(){super(...arguments);this.instance=null}connectedCallback(){let t={},n=this.getAttribute("speed"),i=this.getAttribute("easing"),s=this.getAttribute("stagger"),d=this.getAttribute("direction"),m=this.getAttribute("selector");n&&(t.speed=parseFloat(n)),i&&(t.easing=i),s&&(t.stagger=parseFloat(s)),d&&(t.direction=d),m&&(t.selector=m),this.hasAttribute("fade")&&(t.fade=this.getAttribute("fade")!=="false"),this.instance=He(this,t)}disconnectedCallback(){this.instance?.destroy(),this.instance=null}};typeof customElements<"u"&&!customElements.get("scroll-draw")&&customElements.define("scroll-draw",Qe);return Mt(_t);})();
|
|
1
|
+
"use strict";var SvgScrollDraw=(()=>{var Ke=Object.defineProperty;var Mt=Object.getOwnPropertyDescriptor;var kt=Object.getOwnPropertyNames;var Pt=Object.prototype.hasOwnProperty;var Ct=(e,r)=>{for(var t in r)Ke(e,t,{get:r[t],enumerable:!0})},Lt=(e,r,t,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let a of kt(r))!Pt.call(e,a)&&a!==t&&Ke(e,a,{get:()=>r[a],enumerable:!(n=Mt(r,a))||n.enumerable});return e};var It=e=>Lt(Ke({},"__esModule",{value:!0}),e);var Yt={};Ct(Yt,{Cinematic:()=>Ye,PRESETS:()=>Be,createBounce:()=>Qe,createElastic:()=>et,createSpring:()=>mt,scrollAnimate:()=>wt,scrollCounter:()=>Et,scrollDraw:()=>Xt,scrollParallax:()=>vt});function mt({tension:e=2.5,friction:r=2.2}={}){return t=>1-Math.cos(t*Math.PI*e)*Math.pow(1-t,r)}function Qe({bounces:e=3,decay:r=.5}={}){let t=Math.max(1,Math.round(e)),n=Math.max(.01,Math.min(.99,r)),a=Math.sqrt(n),i=0,d=[];for(let p=0;p<t;p++){let x=Math.pow(a,p);d.push(x),i+=x}let m=[0],c=0;for(let p=0;p<t;p++)c+=d[p]/i,m.push(c);return p=>{if(p<=0)return 0;if(p>=1)return 1;for(let x=0;x<t;x++)if(p<=m[x+1]){let F=(p-m[x])/(m[x+1]-m[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 et({amplitude:e=1,period:r=.4}={}){let t=Math.max(1,e),n=Math.max(.1,r),a=t<=1?n/4:n/(2*Math.PI)*Math.asin(1/t);return i=>i<=0?0:i>=1?1:t*Math.pow(2,-10*i)*Math.sin((i-a)*(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:Qe(),elastic:et()};function be(e="top bottom"){let r=e.trim();if(/^\d+(\.\d+)?%$/.test(r))return{element:"top",viewport:r};let[t="top",n="bottom"]=r.split(/\s+/).filter(Boolean);return{element:t,viewport:n}}function lt(e,r,t,n){switch(n){case"top":return e+t;case"center":return e+t+r/2;case"bottom":return e+t+r;default:return e+t}}function ct(e,r){if(/^\d+(\.\d+)?%$/.test(e))return r*(parseFloat(e)/100);switch(e){case"top":return 0;case"center":return r/2;case"bottom":return r;default:return r}}function Ve(e){let r=e.tagName.toLowerCase();if(r==="rect"){let t=parseFloat(e.getAttribute("width")??"0"),n=parseFloat(e.getAttribute("height")??"0");return 2*(t+n)}if(r==="circle"){let t=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*t}return e.getTotalLength()}function Dt(e,r,t){return Math.min(t,Math.max(r,e))}function re(e,r,t,n){return t===r?0:Dt((e-r)/(t-r)*n,0,1)}function xe(e,r,t,n,a){let i=lt(e.top,e.height,r,n.element)-ct(n.viewport,t),d=lt(e.top,e.height,r,a.element)-ct(a.viewport,t);return{tStart:i,tEnd:d}}function ut(e){let r=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(r)return[parseInt(r[1]+r[1],16),parseInt(r[2]+r[2],16),parseInt(r[3]+r[3],16)];let t=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(t)return[parseInt(t[1],16),parseInt(t[2],16),parseInt(t[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,r,t){let n=ut(e),a=ut(r);return!n||!a?e:`rgb(${Math.round(n[0]+(a[0]-n[0])*t)},${Math.round(n[1]+(a[1]-n[1])*t)},${Math.round(n[2]+(a[2]-n[2])*t)})`}var Be={sketch:{easing:"ease-in",stagger:.1,speed:.9,fade:!1},reveal:{easing:"ease-out",fade:!0,speed:1.2,once:!0},typewriter:{easing:"linear",stagger:.05,speed:1.5},cinematic:{easing:"ease-in-out",fade:!0,speed:.75},spring:{easing:"spring",speed:1.1}};function ft(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r)}var pt={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Ot=0;function Ft(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Nt(e){let r=e.getAttribute("stroke"),t=e.getAttribute("fill");!r||r==="none"?ft("Element has no stroke \u2014 path will not be visible.",e):t&&t!=="none"&&t!=="transparent"&&ft("Element has a fill \u2014 it may obscure the stroke animation.",e)}function Rt(e,r,t){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 a(){let i=t==="x"?window.scrollX:window.scrollY,d=e-i,m=r-i,c=t==="x";n.innerHTML=`
|
|
2
|
+
<div style="position:absolute;${c?`left:${d}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${d}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
|
|
3
|
+
<div style="position:absolute;${c?`left:${m}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${m}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",a,{passive:!0}),a(),n}function tt(e,r,t){let n=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),a=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,i=>{let d=parseFloat(i),m=n[a++]??d;return String(+(d+(m-d)*t).toFixed(4))})}function We(e,r={}){if(typeof window>"u")return{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:t,...n}=r,a=t?{...Be[t],...n}:n,i=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:d="path, polyline, line, polygon, rect, circle",speed:m=1,fade:c=!1,easing:p="linear",trigger:x={},stagger:F=0,direction:E="forward",once:W=!1,debug:ge=!1,axis:S="y",scrollContainer:M,autoReverse:g=!1,delay:A=0,strokeColor:b,strokeWidth:R,fillOpacity:z,waypoints:T,velocityScale:H=!1,threshold:ye=0,rootMargin:we="0px",repeat:ae=0,repeatDelay:ve=0,morphTo:k,clip:U,autoplay:se=!1,duration:ce=1e3,native:Z=!0,onProgress:y,onStart:N,onComplete:le,onEnter:ue,onLeave:Me,onEnterBack:Ie,onLeaveBack:ke}=a,me=U===!0?"left":typeof U=="string"?U:!1,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,f=Array.isArray(z)?z[0]:null,P=Array.isArray(z)?z[1]:typeof z=="number"?z:null;function G(o){let l=o*100;switch(me){case"right":return`inset(0 0 0 ${100-l}%)`;case"top":return`inset(0 0 ${100-l}% 0)`;case"bottom":return`inset(${100-l}% 0 0 0)`;case"center":return`circle(${o*150}% at 50% 50%)`;default:return`inset(0 ${100-l}% 0 0)`}}let $=me?[]:Array.from(e.querySelectorAll(d)),D=[],C=[],Y=0,J=0,j=!1,oe=!1,X=0,Fe=!1,pe=-1,Ne=-1,K=!1,Te=0,he=0,Ee,Ue=null,Se=new Set,Re=-1,st=performance.now(),Pe=NaN;function De(){return _?S==="x"?_.scrollLeft:_.scrollTop:S==="x"?window.scrollX:window.scrollY}function it(){return _?S==="x"?_.clientWidth:_.clientHeight:S==="x"?window.innerWidth:window.innerHeight}function at(){let o=e.getBoundingClientRect(),l,w,q;if(_){let ee=_.getBoundingClientRect();l=S==="x"?o.left-ee.left+_.scrollLeft:o.top-ee.top+_.scrollTop,w=S==="x"?o.width:o.height,q=De()}else l=S==="x"?o.left:o.top,w=S==="x"?o.width:o.height,q=De();let Q=xe({top:l,height:w},q,it(),Ae,Oe);Y=Q.tStart,J=Q.tEnd,ge&&process.env.NODE_ENV!=="production"&&(Ue?.remove(),Ue=Rt(Y,J,S))}function xt(o,l){if(e.style.setProperty("--scroll-draw-progress",String(o)),me){let w=l==="reverse"?1-o:o;e.style.clipPath=G(w);return}$.forEach((w,q)=>{w.style.strokeDashoffset=l==="reverse"?`${D[q]*o}`:`${D[q]*(1-o)}`,c&&(w.style.opacity=l==="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}`),f!==null&&P!==null?w.style.fillOpacity=`${f+(P-f)*o}`:P!==null&&(w.style.fillOpacity=`${P}`),k&&w.tagName.toLowerCase()==="path"&&C[q]&&w.setAttribute("d",tt(C[q],k,o))})}function He(){if(e.style.setProperty("--scroll-draw-progress","0"),me){e.style.clipPath=G(0);return}$.forEach((o,l)=>{o.style.strokeDasharray=`${D[l]}`,o.style.strokeDashoffset=E==="reverse"?"0":`${D[l]}`,c?o.style.opacity=E==="reverse"?"1":"0":o.style.opacity="",ne&&(o.style.stroke=ne),B!==null&&(o.style.strokeWidth=`${B}`),f!==null&&(o.style.fillOpacity=`${f}`),k&&o.tagName.toLowerCase()==="path"&&C[l]&&o.setAttribute("d",C[l])})}if($.forEach(o=>{Nt(o);let l=Ve(o);D.push(l),o.tagName.toLowerCase()==="path"?C.push(o.getAttribute("d")??""):C.push(""),i?(o.style.strokeDasharray=`${l}`,o.style.strokeDashoffset=E==="reverse"?`${l}`:"0",c&&(o.style.opacity="1"),V&&(o.style.stroke=V),s!==null&&(o.style.strokeWidth=`${s}`),P!==null&&(o.style.fillOpacity=`${P}`),k&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",k)):(o.style.strokeDasharray=`${l}`,o.style.strokeDashoffset=E==="reverse"?"0":`${l}`,c?o.style.opacity=E==="reverse"?"1":"0":o.style.opacity="",ne&&(o.style.stroke=ne),B!==null&&(o.style.strokeWidth=`${B}`),f!==null&&(o.style.fillOpacity=`${f}`))}),me){if(i)return e.style.clipPath=G(1),le?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=G(0)}else if(i)return le?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function At(){return!(Z===!1||!Ft()||!$.length||typeof p!="string"||!(p in pt)||me||S!=="y"||_||m!==1||F!==0||W||g||H!==!1||k||T||ae||A>0||y||N||le||ue||Me||Ie||ke||b!=null||R!=null||z!=null||(x.start??"top bottom").trim()!=="top bottom"||(x.end??"bottom top").trim()!=="bottom top")}function Tt(){let o=`svg-scroll-draw-${++Ot}`,l=E==="reverse"?"0":"var(--ssd-len)",w=E==="reverse"?"var(--ssd-len)":"0",q=`stroke-dashoffset:${l};`,Q=`stroke-dashoffset:${w};`;c&&(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:${pt[p]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(ee);function ie(u,v){u.style.setProperty("--ssd-len",String(D[v])),u.style.strokeDasharray=`${D[v]}`,u.style.strokeDashoffset="",u.style.opacity="",u.style.animationPlayState="",u.classList.add(o)}$.forEach(ie);let h=!1,L=-1;function I(){if(L>=0)return L;let u=e.getBoundingClientRect(),{tStart:v,tEnd:O}=xe({top:u.top,height:u.height},De(),it(),Ae,Oe);return fe(re(De(),v,O,m))}return{destroy(){$.forEach(u=>{u.classList.remove(o),u.style.removeProperty("--ssd-len"),u.style.animationPlayState=""}),ee.remove()},replay(){h=!1,L=-1,$.forEach(ie)},pause(){h=!0,$.forEach(u=>{u.style.animationPlayState="paused"})},resume(){h&&(h=!1,$.forEach(u=>{u.style.animationPlayState="running"}))},seek(u){let v=Math.min(1,Math.max(0,u));L=v,h=!0,$.forEach((O,$e)=>{O.classList.remove(o),O.style.strokeDashoffset=E==="reverse"?`${D[$e]*v}`:`${D[$e]*(1-v)}`,c&&(O.style.opacity=E==="reverse"?`${1-v}`:`${v}`)})},getProgress(){return I()}}}if(At())return Tt();function $t(){let o=Math.max(1,ce),l=0,w=0;function q(I){let u=!0;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),y?.(O),v<1&&(u=!1)}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)}`,c&&(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}`),f!==null&&P!==null?v.style.fillOpacity=`${f+(P-f)*de}`:P!==null&&(v.style.fillOpacity=`${P}`),k&&v.tagName.toLowerCase()==="path"&&C[O]&&v.setAttribute("d",tt(C[O],k,de)),O===0&&(y?.(de),e.style.setProperty("--scroll-draw-progress",String(de))),Ce<1&&(u=!1)});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 u}function Q(I){if(K)return;let u=I-l;oe||(oe=!0,N?.());let v=q(u);if(v&&!j){j=!0,q(o*(1+Math.max(0,$.length-1)*F)),le?.(),he<(ae==="infinite"?1/0:ae??0)&&(he++,Ee=setTimeout(()=>{l=performance.now(),oe=!1,j=!1,Se.clear(),He(),X=requestAnimationFrame(Q)},ve));return}v||(X=requestAnimationFrame(Q))}function ee(){cancelAnimationFrame(X),clearTimeout(Ee),l=performance.now(),w=0,K=!1,oe=!1,j=!1,he=0,Se.clear(),He(),X=requestAnimationFrame(Q)}let ie=new IntersectionObserver(I=>{I.forEach(u=>{u.isIntersecting&&!(W&&j)?ee():!u.isIntersecting&&!W&&!j&&(cancelAnimationFrame(X),clearTimeout(Ee),l=null)})},{root:_??null,threshold:ye,rootMargin:we}),h;function L(){clearTimeout(h),h=setTimeout(()=>{$.forEach((I,u)=>{D[u]=Ve(I),I.style.strokeDasharray=`${D[u]}`})},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(h)},replay(){he=0,ee()},pause(){K||(K=!0,w=performance.now()-l,cancelAnimationFrame(X))},resume(){K&&(K=!1,l=performance.now()-w,X=requestAnimationFrame(Q))},seek(I){let u=Math.min(1,Math.max(0,I));Te=u,K=!0,w=u*o,l=performance.now()-w,cancelAnimationFrame(X),q(w)},getProgress(){return Te}}}if(se)return $t();at();function qe(){if(!Fe||K)return;let o=performance.now(),l=De(),w=m;if(H!==!1){let h=o-st,L=h>0?Math.abs(l-(Re<0?l:Re))/h:0;w=m*Math.max(.2,1+L*(typeof H=="number"?H:1)*.04)}Re=l,st=o;let q=g?Ne===-1||l>=Ne?"forward":"reverse":E;Ne=l;let Q=J-Y,ee=!0,ie=Q===0?0:(l-Y)/Q;if(isNaN(Pe)||(Pe<=0&&ie>0?ue?.():Pe>0&&ie<=0&&ke?.(),Pe<1&&ie>=1?Me?.():Pe>=1&&ie<1&&Ie?.()),Pe=ie,me){let h=fe(re(l,Y,J,w));W&&!g&&(pe=Math.max(pe,h),h=pe),Te=h,e.style.setProperty("--scroll-draw-progress",String(h));let L=q==="reverse"?1-h:h;e.style.clipPath=G(L),y?.(h),!oe&&re(l,Y,J,w)>0&&(oe=!0,N?.()),h>=1&&!j?(j=!0,le?.(),he<(ae==="infinite"?1/0:ae??0)&&(he++,Ee=setTimeout(()=>{pe=-1,oe=!1,j=!1,e.style.clipPath=G(0)},ve))):h<1&&!W&&(j=!1),X=requestAnimationFrame(qe);return}if($.forEach((h,L)=>{let I=L*F*Q,u=fe(re(l,Y+I,J+I,w));W&&!g&&(pe=Math.max(pe,u),u=pe),Te=u,h.style.strokeDashoffset=q==="reverse"?`${D[L]*u}`:`${D[L]*(1-u)}`,c&&(h.style.opacity=q==="reverse"?`${1-u}`:`${u}`),ne&&V?h.style.stroke=Le(ne,V,u):V&&(h.style.stroke=V),B!==null&&s!==null?h.style.strokeWidth=`${B+(s-B)*u}`:s!==null&&(h.style.strokeWidth=`${s}`),f!==null&&P!==null?h.style.fillOpacity=`${f+(P-f)*u}`:P!==null&&(h.style.fillOpacity=`${P}`),k&&h.tagName.toLowerCase()==="path"&&C[L]&&h.setAttribute("d",tt(C[L],k,u)),L===0&&(y?.(u),e.style.setProperty("--scroll-draw-progress",String(u))),u<1&&(ee=!1)}),T){let h=fe(re(l,Y,J,w));for(let L in T){let I=parseFloat(L);h>=I&&!Se.has(I)&&(Se.add(I),T[L]?.())}}!oe&&re(l,Y,J,w)>0&&(oe=!0,N?.()),ee&&!j?(j=!0,le?.(),he<(ae==="infinite"?1/0:ae??0)&&(he++,Ee=setTimeout(()=>{pe=-1,oe=!1,j=!1,Se.clear(),He()},ve))):!ee&&!W&&(j=!1),X=requestAnimationFrame(qe)}let Ze=new IntersectionObserver(o=>{o.forEach(l=>{Fe=l.isIntersecting,Fe&&!K?X=requestAnimationFrame(qe):cancelAnimationFrame(X)})},{root:_??null,threshold:ye,rootMargin:we}),Je;function ze(){clearTimeout(Je),Je=setTimeout(()=>{$.forEach((o,l)=>{D[l]=Ve(o),o.style.strokeDasharray=`${D[l]}`}),at()},150)}return window.addEventListener("resize",ze),window.addEventListener("orientationchange",ze),A>0?setTimeout(()=>Ze.observe(e),A):Ze.observe(e),{destroy(){cancelAnimationFrame(X),clearTimeout(Ee),Ze.disconnect(),window.removeEventListener("resize",ze),window.removeEventListener("orientationchange",ze),clearTimeout(Je),Ue?.remove()},replay(){pe=-1,Ne=-1,Re=-1,oe=!1,j=!1,he=0,K=!1,Se.clear(),clearTimeout(Ee),He()},pause(){K=!0,cancelAnimationFrame(X)},resume(){K&&(K=!1,Fe&&(X=requestAnimationFrame(qe)))},seek(o){let l=Math.min(1,Math.max(0,o));Te=l,pe=l,K=!0,cancelAnimationFrame(X),xt(l,E)},getProgress(){return Te}}}var dt=new Map;function _e(e,r){dt.set(e,r)}function Ge(e){dt.delete(e)}function Ht(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function gt(e){let r=[],t=/([\w]+)\(([^)]*)\)/g,n;for(;(n=t.exec(e))!==null;){let a=[],i=[],d=n[2].trim();if(d)for(let m of d.split(/[\s,]+/)){let c=m.match(/^([-+]?[\d.eE]+)(.*)$/);a.push(c?parseFloat(c[1]):0),i.push(c?c[2]:"")}r.push({fn:n[1],nums:a,units:i})}return r}function qt(e,r,t){let n=gt(e),a=gt(r);return n.length===0||n.length!==a.length?t<1?e:r:n.map((i,d)=>{let m=a[d];return i.fn!==m.fn||i.nums.length!==m.nums.length?t<1?`${i.fn}(${i.nums.map((c,p)=>`${c}${i.units[p]}`).join(", ")})`:`${m.fn}(${m.nums.map((c,p)=>`${c}${m.units[p]}`).join(", ")})`:`${i.fn}(${i.nums.map((c,p)=>`${c+(m.nums[p]-c)*t}${i.units[p]}`).join(", ")})`}).join(" ")}function yt(e,r,t){if(typeof e=="number"&&typeof r=="number")return String(e+(r-e)*t);let n=String(e),a=String(r);if(Ht(n))return Le(n,a,t);if(n.includes("("))return qt(n,a,t);let i=n.match(/^([-+]?[\d.]+)(.*)$/),d=a.match(/^([-+]?[\d.]+)(.*)$/);if(i&&d){let m=parseFloat(i[1]),c=parseFloat(d[1]);return`${m+(c-m)*t}${i[2]||d[2]}`}return t<1?n:a}function zt(e){return e.replace(/([A-Z])/g,r=>`-${r.toLowerCase()}`)}var ht={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Vt=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 bt(e,r){let t={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return t;let{props:n,trigger:a={},easing:i="ease-out",speed:d=1,once:m=!1,axis:c="y",scrollContainer:p,native:x=!0,velocityScale:F=!1,onProgress:E,onComplete:W,onEnter:ge,onLeave:S,onEnterBack:M,onLeaveBack:g}=r,A=window.matchMedia("(prefers-reduced-motion: reduce)").matches,b=typeof i=="function"?i:te[i]??te["ease-out"],R=be(a.start??"top bottom"),z=be(a.end??"bottom top"),T=typeof p=="string"?document.querySelector(p):p??null,H=Object.entries(n).map(([s,f])=>({prop:zt(s),from:Array.isArray(f)?f[0]:"",to:Array.isArray(f)?f[1]:f}));function ye(){let s=window.getComputedStyle(e);for(let f of H)f.from===""&&(f.from=s.getPropertyValue(f.prop).trim()||"0")}function we(){for(let s of H)e.style.setProperty(s.prop,String(s.to))}if(A)return we(),W?.(),t;ye();function ae(){if(!x||!Wt()||typeof i!="string"||!(i in ht)||c!=="y"||T||m||d!==1||E||W||ge||S||M||g||F!==!1||(a.start??"top bottom").trim()!=="top bottom"||(a.end??"bottom top").trim()!=="bottom top")return!1;for(let s of H)if(!Vt.has(s.prop))return!1;return!0}function ve(){let s=`ssd-a-${++Bt}`,f=H.map(C=>`${C.prop}:${C.from}`).join(";"),P=H.map(C=>`${C.prop}:${C.to}`).join(";"),G=document.createElement("style");G.setAttribute("data-ssd-animate",""),G.textContent=`@keyframes ${s}{from{${f}}to{${P}}}.${s}{animation-name:${s};animation-duration:auto;animation-timing-function:${ht[i]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(G),e.classList.add(s);let $=()=>c==="x"?window.scrollX:window.scrollY,D=()=>c==="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,yt(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,d))}}}if(ae())return ve();let k=0,U=0,se=0,ce=!1,Z=!1,y=-1,N=0,le=!1,ue=NaN,Me=-1,Ie=0,ke=()=>T?c==="x"?T.scrollLeft:T.scrollTop:c==="x"?window.scrollX:window.scrollY,me=()=>T?c==="x"?T.clientWidth:T.clientHeight:c==="x"?window.innerWidth:window.innerHeight;function fe(){let s=e.getBoundingClientRect(),f,P;if(T){let $=T.getBoundingClientRect();f=c==="x"?s.left-$.left+T.scrollLeft:s.top-$.top+T.scrollTop,P=c==="x"?s.width:s.height}else f=c==="x"?s.left:s.top,P=c==="x"?s.width:s.height;let G=xe({top:f,height:P},ke(),me(),R,z);k=G.tStart,U=G.tEnd}function Ae(s){e.style.setProperty("--scroll-draw-progress",String(s));for(let f of H)e.style.setProperty(f.prop,yt(f.from,f.to,s));E?.(s)}function Oe(s){if(isNaN(ue)){ue=s;return}ue<=0&&s>0?ge?.():ue>0&&s<=0&&g?.(),ue<1&&s>=1?S?.():ue>=1&&s<1&&M?.(),ue=s}function _(){if(!ce||Z)return;let s=performance.now(),f=ke(),P=d;if(F!==!1){let D=s-Ie,C=D>0?Math.abs(f-(Me<0?f:Me))/D:0;P=d*Math.max(.2,1+C*(typeof F=="number"?F:1)*.04)}Me=f,Ie=s;let G=U===k?0:(f-k)/(U-k);Oe(G);let $=b(re(f,k,U,P));m&&(y=Math.max(y,$),$=y),N=$,Ae($),$>=1&&!le?(le=!0,W?.()):$<1&&!m&&(le=!1),se=requestAnimationFrame(_)}fe();{let s=b(re(ke(),k,U,d));m&&s>0&&(y=s),N=s,Ae(s)}let ne=new IntersectionObserver(s=>{s.forEach(f=>{ce=f.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),_e(e,{type:"animate",getProgress:()=>N,getTrigger:()=>({tStart:k,tEnd:U})}),{destroy(){cancelAnimationFrame(se),ne.disconnect(),window.removeEventListener("resize",B),window.removeEventListener("orientationchange",B),clearTimeout(V),Ge(e)},replay(){y=-1,le=!1,N=0,Z=!1,Ae(0)},pause(){Z=!0,cancelAnimationFrame(se)},resume(){Z&&(Z=!1,ce&&(se=requestAnimationFrame(_)))},seek(s){let f=Math.min(1,Math.max(0,s));N=f,y=f,Z=!0,cancelAnimationFrame(se),Ae(f)},getProgress(){return N}}}var je={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function wt(e,r){if(typeof window>"u")return je;let t=typeof e=="string"?document.querySelector(e):e;return t?bt(t,r):(process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollAnimate: element not found:",e),je)}function vt(e,r={}){if(typeof window>"u")return je;let t=typeof e=="string"?document.querySelector(e):e;if(!t)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollParallax: element not found:",e),je;let{speed:n=.3,axis:a="y",easing:i="linear",trigger:d,onProgress:m}=r,c=t.getBoundingClientRect(),p=a==="x"?c.width:c.height,x=n*p;return bt(t,{props:a==="x"?{transform:["translateX(0px)",`translateX(${-x}px)`]}:{transform:["translateY(0px)",`translateY(${-x}px)`]},trigger:d??{start:"top bottom",end:"bottom top"},easing:i,native:!1,onProgress:m})}var rt={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Et(e,r){if(typeof window>"u")return rt;let t=typeof e=="string"?document.querySelector(e):e;if(!t)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollCounter: element not found:",e),rt;let n=t,{from:a=0,to:i,format:d,easing:m="ease-out",trigger:c={},once:p=!0,decimals:x,onComplete:F}=r,E=x!==void 0?y=>y.toFixed(x):d??(y=>String(Math.round(y))),W=typeof m=="function"?m:te[m]??te["ease-out"],ge=be(c.start??"top 80%"),S=be(c.end??"top 20%");if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return n.textContent=E(i),F?.(),rt;n.textContent=E(a);let g=0,A=0,b=0,R=!1,z=!1,T=-1,H=0,ye=!1,we=()=>window.scrollY,ae=()=>window.innerHeight;function ve(){let y=n.getBoundingClientRect(),N=xe({top:y.top,height:y.height},we(),ae(),ge,S);g=N.tStart,A=N.tEnd}function k(y){n.textContent=E(a+(i-a)*y),n.style.setProperty("--scroll-draw-progress",String(y))}function U(){if(!R||z)return;let y=W(re(we(),g,A,1));p&&(T=Math.max(T,y),y=T),H=y,k(y),y>=1&&!ye?(ye=!0,F?.()):y<1&&!p&&(ye=!1),b=requestAnimationFrame(U)}ve();{let y=W(re(we(),g,A,1));p&&y>0&&(T=y),H=y,k(y)}let se=new IntersectionObserver(y=>{y.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),_e(n,{type:"counter",getProgress:()=>H,getTrigger:()=>({tStart:g,tEnd:A})}),{destroy(){cancelAnimationFrame(b),se.disconnect(),window.removeEventListener("resize",Z),window.removeEventListener("orientationchange",Z),clearTimeout(ce),Ge(n)},replay(){T=-1,ye=!1,H=0,z=!1,k(0)},pause(){z=!0,cancelAnimationFrame(b)},resume(){z&&(z=!1,R&&(b=requestAnimationFrame(U)))},seek(y){let N=Math.min(1,Math.max(0,y));H=N,T=N,z=!0,cancelAnimationFrame(b),k(N)},getProgress(){return H}}}var St="http://www.w3.org/2000/svg",_t="cinematic-photo",nt=e=>e<0?0:e>1?1:e;function Xe(e){let r=parseFloat(e);return Number.isFinite(r)?nt(r/100):0}function Gt(e){return te[e]??te.linear}var jt={destroy:()=>{},getProgress:()=>0},Ye=class{constructor(r){if(typeof document>"u"){this.mount=null;return}this.mount=typeof r.wrapper=="string"?document.querySelector(r.wrapper):r.wrapper,!this.mount&&process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] Cinematic: wrapper not found:",r.wrapper)}loadStory(r){let t=this.mount;if(typeof window>"u"||!t)return jt;t.style.position="relative",t.style.height=r.totalHeight,t.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;",t.appendChild(n);let a=[];for(let S of r.scenes){if(S.background){let g=document.createElement("img");g.id=_t,g.src=S.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 M=S.animations.filter(g=>g.type==="draw");if(M.length){let g=document.createElementNS(St,"svg");g.setAttribute("viewBox",`0 0 ${r.canvas.width} ${r.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 A of M){let b=document.createElementNS(St,"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),g.appendChild(b),a.push({kind:"draw",el:b,start:Xe(A.start),end:Xe(A.end),ease:Gt(A.easing),length:R})}}for(let g of S.animations){if(g.type!=="fade")continue;let A=n.querySelector(g.target)??document.querySelector(g.target);A&&(A.style.opacity=String(g.from),a.push({kind:"fade",el:A,start:Xe(g.start),end:Xe(g.end),ease:te["ease-in-out"]??te.linear,from:g.from,to:g.to}))}}let i=0,d=()=>{let S=t.offsetHeight-window.innerHeight;return S<=0?t.getBoundingClientRect().top<=0?1:0:nt(-t.getBoundingClientRect().top/S)},m=S=>{for(let M of a){let g=M.end-M.start,A=g<=0?S>=M.end?1:0:nt((S-M.start)/g),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 m(1),{destroy:()=>{},getProgress:()=>1};let c=0,p=!1,x=!1,F=()=>{i=d(),m(i),p&&(c=requestAnimationFrame(F))},E=()=>{p||(p=!0,c=requestAnimationFrame(F))},W=()=>{p=!1,cancelAnimationFrame(c)},ge=new IntersectionObserver(S=>{for(let M of S)x=M.isIntersecting,x?E():W()},{threshold:0});return ge.observe(n),i=d(),m(i),{destroy(){W(),ge.disconnect()},getProgress:()=>i}}};function Xt(e,r){let t={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return t;let n=typeof e=="string"?document.querySelector(e):e;return n?We(n,r):(console.warn("[svg-scroll-draw] Container not found:",e),t)}var ot=class extends HTMLElement{constructor(){super(...arguments);this.instance=null}connectedCallback(){let t={},n=this.getAttribute("speed"),a=this.getAttribute("easing"),i=this.getAttribute("stagger"),d=this.getAttribute("direction"),m=this.getAttribute("selector");n&&(t.speed=parseFloat(n)),a&&(t.easing=a),i&&(t.stagger=parseFloat(i)),d&&(t.direction=d),m&&(t.selector=m),this.hasAttribute("fade")&&(t.fade=this.getAttribute("fade")!=="false"),this.instance=We(this,t)}disconnectedCallback(){this.instance?.destroy(),this.instance=null}};typeof customElements<"u"&&!customElements.get("scroll-draw")&&customElements.define("scroll-draw",ot);return It(Yt);})();
|
package/dist/devtools/index.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
'use strict';var C=new Map;function x(){return C}var v={draw:"#60a5fa",animate:"#4ade80",counter:"#fbbf24",video:"#c084fc",text:"#fb923c"},n=null,o=null,b=0,p=false,m=null;function L(){o?.remove(),o=document.createElement("div"),o.setAttribute("data-ssd-devtools-overlay",""),o.style.cssText="position:fixed;pointer-events:none;z-index:99998;inset:0;overflow:hidden;",document.body.appendChild(o);}function $(){if(!o)return;o.innerHTML="";let e=window.scrollY,l=window.innerHeight;for(let[,t]of x()){let{tStart:i,tEnd:r}=t.getTrigger(),d=v[t.type]??"#60a5fa",f=i-e,s=r-e;if(s<-100||f>l+100)continue;let c=(u,y)=>{let a=document.createElement("div");a.style.cssText=`position:absolute;left:0;right:0;top:${u}px;height:2px;background:${d};opacity:0.85;`;let g=document.createElement("span");return g.textContent=y,g.style.cssText=`position:absolute;right:8px;top:-18px;font:bold 9px/1 monospace;color:#fff;background:${d};padding:2px 5px;border-radius:3px;white-space:nowrap;`,a.appendChild(g),a};o.appendChild(c(f,`\u25B6 ${t.type}:start`)),o.appendChild(c(s,`\u25A0 ${t.type}:end`));}}function M(){n?.remove(),n=document.createElement("div"),n.setAttribute("data-ssd-devtools-panel",""),n.style.cssText="position:fixed;bottom:12px;right:12px;z-index:99999;background:rgba(10,10,10,0.92);color:#e8e8e3;border-radius:10px;border:1px solid #333;font:12px/1.5 monospace;padding:10px 14px;min-width:220px;max-width:280px;pointer-events:none;backdrop-filter:blur(4px);";let e=document.createElement("div");e.style.cssText="font-weight:bold;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:#888;margin-bottom:8px;",e.textContent="\u26A1 svg-scroll-draw devtools",n.appendChild(e),document.body.appendChild(n);}function k(){if(!n)return;for(;n.children.length>1;)n.removeChild(n.lastChild);let e=x();if(e.size===0){let t=document.createElement("div");t.style.cssText="color:#555;font-size:11px;",t.textContent="No active instances.",n.appendChild(t);return}for(let[t,i]of e){let r=i.getProgress(),d=v[i.type]??"#60a5fa",f=t.id?`#${t.id}`:t.className?`.${t.className.split(" ")[0]}`:i.type,s=document.createElement("div");s.style.cssText="margin-bottom:6px;";let c=document.createElement("div");c.style.cssText=`font-size:10px;color:${d};margin-bottom:2px;`,c.textContent=`${i.type} ${f}`;let u=document.createElement("div");u.style.cssText="height:6px;background:#222;border-radius:3px;overflow:hidden;";let y=document.createElement("div");y.style.cssText=`height:100%;width:${Math.round(r*100)}%;background:${d};border-radius:3px;transition:width 0.1s;`,u.appendChild(y),s.appendChild(c),s.appendChild(u);let a=document.createElement("div");a.style.cssText="font-size:9px;color:#555;text-align:right;margin-top:1px;",a.textContent=`${Math.round(r*100)}%`,s.appendChild(a),n.appendChild(s);}}function h(){$(),k(),b=requestAnimationFrame(h);}function E(){process.env.NODE_ENV!=="production"&&(p||(p=true,L(),M(),b=requestAnimationFrame(h),m=e=>{(e.metaKey||e.ctrlKey)&&e.shiftKey&&e.key.toLowerCase()==="s"&&(e.preventDefault(),w());},window.addEventListener("keydown",m)));}function T(){p&&(p=false,cancelAnimationFrame(b),n?.remove(),n=null,o?.remove(),o=null,m&&(window.removeEventListener("keydown",m),m=null));}function w(){p?T():E();}function H(e){if(!p)return;let l=typeof e=="string"?document.querySelector(e):e;if(!l)return;let t=x().get(l);if(!t)return;let i=v[t.type]??"#60a5fa",r=l,d=r.style.outline;r.style.outline=`2px solid ${i}`,r.style.outlineOffset="2px",setTimeout(()=>{r.style.outline=d,r.style.outlineOffset="";},2e3);}var _={enable:E,disable:T,toggle:w,highlight:H};exports.devtools=_;
|
|
1
|
+
'use strict';var C=new Map;function x(){return C}var v={draw:"#60a5fa",animate:"#4ade80",counter:"#fbbf24",video:"#c084fc",text:"#fb923c",pin:"#f43f5e",snap:"#22d3ee"},n=null,o=null,b=0,p=false,m=null;function L(){o?.remove(),o=document.createElement("div"),o.setAttribute("data-ssd-devtools-overlay",""),o.style.cssText="position:fixed;pointer-events:none;z-index:99998;inset:0;overflow:hidden;",document.body.appendChild(o);}function $(){if(!o)return;o.innerHTML="";let e=window.scrollY,l=window.innerHeight;for(let[,t]of x()){let{tStart:i,tEnd:r}=t.getTrigger(),d=v[t.type]??"#60a5fa",f=i-e,s=r-e;if(s<-100||f>l+100)continue;let c=(u,y)=>{let a=document.createElement("div");a.style.cssText=`position:absolute;left:0;right:0;top:${u}px;height:2px;background:${d};opacity:0.85;`;let g=document.createElement("span");return g.textContent=y,g.style.cssText=`position:absolute;right:8px;top:-18px;font:bold 9px/1 monospace;color:#fff;background:${d};padding:2px 5px;border-radius:3px;white-space:nowrap;`,a.appendChild(g),a};o.appendChild(c(f,`\u25B6 ${t.type}:start`)),o.appendChild(c(s,`\u25A0 ${t.type}:end`));}}function M(){n?.remove(),n=document.createElement("div"),n.setAttribute("data-ssd-devtools-panel",""),n.style.cssText="position:fixed;bottom:12px;right:12px;z-index:99999;background:rgba(10,10,10,0.92);color:#e8e8e3;border-radius:10px;border:1px solid #333;font:12px/1.5 monospace;padding:10px 14px;min-width:220px;max-width:280px;pointer-events:none;backdrop-filter:blur(4px);";let e=document.createElement("div");e.style.cssText="font-weight:bold;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:#888;margin-bottom:8px;",e.textContent="\u26A1 svg-scroll-draw devtools",n.appendChild(e),document.body.appendChild(n);}function k(){if(!n)return;for(;n.children.length>1;)n.removeChild(n.lastChild);let e=x();if(e.size===0){let t=document.createElement("div");t.style.cssText="color:#555;font-size:11px;",t.textContent="No active instances.",n.appendChild(t);return}for(let[t,i]of e){let r=i.getProgress(),d=v[i.type]??"#60a5fa",f=t.id?`#${t.id}`:t.className?`.${t.className.split(" ")[0]}`:i.type,s=document.createElement("div");s.style.cssText="margin-bottom:6px;";let c=document.createElement("div");c.style.cssText=`font-size:10px;color:${d};margin-bottom:2px;`,c.textContent=`${i.type} ${f}`;let u=document.createElement("div");u.style.cssText="height:6px;background:#222;border-radius:3px;overflow:hidden;";let y=document.createElement("div");y.style.cssText=`height:100%;width:${Math.round(r*100)}%;background:${d};border-radius:3px;transition:width 0.1s;`,u.appendChild(y),s.appendChild(c),s.appendChild(u);let a=document.createElement("div");a.style.cssText="font-size:9px;color:#555;text-align:right;margin-top:1px;",a.textContent=`${Math.round(r*100)}%`,s.appendChild(a),n.appendChild(s);}}function h(){$(),k(),b=requestAnimationFrame(h);}function E(){process.env.NODE_ENV!=="production"&&(p||(p=true,L(),M(),b=requestAnimationFrame(h),m=e=>{(e.metaKey||e.ctrlKey)&&e.shiftKey&&e.key.toLowerCase()==="s"&&(e.preventDefault(),w());},window.addEventListener("keydown",m)));}function T(){p&&(p=false,cancelAnimationFrame(b),n?.remove(),n=null,o?.remove(),o=null,m&&(window.removeEventListener("keydown",m),m=null));}function w(){p?T():E();}function H(e){if(!p)return;let l=typeof e=="string"?document.querySelector(e):e;if(!l)return;let t=x().get(l);if(!t)return;let i=v[t.type]??"#60a5fa",r=l,d=r.style.outline;r.style.outline=`2px solid ${i}`,r.style.outlineOffset="2px",setTimeout(()=>{r.style.outline=d,r.style.outlineOffset="";},2e3);}var _={enable:E,disable:T,toggle:w,highlight:H};exports.devtools=_;
|
package/dist/devtools/index.mjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var C=new Map;function x(){return C}var v={draw:"#60a5fa",animate:"#4ade80",counter:"#fbbf24",video:"#c084fc",text:"#fb923c"},n=null,o=null,b=0,p=false,m=null;function L(){o?.remove(),o=document.createElement("div"),o.setAttribute("data-ssd-devtools-overlay",""),o.style.cssText="position:fixed;pointer-events:none;z-index:99998;inset:0;overflow:hidden;",document.body.appendChild(o);}function $(){if(!o)return;o.innerHTML="";let e=window.scrollY,l=window.innerHeight;for(let[,t]of x()){let{tStart:i,tEnd:r}=t.getTrigger(),d=v[t.type]??"#60a5fa",f=i-e,s=r-e;if(s<-100||f>l+100)continue;let c=(u,y)=>{let a=document.createElement("div");a.style.cssText=`position:absolute;left:0;right:0;top:${u}px;height:2px;background:${d};opacity:0.85;`;let g=document.createElement("span");return g.textContent=y,g.style.cssText=`position:absolute;right:8px;top:-18px;font:bold 9px/1 monospace;color:#fff;background:${d};padding:2px 5px;border-radius:3px;white-space:nowrap;`,a.appendChild(g),a};o.appendChild(c(f,`\u25B6 ${t.type}:start`)),o.appendChild(c(s,`\u25A0 ${t.type}:end`));}}function M(){n?.remove(),n=document.createElement("div"),n.setAttribute("data-ssd-devtools-panel",""),n.style.cssText="position:fixed;bottom:12px;right:12px;z-index:99999;background:rgba(10,10,10,0.92);color:#e8e8e3;border-radius:10px;border:1px solid #333;font:12px/1.5 monospace;padding:10px 14px;min-width:220px;max-width:280px;pointer-events:none;backdrop-filter:blur(4px);";let e=document.createElement("div");e.style.cssText="font-weight:bold;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:#888;margin-bottom:8px;",e.textContent="\u26A1 svg-scroll-draw devtools",n.appendChild(e),document.body.appendChild(n);}function k(){if(!n)return;for(;n.children.length>1;)n.removeChild(n.lastChild);let e=x();if(e.size===0){let t=document.createElement("div");t.style.cssText="color:#555;font-size:11px;",t.textContent="No active instances.",n.appendChild(t);return}for(let[t,i]of e){let r=i.getProgress(),d=v[i.type]??"#60a5fa",f=t.id?`#${t.id}`:t.className?`.${t.className.split(" ")[0]}`:i.type,s=document.createElement("div");s.style.cssText="margin-bottom:6px;";let c=document.createElement("div");c.style.cssText=`font-size:10px;color:${d};margin-bottom:2px;`,c.textContent=`${i.type} ${f}`;let u=document.createElement("div");u.style.cssText="height:6px;background:#222;border-radius:3px;overflow:hidden;";let y=document.createElement("div");y.style.cssText=`height:100%;width:${Math.round(r*100)}%;background:${d};border-radius:3px;transition:width 0.1s;`,u.appendChild(y),s.appendChild(c),s.appendChild(u);let a=document.createElement("div");a.style.cssText="font-size:9px;color:#555;text-align:right;margin-top:1px;",a.textContent=`${Math.round(r*100)}%`,s.appendChild(a),n.appendChild(s);}}function h(){$(),k(),b=requestAnimationFrame(h);}function E(){process.env.NODE_ENV!=="production"&&(p||(p=true,L(),M(),b=requestAnimationFrame(h),m=e=>{(e.metaKey||e.ctrlKey)&&e.shiftKey&&e.key.toLowerCase()==="s"&&(e.preventDefault(),w());},window.addEventListener("keydown",m)));}function T(){p&&(p=false,cancelAnimationFrame(b),n?.remove(),n=null,o?.remove(),o=null,m&&(window.removeEventListener("keydown",m),m=null));}function w(){p?T():E();}function H(e){if(!p)return;let l=typeof e=="string"?document.querySelector(e):e;if(!l)return;let t=x().get(l);if(!t)return;let i=v[t.type]??"#60a5fa",r=l,d=r.style.outline;r.style.outline=`2px solid ${i}`,r.style.outlineOffset="2px",setTimeout(()=>{r.style.outline=d,r.style.outlineOffset="";},2e3);}var _={enable:E,disable:T,toggle:w,highlight:H};export{_ as devtools};
|
|
1
|
+
var C=new Map;function x(){return C}var v={draw:"#60a5fa",animate:"#4ade80",counter:"#fbbf24",video:"#c084fc",text:"#fb923c",pin:"#f43f5e",snap:"#22d3ee"},n=null,o=null,b=0,p=false,m=null;function L(){o?.remove(),o=document.createElement("div"),o.setAttribute("data-ssd-devtools-overlay",""),o.style.cssText="position:fixed;pointer-events:none;z-index:99998;inset:0;overflow:hidden;",document.body.appendChild(o);}function $(){if(!o)return;o.innerHTML="";let e=window.scrollY,l=window.innerHeight;for(let[,t]of x()){let{tStart:i,tEnd:r}=t.getTrigger(),d=v[t.type]??"#60a5fa",f=i-e,s=r-e;if(s<-100||f>l+100)continue;let c=(u,y)=>{let a=document.createElement("div");a.style.cssText=`position:absolute;left:0;right:0;top:${u}px;height:2px;background:${d};opacity:0.85;`;let g=document.createElement("span");return g.textContent=y,g.style.cssText=`position:absolute;right:8px;top:-18px;font:bold 9px/1 monospace;color:#fff;background:${d};padding:2px 5px;border-radius:3px;white-space:nowrap;`,a.appendChild(g),a};o.appendChild(c(f,`\u25B6 ${t.type}:start`)),o.appendChild(c(s,`\u25A0 ${t.type}:end`));}}function M(){n?.remove(),n=document.createElement("div"),n.setAttribute("data-ssd-devtools-panel",""),n.style.cssText="position:fixed;bottom:12px;right:12px;z-index:99999;background:rgba(10,10,10,0.92);color:#e8e8e3;border-radius:10px;border:1px solid #333;font:12px/1.5 monospace;padding:10px 14px;min-width:220px;max-width:280px;pointer-events:none;backdrop-filter:blur(4px);";let e=document.createElement("div");e.style.cssText="font-weight:bold;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:#888;margin-bottom:8px;",e.textContent="\u26A1 svg-scroll-draw devtools",n.appendChild(e),document.body.appendChild(n);}function k(){if(!n)return;for(;n.children.length>1;)n.removeChild(n.lastChild);let e=x();if(e.size===0){let t=document.createElement("div");t.style.cssText="color:#555;font-size:11px;",t.textContent="No active instances.",n.appendChild(t);return}for(let[t,i]of e){let r=i.getProgress(),d=v[i.type]??"#60a5fa",f=t.id?`#${t.id}`:t.className?`.${t.className.split(" ")[0]}`:i.type,s=document.createElement("div");s.style.cssText="margin-bottom:6px;";let c=document.createElement("div");c.style.cssText=`font-size:10px;color:${d};margin-bottom:2px;`,c.textContent=`${i.type} ${f}`;let u=document.createElement("div");u.style.cssText="height:6px;background:#222;border-radius:3px;overflow:hidden;";let y=document.createElement("div");y.style.cssText=`height:100%;width:${Math.round(r*100)}%;background:${d};border-radius:3px;transition:width 0.1s;`,u.appendChild(y),s.appendChild(c),s.appendChild(u);let a=document.createElement("div");a.style.cssText="font-size:9px;color:#555;text-align:right;margin-top:1px;",a.textContent=`${Math.round(r*100)}%`,s.appendChild(a),n.appendChild(s);}}function h(){$(),k(),b=requestAnimationFrame(h);}function E(){process.env.NODE_ENV!=="production"&&(p||(p=true,L(),M(),b=requestAnimationFrame(h),m=e=>{(e.metaKey||e.ctrlKey)&&e.shiftKey&&e.key.toLowerCase()==="s"&&(e.preventDefault(),w());},window.addEventListener("keydown",m)));}function T(){p&&(p=false,cancelAnimationFrame(b),n?.remove(),n=null,o?.remove(),o=null,m&&(window.removeEventListener("keydown",m),m=null));}function w(){p?T():E();}function H(e){if(!p)return;let l=typeof e=="string"?document.querySelector(e):e;if(!l)return;let t=x().get(l);if(!t)return;let i=v[t.type]??"#60a5fa",r=l,d=r.style.outline;r.style.outline=`2px solid ${i}`,r.style.outlineOffset="2px",setTimeout(()=>{r.style.outline=d,r.style.outlineOffset="";},2e3);}var _={enable:E,disable:T,toggle:w,highlight:H};export{_ as devtools};
|
package/dist/group/index.cjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';function
|
|
2
|
-
<div style="position:absolute;${
|
|
3
|
-
<div style="position:absolute;${l?`left:${i}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${i}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(t),window.addEventListener("scroll",o,{passive:true}),o(),t}function _e(e,n,r){let t=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),o=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,c=>{let m=parseFloat(c),i=t[o++]??m;return String(+(m+(i-m)*r).toFixed(4))})}function Ge(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...t}=n,o=r?{...Je[r],...t}:t,c=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:m="path, polyline, line, polygon, rect, circle",speed:i=1,fade:l=false,easing:g="linear",trigger:x={},stagger:V=0,direction:E="forward",once:re=false,debug:Pe=false,axis:z="y",scrollContainer:Ee,autoReverse:L=false,delay:W=0,strokeColor:ne,strokeWidth:se,fillOpacity:oe,waypoints:ie,velocityScale:ae=false,threshold:ge=0,rootMargin:Z="0px",repeat:_=0,repeatDelay:B=0,morphTo:D,clip:J,autoplay:ve=false,duration:Me=1e3,native:ze=true,onProgress:ce,onStart:le,onComplete:K}=o,j=J===true?"left":typeof J=="string"?J:false,X=typeof g=="function"?g:xe[g]??xe.linear,ye=$e(x.start??"top bottom"),u=$e(x.end??"bottom top"),f=typeof Ee=="string"?document.querySelector(Ee):Ee??null,O=Array.isArray(ne)?ne[0]:null,S=Array.isArray(ne)?ne[1]:typeof ne=="string"?ne:null,M=Array.isArray(se)?se[0]:null,F=Array.isArray(se)?se[1]:typeof se=="number"?se:null,w=Array.isArray(oe)?oe[0]:null,A=Array.isArray(oe)?oe[1]:typeof oe=="number"?oe:null;function q(s){let a=s*100;switch(j){case "right":return `inset(0 0 0 ${100-a}%)`;case "top":return `inset(0 0 ${100-a}% 0)`;case "bottom":return `inset(${100-a}% 0 0 0)`;case "center":return `circle(${s*150}% at 50% 50%)`;default:return `inset(0 ${100-a}% 0 0)`}}let I=j?[]:Array.from(e.querySelectorAll(m)),T=[],Q=[],fe=0,me=0,N=false,Y=false,C=0,De=false,ee=-1,Ie=-1,R=false,he=0,ue=0,pe,We=null,de=new Set,Ce=-1,Be=performance.now();function ke(){return f?z==="x"?f.scrollLeft:f.scrollTop:z==="x"?window.scrollX:window.scrollY}function je(){return f?z==="x"?f.clientWidth:f.clientHeight:z==="x"?window.innerWidth:window.innerHeight}function Xe(){let s=e.getBoundingClientRect(),a,y,P;if(f){let H=f.getBoundingClientRect();a=z==="x"?s.left-H.left+f.scrollLeft:s.top-H.top+f.scrollTop,y=z==="x"?s.width:s.height,P=ke();}else a=z==="x"?s.left:s.top,y=z==="x"?s.width:s.height,P=ke();let G=Ae({top:a,height:y},P,je(),ye,u);fe=G.tStart,me=G.tEnd,Pe&&process.env.NODE_ENV!=="production"&&(We?.remove(),We=bt(fe,me,z));}function lt(s,a){if(e.style.setProperty("--scroll-draw-progress",String(s)),j){let y=a==="reverse"?1-s:s;e.style.clipPath=q(y);return}I.forEach((y,P)=>{y.style.strokeDashoffset=a==="reverse"?`${T[P]*s}`:`${T[P]*(1-s)}`,l&&(y.style.opacity=a==="reverse"?`${1-s}`:`${s}`),O&&S?y.style.stroke=Te(O,S,s):S&&(y.style.stroke=S),M!==null&&F!==null?y.style.strokeWidth=`${M+(F-M)*s}`:F!==null&&(y.style.strokeWidth=`${F}`),w!==null&&A!==null?y.style.fillOpacity=`${w+(A-w)*s}`:A!==null&&(y.style.fillOpacity=`${A}`),D&&y.tagName.toLowerCase()==="path"&&Q[P]&&y.setAttribute("d",_e(Q[P],D,s));});}function Oe(){if(e.style.setProperty("--scroll-draw-progress","0"),j){e.style.clipPath=q(0);return}I.forEach((s,a)=>{s.style.strokeDasharray=`${T[a]}`,s.style.strokeDashoffset=E==="reverse"?"0":`${T[a]}`,l?s.style.opacity=E==="reverse"?"1":"0":s.style.opacity="",O&&(s.style.stroke=O),M!==null&&(s.style.strokeWidth=`${M}`),w!==null&&(s.style.fillOpacity=`${w}`),D&&s.tagName.toLowerCase()==="path"&&Q[a]&&s.setAttribute("d",Q[a]);});}if(I.forEach(s=>{ht(s);let a=Re(s);T.push(a),s.tagName.toLowerCase()==="path"?Q.push(s.getAttribute("d")??""):Q.push(""),c?(s.style.strokeDasharray=`${a}`,s.style.strokeDashoffset=E==="reverse"?`${a}`:"0",l&&(s.style.opacity="1"),S&&(s.style.stroke=S),F!==null&&(s.style.strokeWidth=`${F}`),A!==null&&(s.style.fillOpacity=`${A}`),D&&s.tagName.toLowerCase()==="path"&&s.setAttribute("d",D)):(s.style.strokeDasharray=`${a}`,s.style.strokeDashoffset=E==="reverse"?"0":`${a}`,l?s.style.opacity=E==="reverse"?"1":"0":s.style.opacity="",O&&(s.style.stroke=O),M!==null&&(s.style.strokeWidth=`${M}`),w!==null&&(s.style.fillOpacity=`${w}`));}),j){if(c)return e.style.clipPath=q(1),K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=q(0);}else if(c)return K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function ut(){return !(ze===false||!yt()||!I.length||typeof g!="string"||!(g in Qe)||j||z!=="y"||f||i!==1||V!==0||re||L||ae!==false||D||ie||_||W>0||ce||le||K||ne!=null||se!=null||oe!=null||(x.start??"top bottom").trim()!=="top bottom"||(x.end??"bottom top").trim()!=="bottom top")}function ct(){let s=`svg-scroll-draw-${++gt}`,a=E==="reverse"?"0":"var(--ssd-len)",y=E==="reverse"?"var(--ssd-len)":"0",P=`stroke-dashoffset:${a};`,G=`stroke-dashoffset:${y};`;l&&(P+=`opacity:${E==="reverse"?1:0};`,G+=`opacity:${E==="reverse"?0:1};`);let H=document.createElement("style");H.setAttribute("data-svg-scroll-draw",""),H.textContent=`@keyframes ${s}{from{${P}}to{${G}}}.${s}{animation-name:${s};animation-duration:auto;animation-timing-function:${Qe[g]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(H);function d(p,b){p.style.setProperty("--ssd-len",String(T[b])),p.style.strokeDasharray=`${T[b]}`,p.style.strokeDashoffset="",p.style.opacity="",p.style.animationPlayState="",p.classList.add(s);}I.forEach(d);let v=false,k=-1;function h(){if(k>=0)return k;let p=e.getBoundingClientRect(),{tStart:b,tEnd:$}=Ae({top:p.top,height:p.height},ke(),je(),ye,u);return X(U(ke(),b,$,i))}return {destroy(){I.forEach(p=>{p.classList.remove(s),p.style.removeProperty("--ssd-len"),p.style.animationPlayState="";}),H.remove();},replay(){v=false,k=-1,I.forEach(d);},pause(){v=true,I.forEach(p=>{p.style.animationPlayState="paused";});},resume(){v&&(v=false,I.forEach(p=>{p.style.animationPlayState="running";}));},seek(p){let b=Math.min(1,Math.max(0,p));k=b,v=true,I.forEach(($,be)=>{$.classList.remove(s),$.style.strokeDashoffset=E==="reverse"?`${T[be]*b}`:`${T[be]*(1-b)}`,l&&($.style.opacity=E==="reverse"?`${1-b}`:`${b}`);});},getProgress(){return h()}}}if(ut())return ct();function ft(){let s=Math.max(1,Me),a=0,y=0;function P(h){let p=true;if(j){let b=Math.min(1,Math.max(0,h/s)),$=X(b);he=$,e.style.setProperty("--scroll-draw-progress",String($)),e.style.clipPath=q(E==="reverse"?1-$:$),ce?.($),b<1&&(p=false);}else I.forEach((b,$)=>{let be=$*V*s,Se=Math.min(1,Math.max(0,(h-be)/s)),te=X(Se);b.style.strokeDashoffset=E==="reverse"?`${T[$]*te}`:`${T[$]*(1-te)}`,l&&(b.style.opacity=E==="reverse"?`${1-te}`:`${te}`),O&&S?b.style.stroke=Te(O,S,te):S&&(b.style.stroke=S),M!==null&&F!==null?b.style.strokeWidth=`${M+(F-M)*te}`:F!==null&&(b.style.strokeWidth=`${F}`),w!==null&&A!==null?b.style.fillOpacity=`${w+(A-w)*te}`:A!==null&&(b.style.fillOpacity=`${A}`),D&&b.tagName.toLowerCase()==="path"&&Q[$]&&b.setAttribute("d",_e(Q[$],D,te)),$===0&&(ce?.(te),e.style.setProperty("--scroll-draw-progress",String(te))),Se<1&&(p=false);});if(ie){let b=Math.min(1,Math.max(0,h/s)),$=X(b);for(let be in ie){let Se=parseFloat(be);$>=Se&&!de.has(Se)&&(de.add(Se),ie[be]?.());}}return p}function G(h){if(R)return;let p=h-a;Y||(Y=true,le?.());let b=P(p);if(b&&!N){N=true,P(s*(1+Math.max(0,I.length-1)*V)),K?.(),ue<(_==="infinite"?1/0:_??0)&&(ue++,pe=setTimeout(()=>{a=performance.now(),Y=false,N=false,de.clear(),Oe(),C=requestAnimationFrame(G);},B));return}b||(C=requestAnimationFrame(G));}function H(){cancelAnimationFrame(C),clearTimeout(pe),a=performance.now(),y=0,R=false,Y=false,N=false,ue=0,de.clear(),Oe(),C=requestAnimationFrame(G);}let d=new IntersectionObserver(h=>{h.forEach(p=>{p.isIntersecting&&!(re&&N)?H():!p.isIntersecting&&!re&&!N&&(cancelAnimationFrame(C),clearTimeout(pe),a=null);});},{root:f??null,threshold:ge,rootMargin:Z}),v;function k(){clearTimeout(v),v=setTimeout(()=>{I.forEach((h,p)=>{T[p]=Re(h),h.style.strokeDasharray=`${T[p]}`;});},150);}return window.addEventListener("resize",k),window.addEventListener("orientationchange",k),W>0?setTimeout(()=>d.observe(e),W):d.observe(e),{destroy(){cancelAnimationFrame(C),clearTimeout(pe),d.disconnect(),window.removeEventListener("resize",k),window.removeEventListener("orientationchange",k),clearTimeout(v);},replay(){ue=0,H();},pause(){R||(R=true,y=performance.now()-a,cancelAnimationFrame(C));},resume(){R&&(R=false,a=performance.now()-y,C=requestAnimationFrame(G));},seek(h){let p=Math.min(1,Math.max(0,h));he=p,R=true,y=p*s,a=performance.now()-y,cancelAnimationFrame(C),P(y);},getProgress(){return he}}}if(ve)return ft();Xe();function Fe(){if(!De||R)return;let s=performance.now(),a=ke(),y=i;if(ae!==false){let d=s-Be,v=d>0?Math.abs(a-(Ce<0?a:Ce))/d:0;y=i*Math.max(.2,1+v*(typeof ae=="number"?ae:1)*.04);}Ce=a,Be=s;let P=L?Ie===-1||a>=Ie?"forward":"reverse":E;Ie=a;let G=me-fe,H=true;if(j){let d=X(U(a,fe,me,y));re&&!L&&(ee=Math.max(ee,d),d=ee),he=d,e.style.setProperty("--scroll-draw-progress",String(d));let v=P==="reverse"?1-d:d;e.style.clipPath=q(v),ce?.(d),!Y&&U(a,fe,me,y)>0&&(Y=true,le?.()),d>=1&&!N?(N=true,K?.(),ue<(_==="infinite"?1/0:_??0)&&(ue++,pe=setTimeout(()=>{ee=-1,Y=false,N=false,e.style.clipPath=q(0);},B))):d<1&&!re&&(N=false),C=requestAnimationFrame(Fe);return}if(I.forEach((d,v)=>{let k=v*V*G,h=X(U(a,fe+k,me+k,y));re&&!L&&(ee=Math.max(ee,h),h=ee),he=h,d.style.strokeDashoffset=P==="reverse"?`${T[v]*h}`:`${T[v]*(1-h)}`,l&&(d.style.opacity=P==="reverse"?`${1-h}`:`${h}`),O&&S?d.style.stroke=Te(O,S,h):S&&(d.style.stroke=S),M!==null&&F!==null?d.style.strokeWidth=`${M+(F-M)*h}`:F!==null&&(d.style.strokeWidth=`${F}`),w!==null&&A!==null?d.style.fillOpacity=`${w+(A-w)*h}`:A!==null&&(d.style.fillOpacity=`${A}`),D&&d.tagName.toLowerCase()==="path"&&Q[v]&&d.setAttribute("d",_e(Q[v],D,h)),v===0&&(ce?.(h),e.style.setProperty("--scroll-draw-progress",String(h))),h<1&&(H=false);}),ie){let d=X(U(a,fe,me,y));for(let v in ie){let k=parseFloat(v);d>=k&&!de.has(k)&&(de.add(k),ie[v]?.());}}!Y&&U(a,fe,me,y)>0&&(Y=true,le?.()),H&&!N?(N=true,K?.(),ue<(_==="infinite"?1/0:_??0)&&(ue++,pe=setTimeout(()=>{ee=-1,Y=false,N=false,de.clear(),Oe();},B))):!H&&!re&&(N=false),C=requestAnimationFrame(Fe);}let qe=new IntersectionObserver(s=>{s.forEach(a=>{De=a.isIntersecting,De&&!R?C=requestAnimationFrame(Fe):cancelAnimationFrame(C);});},{root:f??null,threshold:ge,rootMargin:Z}),Ve;function Ne(){clearTimeout(Ve),Ve=setTimeout(()=>{I.forEach((s,a)=>{T[a]=Re(s),s.style.strokeDasharray=`${T[a]}`;}),Xe();},150);}return window.addEventListener("resize",Ne),window.addEventListener("orientationchange",Ne),W>0?setTimeout(()=>qe.observe(e),W):qe.observe(e),{destroy(){cancelAnimationFrame(C),clearTimeout(pe),qe.disconnect(),window.removeEventListener("resize",Ne),window.removeEventListener("orientationchange",Ne),clearTimeout(Ve),We?.remove();},replay(){ee=-1,Ie=-1,Ce=-1,Y=false,N=false,ue=0,R=false,de.clear(),clearTimeout(pe),Oe();},pause(){R=true,cancelAnimationFrame(C);},resume(){R&&(R=false,De&&(C=requestAnimationFrame(Fe)));},seek(s){let a=Math.min(1,Math.max(0,s));he=a,ee=a,R=true,cancelAnimationFrame(C),lt(a,E);},getProgress(){return he}}}var et=new Map;function tt(e,n){et.set(e,n);}function rt(e){et.delete(e);}function wt(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function nt(e){let n=[],r=/([\w]+)\(([^)]*)\)/g,t;for(;(t=r.exec(e))!==null;){let o=[],c=[],m=t[2].trim();if(m)for(let i of m.split(/[\s,]+/)){let l=i.match(/^([-+]?[\d.eE]+)(.*)$/);o.push(l?parseFloat(l[1]):0),c.push(l?l[2]:"");}n.push({fn:t[1],nums:o,units:c});}return n}function Et(e,n,r){let t=nt(e),o=nt(n);return t.length===0||t.length!==o.length?r<1?e:n:t.map((c,m)=>{let i=o[m];return c.fn!==i.fn||c.nums.length!==i.nums.length?r<1?`${c.fn}(${c.nums.map((l,g)=>`${l}${c.units[g]}`).join(", ")})`:`${i.fn}(${i.nums.map((l,g)=>`${l}${i.units[g]}`).join(", ")})`:`${c.fn}(${c.nums.map((l,g)=>`${l+(i.nums[g]-l)*r}${c.units[g]}`).join(", ")})`}).join(" ")}function st(e,n,r){if(typeof e=="number"&&typeof n=="number")return String(e+(n-e)*r);let t=String(e),o=String(n);if(wt(t))return Te(t,o,r);if(t.includes("("))return Et(t,o,r);let c=t.match(/^([-+]?[\d.]+)(.*)$/),m=o.match(/^([-+]?[\d.]+)(.*)$/);if(c&&m){let i=parseFloat(c[1]),l=parseFloat(m[1]);return `${i+(l-i)*r}${c[2]||m[2]}`}return r<1?t:o}function vt(e){return e.replace(/([A-Z])/g,n=>`-${n.toLowerCase()}`)}var ot={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},St=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),xt=0;function $t(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function He(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let{props:t,trigger:o={},easing:c="ease-out",speed:m=1,once:i=false,axis:l="y",scrollContainer:g,native:x=true,onProgress:V,onComplete:E}=n,re=window.matchMedia("(prefers-reduced-motion: reduce)").matches,Pe=typeof c=="function"?c:xe[c]??xe["ease-out"],z=$e(o.start??"top bottom"),Ee=$e(o.end??"bottom top"),L=typeof g=="string"?document.querySelector(g):g??null,W=Object.entries(t).map(([u,f])=>({prop:vt(u),from:Array.isArray(f)?f[0]:"",to:Array.isArray(f)?f[1]:f}));function ne(){let u=window.getComputedStyle(e);for(let f of W)f.from===""&&(f.from=u.getPropertyValue(f.prop).trim()||"0");}function se(){for(let u of W)e.style.setProperty(u.prop,String(u.to));}if(re)return se(),E?.(),r;ne();function oe(){if(!x||!$t()||typeof c!="string"||!(c in ot)||l!=="y"||L||i||m!==1||V||E||(o.start??"top bottom").trim()!=="top bottom"||(o.end??"bottom top").trim()!=="bottom top")return false;for(let u of W)if(!St.has(u.prop))return false;return true}function ie(){let u=`ssd-a-${++xt}`,f=W.map(w=>`${w.prop}:${w.from}`).join(";"),O=W.map(w=>`${w.prop}:${w.to}`).join(";"),S=document.createElement("style");S.setAttribute("data-ssd-animate",""),S.textContent=`@keyframes ${u}{from{${f}}to{${O}}}.${u}{animation-name:${u};animation-duration:auto;animation-timing-function:${ot[c]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(S),e.classList.add(u);let M=()=>l==="x"?window.scrollX:window.scrollY,F=()=>l==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(u),S.remove();},replay(){e.classList.remove(u),e.offsetWidth,e.classList.add(u);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(w){let A=Math.min(1,Math.max(0,w));e.classList.remove(u);for(let q of W)e.style.setProperty(q.prop,st(q.from,q.to,A));},getProgress(){let w=e.getBoundingClientRect(),A=M(),q=F(),{tStart:I,tEnd:T}=Ae({top:w.top,height:w.height},A,q,z,Ee);return Pe(U(A,I,T,m))}}}if(oe())return ie();let ae=0,ge=0,Z=0,_=false,B=false,D=-1,J=0,ve=false,Me=()=>L?l==="x"?L.scrollLeft:L.scrollTop:l==="x"?window.scrollX:window.scrollY,ze=()=>L?l==="x"?L.clientWidth:L.clientHeight:l==="x"?window.innerWidth:window.innerHeight;function ce(){let u=e.getBoundingClientRect(),f,O;if(L){let M=L.getBoundingClientRect();f=l==="x"?u.left-M.left+L.scrollLeft:u.top-M.top+L.scrollTop,O=l==="x"?u.width:u.height;}else f=l==="x"?u.left:u.top,O=l==="x"?u.width:u.height;let S=Ae({top:f,height:O},Me(),ze(),z,Ee);ae=S.tStart,ge=S.tEnd;}function le(u){e.style.setProperty("--scroll-draw-progress",String(u));for(let f of W)e.style.setProperty(f.prop,st(f.from,f.to,u));V?.(u);}function K(){if(!_||B)return;let u=Pe(U(Me(),ae,ge,m));i&&(D=Math.max(D,u),u=D),J=u,le(u),u>=1&&!ve?(ve=true,E?.()):u<1&&!i&&(ve=false),Z=requestAnimationFrame(K);}ce();{let u=Pe(U(Me(),ae,ge,m));i&&u>0&&(D=u),J=u,le(u);}let j=new IntersectionObserver(u=>{u.forEach(f=>{_=f.isIntersecting,_&&!B?Z=requestAnimationFrame(K):cancelAnimationFrame(Z);});},{root:L??null}),X;function ye(){clearTimeout(X),X=setTimeout(ce,150);}return window.addEventListener("resize",ye),window.addEventListener("orientationchange",ye),j.observe(e),tt(e,{type:"animate",getProgress:()=>J,getTrigger:()=>({tStart:ae,tEnd:ge})}),{destroy(){cancelAnimationFrame(Z),j.disconnect(),window.removeEventListener("resize",ye),window.removeEventListener("orientationchange",ye),clearTimeout(X),rt(e);},replay(){D=-1,ve=false,J=0,B=false,le(0);},pause(){B=true,cancelAnimationFrame(Z);},resume(){B&&(B=false,_&&(Z=requestAnimationFrame(K)));},seek(u){let f=Math.min(1,Math.max(0,u));J=f,D=f,B=true,cancelAnimationFrame(Z),le(f);},getProgress(){return J}}}var it={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function at(e,n={}){if(typeof window>"u")return it;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollParallax: element not found:",e),it;let{speed:t=.3,axis:o="y",easing:c="linear",trigger:m,onProgress:i}=n,l=r.getBoundingClientRect(),g=o==="x"?l.width:l.height,x=t*g;return He(r,{props:o==="x"?{transform:["translateX(0px)",`translateX(${-x}px)`]}:{transform:["translateY(0px)",`translateY(${-x}px)`]},trigger:m??{start:"top bottom",end:"bottom top"},easing:c,native:false,onProgress:i})}function Le(e){return e.map(n=>typeof n=="string"?document.querySelector(n):n).filter(n=>n!==null)}var we={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function Nt(e,n={}){if(typeof window>"u")return we;let r=Le(e).map(t=>Ge(t,n));return {destroy(){r.forEach(t=>t.destroy());},replay(){r.forEach(t=>t.replay());},pause(){r.forEach(t=>t.pause());},resume(){r.forEach(t=>t.resume());},seek(t){r.forEach(o=>o.seek(t));},getProgress(){return r[0]?.getProgress()??0}}}function Rt(e,n={}){if(typeof window>"u")return we;let r=Le(e);if(r.length===0)return we;let t=0,o=[];function c(i){return Ge(r[i],{...n,once:true,onComplete(){n.onComplete?.(),t=i+1,o[t]?.resume();}})}function m(){r.forEach((i,l)=>{o[l]=c(l);});for(let i=1;i<o.length;i++)o[i].pause();}return m(),{destroy(){o.forEach(i=>i.destroy()),o.length=0;},replay(){o.forEach(i=>i.destroy()),o.length=0,t=0,m();},pause(){o[t]?.pause();},resume(){o[t]?.resume();},seek(i){o[t]?.seek(i);},getProgress(){return o[t]?.getProgress()??0}}}function Ht(e,n){if(typeof window>"u")return we;let r=Le(e).map(t=>He(t,n));return {destroy(){r.forEach(t=>t.destroy());},replay(){r.forEach(t=>t.replay());},pause(){r.forEach(t=>t.pause());},resume(){r.forEach(t=>t.resume());},seek(t){r.forEach(o=>o.seek(t));},getProgress(){return r[0]?.getProgress()??0}}}function zt(e,n){if(typeof window>"u")return we;let r=Le(e);if(r.length===0)return we;let t=0,o=[];function c(i){return He(r[i],{...n,once:true,onComplete(){n.onComplete?.(),t=i+1,o[t]?.resume();}})}function m(){r.forEach((i,l)=>{o[l]=c(l);});for(let i=1;i<o.length;i++)o[i].pause();}return m(),{destroy(){o.forEach(i=>i.destroy()),o.length=0;},replay(){o.forEach(i=>i.destroy()),o.length=0,t=0,m();},pause(){o[t]?.pause();},resume(){o[t]?.resume();},seek(i){o[t]?.seek(i);},getProgress(){return o[t]?.getProgress()??0}}}function Wt(e,n={}){if(typeof window>"u")return we;let r=Le(e).map(t=>at(t,n));return {destroy(){r.forEach(t=>t.destroy());},replay(){r.forEach(t=>t.replay());},pause(){r.forEach(t=>t.pause());},resume(){r.forEach(t=>t.resume());},seek(t){r.forEach(o=>o.seek(t));},getProgress(){return r[0]?.getProgress()??0}}}exports.scrollAnimateGroup=Ht;exports.scrollAnimateSequence=zt;exports.scrollDrawGroup=Nt;exports.scrollDrawSequence=Rt;exports.scrollParallaxGroup=Wt;
|
|
1
|
+
'use strict';function ht({bounces:e=3,decay:n=.5}={}){let r=Math.max(1,Math.round(e)),t=Math.max(.01,Math.min(.99,n)),s=Math.sqrt(t),f=0,p=[];for(let g=0;g<r;g++){let A=Math.pow(s,g);p.push(A),f+=A;}let a=[0],c=0;for(let g=0;g<r;g++)c+=p[g]/f,a.push(c);return g=>{if(g<=0)return 0;if(g>=1)return 1;for(let A=0;A<r;A++)if(g<=a[A+1]){let R=(g-a[A])/(a[A+1]-a[A]);if(A===0)return R*(2-R);let x=1-Math.pow(t,A);return x+(1-x)*(2*R-1)*(2*R-1)}return 1}}function bt({amplitude:e=1,period:n=.4}={}){let r=Math.max(1,e),t=Math.max(.1,n),s=r<=1?t/4:t/(2*Math.PI)*Math.asin(1/r);return f=>f<=0?0:f>=1?1:r*Math.pow(2,-10*f)*Math.sin((f-s)*(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:ht(),elastic:bt()};function Te(e="top bottom"){let n=e.trim();if(/^\d+(\.\d+)?%$/.test(n))return {element:"top",viewport:n};let[r="top",t="bottom"]=n.split(/\s+/).filter(Boolean);return {element:r,viewport:t}}function Qe(e,n,r,t){switch(t){case "top":return e+r;case "center":return e+r+n/2;case "bottom":return e+r+n;default:return e+r}}function et(e,n){if(/^\d+(\.\d+)?%$/.test(e))return n*(parseFloat(e)/100);switch(e){case "top":return 0;case "center":return n/2;case "bottom":return n;default:return n}}function Be(e){let n=e.tagName.toLowerCase();if(n==="rect"){let r=parseFloat(e.getAttribute("width")??"0"),t=parseFloat(e.getAttribute("height")??"0");return 2*(r+t)}if(n==="circle"){let r=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*r}return e.getTotalLength()}function wt(e,n,r){return Math.min(r,Math.max(n,e))}function K(e,n,r,t){return r===n?0:wt((e-n)/(r-n)*t,0,1)}function Pe(e,n,r,t,s){let f=Qe(e.top,e.height,n,t.element)-et(t.viewport,r),p=Qe(e.top,e.height,n,s.element)-et(s.viewport,r);return {tStart:f,tEnd:p}}function tt(e){let n=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(n)return [parseInt(n[1]+n[1],16),parseInt(n[2]+n[2],16),parseInt(n[3]+n[3],16)];let r=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(r)return [parseInt(r[1],16),parseInt(r[2],16),parseInt(r[3],16)];let t=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return t?[parseInt(t[1]),parseInt(t[2]),parseInt(t[3])]:null}function Me(e,n,r){let t=tt(e),s=tt(n);return !t||!s?e:`rgb(${Math.round(t[0]+(s[0]-t[0])*r)},${Math.round(t[1]+(s[1]-t[1])*r)},${Math.round(t[2]+(s[2]-t[2])*r)})`}var rt={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 nt(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n);}var ot={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},vt=0;function Et(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function St(e){let n=e.getAttribute("stroke"),r=e.getAttribute("fill");!n||n==="none"?nt("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&&nt("Element has a fill \u2014 it may obscure the stroke animation.",e);}function xt(e,n,r){let t=document.createElement("div");t.setAttribute("data-svg-scroll-draw-debug",""),t.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function s(){let f=r==="x"?window.scrollX:window.scrollY,p=e-f,a=n-f,c=r==="x";t.innerHTML=`
|
|
2
|
+
<div style="position:absolute;${c?`left:${p}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${p}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
|
|
3
|
+
<div style="position:absolute;${c?`left:${a}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${a}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",s,{passive:true}),s(),t}function Ye(e,n,r){let t=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),s=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,f=>{let p=parseFloat(f),a=t[s++]??p;return String(+(p+(a-p)*r).toFixed(4))})}function Ue(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let{preset:r,...t}=n,s=r?{...rt[r],...t}:t,f=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:p="path, polyline, line, polygon, rect, circle",speed:a=1,fade:c=false,easing:g="linear",trigger:A={},stagger:R=0,direction:x="forward",once:Y=false,debug:Ce=false,axis:V="y",scrollContainer:we,autoReverse:pe=false,delay:de=0,strokeColor:U,strokeWidth:Q,fillOpacity:ee,waypoints:P,velocityScale:G=false,threshold:Oe=0,rootMargin:Ne="0px",repeat:ae=0,repeatDelay:ke=0,morphTo:k,clip:te,autoplay:le=false,duration:ve=1e3,native:ce=true,onProgress:j,onStart:Z,onComplete:J,onEnter:re,onLeave:Ee,onEnterBack:Le,onLeaveBack:Se}=s,ne=te===true?"left":typeof te=="string"?te:false,oe=typeof g=="function"?g:Ae[g]??Ae.linear,ge=Te(A.start??"top bottom"),Fe=Te(A.end??"bottom top"),I=typeof we=="string"?document.querySelector(we):we??null,B=Array.isArray(U)?U[0]:null,L=Array.isArray(U)?U[1]:typeof U=="string"?U:null,D=Array.isArray(Q)?Q[0]:null,i=Array.isArray(Q)?Q[1]:typeof Q=="number"?Q:null,m=Array.isArray(ee)?ee[0]:null,w=Array.isArray(ee)?ee[1]:typeof ee=="number"?ee:null;function C(o){let l=o*100;switch(ne){case "right":return `inset(0 0 0 ${100-l}%)`;case "top":return `inset(0 0 ${100-l}% 0)`;case "bottom":return `inset(${100-l}% 0 0 0)`;case "center":return `circle(${o*150}% at 50% 50%)`;default:return `inset(0 ${100-l}% 0 0)`}}let b=ne?[]:Array.from(e.querySelectorAll(p)),$=[],v=[],F=0,H=0,O=false,_=false,N=0,Re=false,se=-1,He=-1,z=false,ye=0,ue=0,fe,Ge=null,me=new Set,ze=-1,Ze=performance.now(),xe=NaN;function De(){return I?V==="x"?I.scrollLeft:I.scrollTop:V==="x"?window.scrollX:window.scrollY}function Je(){return I?V==="x"?I.clientWidth:I.clientHeight:V==="x"?window.innerWidth:window.innerHeight}function Ke(){let o=e.getBoundingClientRect(),l,y,M;if(I){let q=I.getBoundingClientRect();l=V==="x"?o.left-q.left+I.scrollLeft:o.top-q.top+I.scrollTop,y=V==="x"?o.width:o.height,M=De();}else l=V==="x"?o.left:o.top,y=V==="x"?o.width:o.height,M=De();let W=Pe({top:l,height:y},M,Je(),ge,Fe);F=W.tStart,H=W.tEnd,Ce&&process.env.NODE_ENV!=="production"&&(Ge?.remove(),Ge=xt(F,H,V));}function pt(o,l){if(e.style.setProperty("--scroll-draw-progress",String(o)),ne){let y=l==="reverse"?1-o:o;e.style.clipPath=C(y);return}b.forEach((y,M)=>{y.style.strokeDashoffset=l==="reverse"?`${$[M]*o}`:`${$[M]*(1-o)}`,c&&(y.style.opacity=l==="reverse"?`${1-o}`:`${o}`),B&&L?y.style.stroke=Me(B,L,o):L&&(y.style.stroke=L),D!==null&&i!==null?y.style.strokeWidth=`${D+(i-D)*o}`:i!==null&&(y.style.strokeWidth=`${i}`),m!==null&&w!==null?y.style.fillOpacity=`${m+(w-m)*o}`:w!==null&&(y.style.fillOpacity=`${w}`),k&&y.tagName.toLowerCase()==="path"&&v[M]&&y.setAttribute("d",Ye(v[M],k,o));});}function We(){if(e.style.setProperty("--scroll-draw-progress","0"),ne){e.style.clipPath=C(0);return}b.forEach((o,l)=>{o.style.strokeDasharray=`${$[l]}`,o.style.strokeDashoffset=x==="reverse"?"0":`${$[l]}`,c?o.style.opacity=x==="reverse"?"1":"0":o.style.opacity="",B&&(o.style.stroke=B),D!==null&&(o.style.strokeWidth=`${D}`),m!==null&&(o.style.fillOpacity=`${m}`),k&&o.tagName.toLowerCase()==="path"&&v[l]&&o.setAttribute("d",v[l]);});}if(b.forEach(o=>{St(o);let l=Be(o);$.push(l),o.tagName.toLowerCase()==="path"?v.push(o.getAttribute("d")??""):v.push(""),f?(o.style.strokeDasharray=`${l}`,o.style.strokeDashoffset=x==="reverse"?`${l}`:"0",c&&(o.style.opacity="1"),L&&(o.style.stroke=L),i!==null&&(o.style.strokeWidth=`${i}`),w!==null&&(o.style.fillOpacity=`${w}`),k&&o.tagName.toLowerCase()==="path"&&o.setAttribute("d",k)):(o.style.strokeDasharray=`${l}`,o.style.strokeDashoffset=x==="reverse"?"0":`${l}`,c?o.style.opacity=x==="reverse"?"1":"0":o.style.opacity="",B&&(o.style.stroke=B),D!==null&&(o.style.strokeWidth=`${D}`),m!==null&&(o.style.fillOpacity=`${m}`));}),ne){if(f)return e.style.clipPath=C(1),J?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=C(0);}else if(f)return J?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function dt(){return !(ce===false||!Et()||!b.length||typeof g!="string"||!(g in ot)||ne||V!=="y"||I||a!==1||R!==0||Y||pe||G!==false||k||P||ae||de>0||j||Z||J||re||Ee||Le||Se||U!=null||Q!=null||ee!=null||(A.start??"top bottom").trim()!=="top bottom"||(A.end??"bottom top").trim()!=="bottom top")}function gt(){let o=`svg-scroll-draw-${++vt}`,l=x==="reverse"?"0":"var(--ssd-len)",y=x==="reverse"?"var(--ssd-len)":"0",M=`stroke-dashoffset:${l};`,W=`stroke-dashoffset:${y};`;c&&(M+=`opacity:${x==="reverse"?1:0};`,W+=`opacity:${x==="reverse"?0:1};`);let q=document.createElement("style");q.setAttribute("data-svg-scroll-draw",""),q.textContent=`@keyframes ${o}{from{${M}}to{${W}}}.${o}{animation-name:${o};animation-duration:auto;animation-timing-function:${ot[g]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(q);function X(u,h){u.style.setProperty("--ssd-len",String($[h])),u.style.strokeDasharray=`${$[h]}`,u.style.strokeDashoffset="",u.style.opacity="",u.style.animationPlayState="",u.classList.add(o);}b.forEach(X);let d=false,E=-1;function S(){if(E>=0)return E;let u=e.getBoundingClientRect(),{tStart:h,tEnd:T}=Pe({top:u.top,height:u.height},De(),Je(),ge,Fe);return oe(K(De(),h,T,a))}return {destroy(){b.forEach(u=>{u.classList.remove(o),u.style.removeProperty("--ssd-len"),u.style.animationPlayState="";}),q.remove();},replay(){d=false,E=-1,b.forEach(X);},pause(){d=true,b.forEach(u=>{u.style.animationPlayState="paused";});},resume(){d&&(d=false,b.forEach(u=>{u.style.animationPlayState="running";}));},seek(u){let h=Math.min(1,Math.max(0,u));E=h,d=true,b.forEach((T,he)=>{T.classList.remove(o),T.style.strokeDashoffset=x==="reverse"?`${$[he]*h}`:`${$[he]*(1-h)}`,c&&(T.style.opacity=x==="reverse"?`${1-h}`:`${h}`);});},getProgress(){return S()}}}if(dt())return gt();function yt(){let o=Math.max(1,ve),l=0,y=0;function M(S){let u=true;if(ne){let h=Math.min(1,Math.max(0,S/o)),T=oe(h);ye=T,e.style.setProperty("--scroll-draw-progress",String(T)),e.style.clipPath=C(x==="reverse"?1-T:T),j?.(T),h<1&&(u=false);}else b.forEach((h,T)=>{let he=T*R*o,$e=Math.min(1,Math.max(0,(S-he)/o)),ie=oe($e);h.style.strokeDashoffset=x==="reverse"?`${$[T]*ie}`:`${$[T]*(1-ie)}`,c&&(h.style.opacity=x==="reverse"?`${1-ie}`:`${ie}`),B&&L?h.style.stroke=Me(B,L,ie):L&&(h.style.stroke=L),D!==null&&i!==null?h.style.strokeWidth=`${D+(i-D)*ie}`:i!==null&&(h.style.strokeWidth=`${i}`),m!==null&&w!==null?h.style.fillOpacity=`${m+(w-m)*ie}`:w!==null&&(h.style.fillOpacity=`${w}`),k&&h.tagName.toLowerCase()==="path"&&v[T]&&h.setAttribute("d",Ye(v[T],k,ie)),T===0&&(j?.(ie),e.style.setProperty("--scroll-draw-progress",String(ie))),$e<1&&(u=false);});if(P){let h=Math.min(1,Math.max(0,S/o)),T=oe(h);for(let he in P){let $e=parseFloat(he);T>=$e&&!me.has($e)&&(me.add($e),P[he]?.());}}return u}function W(S){if(z)return;let u=S-l;_||(_=true,Z?.());let h=M(u);if(h&&!O){O=true,M(o*(1+Math.max(0,b.length-1)*R)),J?.(),ue<(ae==="infinite"?1/0:ae??0)&&(ue++,fe=setTimeout(()=>{l=performance.now(),_=false,O=false,me.clear(),We(),N=requestAnimationFrame(W);},ke));return}h||(N=requestAnimationFrame(W));}function q(){cancelAnimationFrame(N),clearTimeout(fe),l=performance.now(),y=0,z=false,_=false,O=false,ue=0,me.clear(),We(),N=requestAnimationFrame(W);}let X=new IntersectionObserver(S=>{S.forEach(u=>{u.isIntersecting&&!(Y&&O)?q():!u.isIntersecting&&!Y&&!O&&(cancelAnimationFrame(N),clearTimeout(fe),l=null);});},{root:I??null,threshold:Oe,rootMargin:Ne}),d;function E(){clearTimeout(d),d=setTimeout(()=>{b.forEach((S,u)=>{$[u]=Be(S),S.style.strokeDasharray=`${$[u]}`;});},150);}return window.addEventListener("resize",E),window.addEventListener("orientationchange",E),de>0?setTimeout(()=>X.observe(e),de):X.observe(e),{destroy(){cancelAnimationFrame(N),clearTimeout(fe),X.disconnect(),window.removeEventListener("resize",E),window.removeEventListener("orientationchange",E),clearTimeout(d);},replay(){ue=0,q();},pause(){z||(z=true,y=performance.now()-l,cancelAnimationFrame(N));},resume(){z&&(z=false,l=performance.now()-y,N=requestAnimationFrame(W));},seek(S){let u=Math.min(1,Math.max(0,S));ye=u,z=true,y=u*o,l=performance.now()-y,cancelAnimationFrame(N),M(y);},getProgress(){return ye}}}if(le)return yt();Ke();function qe(){if(!Re||z)return;let o=performance.now(),l=De(),y=a;if(G!==false){let d=o-Ze,E=d>0?Math.abs(l-(ze<0?l:ze))/d:0;y=a*Math.max(.2,1+E*(typeof G=="number"?G:1)*.04);}ze=l,Ze=o;let M=pe?He===-1||l>=He?"forward":"reverse":x;He=l;let W=H-F,q=true,X=W===0?0:(l-F)/W;if(isNaN(xe)||(xe<=0&&X>0?re?.():xe>0&&X<=0&&Se?.(),xe<1&&X>=1?Ee?.():xe>=1&&X<1&&Le?.()),xe=X,ne){let d=oe(K(l,F,H,y));Y&&!pe&&(se=Math.max(se,d),d=se),ye=d,e.style.setProperty("--scroll-draw-progress",String(d));let E=M==="reverse"?1-d:d;e.style.clipPath=C(E),j?.(d),!_&&K(l,F,H,y)>0&&(_=true,Z?.()),d>=1&&!O?(O=true,J?.(),ue<(ae==="infinite"?1/0:ae??0)&&(ue++,fe=setTimeout(()=>{se=-1,_=false,O=false,e.style.clipPath=C(0);},ke))):d<1&&!Y&&(O=false),N=requestAnimationFrame(qe);return}if(b.forEach((d,E)=>{let S=E*R*W,u=oe(K(l,F+S,H+S,y));Y&&!pe&&(se=Math.max(se,u),u=se),ye=u,d.style.strokeDashoffset=M==="reverse"?`${$[E]*u}`:`${$[E]*(1-u)}`,c&&(d.style.opacity=M==="reverse"?`${1-u}`:`${u}`),B&&L?d.style.stroke=Me(B,L,u):L&&(d.style.stroke=L),D!==null&&i!==null?d.style.strokeWidth=`${D+(i-D)*u}`:i!==null&&(d.style.strokeWidth=`${i}`),m!==null&&w!==null?d.style.fillOpacity=`${m+(w-m)*u}`:w!==null&&(d.style.fillOpacity=`${w}`),k&&d.tagName.toLowerCase()==="path"&&v[E]&&d.setAttribute("d",Ye(v[E],k,u)),E===0&&(j?.(u),e.style.setProperty("--scroll-draw-progress",String(u))),u<1&&(q=false);}),P){let d=oe(K(l,F,H,y));for(let E in P){let S=parseFloat(E);d>=S&&!me.has(S)&&(me.add(S),P[E]?.());}}!_&&K(l,F,H,y)>0&&(_=true,Z?.()),q&&!O?(O=true,J?.(),ue<(ae==="infinite"?1/0:ae??0)&&(ue++,fe=setTimeout(()=>{se=-1,_=false,O=false,me.clear(),We();},ke))):!q&&!Y&&(O=false),N=requestAnimationFrame(qe);}let je=new IntersectionObserver(o=>{o.forEach(l=>{Re=l.isIntersecting,Re&&!z?N=requestAnimationFrame(qe):cancelAnimationFrame(N);});},{root:I??null,threshold:Oe,rootMargin:Ne}),Xe;function Ve(){clearTimeout(Xe),Xe=setTimeout(()=>{b.forEach((o,l)=>{$[l]=Be(o),o.style.strokeDasharray=`${$[l]}`;}),Ke();},150);}return window.addEventListener("resize",Ve),window.addEventListener("orientationchange",Ve),de>0?setTimeout(()=>je.observe(e),de):je.observe(e),{destroy(){cancelAnimationFrame(N),clearTimeout(fe),je.disconnect(),window.removeEventListener("resize",Ve),window.removeEventListener("orientationchange",Ve),clearTimeout(Xe),Ge?.remove();},replay(){se=-1,He=-1,ze=-1,_=false,O=false,ue=0,z=false,me.clear(),clearTimeout(fe),We();},pause(){z=true,cancelAnimationFrame(N);},resume(){z&&(z=false,Re&&(N=requestAnimationFrame(qe)));},seek(o){let l=Math.min(1,Math.max(0,o));ye=l,se=l,z=true,cancelAnimationFrame(N),pt(l,x);},getProgress(){return ye}}}var st=new Map;function it(e,n){st.set(e,n);}function at(e){st.delete(e);}function $t(e){return e.startsWith("#")||e.startsWith("rgb")||e.startsWith("hsl")}function lt(e){let n=[],r=/([\w]+)\(([^)]*)\)/g,t;for(;(t=r.exec(e))!==null;){let s=[],f=[],p=t[2].trim();if(p)for(let a of p.split(/[\s,]+/)){let c=a.match(/^([-+]?[\d.eE]+)(.*)$/);s.push(c?parseFloat(c[1]):0),f.push(c?c[2]:"");}n.push({fn:t[1],nums:s,units:f});}return n}function At(e,n,r){let t=lt(e),s=lt(n);return t.length===0||t.length!==s.length?r<1?e:n:t.map((f,p)=>{let a=s[p];return f.fn!==a.fn||f.nums.length!==a.nums.length?r<1?`${f.fn}(${f.nums.map((c,g)=>`${c}${f.units[g]}`).join(", ")})`:`${a.fn}(${a.nums.map((c,g)=>`${c}${a.units[g]}`).join(", ")})`:`${f.fn}(${f.nums.map((c,g)=>`${c+(a.nums[g]-c)*r}${f.units[g]}`).join(", ")})`}).join(" ")}function ct(e,n,r){if(typeof e=="number"&&typeof n=="number")return String(e+(n-e)*r);let t=String(e),s=String(n);if($t(t))return Me(t,s,r);if(t.includes("("))return At(t,s,r);let f=t.match(/^([-+]?[\d.]+)(.*)$/),p=s.match(/^([-+]?[\d.]+)(.*)$/);if(f&&p){let a=parseFloat(f[1]),c=parseFloat(p[1]);return `${a+(c-a)*r}${f[2]||p[2]}`}return r<1?t:s}function Tt(e){return e.replace(/([A-Z])/g,n=>`-${n.toLowerCase()}`)}var ut={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Pt=new Set(["opacity","transform","background-color","color","filter","scale","translate","rotate"]),Mt=0;function kt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function _e(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let{props:t,trigger:s={},easing:f="ease-out",speed:p=1,once:a=false,axis:c="y",scrollContainer:g,native:A=true,velocityScale:R=false,onProgress:x,onComplete:Y,onEnter:Ce,onLeave:V,onEnterBack:we,onLeaveBack:pe}=n,de=window.matchMedia("(prefers-reduced-motion: reduce)").matches,U=typeof f=="function"?f:Ae[f]??Ae["ease-out"],Q=Te(s.start??"top bottom"),ee=Te(s.end??"bottom top"),P=typeof g=="string"?document.querySelector(g):g??null,G=Object.entries(t).map(([i,m])=>({prop:Tt(i),from:Array.isArray(m)?m[0]:"",to:Array.isArray(m)?m[1]:m}));function Oe(){let i=window.getComputedStyle(e);for(let m of G)m.from===""&&(m.from=i.getPropertyValue(m.prop).trim()||"0");}function Ne(){for(let i of G)e.style.setProperty(i.prop,String(i.to));}if(de)return Ne(),Y?.(),r;Oe();function ae(){if(!A||!kt()||typeof f!="string"||!(f in ut)||c!=="y"||P||a||p!==1||x||Y||Ce||V||we||pe||R!==false||(s.start??"top bottom").trim()!=="top bottom"||(s.end??"bottom top").trim()!=="bottom top")return false;for(let i of G)if(!Pt.has(i.prop))return false;return true}function ke(){let i=`ssd-a-${++Mt}`,m=G.map(v=>`${v.prop}:${v.from}`).join(";"),w=G.map(v=>`${v.prop}:${v.to}`).join(";"),C=document.createElement("style");C.setAttribute("data-ssd-animate",""),C.textContent=`@keyframes ${i}{from{${m}}to{${w}}}.${i}{animation-name:${i};animation-duration:auto;animation-timing-function:${ut[f]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(C),e.classList.add(i);let b=()=>c==="x"?window.scrollX:window.scrollY,$=()=>c==="x"?window.innerWidth:window.innerHeight;return {destroy(){e.classList.remove(i),C.remove();},replay(){e.classList.remove(i),e.offsetWidth,e.classList.add(i);},pause(){e.style.animationPlayState="paused";},resume(){e.style.animationPlayState="";},seek(v){let F=Math.min(1,Math.max(0,v));e.classList.remove(i);for(let H of G)e.style.setProperty(H.prop,ct(H.from,H.to,F));},getProgress(){let v=e.getBoundingClientRect(),F=b(),H=$(),{tStart:O,tEnd:_}=Pe({top:v.top,height:v.height},F,H,Q,ee);return U(K(F,O,_,p))}}}if(ae())return ke();let k=0,te=0,le=0,ve=false,ce=false,j=-1,Z=0,J=false,re=NaN,Ee=-1,Le=0,Se=()=>P?c==="x"?P.scrollLeft:P.scrollTop:c==="x"?window.scrollX:window.scrollY,ne=()=>P?c==="x"?P.clientWidth:P.clientHeight:c==="x"?window.innerWidth:window.innerHeight;function oe(){let i=e.getBoundingClientRect(),m,w;if(P){let b=P.getBoundingClientRect();m=c==="x"?i.left-b.left+P.scrollLeft:i.top-b.top+P.scrollTop,w=c==="x"?i.width:i.height;}else m=c==="x"?i.left:i.top,w=c==="x"?i.width:i.height;let C=Pe({top:m,height:w},Se(),ne(),Q,ee);k=C.tStart,te=C.tEnd;}function ge(i){e.style.setProperty("--scroll-draw-progress",String(i));for(let m of G)e.style.setProperty(m.prop,ct(m.from,m.to,i));x?.(i);}function Fe(i){if(isNaN(re)){re=i;return}re<=0&&i>0?Ce?.():re>0&&i<=0&&pe?.(),re<1&&i>=1?V?.():re>=1&&i<1&&we?.(),re=i;}function I(){if(!ve||ce)return;let i=performance.now(),m=Se(),w=p;if(R!==false){let $=i-Le,v=$>0?Math.abs(m-(Ee<0?m:Ee))/$:0;w=p*Math.max(.2,1+v*(typeof R=="number"?R:1)*.04);}Ee=m,Le=i;let C=te===k?0:(m-k)/(te-k);Fe(C);let b=U(K(m,k,te,w));a&&(j=Math.max(j,b),b=j),Z=b,ge(b),b>=1&&!J?(J=true,Y?.()):b<1&&!a&&(J=false),le=requestAnimationFrame(I);}oe();{let i=U(K(Se(),k,te,p));a&&i>0&&(j=i),Z=i,ge(i);}let B=new IntersectionObserver(i=>{i.forEach(m=>{ve=m.isIntersecting,ve&&!ce?le=requestAnimationFrame(I):cancelAnimationFrame(le);});},{root:P??null}),L;function D(){clearTimeout(L),L=setTimeout(oe,150);}return window.addEventListener("resize",D),window.addEventListener("orientationchange",D),B.observe(e),it(e,{type:"animate",getProgress:()=>Z,getTrigger:()=>({tStart:k,tEnd:te})}),{destroy(){cancelAnimationFrame(le),B.disconnect(),window.removeEventListener("resize",D),window.removeEventListener("orientationchange",D),clearTimeout(L),at(e);},replay(){j=-1,J=false,Z=0,ce=false,ge(0);},pause(){ce=true,cancelAnimationFrame(le);},resume(){ce&&(ce=false,ve&&(le=requestAnimationFrame(I)));},seek(i){let m=Math.min(1,Math.max(0,i));Z=m,j=m,ce=true,cancelAnimationFrame(le),ge(m);},getProgress(){return Z}}}var ft={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function mt(e,n={}){if(typeof window>"u")return ft;let r=typeof e=="string"?document.querySelector(e):e;if(!r)return process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] scrollParallax: element not found:",e),ft;let{speed:t=.3,axis:s="y",easing:f="linear",trigger:p,onProgress:a}=n,c=r.getBoundingClientRect(),g=s==="x"?c.width:c.height,A=t*g;return _e(r,{props:s==="x"?{transform:["translateX(0px)",`translateX(${-A}px)`]}:{transform:["translateY(0px)",`translateY(${-A}px)`]},trigger:p??{start:"top bottom",end:"bottom top"},easing:f,native:false,onProgress:a})}function Ie(e){return e.map(n=>typeof n=="string"?document.querySelector(n):n).filter(n=>n!==null)}var be={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};function qt(e,n={}){if(typeof window>"u")return be;let r=Ie(e).map(t=>Ue(t,n));return {destroy(){r.forEach(t=>t.destroy());},replay(){r.forEach(t=>t.replay());},pause(){r.forEach(t=>t.pause());},resume(){r.forEach(t=>t.resume());},seek(t){r.forEach(s=>s.seek(t));},getProgress(){return r[0]?.getProgress()??0}}}function Vt(e,n={}){if(typeof window>"u")return be;let r=Ie(e);if(r.length===0)return be;let t=0,s=[];function f(a){return Ue(r[a],{...n,once:true,onComplete(){n.onComplete?.(),t=a+1,s[t]?.resume();}})}function p(){r.forEach((a,c)=>{s[c]=f(c);});for(let a=1;a<s.length;a++)s[a].pause();}return p(),{destroy(){s.forEach(a=>a.destroy()),s.length=0;},replay(){s.forEach(a=>a.destroy()),s.length=0,t=0,p();},pause(){s[t]?.pause();},resume(){s[t]?.resume();},seek(a){s[t]?.seek(a);},getProgress(){return s[t]?.getProgress()??0}}}function Bt(e,n){if(typeof window>"u")return be;let r=Ie(e).map(t=>_e(t,n));return {destroy(){r.forEach(t=>t.destroy());},replay(){r.forEach(t=>t.replay());},pause(){r.forEach(t=>t.pause());},resume(){r.forEach(t=>t.resume());},seek(t){r.forEach(s=>s.seek(t));},getProgress(){return r[0]?.getProgress()??0}}}function _t(e,n){if(typeof window>"u")return be;let r=Ie(e);if(r.length===0)return be;let t=0,s=[];function f(a){return _e(r[a],{...n,once:true,onComplete(){n.onComplete?.(),t=a+1,s[t]?.resume();}})}function p(){r.forEach((a,c)=>{s[c]=f(c);});for(let a=1;a<s.length;a++)s[a].pause();}return p(),{destroy(){s.forEach(a=>a.destroy()),s.length=0;},replay(){s.forEach(a=>a.destroy()),s.length=0,t=0,p();},pause(){s[t]?.pause();},resume(){s[t]?.resume();},seek(a){s[t]?.seek(a);},getProgress(){return s[t]?.getProgress()??0}}}function Gt(e,n={}){if(typeof window>"u")return be;let r=Ie(e).map(t=>mt(t,n));return {destroy(){r.forEach(t=>t.destroy());},replay(){r.forEach(t=>t.replay());},pause(){r.forEach(t=>t.pause());},resume(){r.forEach(t=>t.resume());},seek(t){r.forEach(s=>s.seek(t));},getProgress(){return r[0]?.getProgress()??0}}}exports.scrollAnimateGroup=Bt;exports.scrollAnimateSequence=_t;exports.scrollDrawGroup=qt;exports.scrollDrawSequence=Vt;exports.scrollParallaxGroup=Gt;
|
package/dist/group/index.d.mts
CHANGED
|
@@ -71,6 +71,14 @@ interface ScrollDrawOptions {
|
|
|
71
71
|
onProgress?: (alpha: number) => void;
|
|
72
72
|
onStart?: () => void;
|
|
73
73
|
onComplete?: () => void;
|
|
74
|
+
/** Fires when scroll position enters the trigger zone (scrolling forward). */
|
|
75
|
+
onEnter?: () => void;
|
|
76
|
+
/** Fires when scroll position exits the trigger zone at the end (scrolling forward). */
|
|
77
|
+
onLeave?: () => void;
|
|
78
|
+
/** Fires when scroll position re-enters the trigger zone from the end (scrolling back). */
|
|
79
|
+
onEnterBack?: () => void;
|
|
80
|
+
/** Fires when scroll position exits the trigger zone at the start (scrolling back). */
|
|
81
|
+
onLeaveBack?: () => void;
|
|
74
82
|
/**
|
|
75
83
|
* Trigger the animation when the element enters the viewport instead of
|
|
76
84
|
* tying it to scroll position. The draw runs over `duration` milliseconds,
|
|
@@ -128,8 +136,22 @@ interface ScrollAnimateOptions {
|
|
|
128
136
|
axis?: 'x' | 'y';
|
|
129
137
|
scrollContainer?: string | Element;
|
|
130
138
|
native?: boolean;
|
|
139
|
+
/**
|
|
140
|
+
* Scale animation speed by scroll velocity — faster scrolling = faster animation.
|
|
141
|
+
* Pass `true` for default sensitivity (1) or a number to control it.
|
|
142
|
+
* Higher values = more dramatic speed-up. Default sensitivity: 1.
|
|
143
|
+
*/
|
|
144
|
+
velocityScale?: boolean | number;
|
|
131
145
|
onProgress?: (alpha: number) => void;
|
|
132
146
|
onComplete?: () => void;
|
|
147
|
+
/** Fires when scroll enters the trigger zone (scrolling forward). */
|
|
148
|
+
onEnter?: () => void;
|
|
149
|
+
/** Fires when scroll exits the trigger zone at the end (scrolling forward). */
|
|
150
|
+
onLeave?: () => void;
|
|
151
|
+
/** Fires when scroll re-enters the trigger zone from the end (scrolling back). */
|
|
152
|
+
onEnterBack?: () => void;
|
|
153
|
+
/** Fires when scroll exits the trigger zone at the start (scrolling back). */
|
|
154
|
+
onLeaveBack?: () => void;
|
|
133
155
|
}
|
|
134
156
|
interface ScrollParallaxOptions {
|
|
135
157
|
speed?: number;
|