svg-scroll-draw 1.2.0 → 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/dist/angular/index.cjs +3 -3
  2. package/dist/angular/index.d.mts +19 -0
  3. package/dist/angular/index.d.ts +19 -0
  4. package/dist/angular/index.mjs +3 -3
  5. package/dist/astro/index.cjs +3 -3
  6. package/dist/astro/index.d.mts +19 -0
  7. package/dist/astro/index.d.ts +19 -0
  8. package/dist/astro/index.mjs +3 -3
  9. package/dist/cdn/svg-scroll-draw.global.js +3 -3
  10. package/dist/cinematic/index.cjs +2 -0
  11. package/dist/cinematic/index.d.mts +72 -0
  12. package/dist/cinematic/index.d.ts +72 -0
  13. package/dist/cinematic/index.mjs +2 -0
  14. package/dist/group/index.cjs +3 -3
  15. package/dist/group/index.d.mts +19 -0
  16. package/dist/group/index.d.ts +19 -0
  17. package/dist/group/index.mjs +3 -3
  18. package/dist/index.cjs +4 -3
  19. package/dist/index.d.mts +91 -1
  20. package/dist/index.d.ts +91 -1
  21. package/dist/index.mjs +4 -3
  22. package/dist/nuxt/index.cjs +3 -3
  23. package/dist/nuxt/index.d.mts +19 -0
  24. package/dist/nuxt/index.d.ts +19 -0
  25. package/dist/nuxt/index.mjs +3 -3
  26. package/dist/react/index.cjs +3 -3
  27. package/dist/react/index.d.mts +19 -0
  28. package/dist/react/index.d.ts +19 -0
  29. package/dist/react/index.mjs +3 -3
  30. package/dist/solid/index.cjs +3 -3
  31. package/dist/solid/index.d.mts +19 -0
  32. package/dist/solid/index.d.ts +19 -0
  33. package/dist/solid/index.mjs +3 -3
  34. package/dist/svelte/index.cjs +3 -3
  35. package/dist/svelte/index.d.mts +19 -0
  36. package/dist/svelte/index.d.ts +19 -0
  37. package/dist/svelte/index.mjs +3 -3
  38. package/dist/vue/index.cjs +3 -3
  39. package/dist/vue/index.d.mts +19 -0
  40. package/dist/vue/index.d.ts +19 -0
  41. package/dist/vue/index.mjs +3 -3
  42. package/dist/web-component/index.cjs +3 -3
  43. package/dist/web-component/index.mjs +3 -3
  44. package/package.json +6 -1
@@ -1,3 +1,3 @@
1
- 'use strict';function Ue({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),o=Math.max(.01,Math.min(.99,r)),c=Math.sqrt(o),u=0,p=[];for(let a=0;a<n;a++){let d=Math.pow(c,a);p.push(d),u+=d;}let h=[0],I=0;for(let a=0;a<n;a++)I+=p[a]/u,h.push(I);return a=>{if(a<=0)return 0;if(a>=1)return 1;for(let d=0;d<n;d++)if(a<=h[d+1]){let U=(a-h[d])/(h[d+1]-h[d]);if(d===0)return U*(2-U);let b=1-Math.pow(o,d);return b+(1-b)*(2*U-1)*(2*U-1)}return 1}}function je({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),o=Math.max(.1,r),c=n<=1?o/4:o/(2*Math.PI)*Math.asin(1/n);return u=>u<=0?0:u>=1?1:n*Math.pow(2,-10*u)*Math.sin((u-c)*(2*Math.PI)/o)+1}var we={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:Ue(),elastic:je()};function $e(e="top bottom"){let r=e.trim();if(/^\d+(\.\d+)?%$/.test(r))return {element:"top",viewport:r};let[n="top",o="bottom"]=r.split(/\s+/).filter(Boolean);return {element:n,viewport:o}}function Ce(e,r,n,o){switch(o){case "top":return e+n;case "center":return e+n+r/2;case "bottom":return e+n+r;default:return e+n}}function Oe(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 xe(e){let r=e.tagName.toLowerCase();if(r==="rect"){let n=parseFloat(e.getAttribute("width")??"0"),o=parseFloat(e.getAttribute("height")??"0");return 2*(n+o)}if(r==="circle"){let n=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*n}return e.getTotalLength()}function Je(e,r,n){return Math.min(n,Math.max(r,e))}function X(e,r,n,o){return n===r?0:Je((e-r)/(n-r)*o,0,1)}function Ee(e,r,n,o,c){let u=Ce(e.top,e.height,r,o.element)-Oe(o.viewport,n),p=Ce(e.top,e.height,r,c.element)-Oe(c.viewport,n);return {tStart:u,tEnd:p}}function Fe(e){let r=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(r)return [parseInt(r[1]+r[1],16),parseInt(r[2]+r[2],16),parseInt(r[3]+r[3],16)];let n=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(n)return [parseInt(n[1],16),parseInt(n[2],16),parseInt(n[3],16)];let o=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return o?[parseInt(o[1]),parseInt(o[2]),parseInt(o[3])]:null}function Se(e,r,n){let o=Fe(e),c=Fe(r);return !o||!c?e:`rgb(${Math.round(o[0]+(c[0]-o[0])*n)},${Math.round(o[1]+(c[1]-o[1])*n)},${Math.round(o[2]+(c[2]-o[2])*n)})`}function Ne(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r);}var Re={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Ke=0;function Qe(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Ye(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?Ne("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&Ne("Element has a fill \u2014 it may obscure the stroke animation.",e);}function Ze(e,r,n){let o=document.createElement("div");o.setAttribute("data-svg-scroll-draw-debug",""),o.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function c(){let u=n==="x"?window.scrollX:window.scrollY,p=e-u,h=r-u,I=n==="x";o.innerHTML=`
2
- <div style="position:absolute;${I?`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;${I?`left:${h}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${h}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(o),window.addEventListener("scroll",c,{passive:true}),c(),o}function We(e,r,n){let o=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),c=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,u=>{let p=parseFloat(u),h=o[c++]??p;return String(+(p+(h-p)*n).toFixed(4))})}function He(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let n=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:o="path, polyline, line, polygon, rect, circle",speed:c=1,fade:u=false,easing:p="linear",trigger:h={},stagger:I=0,direction:a="forward",once:d=false,debug:U=false,axis:b="y",scrollContainer:me,autoReverse:ee=false,delay:pe=0,strokeColor:H,strokeWidth:V,fillOpacity:G,waypoints:te,velocityScale:re=false,threshold:Ge=0,rootMargin:ze="0px",repeat:J=0,repeatDelay:Me=0,morphTo:C,clip:de,native:qe=true,onProgress:ye,onStart:he,onComplete:K}=r,z=de===true?"left":typeof de=="string"?de:false,ne=typeof p=="function"?p:we[p]??we.linear,ke=$e(h.start??"top bottom"),Ae=$e(h.end??"bottom top"),$=typeof me=="string"?document.querySelector(me):me??null,O=Array.isArray(H)?H[0]:null,S=Array.isArray(H)?H[1]:typeof H=="string"?H:null,M=Array.isArray(V)?V[0]:null,k=Array.isArray(V)?V[1]:typeof V=="number"?V:null,A=Array.isArray(G)?G[0]:null,T=Array.isArray(G)?G[1]:typeof G=="number"?G:null;function j(t){let s=t*100;switch(z){case "right":return `inset(0 0 0 ${100-s}%)`;case "top":return `inset(0 0 ${100-s}% 0)`;case "bottom":return `inset(${100-s}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-s}% 0 0)`}}let x=z?[]:Array.from(e.querySelectorAll(o)),v=[],F=[],N=0,R=0,D=false,q=false,W=0,se=false,P=-1,oe=-1,B=false,ie=0,Q=0,ae,ge=null,le=new Set,ue=-1,Te=performance.now();function Y(){return $?b==="x"?$.scrollLeft:$.scrollTop:b==="x"?window.scrollX:window.scrollY}function Pe(){return $?b==="x"?$.clientWidth:$.clientHeight:b==="x"?window.innerWidth:window.innerHeight}function Le(){let t=e.getBoundingClientRect(),s,l,g;if($){let E=$.getBoundingClientRect();s=b==="x"?t.left-E.left+$.scrollLeft:t.top-E.top+$.scrollTop,l=b==="x"?t.width:t.height,g=Y();}else s=b==="x"?t.left:t.top,l=b==="x"?t.width:t.height,g=Y();let _=Ee({top:s,height:l},g,Pe(),ke,Ae);N=_.tStart,R=_.tEnd,U&&process.env.NODE_ENV!=="production"&&(ge?.remove(),ge=Ze(N,R,b));}function Be(t,s){if(e.style.setProperty("--scroll-draw-progress",String(t)),z){let l=s==="reverse"?1-t:t;e.style.clipPath=j(l);return}x.forEach((l,g)=>{l.style.strokeDashoffset=s==="reverse"?`${v[g]*t}`:`${v[g]*(1-t)}`,u&&(l.style.opacity=s==="reverse"?`${1-t}`:`${t}`),O&&S?l.style.stroke=Se(O,S,t):S&&(l.style.stroke=S),M!==null&&k!==null?l.style.strokeWidth=`${M+(k-M)*t}`:k!==null&&(l.style.strokeWidth=`${k}`),A!==null&&T!==null?l.style.fillOpacity=`${A+(T-A)*t}`:T!==null&&(l.style.fillOpacity=`${T}`),C&&l.tagName.toLowerCase()==="path"&&F[g]&&l.setAttribute("d",We(F[g],C,t));});}function De(){if(e.style.setProperty("--scroll-draw-progress","0"),z){e.style.clipPath=j(0);return}x.forEach((t,s)=>{t.style.strokeDasharray=`${v[s]}`,t.style.strokeDashoffset=a==="reverse"?"0":`${v[s]}`,u?t.style.opacity=a==="reverse"?"1":"0":t.style.opacity="",O&&(t.style.stroke=O),M!==null&&(t.style.strokeWidth=`${M}`),A!==null&&(t.style.fillOpacity=`${A}`),C&&t.tagName.toLowerCase()==="path"&&F[s]&&t.setAttribute("d",F[s]);});}if(x.forEach(t=>{Ye(t);let s=xe(t);v.push(s),t.tagName.toLowerCase()==="path"?F.push(t.getAttribute("d")??""):F.push(""),n?(t.style.strokeDasharray=`${s}`,t.style.strokeDashoffset=a==="reverse"?`${s}`:"0",u&&(t.style.opacity="1"),S&&(t.style.stroke=S),k!==null&&(t.style.strokeWidth=`${k}`),T!==null&&(t.style.fillOpacity=`${T}`),C&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",C)):(t.style.strokeDasharray=`${s}`,t.style.strokeDashoffset=a==="reverse"?"0":`${s}`,u?t.style.opacity=a==="reverse"?"1":"0":t.style.opacity="",O&&(t.style.stroke=O),M!==null&&(t.style.strokeWidth=`${M}`),A!==null&&(t.style.fillOpacity=`${A}`));}),z){if(n)return e.style.clipPath=j(1),K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=j(0);}else if(n)return K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function _e(){return !(qe===false||!Qe()||!x.length||typeof p!="string"||!(p in Re)||z||b!=="y"||$||c!==1||I!==0||d||ee||re!==false||C||te||J||pe>0||ye||he||K||H!=null||V!=null||G!=null||(h.start??"top bottom").trim()!=="top bottom"||(h.end??"bottom top").trim()!=="bottom top")}function Xe(){let t=`svg-scroll-draw-${++Ke}`,s=a==="reverse"?"0":"var(--ssd-len)",l=a==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${s};`,_=`stroke-dashoffset:${l};`;u&&(g+=`opacity:${a==="reverse"?1:0};`,_+=`opacity:${a==="reverse"?0:1};`);let E=document.createElement("style");E.setAttribute("data-svg-scroll-draw",""),E.textContent=`@keyframes ${t}{from{${g}}to{${_}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Re[p]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(E);function i(m,L){m.style.setProperty("--ssd-len",String(v[L])),m.style.strokeDasharray=`${v[L]}`,m.style.strokeDashoffset="",m.style.opacity="",m.style.animationPlayState="",m.classList.add(t);}x.forEach(i);let f=false,w=-1;function y(){if(w>=0)return w;let m=e.getBoundingClientRect(),{tStart:L,tEnd:Z}=Ee({top:m.top,height:m.height},Y(),Pe(),ke,Ae);return ne(X(Y(),L,Z,c))}return {destroy(){x.forEach(m=>{m.classList.remove(t),m.style.removeProperty("--ssd-len"),m.style.animationPlayState="";}),E.remove();},replay(){f=false,w=-1,x.forEach(i);},pause(){f=true,x.forEach(m=>{m.style.animationPlayState="paused";});},resume(){f&&(f=false,x.forEach(m=>{m.style.animationPlayState="running";}));},seek(m){let L=Math.min(1,Math.max(0,m));w=L,f=true,x.forEach((Z,Ie)=>{Z.classList.remove(t),Z.style.strokeDashoffset=a==="reverse"?`${v[Ie]*L}`:`${v[Ie]*(1-L)}`,u&&(Z.style.opacity=a==="reverse"?`${1-L}`:`${L}`);});},getProgress(){return y()}}}if(_e())return Xe();Le();function ce(){if(!se||B)return;let t=performance.now(),s=Y(),l=c;if(re!==false){let i=t-Te,f=i>0?Math.abs(s-(ue<0?s:ue))/i:0;l=c*Math.max(.2,1+f*(typeof re=="number"?re:1)*.04);}ue=s,Te=t;let g=ee?oe===-1||s>=oe?"forward":"reverse":a;oe=s;let _=R-N,E=true;if(z){let i=ne(X(s,N,R,l));d&&!ee&&(P=Math.max(P,i),i=P),ie=i,e.style.setProperty("--scroll-draw-progress",String(i));let f=g==="reverse"?1-i:i;e.style.clipPath=j(f),ye?.(i),!q&&X(s,N,R,l)>0&&(q=true,he?.()),i>=1&&!D?(D=true,K?.(),Q<(J==="infinite"?1/0:J??0)&&(Q++,ae=setTimeout(()=>{P=-1,q=false,D=false,e.style.clipPath=j(0);},Me))):i<1&&!d&&(D=false),W=requestAnimationFrame(ce);return}if(x.forEach((i,f)=>{let w=f*I*_,y=ne(X(s,N+w,R+w,l));d&&!ee&&(P=Math.max(P,y),y=P),ie=y,i.style.strokeDashoffset=g==="reverse"?`${v[f]*y}`:`${v[f]*(1-y)}`,u&&(i.style.opacity=g==="reverse"?`${1-y}`:`${y}`),O&&S?i.style.stroke=Se(O,S,y):S&&(i.style.stroke=S),M!==null&&k!==null?i.style.strokeWidth=`${M+(k-M)*y}`:k!==null&&(i.style.strokeWidth=`${k}`),A!==null&&T!==null?i.style.fillOpacity=`${A+(T-A)*y}`:T!==null&&(i.style.fillOpacity=`${T}`),C&&i.tagName.toLowerCase()==="path"&&F[f]&&i.setAttribute("d",We(F[f],C,y)),f===0&&(ye?.(y),e.style.setProperty("--scroll-draw-progress",String(y))),y<1&&(E=false);}),te){let i=ne(X(s,N,R,l));for(let f in te){let w=parseFloat(f);i>=w&&!le.has(w)&&(le.add(w),te[f]?.());}}!q&&X(s,N,R,l)>0&&(q=true,he?.()),E&&!D?(D=true,K?.(),Q<(J==="infinite"?1/0:J??0)&&(Q++,ae=setTimeout(()=>{P=-1,q=false,D=false,le.clear(),De();},Me))):!E&&!d&&(D=false),W=requestAnimationFrame(ce);}let be=new IntersectionObserver(t=>{t.forEach(s=>{se=s.isIntersecting,se&&!B?W=requestAnimationFrame(ce):cancelAnimationFrame(W);});},{root:$??null,threshold:Ge,rootMargin:ze}),ve;function fe(){clearTimeout(ve),ve=setTimeout(()=>{x.forEach((t,s)=>{v[s]=xe(t),t.style.strokeDasharray=`${v[s]}`;}),Le();},150);}return window.addEventListener("resize",fe),window.addEventListener("orientationchange",fe),pe>0?setTimeout(()=>be.observe(e),pe):be.observe(e),{destroy(){cancelAnimationFrame(W),clearTimeout(ae),be.disconnect(),window.removeEventListener("resize",fe),window.removeEventListener("orientationchange",fe),clearTimeout(ve),ge?.remove();},replay(){P=-1,oe=-1,ue=-1,q=false,D=false,Q=0,B=false,le.clear(),clearTimeout(ae),De();},pause(){B=true,cancelAnimationFrame(W);},resume(){B&&(B=false,se&&(W=requestAnimationFrame(ce)));},seek(t){let s=Math.min(1,Math.max(0,t));ie=s,P=s,B=true,cancelAnimationFrame(W),Be(s,a);},getProgress(){return ie}}}var Ve=class{constructor(){this.instance=null;}init(r,n={}){return this.destroy(),this.instance=He(r,n),this}replay(){return this.instance?.replay(),this}destroy(){return this.instance?.destroy(),this.instance=null,this}};exports.ScrollDrawRef=Ve;
1
+ 'use strict';function Ye({bounces:e=3,decay:n=.5}={}){let s=Math.max(1,Math.round(e)),o=Math.max(.01,Math.min(.99,n)),d=Math.sqrt(o),m=0,b=[];for(let u=0;u<s;u++){let h=Math.pow(d,u);b.push(h),m+=h;}let $=[0],N=0;for(let u=0;u<s;u++)N+=b[u]/m,$.push(N);return u=>{if(u<=0)return 0;if(u>=1)return 1;for(let h=0;h<s;h++)if(u<=$[h+1]){let se=(u-$[h])/($[h+1]-$[h]);if(h===0)return se*(2-se);let P=1-Math.pow(o,h);return P+(1-P)*(2*se-1)*(2*se-1)}return 1}}function Ze({amplitude:e=1,period:n=.4}={}){let s=Math.max(1,e),o=Math.max(.1,n),d=s<=1?o/4:o/(2*Math.PI)*Math.asin(1/s);return m=>m<=0?0:m>=1?1:s*Math.pow(2,-10*m)*Math.sin((m-d)*(2*Math.PI)/o)+1}var Se={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:Ye(),elastic:Ze()};function ke(e="top bottom"){let n=e.trim();if(/^\d+(\.\d+)?%$/.test(n))return {element:"top",viewport:n};let[s="top",o="bottom"]=n.split(/\s+/).filter(Boolean);return {element:s,viewport:o}}function He(e,n,s,o){switch(o){case "top":return e+s;case "center":return e+s+n/2;case "bottom":return e+s+n;default:return e+s}}function We(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 s=parseFloat(e.getAttribute("width")??"0"),o=parseFloat(e.getAttribute("height")??"0");return 2*(s+o)}if(n==="circle"){let s=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*s}return e.getTotalLength()}function et(e,n,s){return Math.min(s,Math.max(n,e))}function ne(e,n,s,o){return s===n?0:et((e-n)/(s-n)*o,0,1)}function Le(e,n,s,o,d){let m=He(e.top,e.height,n,o.element)-We(o.viewport,s),b=He(e.top,e.height,n,d.element)-We(d.viewport,s);return {tStart:m,tEnd:b}}function ze(e){let n=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(n)return [parseInt(n[1]+n[1],16),parseInt(n[2]+n[2],16),parseInt(n[3]+n[3],16)];let s=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(s)return [parseInt(s[1],16),parseInt(s[2],16),parseInt(s[3],16)];let o=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return o?[parseInt(o[1]),parseInt(o[2]),parseInt(o[3])]:null}function ve(e,n,s){let o=ze(e),d=ze(n);return !o||!d?e:`rgb(${Math.round(o[0]+(d[0]-o[0])*s)},${Math.round(o[1]+(d[1]-o[1])*s)},${Math.round(o[2]+(d[2]-o[2])*s)})`}function qe(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n);}var Ve={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},tt=0;function rt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function nt(e){let n=e.getAttribute("stroke"),s=e.getAttribute("fill");!n||n==="none"?qe("Element has no stroke \u2014 path will not be visible.",e):s&&s!=="none"&&s!=="transparent"&&qe("Element has a fill \u2014 it may obscure the stroke animation.",e);}function st(e,n,s){let o=document.createElement("div");o.setAttribute("data-svg-scroll-draw-debug",""),o.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 d(){let m=s==="x"?window.scrollX:window.scrollY,b=e-m,$=n-m,N=s==="x";o.innerHTML=`
2
+ <div style="position:absolute;${N?`left:${b}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${b}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;${N?`left:${$}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${$}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(o),window.addEventListener("scroll",d,{passive:true}),d(),o}function Pe(e,n,s){let o=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),d=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,m=>{let b=parseFloat(m),$=o[d++]??b;return String(+(b+($-b)*s).toFixed(4))})}function Ge(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let s=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:o="path, polyline, line, polygon, rect, circle",speed:d=1,fade:m=false,easing:b="linear",trigger:$={},stagger:N=0,direction:u="forward",once:h=false,debug:se=false,axis:P="y",scrollContainer:Ee,autoReverse:ce=false,delay:ae=0,strokeColor:j,strokeWidth:J,fillOpacity:K,waypoints:Q,velocityScale:fe=false,threshold:De=0,rootMargin:Ie="0px",repeat:Y=0,repeatDelay:$e=0,morphTo:R,clip:xe,autoplay:_e=false,duration:Xe=1e3,native:Ue=true,onProgress:le,onStart:me,onComplete:oe}=n,G=xe===true?"left":typeof xe=="string"?xe:false,Z=typeof b=="function"?b:Se[b]??Se.linear,Fe=ke($.start??"top bottom"),Ce=ke($.end??"bottom top"),D=typeof Ee=="string"?document.querySelector(Ee):Ee??null,H=Array.isArray(j)?j[0]:null,A=Array.isArray(j)?j[1]:typeof j=="string"?j:null,I=Array.isArray(J)?J[0]:null,T=Array.isArray(J)?J[1]:typeof J=="number"?J:null,F=Array.isArray(K)?K[0]:null,S=Array.isArray(K)?K[1]:typeof K=="number"?K:null;function ee(t){let r=t*100;switch(G){case "right":return `inset(0 0 0 ${100-r}%)`;case "top":return `inset(0 0 ${100-r}% 0)`;case "bottom":return `inset(${100-r}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-r}% 0 0)`}}let x=G?[]:Array.from(e.querySelectorAll(o)),v=[],W=[],B=0,_=0,M=false,O=false,E=0,pe=false,z=-1,de=-1,k=false,te=0,V=0,X,Me=null,U=new Set,ye=-1,Oe=performance.now();function ue(){return D?P==="x"?D.scrollLeft:D.scrollTop:P==="x"?window.scrollX:window.scrollY}function Ne(){return D?P==="x"?D.clientWidth:D.clientHeight:P==="x"?window.innerWidth:window.innerHeight}function Re(){let t=e.getBoundingClientRect(),r,l,g;if(D){let L=D.getBoundingClientRect();r=P==="x"?t.left-L.left+D.scrollLeft:t.top-L.top+D.scrollTop,l=P==="x"?t.width:t.height,g=ue();}else r=P==="x"?t.left:t.top,l=P==="x"?t.width:t.height,g=ue();let C=Le({top:r,height:l},g,Ne(),Fe,Ce);B=C.tStart,_=C.tEnd,se&&process.env.NODE_ENV!=="production"&&(Me?.remove(),Me=st(B,_,P));}function je(t,r){if(e.style.setProperty("--scroll-draw-progress",String(t)),G){let l=r==="reverse"?1-t:t;e.style.clipPath=ee(l);return}x.forEach((l,g)=>{l.style.strokeDashoffset=r==="reverse"?`${v[g]*t}`:`${v[g]*(1-t)}`,m&&(l.style.opacity=r==="reverse"?`${1-t}`:`${t}`),H&&A?l.style.stroke=ve(H,A,t):A&&(l.style.stroke=A),I!==null&&T!==null?l.style.strokeWidth=`${I+(T-I)*t}`:T!==null&&(l.style.strokeWidth=`${T}`),F!==null&&S!==null?l.style.fillOpacity=`${F+(S-F)*t}`:S!==null&&(l.style.fillOpacity=`${S}`),R&&l.tagName.toLowerCase()==="path"&&W[g]&&l.setAttribute("d",Pe(W[g],R,t));});}function he(){if(e.style.setProperty("--scroll-draw-progress","0"),G){e.style.clipPath=ee(0);return}x.forEach((t,r)=>{t.style.strokeDasharray=`${v[r]}`,t.style.strokeDashoffset=u==="reverse"?"0":`${v[r]}`,m?t.style.opacity=u==="reverse"?"1":"0":t.style.opacity="",H&&(t.style.stroke=H),I!==null&&(t.style.strokeWidth=`${I}`),F!==null&&(t.style.fillOpacity=`${F}`),R&&t.tagName.toLowerCase()==="path"&&W[r]&&t.setAttribute("d",W[r]);});}if(x.forEach(t=>{nt(t);let r=we(t);v.push(r),t.tagName.toLowerCase()==="path"?W.push(t.getAttribute("d")??""):W.push(""),s?(t.style.strokeDasharray=`${r}`,t.style.strokeDashoffset=u==="reverse"?`${r}`:"0",m&&(t.style.opacity="1"),A&&(t.style.stroke=A),T!==null&&(t.style.strokeWidth=`${T}`),S!==null&&(t.style.fillOpacity=`${S}`),R&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",R)):(t.style.strokeDasharray=`${r}`,t.style.strokeDashoffset=u==="reverse"?"0":`${r}`,m?t.style.opacity=u==="reverse"?"1":"0":t.style.opacity="",H&&(t.style.stroke=H),I!==null&&(t.style.strokeWidth=`${I}`),F!==null&&(t.style.fillOpacity=`${F}`));}),G){if(s)return e.style.clipPath=ee(1),oe?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ee(0);}else if(s)return oe?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Je(){return !(Ue===false||!rt()||!x.length||typeof b!="string"||!(b in Ve)||G||P!=="y"||D||d!==1||N!==0||h||ce||fe!==false||R||Q||Y||ae>0||le||me||oe||j!=null||J!=null||K!=null||($.start??"top bottom").trim()!=="top bottom"||($.end??"bottom top").trim()!=="bottom top")}function Ke(){let t=`svg-scroll-draw-${++tt}`,r=u==="reverse"?"0":"var(--ssd-len)",l=u==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${r};`,C=`stroke-dashoffset:${l};`;m&&(g+=`opacity:${u==="reverse"?1:0};`,C+=`opacity:${u==="reverse"?0:1};`);let L=document.createElement("style");L.setAttribute("data-svg-scroll-draw",""),L.textContent=`@keyframes ${t}{from{${g}}to{${C}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Ve[b]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(L);function a(i,f){i.style.setProperty("--ssd-len",String(v[f])),i.style.strokeDasharray=`${v[f]}`,i.style.strokeDashoffset="",i.style.opacity="",i.style.animationPlayState="",i.classList.add(t);}x.forEach(a);let p=false,w=-1;function c(){if(w>=0)return w;let i=e.getBoundingClientRect(),{tStart:f,tEnd:y}=Le({top:i.top,height:i.height},ue(),Ne(),Fe,Ce);return Z(ne(ue(),f,y,d))}return {destroy(){x.forEach(i=>{i.classList.remove(t),i.style.removeProperty("--ssd-len"),i.style.animationPlayState="";}),L.remove();},replay(){p=false,w=-1,x.forEach(a);},pause(){p=true,x.forEach(i=>{i.style.animationPlayState="paused";});},resume(){p&&(p=false,x.forEach(i=>{i.style.animationPlayState="running";}));},seek(i){let f=Math.min(1,Math.max(0,i));w=f,p=true,x.forEach((y,re)=>{y.classList.remove(t),y.style.strokeDashoffset=u==="reverse"?`${v[re]*f}`:`${v[re]*(1-f)}`,m&&(y.style.opacity=u==="reverse"?`${1-f}`:`${f}`);});},getProgress(){return c()}}}if(Je())return Ke();function Qe(){let t=Math.max(1,Xe),r=0,l=0;function g(c){let i=true;if(G){let f=Math.min(1,Math.max(0,c/t)),y=Z(f);te=y,e.style.setProperty("--scroll-draw-progress",String(y)),e.style.clipPath=ee(u==="reverse"?1-y:y),le?.(y),f<1&&(i=false);}else x.forEach((f,y)=>{let re=y*N*t,ie=Math.min(1,Math.max(0,(c-re)/t)),q=Z(ie);f.style.strokeDashoffset=u==="reverse"?`${v[y]*q}`:`${v[y]*(1-q)}`,m&&(f.style.opacity=u==="reverse"?`${1-q}`:`${q}`),H&&A?f.style.stroke=ve(H,A,q):A&&(f.style.stroke=A),I!==null&&T!==null?f.style.strokeWidth=`${I+(T-I)*q}`:T!==null&&(f.style.strokeWidth=`${T}`),F!==null&&S!==null?f.style.fillOpacity=`${F+(S-F)*q}`:S!==null&&(f.style.fillOpacity=`${S}`),R&&f.tagName.toLowerCase()==="path"&&W[y]&&f.setAttribute("d",Pe(W[y],R,q)),y===0&&(le?.(q),e.style.setProperty("--scroll-draw-progress",String(q))),ie<1&&(i=false);});if(Q){let f=Math.min(1,Math.max(0,c/t)),y=Z(f);for(let re in Q){let ie=parseFloat(re);y>=ie&&!U.has(ie)&&(U.add(ie),Q[re]?.());}}return i}function C(c){if(k)return;let i=c-r;O||(O=true,me?.());let f=g(i);if(f&&!M){M=true,g(t*(1+Math.max(0,x.length-1)*N)),oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{r=performance.now(),O=false,M=false,U.clear(),he(),E=requestAnimationFrame(C);},$e));return}f||(E=requestAnimationFrame(C));}function L(){cancelAnimationFrame(E),clearTimeout(X),r=performance.now(),l=0,k=false,O=false,M=false,V=0,U.clear(),he(),E=requestAnimationFrame(C);}let a=new IntersectionObserver(c=>{c.forEach(i=>{i.isIntersecting&&!(h&&M)?L():!i.isIntersecting&&!h&&!M&&(cancelAnimationFrame(E),clearTimeout(X),r=null);});},{root:D??null,threshold:De,rootMargin:Ie}),p;function w(){clearTimeout(p),p=setTimeout(()=>{x.forEach((c,i)=>{v[i]=we(c),c.style.strokeDasharray=`${v[i]}`;});},150);}return window.addEventListener("resize",w),window.addEventListener("orientationchange",w),ae>0?setTimeout(()=>a.observe(e),ae):a.observe(e),{destroy(){cancelAnimationFrame(E),clearTimeout(X),a.disconnect(),window.removeEventListener("resize",w),window.removeEventListener("orientationchange",w),clearTimeout(p);},replay(){V=0,L();},pause(){k||(k=true,l=performance.now()-r,cancelAnimationFrame(E));},resume(){k&&(k=false,r=performance.now()-l,E=requestAnimationFrame(C));},seek(c){let i=Math.min(1,Math.max(0,c));te=i,k=true,l=i*t,r=performance.now()-l,cancelAnimationFrame(E),g(l);},getProgress(){return te}}}if(_e)return Qe();Re();function ge(){if(!pe||k)return;let t=performance.now(),r=ue(),l=d;if(fe!==false){let a=t-Oe,p=a>0?Math.abs(r-(ye<0?r:ye))/a:0;l=d*Math.max(.2,1+p*(typeof fe=="number"?fe:1)*.04);}ye=r,Oe=t;let g=ce?de===-1||r>=de?"forward":"reverse":u;de=r;let C=_-B,L=true;if(G){let a=Z(ne(r,B,_,l));h&&!ce&&(z=Math.max(z,a),a=z),te=a,e.style.setProperty("--scroll-draw-progress",String(a));let p=g==="reverse"?1-a:a;e.style.clipPath=ee(p),le?.(a),!O&&ne(r,B,_,l)>0&&(O=true,me?.()),a>=1&&!M?(M=true,oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{z=-1,O=false,M=false,e.style.clipPath=ee(0);},$e))):a<1&&!h&&(M=false),E=requestAnimationFrame(ge);return}if(x.forEach((a,p)=>{let w=p*N*C,c=Z(ne(r,B+w,_+w,l));h&&!ce&&(z=Math.max(z,c),c=z),te=c,a.style.strokeDashoffset=g==="reverse"?`${v[p]*c}`:`${v[p]*(1-c)}`,m&&(a.style.opacity=g==="reverse"?`${1-c}`:`${c}`),H&&A?a.style.stroke=ve(H,A,c):A&&(a.style.stroke=A),I!==null&&T!==null?a.style.strokeWidth=`${I+(T-I)*c}`:T!==null&&(a.style.strokeWidth=`${T}`),F!==null&&S!==null?a.style.fillOpacity=`${F+(S-F)*c}`:S!==null&&(a.style.fillOpacity=`${S}`),R&&a.tagName.toLowerCase()==="path"&&W[p]&&a.setAttribute("d",Pe(W[p],R,c)),p===0&&(le?.(c),e.style.setProperty("--scroll-draw-progress",String(c))),c<1&&(L=false);}),Q){let a=Z(ne(r,B,_,l));for(let p in Q){let w=parseFloat(p);a>=w&&!U.has(w)&&(U.add(w),Q[p]?.());}}!O&&ne(r,B,_,l)>0&&(O=true,me?.()),L&&!M?(M=true,oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{z=-1,O=false,M=false,U.clear(),he();},$e))):!L&&!h&&(M=false),E=requestAnimationFrame(ge);}let Ae=new IntersectionObserver(t=>{t.forEach(r=>{pe=r.isIntersecting,pe&&!k?E=requestAnimationFrame(ge):cancelAnimationFrame(E);});},{root:D??null,threshold:De,rootMargin:Ie}),Te;function be(){clearTimeout(Te),Te=setTimeout(()=>{x.forEach((t,r)=>{v[r]=we(t),t.style.strokeDasharray=`${v[r]}`;}),Re();},150);}return window.addEventListener("resize",be),window.addEventListener("orientationchange",be),ae>0?setTimeout(()=>Ae.observe(e),ae):Ae.observe(e),{destroy(){cancelAnimationFrame(E),clearTimeout(X),Ae.disconnect(),window.removeEventListener("resize",be),window.removeEventListener("orientationchange",be),clearTimeout(Te),Me?.remove();},replay(){z=-1,de=-1,ye=-1,O=false,M=false,V=0,k=false,U.clear(),clearTimeout(X),he();},pause(){k=true,cancelAnimationFrame(E);},resume(){k&&(k=false,pe&&(E=requestAnimationFrame(ge)));},seek(t){let r=Math.min(1,Math.max(0,t));te=r,z=r,k=true,cancelAnimationFrame(E),je(r,u);},getProgress(){return te}}}var Be=class{constructor(){this.instance=null;}init(n,s={}){return this.destroy(),this.instance=Ge(n,s),this}replay(){return this.instance?.replay(),this}destroy(){return this.instance?.destroy(),this.instance=null,this}};exports.ScrollDrawRef=Be;
@@ -60,6 +60,25 @@ interface ScrollDrawOptions {
60
60
  onProgress?: (alpha: number) => void;
61
61
  onStart?: () => void;
62
62
  onComplete?: () => void;
63
+ /**
64
+ * Trigger the animation when the element enters the viewport instead of
65
+ * tying it to scroll position. The draw runs over `duration` milliseconds,
66
+ * replaying each time the element re-enters the viewport (use `once: true`
67
+ * to play only the first time).
68
+ *
69
+ * All visual options work in autoplay mode — `easing`, `stagger`, `fade`,
70
+ * `strokeColor`, `strokeWidth`, `fillOpacity`, `clip`, `morphTo`, `waypoints`,
71
+ * `repeat`, `repeatDelay`, `onStart`, `onComplete`, `onProgress`, etc.
72
+ *
73
+ * The full instance API (`pause`, `resume`, `seek`, `replay`, `getProgress`)
74
+ * also works — `seek(0.5)` pauses at 50% of the duration.
75
+ */
76
+ autoplay?: boolean;
77
+ /**
78
+ * Duration of the autoplay animation in milliseconds. Only used when
79
+ * `autoplay: true`. Default `1000`.
80
+ */
81
+ duration?: number;
63
82
  /**
64
83
  * Use the browser's native CSS scroll-driven animation
65
84
  * (`animation-timeline: view()`) when the configuration is simple enough and
@@ -60,6 +60,25 @@ interface ScrollDrawOptions {
60
60
  onProgress?: (alpha: number) => void;
61
61
  onStart?: () => void;
62
62
  onComplete?: () => void;
63
+ /**
64
+ * Trigger the animation when the element enters the viewport instead of
65
+ * tying it to scroll position. The draw runs over `duration` milliseconds,
66
+ * replaying each time the element re-enters the viewport (use `once: true`
67
+ * to play only the first time).
68
+ *
69
+ * All visual options work in autoplay mode — `easing`, `stagger`, `fade`,
70
+ * `strokeColor`, `strokeWidth`, `fillOpacity`, `clip`, `morphTo`, `waypoints`,
71
+ * `repeat`, `repeatDelay`, `onStart`, `onComplete`, `onProgress`, etc.
72
+ *
73
+ * The full instance API (`pause`, `resume`, `seek`, `replay`, `getProgress`)
74
+ * also works — `seek(0.5)` pauses at 50% of the duration.
75
+ */
76
+ autoplay?: boolean;
77
+ /**
78
+ * Duration of the autoplay animation in milliseconds. Only used when
79
+ * `autoplay: true`. Default `1000`.
80
+ */
81
+ duration?: number;
63
82
  /**
64
83
  * Use the browser's native CSS scroll-driven animation
65
84
  * (`animation-timeline: view()`) when the configuration is simple enough and
@@ -1,3 +1,3 @@
1
- function Ue({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),o=Math.max(.01,Math.min(.99,r)),c=Math.sqrt(o),u=0,p=[];for(let a=0;a<n;a++){let d=Math.pow(c,a);p.push(d),u+=d;}let h=[0],I=0;for(let a=0;a<n;a++)I+=p[a]/u,h.push(I);return a=>{if(a<=0)return 0;if(a>=1)return 1;for(let d=0;d<n;d++)if(a<=h[d+1]){let U=(a-h[d])/(h[d+1]-h[d]);if(d===0)return U*(2-U);let b=1-Math.pow(o,d);return b+(1-b)*(2*U-1)*(2*U-1)}return 1}}function je({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),o=Math.max(.1,r),c=n<=1?o/4:o/(2*Math.PI)*Math.asin(1/n);return u=>u<=0?0:u>=1?1:n*Math.pow(2,-10*u)*Math.sin((u-c)*(2*Math.PI)/o)+1}var we={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:Ue(),elastic:je()};function $e(e="top bottom"){let r=e.trim();if(/^\d+(\.\d+)?%$/.test(r))return {element:"top",viewport:r};let[n="top",o="bottom"]=r.split(/\s+/).filter(Boolean);return {element:n,viewport:o}}function Ce(e,r,n,o){switch(o){case "top":return e+n;case "center":return e+n+r/2;case "bottom":return e+n+r;default:return e+n}}function Oe(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 xe(e){let r=e.tagName.toLowerCase();if(r==="rect"){let n=parseFloat(e.getAttribute("width")??"0"),o=parseFloat(e.getAttribute("height")??"0");return 2*(n+o)}if(r==="circle"){let n=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*n}return e.getTotalLength()}function Je(e,r,n){return Math.min(n,Math.max(r,e))}function X(e,r,n,o){return n===r?0:Je((e-r)/(n-r)*o,0,1)}function Ee(e,r,n,o,c){let u=Ce(e.top,e.height,r,o.element)-Oe(o.viewport,n),p=Ce(e.top,e.height,r,c.element)-Oe(c.viewport,n);return {tStart:u,tEnd:p}}function Fe(e){let r=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(r)return [parseInt(r[1]+r[1],16),parseInt(r[2]+r[2],16),parseInt(r[3]+r[3],16)];let n=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(n)return [parseInt(n[1],16),parseInt(n[2],16),parseInt(n[3],16)];let o=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return o?[parseInt(o[1]),parseInt(o[2]),parseInt(o[3])]:null}function Se(e,r,n){let o=Fe(e),c=Fe(r);return !o||!c?e:`rgb(${Math.round(o[0]+(c[0]-o[0])*n)},${Math.round(o[1]+(c[1]-o[1])*n)},${Math.round(o[2]+(c[2]-o[2])*n)})`}function Ne(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r);}var Re={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},Ke=0;function Qe(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Ye(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?Ne("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&Ne("Element has a fill \u2014 it may obscure the stroke animation.",e);}function Ze(e,r,n){let o=document.createElement("div");o.setAttribute("data-svg-scroll-draw-debug",""),o.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function c(){let u=n==="x"?window.scrollX:window.scrollY,p=e-u,h=r-u,I=n==="x";o.innerHTML=`
2
- <div style="position:absolute;${I?`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;${I?`left:${h}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${h}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(o),window.addEventListener("scroll",c,{passive:true}),c(),o}function We(e,r,n){let o=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),c=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,u=>{let p=parseFloat(u),h=o[c++]??p;return String(+(p+(h-p)*n).toFixed(4))})}function He(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let n=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:o="path, polyline, line, polygon, rect, circle",speed:c=1,fade:u=false,easing:p="linear",trigger:h={},stagger:I=0,direction:a="forward",once:d=false,debug:U=false,axis:b="y",scrollContainer:me,autoReverse:ee=false,delay:pe=0,strokeColor:H,strokeWidth:V,fillOpacity:G,waypoints:te,velocityScale:re=false,threshold:Ge=0,rootMargin:ze="0px",repeat:J=0,repeatDelay:Me=0,morphTo:C,clip:de,native:qe=true,onProgress:ye,onStart:he,onComplete:K}=r,z=de===true?"left":typeof de=="string"?de:false,ne=typeof p=="function"?p:we[p]??we.linear,ke=$e(h.start??"top bottom"),Ae=$e(h.end??"bottom top"),$=typeof me=="string"?document.querySelector(me):me??null,O=Array.isArray(H)?H[0]:null,S=Array.isArray(H)?H[1]:typeof H=="string"?H:null,M=Array.isArray(V)?V[0]:null,k=Array.isArray(V)?V[1]:typeof V=="number"?V:null,A=Array.isArray(G)?G[0]:null,T=Array.isArray(G)?G[1]:typeof G=="number"?G:null;function j(t){let s=t*100;switch(z){case "right":return `inset(0 0 0 ${100-s}%)`;case "top":return `inset(0 0 ${100-s}% 0)`;case "bottom":return `inset(${100-s}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-s}% 0 0)`}}let x=z?[]:Array.from(e.querySelectorAll(o)),v=[],F=[],N=0,R=0,D=false,q=false,W=0,se=false,P=-1,oe=-1,B=false,ie=0,Q=0,ae,ge=null,le=new Set,ue=-1,Te=performance.now();function Y(){return $?b==="x"?$.scrollLeft:$.scrollTop:b==="x"?window.scrollX:window.scrollY}function Pe(){return $?b==="x"?$.clientWidth:$.clientHeight:b==="x"?window.innerWidth:window.innerHeight}function Le(){let t=e.getBoundingClientRect(),s,l,g;if($){let E=$.getBoundingClientRect();s=b==="x"?t.left-E.left+$.scrollLeft:t.top-E.top+$.scrollTop,l=b==="x"?t.width:t.height,g=Y();}else s=b==="x"?t.left:t.top,l=b==="x"?t.width:t.height,g=Y();let _=Ee({top:s,height:l},g,Pe(),ke,Ae);N=_.tStart,R=_.tEnd,U&&process.env.NODE_ENV!=="production"&&(ge?.remove(),ge=Ze(N,R,b));}function Be(t,s){if(e.style.setProperty("--scroll-draw-progress",String(t)),z){let l=s==="reverse"?1-t:t;e.style.clipPath=j(l);return}x.forEach((l,g)=>{l.style.strokeDashoffset=s==="reverse"?`${v[g]*t}`:`${v[g]*(1-t)}`,u&&(l.style.opacity=s==="reverse"?`${1-t}`:`${t}`),O&&S?l.style.stroke=Se(O,S,t):S&&(l.style.stroke=S),M!==null&&k!==null?l.style.strokeWidth=`${M+(k-M)*t}`:k!==null&&(l.style.strokeWidth=`${k}`),A!==null&&T!==null?l.style.fillOpacity=`${A+(T-A)*t}`:T!==null&&(l.style.fillOpacity=`${T}`),C&&l.tagName.toLowerCase()==="path"&&F[g]&&l.setAttribute("d",We(F[g],C,t));});}function De(){if(e.style.setProperty("--scroll-draw-progress","0"),z){e.style.clipPath=j(0);return}x.forEach((t,s)=>{t.style.strokeDasharray=`${v[s]}`,t.style.strokeDashoffset=a==="reverse"?"0":`${v[s]}`,u?t.style.opacity=a==="reverse"?"1":"0":t.style.opacity="",O&&(t.style.stroke=O),M!==null&&(t.style.strokeWidth=`${M}`),A!==null&&(t.style.fillOpacity=`${A}`),C&&t.tagName.toLowerCase()==="path"&&F[s]&&t.setAttribute("d",F[s]);});}if(x.forEach(t=>{Ye(t);let s=xe(t);v.push(s),t.tagName.toLowerCase()==="path"?F.push(t.getAttribute("d")??""):F.push(""),n?(t.style.strokeDasharray=`${s}`,t.style.strokeDashoffset=a==="reverse"?`${s}`:"0",u&&(t.style.opacity="1"),S&&(t.style.stroke=S),k!==null&&(t.style.strokeWidth=`${k}`),T!==null&&(t.style.fillOpacity=`${T}`),C&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",C)):(t.style.strokeDasharray=`${s}`,t.style.strokeDashoffset=a==="reverse"?"0":`${s}`,u?t.style.opacity=a==="reverse"?"1":"0":t.style.opacity="",O&&(t.style.stroke=O),M!==null&&(t.style.strokeWidth=`${M}`),A!==null&&(t.style.fillOpacity=`${A}`));}),z){if(n)return e.style.clipPath=j(1),K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=j(0);}else if(n)return K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function _e(){return !(qe===false||!Qe()||!x.length||typeof p!="string"||!(p in Re)||z||b!=="y"||$||c!==1||I!==0||d||ee||re!==false||C||te||J||pe>0||ye||he||K||H!=null||V!=null||G!=null||(h.start??"top bottom").trim()!=="top bottom"||(h.end??"bottom top").trim()!=="bottom top")}function Xe(){let t=`svg-scroll-draw-${++Ke}`,s=a==="reverse"?"0":"var(--ssd-len)",l=a==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${s};`,_=`stroke-dashoffset:${l};`;u&&(g+=`opacity:${a==="reverse"?1:0};`,_+=`opacity:${a==="reverse"?0:1};`);let E=document.createElement("style");E.setAttribute("data-svg-scroll-draw",""),E.textContent=`@keyframes ${t}{from{${g}}to{${_}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Re[p]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(E);function i(m,L){m.style.setProperty("--ssd-len",String(v[L])),m.style.strokeDasharray=`${v[L]}`,m.style.strokeDashoffset="",m.style.opacity="",m.style.animationPlayState="",m.classList.add(t);}x.forEach(i);let f=false,w=-1;function y(){if(w>=0)return w;let m=e.getBoundingClientRect(),{tStart:L,tEnd:Z}=Ee({top:m.top,height:m.height},Y(),Pe(),ke,Ae);return ne(X(Y(),L,Z,c))}return {destroy(){x.forEach(m=>{m.classList.remove(t),m.style.removeProperty("--ssd-len"),m.style.animationPlayState="";}),E.remove();},replay(){f=false,w=-1,x.forEach(i);},pause(){f=true,x.forEach(m=>{m.style.animationPlayState="paused";});},resume(){f&&(f=false,x.forEach(m=>{m.style.animationPlayState="running";}));},seek(m){let L=Math.min(1,Math.max(0,m));w=L,f=true,x.forEach((Z,Ie)=>{Z.classList.remove(t),Z.style.strokeDashoffset=a==="reverse"?`${v[Ie]*L}`:`${v[Ie]*(1-L)}`,u&&(Z.style.opacity=a==="reverse"?`${1-L}`:`${L}`);});},getProgress(){return y()}}}if(_e())return Xe();Le();function ce(){if(!se||B)return;let t=performance.now(),s=Y(),l=c;if(re!==false){let i=t-Te,f=i>0?Math.abs(s-(ue<0?s:ue))/i:0;l=c*Math.max(.2,1+f*(typeof re=="number"?re:1)*.04);}ue=s,Te=t;let g=ee?oe===-1||s>=oe?"forward":"reverse":a;oe=s;let _=R-N,E=true;if(z){let i=ne(X(s,N,R,l));d&&!ee&&(P=Math.max(P,i),i=P),ie=i,e.style.setProperty("--scroll-draw-progress",String(i));let f=g==="reverse"?1-i:i;e.style.clipPath=j(f),ye?.(i),!q&&X(s,N,R,l)>0&&(q=true,he?.()),i>=1&&!D?(D=true,K?.(),Q<(J==="infinite"?1/0:J??0)&&(Q++,ae=setTimeout(()=>{P=-1,q=false,D=false,e.style.clipPath=j(0);},Me))):i<1&&!d&&(D=false),W=requestAnimationFrame(ce);return}if(x.forEach((i,f)=>{let w=f*I*_,y=ne(X(s,N+w,R+w,l));d&&!ee&&(P=Math.max(P,y),y=P),ie=y,i.style.strokeDashoffset=g==="reverse"?`${v[f]*y}`:`${v[f]*(1-y)}`,u&&(i.style.opacity=g==="reverse"?`${1-y}`:`${y}`),O&&S?i.style.stroke=Se(O,S,y):S&&(i.style.stroke=S),M!==null&&k!==null?i.style.strokeWidth=`${M+(k-M)*y}`:k!==null&&(i.style.strokeWidth=`${k}`),A!==null&&T!==null?i.style.fillOpacity=`${A+(T-A)*y}`:T!==null&&(i.style.fillOpacity=`${T}`),C&&i.tagName.toLowerCase()==="path"&&F[f]&&i.setAttribute("d",We(F[f],C,y)),f===0&&(ye?.(y),e.style.setProperty("--scroll-draw-progress",String(y))),y<1&&(E=false);}),te){let i=ne(X(s,N,R,l));for(let f in te){let w=parseFloat(f);i>=w&&!le.has(w)&&(le.add(w),te[f]?.());}}!q&&X(s,N,R,l)>0&&(q=true,he?.()),E&&!D?(D=true,K?.(),Q<(J==="infinite"?1/0:J??0)&&(Q++,ae=setTimeout(()=>{P=-1,q=false,D=false,le.clear(),De();},Me))):!E&&!d&&(D=false),W=requestAnimationFrame(ce);}let be=new IntersectionObserver(t=>{t.forEach(s=>{se=s.isIntersecting,se&&!B?W=requestAnimationFrame(ce):cancelAnimationFrame(W);});},{root:$??null,threshold:Ge,rootMargin:ze}),ve;function fe(){clearTimeout(ve),ve=setTimeout(()=>{x.forEach((t,s)=>{v[s]=xe(t),t.style.strokeDasharray=`${v[s]}`;}),Le();},150);}return window.addEventListener("resize",fe),window.addEventListener("orientationchange",fe),pe>0?setTimeout(()=>be.observe(e),pe):be.observe(e),{destroy(){cancelAnimationFrame(W),clearTimeout(ae),be.disconnect(),window.removeEventListener("resize",fe),window.removeEventListener("orientationchange",fe),clearTimeout(ve),ge?.remove();},replay(){P=-1,oe=-1,ue=-1,q=false,D=false,Q=0,B=false,le.clear(),clearTimeout(ae),De();},pause(){B=true,cancelAnimationFrame(W);},resume(){B&&(B=false,se&&(W=requestAnimationFrame(ce)));},seek(t){let s=Math.min(1,Math.max(0,t));ie=s,P=s,B=true,cancelAnimationFrame(W),Be(s,a);},getProgress(){return ie}}}var Ve=class{constructor(){this.instance=null;}init(r,n={}){return this.destroy(),this.instance=He(r,n),this}replay(){return this.instance?.replay(),this}destroy(){return this.instance?.destroy(),this.instance=null,this}};export{Ve as ScrollDrawRef};
1
+ function Ye({bounces:e=3,decay:n=.5}={}){let s=Math.max(1,Math.round(e)),o=Math.max(.01,Math.min(.99,n)),d=Math.sqrt(o),m=0,b=[];for(let u=0;u<s;u++){let h=Math.pow(d,u);b.push(h),m+=h;}let $=[0],N=0;for(let u=0;u<s;u++)N+=b[u]/m,$.push(N);return u=>{if(u<=0)return 0;if(u>=1)return 1;for(let h=0;h<s;h++)if(u<=$[h+1]){let se=(u-$[h])/($[h+1]-$[h]);if(h===0)return se*(2-se);let P=1-Math.pow(o,h);return P+(1-P)*(2*se-1)*(2*se-1)}return 1}}function Ze({amplitude:e=1,period:n=.4}={}){let s=Math.max(1,e),o=Math.max(.1,n),d=s<=1?o/4:o/(2*Math.PI)*Math.asin(1/s);return m=>m<=0?0:m>=1?1:s*Math.pow(2,-10*m)*Math.sin((m-d)*(2*Math.PI)/o)+1}var Se={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:Ye(),elastic:Ze()};function ke(e="top bottom"){let n=e.trim();if(/^\d+(\.\d+)?%$/.test(n))return {element:"top",viewport:n};let[s="top",o="bottom"]=n.split(/\s+/).filter(Boolean);return {element:s,viewport:o}}function He(e,n,s,o){switch(o){case "top":return e+s;case "center":return e+s+n/2;case "bottom":return e+s+n;default:return e+s}}function We(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 s=parseFloat(e.getAttribute("width")??"0"),o=parseFloat(e.getAttribute("height")??"0");return 2*(s+o)}if(n==="circle"){let s=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*s}return e.getTotalLength()}function et(e,n,s){return Math.min(s,Math.max(n,e))}function ne(e,n,s,o){return s===n?0:et((e-n)/(s-n)*o,0,1)}function Le(e,n,s,o,d){let m=He(e.top,e.height,n,o.element)-We(o.viewport,s),b=He(e.top,e.height,n,d.element)-We(d.viewport,s);return {tStart:m,tEnd:b}}function ze(e){let n=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(n)return [parseInt(n[1]+n[1],16),parseInt(n[2]+n[2],16),parseInt(n[3]+n[3],16)];let s=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(s)return [parseInt(s[1],16),parseInt(s[2],16),parseInt(s[3],16)];let o=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return o?[parseInt(o[1]),parseInt(o[2]),parseInt(o[3])]:null}function ve(e,n,s){let o=ze(e),d=ze(n);return !o||!d?e:`rgb(${Math.round(o[0]+(d[0]-o[0])*s)},${Math.round(o[1]+(d[1]-o[1])*s)},${Math.round(o[2]+(d[2]-o[2])*s)})`}function qe(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n);}var Ve={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},tt=0;function rt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function nt(e){let n=e.getAttribute("stroke"),s=e.getAttribute("fill");!n||n==="none"?qe("Element has no stroke \u2014 path will not be visible.",e):s&&s!=="none"&&s!=="transparent"&&qe("Element has a fill \u2014 it may obscure the stroke animation.",e);}function st(e,n,s){let o=document.createElement("div");o.setAttribute("data-svg-scroll-draw-debug",""),o.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 d(){let m=s==="x"?window.scrollX:window.scrollY,b=e-m,$=n-m,N=s==="x";o.innerHTML=`
2
+ <div style="position:absolute;${N?`left:${b}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${b}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;${N?`left:${$}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${$}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(o),window.addEventListener("scroll",d,{passive:true}),d(),o}function Pe(e,n,s){let o=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),d=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,m=>{let b=parseFloat(m),$=o[d++]??b;return String(+(b+($-b)*s).toFixed(4))})}function Ge(e,n={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let s=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:o="path, polyline, line, polygon, rect, circle",speed:d=1,fade:m=false,easing:b="linear",trigger:$={},stagger:N=0,direction:u="forward",once:h=false,debug:se=false,axis:P="y",scrollContainer:Ee,autoReverse:ce=false,delay:ae=0,strokeColor:j,strokeWidth:J,fillOpacity:K,waypoints:Q,velocityScale:fe=false,threshold:De=0,rootMargin:Ie="0px",repeat:Y=0,repeatDelay:$e=0,morphTo:R,clip:xe,autoplay:_e=false,duration:Xe=1e3,native:Ue=true,onProgress:le,onStart:me,onComplete:oe}=n,G=xe===true?"left":typeof xe=="string"?xe:false,Z=typeof b=="function"?b:Se[b]??Se.linear,Fe=ke($.start??"top bottom"),Ce=ke($.end??"bottom top"),D=typeof Ee=="string"?document.querySelector(Ee):Ee??null,H=Array.isArray(j)?j[0]:null,A=Array.isArray(j)?j[1]:typeof j=="string"?j:null,I=Array.isArray(J)?J[0]:null,T=Array.isArray(J)?J[1]:typeof J=="number"?J:null,F=Array.isArray(K)?K[0]:null,S=Array.isArray(K)?K[1]:typeof K=="number"?K:null;function ee(t){let r=t*100;switch(G){case "right":return `inset(0 0 0 ${100-r}%)`;case "top":return `inset(0 0 ${100-r}% 0)`;case "bottom":return `inset(${100-r}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-r}% 0 0)`}}let x=G?[]:Array.from(e.querySelectorAll(o)),v=[],W=[],B=0,_=0,M=false,O=false,E=0,pe=false,z=-1,de=-1,k=false,te=0,V=0,X,Me=null,U=new Set,ye=-1,Oe=performance.now();function ue(){return D?P==="x"?D.scrollLeft:D.scrollTop:P==="x"?window.scrollX:window.scrollY}function Ne(){return D?P==="x"?D.clientWidth:D.clientHeight:P==="x"?window.innerWidth:window.innerHeight}function Re(){let t=e.getBoundingClientRect(),r,l,g;if(D){let L=D.getBoundingClientRect();r=P==="x"?t.left-L.left+D.scrollLeft:t.top-L.top+D.scrollTop,l=P==="x"?t.width:t.height,g=ue();}else r=P==="x"?t.left:t.top,l=P==="x"?t.width:t.height,g=ue();let C=Le({top:r,height:l},g,Ne(),Fe,Ce);B=C.tStart,_=C.tEnd,se&&process.env.NODE_ENV!=="production"&&(Me?.remove(),Me=st(B,_,P));}function je(t,r){if(e.style.setProperty("--scroll-draw-progress",String(t)),G){let l=r==="reverse"?1-t:t;e.style.clipPath=ee(l);return}x.forEach((l,g)=>{l.style.strokeDashoffset=r==="reverse"?`${v[g]*t}`:`${v[g]*(1-t)}`,m&&(l.style.opacity=r==="reverse"?`${1-t}`:`${t}`),H&&A?l.style.stroke=ve(H,A,t):A&&(l.style.stroke=A),I!==null&&T!==null?l.style.strokeWidth=`${I+(T-I)*t}`:T!==null&&(l.style.strokeWidth=`${T}`),F!==null&&S!==null?l.style.fillOpacity=`${F+(S-F)*t}`:S!==null&&(l.style.fillOpacity=`${S}`),R&&l.tagName.toLowerCase()==="path"&&W[g]&&l.setAttribute("d",Pe(W[g],R,t));});}function he(){if(e.style.setProperty("--scroll-draw-progress","0"),G){e.style.clipPath=ee(0);return}x.forEach((t,r)=>{t.style.strokeDasharray=`${v[r]}`,t.style.strokeDashoffset=u==="reverse"?"0":`${v[r]}`,m?t.style.opacity=u==="reverse"?"1":"0":t.style.opacity="",H&&(t.style.stroke=H),I!==null&&(t.style.strokeWidth=`${I}`),F!==null&&(t.style.fillOpacity=`${F}`),R&&t.tagName.toLowerCase()==="path"&&W[r]&&t.setAttribute("d",W[r]);});}if(x.forEach(t=>{nt(t);let r=we(t);v.push(r),t.tagName.toLowerCase()==="path"?W.push(t.getAttribute("d")??""):W.push(""),s?(t.style.strokeDasharray=`${r}`,t.style.strokeDashoffset=u==="reverse"?`${r}`:"0",m&&(t.style.opacity="1"),A&&(t.style.stroke=A),T!==null&&(t.style.strokeWidth=`${T}`),S!==null&&(t.style.fillOpacity=`${S}`),R&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",R)):(t.style.strokeDasharray=`${r}`,t.style.strokeDashoffset=u==="reverse"?"0":`${r}`,m?t.style.opacity=u==="reverse"?"1":"0":t.style.opacity="",H&&(t.style.stroke=H),I!==null&&(t.style.strokeWidth=`${I}`),F!==null&&(t.style.fillOpacity=`${F}`));}),G){if(s)return e.style.clipPath=ee(1),oe?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ee(0);}else if(s)return oe?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Je(){return !(Ue===false||!rt()||!x.length||typeof b!="string"||!(b in Ve)||G||P!=="y"||D||d!==1||N!==0||h||ce||fe!==false||R||Q||Y||ae>0||le||me||oe||j!=null||J!=null||K!=null||($.start??"top bottom").trim()!=="top bottom"||($.end??"bottom top").trim()!=="bottom top")}function Ke(){let t=`svg-scroll-draw-${++tt}`,r=u==="reverse"?"0":"var(--ssd-len)",l=u==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${r};`,C=`stroke-dashoffset:${l};`;m&&(g+=`opacity:${u==="reverse"?1:0};`,C+=`opacity:${u==="reverse"?0:1};`);let L=document.createElement("style");L.setAttribute("data-svg-scroll-draw",""),L.textContent=`@keyframes ${t}{from{${g}}to{${C}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Ve[b]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(L);function a(i,f){i.style.setProperty("--ssd-len",String(v[f])),i.style.strokeDasharray=`${v[f]}`,i.style.strokeDashoffset="",i.style.opacity="",i.style.animationPlayState="",i.classList.add(t);}x.forEach(a);let p=false,w=-1;function c(){if(w>=0)return w;let i=e.getBoundingClientRect(),{tStart:f,tEnd:y}=Le({top:i.top,height:i.height},ue(),Ne(),Fe,Ce);return Z(ne(ue(),f,y,d))}return {destroy(){x.forEach(i=>{i.classList.remove(t),i.style.removeProperty("--ssd-len"),i.style.animationPlayState="";}),L.remove();},replay(){p=false,w=-1,x.forEach(a);},pause(){p=true,x.forEach(i=>{i.style.animationPlayState="paused";});},resume(){p&&(p=false,x.forEach(i=>{i.style.animationPlayState="running";}));},seek(i){let f=Math.min(1,Math.max(0,i));w=f,p=true,x.forEach((y,re)=>{y.classList.remove(t),y.style.strokeDashoffset=u==="reverse"?`${v[re]*f}`:`${v[re]*(1-f)}`,m&&(y.style.opacity=u==="reverse"?`${1-f}`:`${f}`);});},getProgress(){return c()}}}if(Je())return Ke();function Qe(){let t=Math.max(1,Xe),r=0,l=0;function g(c){let i=true;if(G){let f=Math.min(1,Math.max(0,c/t)),y=Z(f);te=y,e.style.setProperty("--scroll-draw-progress",String(y)),e.style.clipPath=ee(u==="reverse"?1-y:y),le?.(y),f<1&&(i=false);}else x.forEach((f,y)=>{let re=y*N*t,ie=Math.min(1,Math.max(0,(c-re)/t)),q=Z(ie);f.style.strokeDashoffset=u==="reverse"?`${v[y]*q}`:`${v[y]*(1-q)}`,m&&(f.style.opacity=u==="reverse"?`${1-q}`:`${q}`),H&&A?f.style.stroke=ve(H,A,q):A&&(f.style.stroke=A),I!==null&&T!==null?f.style.strokeWidth=`${I+(T-I)*q}`:T!==null&&(f.style.strokeWidth=`${T}`),F!==null&&S!==null?f.style.fillOpacity=`${F+(S-F)*q}`:S!==null&&(f.style.fillOpacity=`${S}`),R&&f.tagName.toLowerCase()==="path"&&W[y]&&f.setAttribute("d",Pe(W[y],R,q)),y===0&&(le?.(q),e.style.setProperty("--scroll-draw-progress",String(q))),ie<1&&(i=false);});if(Q){let f=Math.min(1,Math.max(0,c/t)),y=Z(f);for(let re in Q){let ie=parseFloat(re);y>=ie&&!U.has(ie)&&(U.add(ie),Q[re]?.());}}return i}function C(c){if(k)return;let i=c-r;O||(O=true,me?.());let f=g(i);if(f&&!M){M=true,g(t*(1+Math.max(0,x.length-1)*N)),oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{r=performance.now(),O=false,M=false,U.clear(),he(),E=requestAnimationFrame(C);},$e));return}f||(E=requestAnimationFrame(C));}function L(){cancelAnimationFrame(E),clearTimeout(X),r=performance.now(),l=0,k=false,O=false,M=false,V=0,U.clear(),he(),E=requestAnimationFrame(C);}let a=new IntersectionObserver(c=>{c.forEach(i=>{i.isIntersecting&&!(h&&M)?L():!i.isIntersecting&&!h&&!M&&(cancelAnimationFrame(E),clearTimeout(X),r=null);});},{root:D??null,threshold:De,rootMargin:Ie}),p;function w(){clearTimeout(p),p=setTimeout(()=>{x.forEach((c,i)=>{v[i]=we(c),c.style.strokeDasharray=`${v[i]}`;});},150);}return window.addEventListener("resize",w),window.addEventListener("orientationchange",w),ae>0?setTimeout(()=>a.observe(e),ae):a.observe(e),{destroy(){cancelAnimationFrame(E),clearTimeout(X),a.disconnect(),window.removeEventListener("resize",w),window.removeEventListener("orientationchange",w),clearTimeout(p);},replay(){V=0,L();},pause(){k||(k=true,l=performance.now()-r,cancelAnimationFrame(E));},resume(){k&&(k=false,r=performance.now()-l,E=requestAnimationFrame(C));},seek(c){let i=Math.min(1,Math.max(0,c));te=i,k=true,l=i*t,r=performance.now()-l,cancelAnimationFrame(E),g(l);},getProgress(){return te}}}if(_e)return Qe();Re();function ge(){if(!pe||k)return;let t=performance.now(),r=ue(),l=d;if(fe!==false){let a=t-Oe,p=a>0?Math.abs(r-(ye<0?r:ye))/a:0;l=d*Math.max(.2,1+p*(typeof fe=="number"?fe:1)*.04);}ye=r,Oe=t;let g=ce?de===-1||r>=de?"forward":"reverse":u;de=r;let C=_-B,L=true;if(G){let a=Z(ne(r,B,_,l));h&&!ce&&(z=Math.max(z,a),a=z),te=a,e.style.setProperty("--scroll-draw-progress",String(a));let p=g==="reverse"?1-a:a;e.style.clipPath=ee(p),le?.(a),!O&&ne(r,B,_,l)>0&&(O=true,me?.()),a>=1&&!M?(M=true,oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{z=-1,O=false,M=false,e.style.clipPath=ee(0);},$e))):a<1&&!h&&(M=false),E=requestAnimationFrame(ge);return}if(x.forEach((a,p)=>{let w=p*N*C,c=Z(ne(r,B+w,_+w,l));h&&!ce&&(z=Math.max(z,c),c=z),te=c,a.style.strokeDashoffset=g==="reverse"?`${v[p]*c}`:`${v[p]*(1-c)}`,m&&(a.style.opacity=g==="reverse"?`${1-c}`:`${c}`),H&&A?a.style.stroke=ve(H,A,c):A&&(a.style.stroke=A),I!==null&&T!==null?a.style.strokeWidth=`${I+(T-I)*c}`:T!==null&&(a.style.strokeWidth=`${T}`),F!==null&&S!==null?a.style.fillOpacity=`${F+(S-F)*c}`:S!==null&&(a.style.fillOpacity=`${S}`),R&&a.tagName.toLowerCase()==="path"&&W[p]&&a.setAttribute("d",Pe(W[p],R,c)),p===0&&(le?.(c),e.style.setProperty("--scroll-draw-progress",String(c))),c<1&&(L=false);}),Q){let a=Z(ne(r,B,_,l));for(let p in Q){let w=parseFloat(p);a>=w&&!U.has(w)&&(U.add(w),Q[p]?.());}}!O&&ne(r,B,_,l)>0&&(O=true,me?.()),L&&!M?(M=true,oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{z=-1,O=false,M=false,U.clear(),he();},$e))):!L&&!h&&(M=false),E=requestAnimationFrame(ge);}let Ae=new IntersectionObserver(t=>{t.forEach(r=>{pe=r.isIntersecting,pe&&!k?E=requestAnimationFrame(ge):cancelAnimationFrame(E);});},{root:D??null,threshold:De,rootMargin:Ie}),Te;function be(){clearTimeout(Te),Te=setTimeout(()=>{x.forEach((t,r)=>{v[r]=we(t),t.style.strokeDasharray=`${v[r]}`;}),Re();},150);}return window.addEventListener("resize",be),window.addEventListener("orientationchange",be),ae>0?setTimeout(()=>Ae.observe(e),ae):Ae.observe(e),{destroy(){cancelAnimationFrame(E),clearTimeout(X),Ae.disconnect(),window.removeEventListener("resize",be),window.removeEventListener("orientationchange",be),clearTimeout(Te),Me?.remove();},replay(){z=-1,de=-1,ye=-1,O=false,M=false,V=0,k=false,U.clear(),clearTimeout(X),he();},pause(){k=true,cancelAnimationFrame(E);},resume(){k&&(k=false,pe&&(E=requestAnimationFrame(ge)));},seek(t){let r=Math.min(1,Math.max(0,t));te=r,z=r,k=true,cancelAnimationFrame(E),je(r,u);},getProgress(){return te}}}var Be=class{constructor(){this.instance=null;}init(n,s={}){return this.destroy(),this.instance=Ge(n,s),this}replay(){return this.instance?.replay(),this}destroy(){return this.instance?.destroy(),this.instance=null,this}};export{Be as ScrollDrawRef};
@@ -1,3 +1,3 @@
1
- 'use strict';function Re({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),s=Math.max(.01,Math.min(.99,r)),c=Math.sqrt(s),u=0,m=[];for(let a=0;a<n;a++){let d=Math.pow(c,a);m.push(d),u+=d;}let h=[0],I=0;for(let a=0;a<n;a++)I+=m[a]/u,h.push(I);return a=>{if(a<=0)return 0;if(a>=1)return 1;for(let d=0;d<n;d++)if(a<=h[d+1]){let J=(a-h[d])/(h[d+1]-h[d]);if(d===0)return J*(2-J);let b=1-Math.pow(s,d);return b+(1-b)*(2*J-1)*(2*J-1)}return 1}}function We({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),s=Math.max(.1,r),c=n<=1?s/4:s/(2*Math.PI)*Math.asin(1/n);return u=>u<=0?0:u>=1?1:n*Math.pow(2,-10*u)*Math.sin((u-c)*(2*Math.PI)/s)+1}var xe={linear:e=>e,"ease-in":e=>e*e,"ease-out":e=>e*(2-e),"ease-in-out":e=>e<.5?2*e*e:-1+(4-2*e)*e,spring:e=>1-Math.cos(e*Math.PI*2.5)*Math.pow(1-e,2.2),bounce:Re(),elastic:We()};function Ee(e="top bottom"){let r=e.trim();if(/^\d+(\.\d+)?%$/.test(r))return {element:"top",viewport:r};let[n="top",s="bottom"]=r.split(/\s+/).filter(Boolean);return {element:n,viewport:s}}function Ce(e,r,n,s){switch(s){case "top":return e+n;case "center":return e+n+r/2;case "bottom":return e+n+r;default:return e+n}}function Fe(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 Se(e){let r=e.tagName.toLowerCase();if(r==="rect"){let n=parseFloat(e.getAttribute("width")??"0"),s=parseFloat(e.getAttribute("height")??"0");return 2*(n+s)}if(r==="circle"){let n=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*n}return e.getTotalLength()}function Ue(e,r,n){return Math.min(n,Math.max(r,e))}function X(e,r,n,s){return n===r?0:Ue((e-r)/(n-r)*s,0,1)}function $e(e,r,n,s,c){let u=Ce(e.top,e.height,r,s.element)-Fe(s.viewport,n),m=Ce(e.top,e.height,r,c.element)-Fe(c.viewport,n);return {tStart:u,tEnd:m}}function Ne(e){let r=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(r)return [parseInt(r[1]+r[1],16),parseInt(r[2]+r[2],16),parseInt(r[3]+r[3],16)];let n=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(n)return [parseInt(n[1],16),parseInt(n[2],16),parseInt(n[3],16)];let s=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return s?[parseInt(s[1]),parseInt(s[2]),parseInt(s[3])]:null}function Me(e,r,n){let s=Ne(e),c=Ne(r);return !s||!c?e:`rgb(${Math.round(s[0]+(c[0]-s[0])*n)},${Math.round(s[1]+(c[1]-s[1])*n)},${Math.round(s[2]+(c[2]-s[2])*n)})`}function He(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r);}var Ve={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},je=0;function Ke(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Qe(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?He("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&He("Element has a fill \u2014 it may obscure the stroke animation.",e);}function Ye(e,r,n){let s=document.createElement("div");s.setAttribute("data-svg-scroll-draw-debug",""),s.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function c(){let u=n==="x"?window.scrollX:window.scrollY,m=e-u,h=r-u,I=n==="x";s.innerHTML=`
2
- <div style="position:absolute;${I?`left:${m}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${m}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
3
- <div style="position:absolute;${I?`left:${h}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${h}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(s),window.addEventListener("scroll",c,{passive:true}),c(),s}function qe(e,r,n){let s=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),c=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,u=>{let m=parseFloat(u),h=s[c++]??m;return String(+(m+(h-m)*n).toFixed(4))})}function pe(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let n=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:s="path, polyline, line, polygon, rect, circle",speed:c=1,fade:u=false,easing:m="linear",trigger:h={},stagger:I=0,direction:a="forward",once:d=false,debug:J=false,axis:b="y",scrollContainer:me,autoReverse:ee=false,delay:de=0,strokeColor:H,strokeWidth:V,fillOpacity:q,waypoints:te,velocityScale:re=false,threshold:Ge=0,rootMargin:ze="0px",repeat:j=0,repeatDelay:ke=0,morphTo:O,clip:ye,native:Be=true,onProgress:he,onStart:ge,onComplete:K}=r,G=ye===true?"left":typeof ye=="string"?ye:false,ne=typeof m=="function"?m:xe[m]??xe.linear,Ae=Ee(h.start??"top bottom"),De=Ee(h.end??"bottom top"),x=typeof me=="string"?document.querySelector(me):me??null,C=Array.isArray(H)?H[0]:null,$=Array.isArray(H)?H[1]:typeof H=="string"?H:null,M=Array.isArray(V)?V[0]:null,k=Array.isArray(V)?V[1]:typeof V=="number"?V:null,A=Array.isArray(q)?q[0]:null,D=Array.isArray(q)?q[1]:typeof q=="number"?q:null;function U(t){let o=t*100;switch(G){case "right":return `inset(0 0 0 ${100-o}%)`;case "top":return `inset(0 0 ${100-o}% 0)`;case "bottom":return `inset(${100-o}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-o}% 0 0)`}}let E=G?[]:Array.from(e.querySelectorAll(s)),w=[],F=[],N=0,R=0,L=false,z=false,W=0,se=false,T=-1,oe=-1,B=false,ie=0,Q=0,ae,be=null,le=new Set,ue=-1,Te=performance.now();function Y(){return x?b==="x"?x.scrollLeft:x.scrollTop:b==="x"?window.scrollX:window.scrollY}function Pe(){return x?b==="x"?x.clientWidth:x.clientHeight:b==="x"?window.innerWidth:window.innerHeight}function Le(){let t=e.getBoundingClientRect(),o,l,g;if(x){let S=x.getBoundingClientRect();o=b==="x"?t.left-S.left+x.scrollLeft:t.top-S.top+x.scrollTop,l=b==="x"?t.width:t.height,g=Y();}else o=b==="x"?t.left:t.top,l=b==="x"?t.width:t.height,g=Y();let _=$e({top:o,height:l},g,Pe(),Ae,De);N=_.tStart,R=_.tEnd,J&&process.env.NODE_ENV!=="production"&&(be?.remove(),be=Ye(N,R,b));}function _e(t,o){if(e.style.setProperty("--scroll-draw-progress",String(t)),G){let l=o==="reverse"?1-t:t;e.style.clipPath=U(l);return}E.forEach((l,g)=>{l.style.strokeDashoffset=o==="reverse"?`${w[g]*t}`:`${w[g]*(1-t)}`,u&&(l.style.opacity=o==="reverse"?`${1-t}`:`${t}`),C&&$?l.style.stroke=Me(C,$,t):$&&(l.style.stroke=$),M!==null&&k!==null?l.style.strokeWidth=`${M+(k-M)*t}`:k!==null&&(l.style.strokeWidth=`${k}`),A!==null&&D!==null?l.style.fillOpacity=`${A+(D-A)*t}`:D!==null&&(l.style.fillOpacity=`${D}`),O&&l.tagName.toLowerCase()==="path"&&F[g]&&l.setAttribute("d",qe(F[g],O,t));});}function Ie(){if(e.style.setProperty("--scroll-draw-progress","0"),G){e.style.clipPath=U(0);return}E.forEach((t,o)=>{t.style.strokeDasharray=`${w[o]}`,t.style.strokeDashoffset=a==="reverse"?"0":`${w[o]}`,u?t.style.opacity=a==="reverse"?"1":"0":t.style.opacity="",C&&(t.style.stroke=C),M!==null&&(t.style.strokeWidth=`${M}`),A!==null&&(t.style.fillOpacity=`${A}`),O&&t.tagName.toLowerCase()==="path"&&F[o]&&t.setAttribute("d",F[o]);});}if(E.forEach(t=>{Qe(t);let o=Se(t);w.push(o),t.tagName.toLowerCase()==="path"?F.push(t.getAttribute("d")??""):F.push(""),n?(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=a==="reverse"?`${o}`:"0",u&&(t.style.opacity="1"),$&&(t.style.stroke=$),k!==null&&(t.style.strokeWidth=`${k}`),D!==null&&(t.style.fillOpacity=`${D}`),O&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",O)):(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=a==="reverse"?"0":`${o}`,u?t.style.opacity=a==="reverse"?"1":"0":t.style.opacity="",C&&(t.style.stroke=C),M!==null&&(t.style.strokeWidth=`${M}`),A!==null&&(t.style.fillOpacity=`${A}`));}),G){if(n)return e.style.clipPath=U(1),K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=U(0);}else if(n)return K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Xe(){return !(Be===false||!Ke()||!E.length||typeof m!="string"||!(m in Ve)||G||b!=="y"||x||c!==1||I!==0||d||ee||re!==false||O||te||j||de>0||he||ge||K||H!=null||V!=null||q!=null||(h.start??"top bottom").trim()!=="top bottom"||(h.end??"bottom top").trim()!=="bottom top")}function Je(){let t=`svg-scroll-draw-${++je}`,o=a==="reverse"?"0":"var(--ssd-len)",l=a==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${o};`,_=`stroke-dashoffset:${l};`;u&&(g+=`opacity:${a==="reverse"?1:0};`,_+=`opacity:${a==="reverse"?0:1};`);let S=document.createElement("style");S.setAttribute("data-svg-scroll-draw",""),S.textContent=`@keyframes ${t}{from{${g}}to{${_}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Ve[m]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(S);function i(p,P){p.style.setProperty("--ssd-len",String(w[P])),p.style.strokeDasharray=`${w[P]}`,p.style.strokeDashoffset="",p.style.opacity="",p.style.animationPlayState="",p.classList.add(t);}E.forEach(i);let f=false,v=-1;function y(){if(v>=0)return v;let p=e.getBoundingClientRect(),{tStart:P,tEnd:Z}=$e({top:p.top,height:p.height},Y(),Pe(),Ae,De);return ne(X(Y(),P,Z,c))}return {destroy(){E.forEach(p=>{p.classList.remove(t),p.style.removeProperty("--ssd-len"),p.style.animationPlayState="";}),S.remove();},replay(){f=false,v=-1,E.forEach(i);},pause(){f=true,E.forEach(p=>{p.style.animationPlayState="paused";});},resume(){f&&(f=false,E.forEach(p=>{p.style.animationPlayState="running";}));},seek(p){let P=Math.min(1,Math.max(0,p));v=P,f=true,E.forEach((Z,Oe)=>{Z.classList.remove(t),Z.style.strokeDashoffset=a==="reverse"?`${w[Oe]*P}`:`${w[Oe]*(1-P)}`,u&&(Z.style.opacity=a==="reverse"?`${1-P}`:`${P}`);});},getProgress(){return y()}}}if(Xe())return Je();Le();function ce(){if(!se||B)return;let t=performance.now(),o=Y(),l=c;if(re!==false){let i=t-Te,f=i>0?Math.abs(o-(ue<0?o:ue))/i:0;l=c*Math.max(.2,1+f*(typeof re=="number"?re:1)*.04);}ue=o,Te=t;let g=ee?oe===-1||o>=oe?"forward":"reverse":a;oe=o;let _=R-N,S=true;if(G){let i=ne(X(o,N,R,l));d&&!ee&&(T=Math.max(T,i),i=T),ie=i,e.style.setProperty("--scroll-draw-progress",String(i));let f=g==="reverse"?1-i:i;e.style.clipPath=U(f),he?.(i),!z&&X(o,N,R,l)>0&&(z=true,ge?.()),i>=1&&!L?(L=true,K?.(),Q<(j==="infinite"?1/0:j??0)&&(Q++,ae=setTimeout(()=>{T=-1,z=false,L=false,e.style.clipPath=U(0);},ke))):i<1&&!d&&(L=false),W=requestAnimationFrame(ce);return}if(E.forEach((i,f)=>{let v=f*I*_,y=ne(X(o,N+v,R+v,l));d&&!ee&&(T=Math.max(T,y),y=T),ie=y,i.style.strokeDashoffset=g==="reverse"?`${w[f]*y}`:`${w[f]*(1-y)}`,u&&(i.style.opacity=g==="reverse"?`${1-y}`:`${y}`),C&&$?i.style.stroke=Me(C,$,y):$&&(i.style.stroke=$),M!==null&&k!==null?i.style.strokeWidth=`${M+(k-M)*y}`:k!==null&&(i.style.strokeWidth=`${k}`),A!==null&&D!==null?i.style.fillOpacity=`${A+(D-A)*y}`:D!==null&&(i.style.fillOpacity=`${D}`),O&&i.tagName.toLowerCase()==="path"&&F[f]&&i.setAttribute("d",qe(F[f],O,y)),f===0&&(he?.(y),e.style.setProperty("--scroll-draw-progress",String(y))),y<1&&(S=false);}),te){let i=ne(X(o,N,R,l));for(let f in te){let v=parseFloat(f);i>=v&&!le.has(v)&&(le.add(v),te[f]?.());}}!z&&X(o,N,R,l)>0&&(z=true,ge?.()),S&&!L?(L=true,K?.(),Q<(j==="infinite"?1/0:j??0)&&(Q++,ae=setTimeout(()=>{T=-1,z=false,L=false,le.clear(),Ie();},ke))):!S&&!d&&(L=false),W=requestAnimationFrame(ce);}let we=new IntersectionObserver(t=>{t.forEach(o=>{se=o.isIntersecting,se&&!B?W=requestAnimationFrame(ce):cancelAnimationFrame(W);});},{root:x??null,threshold:Ge,rootMargin:ze}),ve;function fe(){clearTimeout(ve),ve=setTimeout(()=>{E.forEach((t,o)=>{w[o]=Se(t),t.style.strokeDasharray=`${w[o]}`;}),Le();},150);}return window.addEventListener("resize",fe),window.addEventListener("orientationchange",fe),de>0?setTimeout(()=>we.observe(e),de):we.observe(e),{destroy(){cancelAnimationFrame(W),clearTimeout(ae),we.disconnect(),window.removeEventListener("resize",fe),window.removeEventListener("orientationchange",fe),clearTimeout(ve),be?.remove();},replay(){T=-1,oe=-1,ue=-1,z=false,L=false,Q=0,B=false,le.clear(),clearTimeout(ae),Ie();},pause(){B=true,cancelAnimationFrame(W);},resume(){B&&(B=false,se&&(W=requestAnimationFrame(ce)));},seek(t){let o=Math.min(1,Math.max(0,t));ie=o,T=o,B=true,cancelAnimationFrame(W),_e(o,a);},getProgress(){return ie}}}function Ze(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let s=typeof e=="string"?document.querySelector(e):e;return s?pe(s,r):(console.warn("[svg-scroll-draw] Container not found:",e),n)}function lt(e=document){return Array.from(e.querySelectorAll("[data-scroll-draw]")).map(r=>{let n={};try{let s=r.dataset.scrollDrawOptions??r.dataset.scrollDrawoptions??"";s&&(n=JSON.parse(s));}catch{}return pe(r,n)})}exports.initScrollDraw=lt;exports.scrollDraw=Ze;
1
+ 'use strict';function Ge({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),s=Math.max(.01,Math.min(.99,r)),d=Math.sqrt(s),m=0,b=[];for(let c=0;c<n;c++){let h=Math.pow(d,c);b.push(h),m+=h;}let E=[0],N=0;for(let c=0;c<n;c++)N+=b[c]/m,E.push(N);return c=>{if(c<=0)return 0;if(c>=1)return 1;for(let h=0;h<n;h++)if(c<=E[h+1]){let oe=(c-E[h])/(E[h+1]-E[h]);if(h===0)return oe*(2-oe);let L=1-Math.pow(s,h);return L+(1-L)*(2*oe-1)*(2*oe-1)}return 1}}function ze({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),s=Math.max(.1,r),d=n<=1?s/4:s/(2*Math.PI)*Math.asin(1/n);return m=>m<=0?0:m>=1?1:n*Math.pow(2,-10*m)*Math.sin((m-d)*(2*Math.PI)/s)+1}var we={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:Ge(),elastic:ze()};function De(e="top bottom"){let r=e.trim();if(/^\d+(\.\d+)?%$/.test(r))return {element:"top",viewport:r};let[n="top",s="bottom"]=r.split(/\s+/).filter(Boolean);return {element:n,viewport:s}}function qe(e,r,n,s){switch(s){case "top":return e+n;case "center":return e+n+r/2;case "bottom":return e+n+r;default:return e+n}}function We(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 n=parseFloat(e.getAttribute("width")??"0"),s=parseFloat(e.getAttribute("height")??"0");return 2*(n+s)}if(r==="circle"){let n=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*n}return e.getTotalLength()}function Ze(e,r,n){return Math.min(n,Math.max(r,e))}function ne(e,r,n,s){return n===r?0:Ze((e-r)/(n-r)*s,0,1)}function Le(e,r,n,s,d){let m=qe(e.top,e.height,r,s.element)-We(s.viewport,n),b=qe(e.top,e.height,r,d.element)-We(d.viewport,n);return {tStart:m,tEnd:b}}function Ve(e){let r=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(r)return [parseInt(r[1]+r[1],16),parseInt(r[2]+r[2],16),parseInt(r[3]+r[3],16)];let n=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(n)return [parseInt(n[1],16),parseInt(n[2],16),parseInt(n[3],16)];let s=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return s?[parseInt(s[1]),parseInt(s[2]),parseInt(s[3])]:null}function Se(e,r,n){let s=Ve(e),d=Ve(r);return !s||!d?e:`rgb(${Math.round(s[0]+(d[0]-s[0])*n)},${Math.round(s[1]+(d[1]-s[1])*n)},${Math.round(s[2]+(d[2]-s[2])*n)})`}function Be(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r);}var _e={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},et=0;function tt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function rt(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?Be("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&Be("Element has a fill \u2014 it may obscure the stroke animation.",e);}function nt(e,r,n){let s=document.createElement("div");s.setAttribute("data-svg-scroll-draw-debug",""),s.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function d(){let m=n==="x"?window.scrollX:window.scrollY,b=e-m,E=r-m,N=n==="x";s.innerHTML=`
2
+ <div style="position:absolute;${N?`left:${b}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${b}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;${N?`left:${E}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${E}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(s),window.addEventListener("scroll",d,{passive:true}),d(),s}function Ie(e,r,n){let s=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),d=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,m=>{let b=parseFloat(m),E=s[d++]??b;return String(+(b+(E-b)*n).toFixed(4))})}function Ee(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let n=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:s="path, polyline, line, polygon, rect, circle",speed:d=1,fade:m=false,easing:b="linear",trigger:E={},stagger:N=0,direction:c="forward",once:h=false,debug:oe=false,axis:L="y",scrollContainer:xe,autoReverse:ue=false,delay:ae=0,strokeColor:J,strokeWidth:U,fillOpacity:Y,waypoints:K,velocityScale:fe=false,threshold:Pe=0,rootMargin:Ce="0px",repeat:Q=0,repeatDelay:Ae=0,morphTo:H,clip:ke,autoplay:je=false,duration:Xe=1e3,native:Je=true,onProgress:le,onStart:me,onComplete:se}=r,z=ke===true?"left":typeof ke=="string"?ke:false,Z=typeof b=="function"?b:we[b]??we.linear,Oe=De(E.start??"top bottom"),Fe=De(E.end??"bottom top"),I=typeof xe=="string"?document.querySelector(xe):xe??null,R=Array.isArray(J)?J[0]:null,k=Array.isArray(J)?J[1]:typeof J=="string"?J:null,P=Array.isArray(U)?U[0]:null,$=Array.isArray(U)?U[1]:typeof U=="number"?U:null,C=Array.isArray(Y)?Y[0]:null,M=Array.isArray(Y)?Y[1]:typeof Y=="number"?Y:null;function ee(t){let o=t*100;switch(z){case "right":return `inset(0 0 0 ${100-o}%)`;case "top":return `inset(0 0 ${100-o}% 0)`;case "bottom":return `inset(${100-o}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-o}% 0 0)`}}let x=z?[]:Array.from(e.querySelectorAll(s)),v=[],q=[],B=0,_=0,A=false,F=false,S=0,pe=false,W=-1,de=-1,T=false,te=0,G=0,j,$e=null,X=new Set,ye=-1,Ne=performance.now();function ce(){return I?L==="x"?I.scrollLeft:I.scrollTop:L==="x"?window.scrollX:window.scrollY}function He(){return I?L==="x"?I.clientWidth:I.clientHeight:L==="x"?window.innerWidth:window.innerHeight}function Re(){let t=e.getBoundingClientRect(),o,l,g;if(I){let D=I.getBoundingClientRect();o=L==="x"?t.left-D.left+I.scrollLeft:t.top-D.top+I.scrollTop,l=L==="x"?t.width:t.height,g=ce();}else o=L==="x"?t.left:t.top,l=L==="x"?t.width:t.height,g=ce();let O=Le({top:o,height:l},g,He(),Oe,Fe);B=O.tStart,_=O.tEnd,oe&&process.env.NODE_ENV!=="production"&&($e?.remove(),$e=nt(B,_,L));}function Ue(t,o){if(e.style.setProperty("--scroll-draw-progress",String(t)),z){let l=o==="reverse"?1-t:t;e.style.clipPath=ee(l);return}x.forEach((l,g)=>{l.style.strokeDashoffset=o==="reverse"?`${v[g]*t}`:`${v[g]*(1-t)}`,m&&(l.style.opacity=o==="reverse"?`${1-t}`:`${t}`),R&&k?l.style.stroke=Se(R,k,t):k&&(l.style.stroke=k),P!==null&&$!==null?l.style.strokeWidth=`${P+($-P)*t}`:$!==null&&(l.style.strokeWidth=`${$}`),C!==null&&M!==null?l.style.fillOpacity=`${C+(M-C)*t}`:M!==null&&(l.style.fillOpacity=`${M}`),H&&l.tagName.toLowerCase()==="path"&&q[g]&&l.setAttribute("d",Ie(q[g],H,t));});}function he(){if(e.style.setProperty("--scroll-draw-progress","0"),z){e.style.clipPath=ee(0);return}x.forEach((t,o)=>{t.style.strokeDasharray=`${v[o]}`,t.style.strokeDashoffset=c==="reverse"?"0":`${v[o]}`,m?t.style.opacity=c==="reverse"?"1":"0":t.style.opacity="",R&&(t.style.stroke=R),P!==null&&(t.style.strokeWidth=`${P}`),C!==null&&(t.style.fillOpacity=`${C}`),H&&t.tagName.toLowerCase()==="path"&&q[o]&&t.setAttribute("d",q[o]);});}if(x.forEach(t=>{rt(t);let o=ve(t);v.push(o),t.tagName.toLowerCase()==="path"?q.push(t.getAttribute("d")??""):q.push(""),n?(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=c==="reverse"?`${o}`:"0",m&&(t.style.opacity="1"),k&&(t.style.stroke=k),$!==null&&(t.style.strokeWidth=`${$}`),M!==null&&(t.style.fillOpacity=`${M}`),H&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",H)):(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=c==="reverse"?"0":`${o}`,m?t.style.opacity=c==="reverse"?"1":"0":t.style.opacity="",R&&(t.style.stroke=R),P!==null&&(t.style.strokeWidth=`${P}`),C!==null&&(t.style.fillOpacity=`${C}`));}),z){if(n)return e.style.clipPath=ee(1),se?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ee(0);}else if(n)return se?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Ye(){return !(Je===false||!tt()||!x.length||typeof b!="string"||!(b in _e)||z||L!=="y"||I||d!==1||N!==0||h||ue||fe!==false||H||K||Q||ae>0||le||me||se||J!=null||U!=null||Y!=null||(E.start??"top bottom").trim()!=="top bottom"||(E.end??"bottom top").trim()!=="bottom top")}function Ke(){let t=`svg-scroll-draw-${++et}`,o=c==="reverse"?"0":"var(--ssd-len)",l=c==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${o};`,O=`stroke-dashoffset:${l};`;m&&(g+=`opacity:${c==="reverse"?1:0};`,O+=`opacity:${c==="reverse"?0:1};`);let D=document.createElement("style");D.setAttribute("data-svg-scroll-draw",""),D.textContent=`@keyframes ${t}{from{${g}}to{${O}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${_e[b]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(D);function a(i,f){i.style.setProperty("--ssd-len",String(v[f])),i.style.strokeDasharray=`${v[f]}`,i.style.strokeDashoffset="",i.style.opacity="",i.style.animationPlayState="",i.classList.add(t);}x.forEach(a);let p=false,w=-1;function u(){if(w>=0)return w;let i=e.getBoundingClientRect(),{tStart:f,tEnd:y}=Le({top:i.top,height:i.height},ce(),He(),Oe,Fe);return Z(ne(ce(),f,y,d))}return {destroy(){x.forEach(i=>{i.classList.remove(t),i.style.removeProperty("--ssd-len"),i.style.animationPlayState="";}),D.remove();},replay(){p=false,w=-1,x.forEach(a);},pause(){p=true,x.forEach(i=>{i.style.animationPlayState="paused";});},resume(){p&&(p=false,x.forEach(i=>{i.style.animationPlayState="running";}));},seek(i){let f=Math.min(1,Math.max(0,i));w=f,p=true,x.forEach((y,re)=>{y.classList.remove(t),y.style.strokeDashoffset=c==="reverse"?`${v[re]*f}`:`${v[re]*(1-f)}`,m&&(y.style.opacity=c==="reverse"?`${1-f}`:`${f}`);});},getProgress(){return u()}}}if(Ye())return Ke();function Qe(){let t=Math.max(1,Xe),o=0,l=0;function g(u){let i=true;if(z){let f=Math.min(1,Math.max(0,u/t)),y=Z(f);te=y,e.style.setProperty("--scroll-draw-progress",String(y)),e.style.clipPath=ee(c==="reverse"?1-y:y),le?.(y),f<1&&(i=false);}else x.forEach((f,y)=>{let re=y*N*t,ie=Math.min(1,Math.max(0,(u-re)/t)),V=Z(ie);f.style.strokeDashoffset=c==="reverse"?`${v[y]*V}`:`${v[y]*(1-V)}`,m&&(f.style.opacity=c==="reverse"?`${1-V}`:`${V}`),R&&k?f.style.stroke=Se(R,k,V):k&&(f.style.stroke=k),P!==null&&$!==null?f.style.strokeWidth=`${P+($-P)*V}`:$!==null&&(f.style.strokeWidth=`${$}`),C!==null&&M!==null?f.style.fillOpacity=`${C+(M-C)*V}`:M!==null&&(f.style.fillOpacity=`${M}`),H&&f.tagName.toLowerCase()==="path"&&q[y]&&f.setAttribute("d",Ie(q[y],H,V)),y===0&&(le?.(V),e.style.setProperty("--scroll-draw-progress",String(V))),ie<1&&(i=false);});if(K){let f=Math.min(1,Math.max(0,u/t)),y=Z(f);for(let re in K){let ie=parseFloat(re);y>=ie&&!X.has(ie)&&(X.add(ie),K[re]?.());}}return i}function O(u){if(T)return;let i=u-o;F||(F=true,me?.());let f=g(i);if(f&&!A){A=true,g(t*(1+Math.max(0,x.length-1)*N)),se?.(),G<(Q==="infinite"?1/0:Q??0)&&(G++,j=setTimeout(()=>{o=performance.now(),F=false,A=false,X.clear(),he(),S=requestAnimationFrame(O);},Ae));return}f||(S=requestAnimationFrame(O));}function D(){cancelAnimationFrame(S),clearTimeout(j),o=performance.now(),l=0,T=false,F=false,A=false,G=0,X.clear(),he(),S=requestAnimationFrame(O);}let a=new IntersectionObserver(u=>{u.forEach(i=>{i.isIntersecting&&!(h&&A)?D():!i.isIntersecting&&!h&&!A&&(cancelAnimationFrame(S),clearTimeout(j),o=null);});},{root:I??null,threshold:Pe,rootMargin:Ce}),p;function w(){clearTimeout(p),p=setTimeout(()=>{x.forEach((u,i)=>{v[i]=ve(u),u.style.strokeDasharray=`${v[i]}`;});},150);}return window.addEventListener("resize",w),window.addEventListener("orientationchange",w),ae>0?setTimeout(()=>a.observe(e),ae):a.observe(e),{destroy(){cancelAnimationFrame(S),clearTimeout(j),a.disconnect(),window.removeEventListener("resize",w),window.removeEventListener("orientationchange",w),clearTimeout(p);},replay(){G=0,D();},pause(){T||(T=true,l=performance.now()-o,cancelAnimationFrame(S));},resume(){T&&(T=false,o=performance.now()-l,S=requestAnimationFrame(O));},seek(u){let i=Math.min(1,Math.max(0,u));te=i,T=true,l=i*t,o=performance.now()-l,cancelAnimationFrame(S),g(l);},getProgress(){return te}}}if(je)return Qe();Re();function ge(){if(!pe||T)return;let t=performance.now(),o=ce(),l=d;if(fe!==false){let a=t-Ne,p=a>0?Math.abs(o-(ye<0?o:ye))/a:0;l=d*Math.max(.2,1+p*(typeof fe=="number"?fe:1)*.04);}ye=o,Ne=t;let g=ue?de===-1||o>=de?"forward":"reverse":c;de=o;let O=_-B,D=true;if(z){let a=Z(ne(o,B,_,l));h&&!ue&&(W=Math.max(W,a),a=W),te=a,e.style.setProperty("--scroll-draw-progress",String(a));let p=g==="reverse"?1-a:a;e.style.clipPath=ee(p),le?.(a),!F&&ne(o,B,_,l)>0&&(F=true,me?.()),a>=1&&!A?(A=true,se?.(),G<(Q==="infinite"?1/0:Q??0)&&(G++,j=setTimeout(()=>{W=-1,F=false,A=false,e.style.clipPath=ee(0);},Ae))):a<1&&!h&&(A=false),S=requestAnimationFrame(ge);return}if(x.forEach((a,p)=>{let w=p*N*O,u=Z(ne(o,B+w,_+w,l));h&&!ue&&(W=Math.max(W,u),u=W),te=u,a.style.strokeDashoffset=g==="reverse"?`${v[p]*u}`:`${v[p]*(1-u)}`,m&&(a.style.opacity=g==="reverse"?`${1-u}`:`${u}`),R&&k?a.style.stroke=Se(R,k,u):k&&(a.style.stroke=k),P!==null&&$!==null?a.style.strokeWidth=`${P+($-P)*u}`:$!==null&&(a.style.strokeWidth=`${$}`),C!==null&&M!==null?a.style.fillOpacity=`${C+(M-C)*u}`:M!==null&&(a.style.fillOpacity=`${M}`),H&&a.tagName.toLowerCase()==="path"&&q[p]&&a.setAttribute("d",Ie(q[p],H,u)),p===0&&(le?.(u),e.style.setProperty("--scroll-draw-progress",String(u))),u<1&&(D=false);}),K){let a=Z(ne(o,B,_,l));for(let p in K){let w=parseFloat(p);a>=w&&!X.has(w)&&(X.add(w),K[p]?.());}}!F&&ne(o,B,_,l)>0&&(F=true,me?.()),D&&!A?(A=true,se?.(),G<(Q==="infinite"?1/0:Q??0)&&(G++,j=setTimeout(()=>{W=-1,F=false,A=false,X.clear(),he();},Ae))):!D&&!h&&(A=false),S=requestAnimationFrame(ge);}let Me=new IntersectionObserver(t=>{t.forEach(o=>{pe=o.isIntersecting,pe&&!T?S=requestAnimationFrame(ge):cancelAnimationFrame(S);});},{root:I??null,threshold:Pe,rootMargin:Ce}),Te;function be(){clearTimeout(Te),Te=setTimeout(()=>{x.forEach((t,o)=>{v[o]=ve(t),t.style.strokeDasharray=`${v[o]}`;}),Re();},150);}return window.addEventListener("resize",be),window.addEventListener("orientationchange",be),ae>0?setTimeout(()=>Me.observe(e),ae):Me.observe(e),{destroy(){cancelAnimationFrame(S),clearTimeout(j),Me.disconnect(),window.removeEventListener("resize",be),window.removeEventListener("orientationchange",be),clearTimeout(Te),$e?.remove();},replay(){W=-1,de=-1,ye=-1,F=false,A=false,G=0,T=false,X.clear(),clearTimeout(j),he();},pause(){T=true,cancelAnimationFrame(S);},resume(){T&&(T=false,pe&&(S=requestAnimationFrame(ge)));},seek(t){let o=Math.min(1,Math.max(0,t));te=o,W=o,T=true,cancelAnimationFrame(S),Ue(o,c);},getProgress(){return te}}}function ot(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let s=typeof e=="string"?document.querySelector(e):e;return s?Ee(s,r):(console.warn("[svg-scroll-draw] Container not found:",e),n)}function gt(e=document){return Array.from(e.querySelectorAll("[data-scroll-draw]")).map(r=>{let n={};try{let s=r.dataset.scrollDrawOptions??r.dataset.scrollDrawoptions??"";s&&(n=JSON.parse(s));}catch{}return Ee(r,n)})}exports.initScrollDraw=gt;exports.scrollDraw=ot;
@@ -60,6 +60,25 @@ interface ScrollDrawOptions {
60
60
  onProgress?: (alpha: number) => void;
61
61
  onStart?: () => void;
62
62
  onComplete?: () => void;
63
+ /**
64
+ * Trigger the animation when the element enters the viewport instead of
65
+ * tying it to scroll position. The draw runs over `duration` milliseconds,
66
+ * replaying each time the element re-enters the viewport (use `once: true`
67
+ * to play only the first time).
68
+ *
69
+ * All visual options work in autoplay mode — `easing`, `stagger`, `fade`,
70
+ * `strokeColor`, `strokeWidth`, `fillOpacity`, `clip`, `morphTo`, `waypoints`,
71
+ * `repeat`, `repeatDelay`, `onStart`, `onComplete`, `onProgress`, etc.
72
+ *
73
+ * The full instance API (`pause`, `resume`, `seek`, `replay`, `getProgress`)
74
+ * also works — `seek(0.5)` pauses at 50% of the duration.
75
+ */
76
+ autoplay?: boolean;
77
+ /**
78
+ * Duration of the autoplay animation in milliseconds. Only used when
79
+ * `autoplay: true`. Default `1000`.
80
+ */
81
+ duration?: number;
63
82
  /**
64
83
  * Use the browser's native CSS scroll-driven animation
65
84
  * (`animation-timeline: view()`) when the configuration is simple enough and
@@ -60,6 +60,25 @@ interface ScrollDrawOptions {
60
60
  onProgress?: (alpha: number) => void;
61
61
  onStart?: () => void;
62
62
  onComplete?: () => void;
63
+ /**
64
+ * Trigger the animation when the element enters the viewport instead of
65
+ * tying it to scroll position. The draw runs over `duration` milliseconds,
66
+ * replaying each time the element re-enters the viewport (use `once: true`
67
+ * to play only the first time).
68
+ *
69
+ * All visual options work in autoplay mode — `easing`, `stagger`, `fade`,
70
+ * `strokeColor`, `strokeWidth`, `fillOpacity`, `clip`, `morphTo`, `waypoints`,
71
+ * `repeat`, `repeatDelay`, `onStart`, `onComplete`, `onProgress`, etc.
72
+ *
73
+ * The full instance API (`pause`, `resume`, `seek`, `replay`, `getProgress`)
74
+ * also works — `seek(0.5)` pauses at 50% of the duration.
75
+ */
76
+ autoplay?: boolean;
77
+ /**
78
+ * Duration of the autoplay animation in milliseconds. Only used when
79
+ * `autoplay: true`. Default `1000`.
80
+ */
81
+ duration?: number;
63
82
  /**
64
83
  * Use the browser's native CSS scroll-driven animation
65
84
  * (`animation-timeline: view()`) when the configuration is simple enough and
@@ -1,3 +1,3 @@
1
- function Re({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),s=Math.max(.01,Math.min(.99,r)),c=Math.sqrt(s),u=0,m=[];for(let a=0;a<n;a++){let d=Math.pow(c,a);m.push(d),u+=d;}let h=[0],I=0;for(let a=0;a<n;a++)I+=m[a]/u,h.push(I);return a=>{if(a<=0)return 0;if(a>=1)return 1;for(let d=0;d<n;d++)if(a<=h[d+1]){let J=(a-h[d])/(h[d+1]-h[d]);if(d===0)return J*(2-J);let b=1-Math.pow(s,d);return b+(1-b)*(2*J-1)*(2*J-1)}return 1}}function We({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),s=Math.max(.1,r),c=n<=1?s/4:s/(2*Math.PI)*Math.asin(1/n);return u=>u<=0?0:u>=1?1:n*Math.pow(2,-10*u)*Math.sin((u-c)*(2*Math.PI)/s)+1}var xe={linear:e=>e,"ease-in":e=>e*e,"ease-out":e=>e*(2-e),"ease-in-out":e=>e<.5?2*e*e:-1+(4-2*e)*e,spring:e=>1-Math.cos(e*Math.PI*2.5)*Math.pow(1-e,2.2),bounce:Re(),elastic:We()};function Ee(e="top bottom"){let r=e.trim();if(/^\d+(\.\d+)?%$/.test(r))return {element:"top",viewport:r};let[n="top",s="bottom"]=r.split(/\s+/).filter(Boolean);return {element:n,viewport:s}}function Ce(e,r,n,s){switch(s){case "top":return e+n;case "center":return e+n+r/2;case "bottom":return e+n+r;default:return e+n}}function Fe(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 Se(e){let r=e.tagName.toLowerCase();if(r==="rect"){let n=parseFloat(e.getAttribute("width")??"0"),s=parseFloat(e.getAttribute("height")??"0");return 2*(n+s)}if(r==="circle"){let n=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*n}return e.getTotalLength()}function Ue(e,r,n){return Math.min(n,Math.max(r,e))}function X(e,r,n,s){return n===r?0:Ue((e-r)/(n-r)*s,0,1)}function $e(e,r,n,s,c){let u=Ce(e.top,e.height,r,s.element)-Fe(s.viewport,n),m=Ce(e.top,e.height,r,c.element)-Fe(c.viewport,n);return {tStart:u,tEnd:m}}function Ne(e){let r=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(r)return [parseInt(r[1]+r[1],16),parseInt(r[2]+r[2],16),parseInt(r[3]+r[3],16)];let n=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(n)return [parseInt(n[1],16),parseInt(n[2],16),parseInt(n[3],16)];let s=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return s?[parseInt(s[1]),parseInt(s[2]),parseInt(s[3])]:null}function Me(e,r,n){let s=Ne(e),c=Ne(r);return !s||!c?e:`rgb(${Math.round(s[0]+(c[0]-s[0])*n)},${Math.round(s[1]+(c[1]-s[1])*n)},${Math.round(s[2]+(c[2]-s[2])*n)})`}function He(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r);}var Ve={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},je=0;function Ke(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function Qe(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?He("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&He("Element has a fill \u2014 it may obscure the stroke animation.",e);}function Ye(e,r,n){let s=document.createElement("div");s.setAttribute("data-svg-scroll-draw-debug",""),s.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function c(){let u=n==="x"?window.scrollX:window.scrollY,m=e-u,h=r-u,I=n==="x";s.innerHTML=`
2
- <div style="position:absolute;${I?`left:${m}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${m}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
3
- <div style="position:absolute;${I?`left:${h}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${h}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(s),window.addEventListener("scroll",c,{passive:true}),c(),s}function qe(e,r,n){let s=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),c=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,u=>{let m=parseFloat(u),h=s[c++]??m;return String(+(m+(h-m)*n).toFixed(4))})}function pe(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let n=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:s="path, polyline, line, polygon, rect, circle",speed:c=1,fade:u=false,easing:m="linear",trigger:h={},stagger:I=0,direction:a="forward",once:d=false,debug:J=false,axis:b="y",scrollContainer:me,autoReverse:ee=false,delay:de=0,strokeColor:H,strokeWidth:V,fillOpacity:q,waypoints:te,velocityScale:re=false,threshold:Ge=0,rootMargin:ze="0px",repeat:j=0,repeatDelay:ke=0,morphTo:O,clip:ye,native:Be=true,onProgress:he,onStart:ge,onComplete:K}=r,G=ye===true?"left":typeof ye=="string"?ye:false,ne=typeof m=="function"?m:xe[m]??xe.linear,Ae=Ee(h.start??"top bottom"),De=Ee(h.end??"bottom top"),x=typeof me=="string"?document.querySelector(me):me??null,C=Array.isArray(H)?H[0]:null,$=Array.isArray(H)?H[1]:typeof H=="string"?H:null,M=Array.isArray(V)?V[0]:null,k=Array.isArray(V)?V[1]:typeof V=="number"?V:null,A=Array.isArray(q)?q[0]:null,D=Array.isArray(q)?q[1]:typeof q=="number"?q:null;function U(t){let o=t*100;switch(G){case "right":return `inset(0 0 0 ${100-o}%)`;case "top":return `inset(0 0 ${100-o}% 0)`;case "bottom":return `inset(${100-o}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-o}% 0 0)`}}let E=G?[]:Array.from(e.querySelectorAll(s)),w=[],F=[],N=0,R=0,L=false,z=false,W=0,se=false,T=-1,oe=-1,B=false,ie=0,Q=0,ae,be=null,le=new Set,ue=-1,Te=performance.now();function Y(){return x?b==="x"?x.scrollLeft:x.scrollTop:b==="x"?window.scrollX:window.scrollY}function Pe(){return x?b==="x"?x.clientWidth:x.clientHeight:b==="x"?window.innerWidth:window.innerHeight}function Le(){let t=e.getBoundingClientRect(),o,l,g;if(x){let S=x.getBoundingClientRect();o=b==="x"?t.left-S.left+x.scrollLeft:t.top-S.top+x.scrollTop,l=b==="x"?t.width:t.height,g=Y();}else o=b==="x"?t.left:t.top,l=b==="x"?t.width:t.height,g=Y();let _=$e({top:o,height:l},g,Pe(),Ae,De);N=_.tStart,R=_.tEnd,J&&process.env.NODE_ENV!=="production"&&(be?.remove(),be=Ye(N,R,b));}function _e(t,o){if(e.style.setProperty("--scroll-draw-progress",String(t)),G){let l=o==="reverse"?1-t:t;e.style.clipPath=U(l);return}E.forEach((l,g)=>{l.style.strokeDashoffset=o==="reverse"?`${w[g]*t}`:`${w[g]*(1-t)}`,u&&(l.style.opacity=o==="reverse"?`${1-t}`:`${t}`),C&&$?l.style.stroke=Me(C,$,t):$&&(l.style.stroke=$),M!==null&&k!==null?l.style.strokeWidth=`${M+(k-M)*t}`:k!==null&&(l.style.strokeWidth=`${k}`),A!==null&&D!==null?l.style.fillOpacity=`${A+(D-A)*t}`:D!==null&&(l.style.fillOpacity=`${D}`),O&&l.tagName.toLowerCase()==="path"&&F[g]&&l.setAttribute("d",qe(F[g],O,t));});}function Ie(){if(e.style.setProperty("--scroll-draw-progress","0"),G){e.style.clipPath=U(0);return}E.forEach((t,o)=>{t.style.strokeDasharray=`${w[o]}`,t.style.strokeDashoffset=a==="reverse"?"0":`${w[o]}`,u?t.style.opacity=a==="reverse"?"1":"0":t.style.opacity="",C&&(t.style.stroke=C),M!==null&&(t.style.strokeWidth=`${M}`),A!==null&&(t.style.fillOpacity=`${A}`),O&&t.tagName.toLowerCase()==="path"&&F[o]&&t.setAttribute("d",F[o]);});}if(E.forEach(t=>{Qe(t);let o=Se(t);w.push(o),t.tagName.toLowerCase()==="path"?F.push(t.getAttribute("d")??""):F.push(""),n?(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=a==="reverse"?`${o}`:"0",u&&(t.style.opacity="1"),$&&(t.style.stroke=$),k!==null&&(t.style.strokeWidth=`${k}`),D!==null&&(t.style.fillOpacity=`${D}`),O&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",O)):(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=a==="reverse"?"0":`${o}`,u?t.style.opacity=a==="reverse"?"1":"0":t.style.opacity="",C&&(t.style.stroke=C),M!==null&&(t.style.strokeWidth=`${M}`),A!==null&&(t.style.fillOpacity=`${A}`));}),G){if(n)return e.style.clipPath=U(1),K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=U(0);}else if(n)return K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Xe(){return !(Be===false||!Ke()||!E.length||typeof m!="string"||!(m in Ve)||G||b!=="y"||x||c!==1||I!==0||d||ee||re!==false||O||te||j||de>0||he||ge||K||H!=null||V!=null||q!=null||(h.start??"top bottom").trim()!=="top bottom"||(h.end??"bottom top").trim()!=="bottom top")}function Je(){let t=`svg-scroll-draw-${++je}`,o=a==="reverse"?"0":"var(--ssd-len)",l=a==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${o};`,_=`stroke-dashoffset:${l};`;u&&(g+=`opacity:${a==="reverse"?1:0};`,_+=`opacity:${a==="reverse"?0:1};`);let S=document.createElement("style");S.setAttribute("data-svg-scroll-draw",""),S.textContent=`@keyframes ${t}{from{${g}}to{${_}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Ve[m]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(S);function i(p,P){p.style.setProperty("--ssd-len",String(w[P])),p.style.strokeDasharray=`${w[P]}`,p.style.strokeDashoffset="",p.style.opacity="",p.style.animationPlayState="",p.classList.add(t);}E.forEach(i);let f=false,v=-1;function y(){if(v>=0)return v;let p=e.getBoundingClientRect(),{tStart:P,tEnd:Z}=$e({top:p.top,height:p.height},Y(),Pe(),Ae,De);return ne(X(Y(),P,Z,c))}return {destroy(){E.forEach(p=>{p.classList.remove(t),p.style.removeProperty("--ssd-len"),p.style.animationPlayState="";}),S.remove();},replay(){f=false,v=-1,E.forEach(i);},pause(){f=true,E.forEach(p=>{p.style.animationPlayState="paused";});},resume(){f&&(f=false,E.forEach(p=>{p.style.animationPlayState="running";}));},seek(p){let P=Math.min(1,Math.max(0,p));v=P,f=true,E.forEach((Z,Oe)=>{Z.classList.remove(t),Z.style.strokeDashoffset=a==="reverse"?`${w[Oe]*P}`:`${w[Oe]*(1-P)}`,u&&(Z.style.opacity=a==="reverse"?`${1-P}`:`${P}`);});},getProgress(){return y()}}}if(Xe())return Je();Le();function ce(){if(!se||B)return;let t=performance.now(),o=Y(),l=c;if(re!==false){let i=t-Te,f=i>0?Math.abs(o-(ue<0?o:ue))/i:0;l=c*Math.max(.2,1+f*(typeof re=="number"?re:1)*.04);}ue=o,Te=t;let g=ee?oe===-1||o>=oe?"forward":"reverse":a;oe=o;let _=R-N,S=true;if(G){let i=ne(X(o,N,R,l));d&&!ee&&(T=Math.max(T,i),i=T),ie=i,e.style.setProperty("--scroll-draw-progress",String(i));let f=g==="reverse"?1-i:i;e.style.clipPath=U(f),he?.(i),!z&&X(o,N,R,l)>0&&(z=true,ge?.()),i>=1&&!L?(L=true,K?.(),Q<(j==="infinite"?1/0:j??0)&&(Q++,ae=setTimeout(()=>{T=-1,z=false,L=false,e.style.clipPath=U(0);},ke))):i<1&&!d&&(L=false),W=requestAnimationFrame(ce);return}if(E.forEach((i,f)=>{let v=f*I*_,y=ne(X(o,N+v,R+v,l));d&&!ee&&(T=Math.max(T,y),y=T),ie=y,i.style.strokeDashoffset=g==="reverse"?`${w[f]*y}`:`${w[f]*(1-y)}`,u&&(i.style.opacity=g==="reverse"?`${1-y}`:`${y}`),C&&$?i.style.stroke=Me(C,$,y):$&&(i.style.stroke=$),M!==null&&k!==null?i.style.strokeWidth=`${M+(k-M)*y}`:k!==null&&(i.style.strokeWidth=`${k}`),A!==null&&D!==null?i.style.fillOpacity=`${A+(D-A)*y}`:D!==null&&(i.style.fillOpacity=`${D}`),O&&i.tagName.toLowerCase()==="path"&&F[f]&&i.setAttribute("d",qe(F[f],O,y)),f===0&&(he?.(y),e.style.setProperty("--scroll-draw-progress",String(y))),y<1&&(S=false);}),te){let i=ne(X(o,N,R,l));for(let f in te){let v=parseFloat(f);i>=v&&!le.has(v)&&(le.add(v),te[f]?.());}}!z&&X(o,N,R,l)>0&&(z=true,ge?.()),S&&!L?(L=true,K?.(),Q<(j==="infinite"?1/0:j??0)&&(Q++,ae=setTimeout(()=>{T=-1,z=false,L=false,le.clear(),Ie();},ke))):!S&&!d&&(L=false),W=requestAnimationFrame(ce);}let we=new IntersectionObserver(t=>{t.forEach(o=>{se=o.isIntersecting,se&&!B?W=requestAnimationFrame(ce):cancelAnimationFrame(W);});},{root:x??null,threshold:Ge,rootMargin:ze}),ve;function fe(){clearTimeout(ve),ve=setTimeout(()=>{E.forEach((t,o)=>{w[o]=Se(t),t.style.strokeDasharray=`${w[o]}`;}),Le();},150);}return window.addEventListener("resize",fe),window.addEventListener("orientationchange",fe),de>0?setTimeout(()=>we.observe(e),de):we.observe(e),{destroy(){cancelAnimationFrame(W),clearTimeout(ae),we.disconnect(),window.removeEventListener("resize",fe),window.removeEventListener("orientationchange",fe),clearTimeout(ve),be?.remove();},replay(){T=-1,oe=-1,ue=-1,z=false,L=false,Q=0,B=false,le.clear(),clearTimeout(ae),Ie();},pause(){B=true,cancelAnimationFrame(W);},resume(){B&&(B=false,se&&(W=requestAnimationFrame(ce)));},seek(t){let o=Math.min(1,Math.max(0,t));ie=o,T=o,B=true,cancelAnimationFrame(W),_e(o,a);},getProgress(){return ie}}}function Ze(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let s=typeof e=="string"?document.querySelector(e):e;return s?pe(s,r):(console.warn("[svg-scroll-draw] Container not found:",e),n)}function lt(e=document){return Array.from(e.querySelectorAll("[data-scroll-draw]")).map(r=>{let n={};try{let s=r.dataset.scrollDrawOptions??r.dataset.scrollDrawoptions??"";s&&(n=JSON.parse(s));}catch{}return pe(r,n)})}export{lt as initScrollDraw,Ze as scrollDraw};
1
+ function Ge({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),s=Math.max(.01,Math.min(.99,r)),d=Math.sqrt(s),m=0,b=[];for(let c=0;c<n;c++){let h=Math.pow(d,c);b.push(h),m+=h;}let E=[0],N=0;for(let c=0;c<n;c++)N+=b[c]/m,E.push(N);return c=>{if(c<=0)return 0;if(c>=1)return 1;for(let h=0;h<n;h++)if(c<=E[h+1]){let oe=(c-E[h])/(E[h+1]-E[h]);if(h===0)return oe*(2-oe);let L=1-Math.pow(s,h);return L+(1-L)*(2*oe-1)*(2*oe-1)}return 1}}function ze({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),s=Math.max(.1,r),d=n<=1?s/4:s/(2*Math.PI)*Math.asin(1/n);return m=>m<=0?0:m>=1?1:n*Math.pow(2,-10*m)*Math.sin((m-d)*(2*Math.PI)/s)+1}var we={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:Ge(),elastic:ze()};function De(e="top bottom"){let r=e.trim();if(/^\d+(\.\d+)?%$/.test(r))return {element:"top",viewport:r};let[n="top",s="bottom"]=r.split(/\s+/).filter(Boolean);return {element:n,viewport:s}}function qe(e,r,n,s){switch(s){case "top":return e+n;case "center":return e+n+r/2;case "bottom":return e+n+r;default:return e+n}}function We(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 n=parseFloat(e.getAttribute("width")??"0"),s=parseFloat(e.getAttribute("height")??"0");return 2*(n+s)}if(r==="circle"){let n=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*n}return e.getTotalLength()}function Ze(e,r,n){return Math.min(n,Math.max(r,e))}function ne(e,r,n,s){return n===r?0:Ze((e-r)/(n-r)*s,0,1)}function Le(e,r,n,s,d){let m=qe(e.top,e.height,r,s.element)-We(s.viewport,n),b=qe(e.top,e.height,r,d.element)-We(d.viewport,n);return {tStart:m,tEnd:b}}function Ve(e){let r=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(r)return [parseInt(r[1]+r[1],16),parseInt(r[2]+r[2],16),parseInt(r[3]+r[3],16)];let n=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(n)return [parseInt(n[1],16),parseInt(n[2],16),parseInt(n[3],16)];let s=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return s?[parseInt(s[1]),parseInt(s[2]),parseInt(s[3])]:null}function Se(e,r,n){let s=Ve(e),d=Ve(r);return !s||!d?e:`rgb(${Math.round(s[0]+(d[0]-s[0])*n)},${Math.round(s[1]+(d[1]-s[1])*n)},${Math.round(s[2]+(d[2]-s[2])*n)})`}function Be(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r);}var _e={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},et=0;function tt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function rt(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?Be("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&Be("Element has a fill \u2014 it may obscure the stroke animation.",e);}function nt(e,r,n){let s=document.createElement("div");s.setAttribute("data-svg-scroll-draw-debug",""),s.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function d(){let m=n==="x"?window.scrollX:window.scrollY,b=e-m,E=r-m,N=n==="x";s.innerHTML=`
2
+ <div style="position:absolute;${N?`left:${b}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${b}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;${N?`left:${E}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${E}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`;}return document.body.appendChild(s),window.addEventListener("scroll",d,{passive:true}),d(),s}function Ie(e,r,n){let s=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),d=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,m=>{let b=parseFloat(m),E=s[d++]??b;return String(+(b+(E-b)*n).toFixed(4))})}function Ee(e,r={}){if(typeof window>"u")return {destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let n=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:s="path, polyline, line, polygon, rect, circle",speed:d=1,fade:m=false,easing:b="linear",trigger:E={},stagger:N=0,direction:c="forward",once:h=false,debug:oe=false,axis:L="y",scrollContainer:xe,autoReverse:ue=false,delay:ae=0,strokeColor:J,strokeWidth:U,fillOpacity:Y,waypoints:K,velocityScale:fe=false,threshold:Pe=0,rootMargin:Ce="0px",repeat:Q=0,repeatDelay:Ae=0,morphTo:H,clip:ke,autoplay:je=false,duration:Xe=1e3,native:Je=true,onProgress:le,onStart:me,onComplete:se}=r,z=ke===true?"left":typeof ke=="string"?ke:false,Z=typeof b=="function"?b:we[b]??we.linear,Oe=De(E.start??"top bottom"),Fe=De(E.end??"bottom top"),I=typeof xe=="string"?document.querySelector(xe):xe??null,R=Array.isArray(J)?J[0]:null,k=Array.isArray(J)?J[1]:typeof J=="string"?J:null,P=Array.isArray(U)?U[0]:null,$=Array.isArray(U)?U[1]:typeof U=="number"?U:null,C=Array.isArray(Y)?Y[0]:null,M=Array.isArray(Y)?Y[1]:typeof Y=="number"?Y:null;function ee(t){let o=t*100;switch(z){case "right":return `inset(0 0 0 ${100-o}%)`;case "top":return `inset(0 0 ${100-o}% 0)`;case "bottom":return `inset(${100-o}% 0 0 0)`;case "center":return `circle(${t*150}% at 50% 50%)`;default:return `inset(0 ${100-o}% 0 0)`}}let x=z?[]:Array.from(e.querySelectorAll(s)),v=[],q=[],B=0,_=0,A=false,F=false,S=0,pe=false,W=-1,de=-1,T=false,te=0,G=0,j,$e=null,X=new Set,ye=-1,Ne=performance.now();function ce(){return I?L==="x"?I.scrollLeft:I.scrollTop:L==="x"?window.scrollX:window.scrollY}function He(){return I?L==="x"?I.clientWidth:I.clientHeight:L==="x"?window.innerWidth:window.innerHeight}function Re(){let t=e.getBoundingClientRect(),o,l,g;if(I){let D=I.getBoundingClientRect();o=L==="x"?t.left-D.left+I.scrollLeft:t.top-D.top+I.scrollTop,l=L==="x"?t.width:t.height,g=ce();}else o=L==="x"?t.left:t.top,l=L==="x"?t.width:t.height,g=ce();let O=Le({top:o,height:l},g,He(),Oe,Fe);B=O.tStart,_=O.tEnd,oe&&process.env.NODE_ENV!=="production"&&($e?.remove(),$e=nt(B,_,L));}function Ue(t,o){if(e.style.setProperty("--scroll-draw-progress",String(t)),z){let l=o==="reverse"?1-t:t;e.style.clipPath=ee(l);return}x.forEach((l,g)=>{l.style.strokeDashoffset=o==="reverse"?`${v[g]*t}`:`${v[g]*(1-t)}`,m&&(l.style.opacity=o==="reverse"?`${1-t}`:`${t}`),R&&k?l.style.stroke=Se(R,k,t):k&&(l.style.stroke=k),P!==null&&$!==null?l.style.strokeWidth=`${P+($-P)*t}`:$!==null&&(l.style.strokeWidth=`${$}`),C!==null&&M!==null?l.style.fillOpacity=`${C+(M-C)*t}`:M!==null&&(l.style.fillOpacity=`${M}`),H&&l.tagName.toLowerCase()==="path"&&q[g]&&l.setAttribute("d",Ie(q[g],H,t));});}function he(){if(e.style.setProperty("--scroll-draw-progress","0"),z){e.style.clipPath=ee(0);return}x.forEach((t,o)=>{t.style.strokeDasharray=`${v[o]}`,t.style.strokeDashoffset=c==="reverse"?"0":`${v[o]}`,m?t.style.opacity=c==="reverse"?"1":"0":t.style.opacity="",R&&(t.style.stroke=R),P!==null&&(t.style.strokeWidth=`${P}`),C!==null&&(t.style.fillOpacity=`${C}`),H&&t.tagName.toLowerCase()==="path"&&q[o]&&t.setAttribute("d",q[o]);});}if(x.forEach(t=>{rt(t);let o=ve(t);v.push(o),t.tagName.toLowerCase()==="path"?q.push(t.getAttribute("d")??""):q.push(""),n?(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=c==="reverse"?`${o}`:"0",m&&(t.style.opacity="1"),k&&(t.style.stroke=k),$!==null&&(t.style.strokeWidth=`${$}`),M!==null&&(t.style.fillOpacity=`${M}`),H&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",H)):(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=c==="reverse"?"0":`${o}`,m?t.style.opacity=c==="reverse"?"1":"0":t.style.opacity="",R&&(t.style.stroke=R),P!==null&&(t.style.strokeWidth=`${P}`),C!==null&&(t.style.fillOpacity=`${C}`));}),z){if(n)return e.style.clipPath=ee(1),se?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ee(0);}else if(n)return se?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Ye(){return !(Je===false||!tt()||!x.length||typeof b!="string"||!(b in _e)||z||L!=="y"||I||d!==1||N!==0||h||ue||fe!==false||H||K||Q||ae>0||le||me||se||J!=null||U!=null||Y!=null||(E.start??"top bottom").trim()!=="top bottom"||(E.end??"bottom top").trim()!=="bottom top")}function Ke(){let t=`svg-scroll-draw-${++et}`,o=c==="reverse"?"0":"var(--ssd-len)",l=c==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${o};`,O=`stroke-dashoffset:${l};`;m&&(g+=`opacity:${c==="reverse"?1:0};`,O+=`opacity:${c==="reverse"?0:1};`);let D=document.createElement("style");D.setAttribute("data-svg-scroll-draw",""),D.textContent=`@keyframes ${t}{from{${g}}to{${O}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${_e[b]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(D);function a(i,f){i.style.setProperty("--ssd-len",String(v[f])),i.style.strokeDasharray=`${v[f]}`,i.style.strokeDashoffset="",i.style.opacity="",i.style.animationPlayState="",i.classList.add(t);}x.forEach(a);let p=false,w=-1;function u(){if(w>=0)return w;let i=e.getBoundingClientRect(),{tStart:f,tEnd:y}=Le({top:i.top,height:i.height},ce(),He(),Oe,Fe);return Z(ne(ce(),f,y,d))}return {destroy(){x.forEach(i=>{i.classList.remove(t),i.style.removeProperty("--ssd-len"),i.style.animationPlayState="";}),D.remove();},replay(){p=false,w=-1,x.forEach(a);},pause(){p=true,x.forEach(i=>{i.style.animationPlayState="paused";});},resume(){p&&(p=false,x.forEach(i=>{i.style.animationPlayState="running";}));},seek(i){let f=Math.min(1,Math.max(0,i));w=f,p=true,x.forEach((y,re)=>{y.classList.remove(t),y.style.strokeDashoffset=c==="reverse"?`${v[re]*f}`:`${v[re]*(1-f)}`,m&&(y.style.opacity=c==="reverse"?`${1-f}`:`${f}`);});},getProgress(){return u()}}}if(Ye())return Ke();function Qe(){let t=Math.max(1,Xe),o=0,l=0;function g(u){let i=true;if(z){let f=Math.min(1,Math.max(0,u/t)),y=Z(f);te=y,e.style.setProperty("--scroll-draw-progress",String(y)),e.style.clipPath=ee(c==="reverse"?1-y:y),le?.(y),f<1&&(i=false);}else x.forEach((f,y)=>{let re=y*N*t,ie=Math.min(1,Math.max(0,(u-re)/t)),V=Z(ie);f.style.strokeDashoffset=c==="reverse"?`${v[y]*V}`:`${v[y]*(1-V)}`,m&&(f.style.opacity=c==="reverse"?`${1-V}`:`${V}`),R&&k?f.style.stroke=Se(R,k,V):k&&(f.style.stroke=k),P!==null&&$!==null?f.style.strokeWidth=`${P+($-P)*V}`:$!==null&&(f.style.strokeWidth=`${$}`),C!==null&&M!==null?f.style.fillOpacity=`${C+(M-C)*V}`:M!==null&&(f.style.fillOpacity=`${M}`),H&&f.tagName.toLowerCase()==="path"&&q[y]&&f.setAttribute("d",Ie(q[y],H,V)),y===0&&(le?.(V),e.style.setProperty("--scroll-draw-progress",String(V))),ie<1&&(i=false);});if(K){let f=Math.min(1,Math.max(0,u/t)),y=Z(f);for(let re in K){let ie=parseFloat(re);y>=ie&&!X.has(ie)&&(X.add(ie),K[re]?.());}}return i}function O(u){if(T)return;let i=u-o;F||(F=true,me?.());let f=g(i);if(f&&!A){A=true,g(t*(1+Math.max(0,x.length-1)*N)),se?.(),G<(Q==="infinite"?1/0:Q??0)&&(G++,j=setTimeout(()=>{o=performance.now(),F=false,A=false,X.clear(),he(),S=requestAnimationFrame(O);},Ae));return}f||(S=requestAnimationFrame(O));}function D(){cancelAnimationFrame(S),clearTimeout(j),o=performance.now(),l=0,T=false,F=false,A=false,G=0,X.clear(),he(),S=requestAnimationFrame(O);}let a=new IntersectionObserver(u=>{u.forEach(i=>{i.isIntersecting&&!(h&&A)?D():!i.isIntersecting&&!h&&!A&&(cancelAnimationFrame(S),clearTimeout(j),o=null);});},{root:I??null,threshold:Pe,rootMargin:Ce}),p;function w(){clearTimeout(p),p=setTimeout(()=>{x.forEach((u,i)=>{v[i]=ve(u),u.style.strokeDasharray=`${v[i]}`;});},150);}return window.addEventListener("resize",w),window.addEventListener("orientationchange",w),ae>0?setTimeout(()=>a.observe(e),ae):a.observe(e),{destroy(){cancelAnimationFrame(S),clearTimeout(j),a.disconnect(),window.removeEventListener("resize",w),window.removeEventListener("orientationchange",w),clearTimeout(p);},replay(){G=0,D();},pause(){T||(T=true,l=performance.now()-o,cancelAnimationFrame(S));},resume(){T&&(T=false,o=performance.now()-l,S=requestAnimationFrame(O));},seek(u){let i=Math.min(1,Math.max(0,u));te=i,T=true,l=i*t,o=performance.now()-l,cancelAnimationFrame(S),g(l);},getProgress(){return te}}}if(je)return Qe();Re();function ge(){if(!pe||T)return;let t=performance.now(),o=ce(),l=d;if(fe!==false){let a=t-Ne,p=a>0?Math.abs(o-(ye<0?o:ye))/a:0;l=d*Math.max(.2,1+p*(typeof fe=="number"?fe:1)*.04);}ye=o,Ne=t;let g=ue?de===-1||o>=de?"forward":"reverse":c;de=o;let O=_-B,D=true;if(z){let a=Z(ne(o,B,_,l));h&&!ue&&(W=Math.max(W,a),a=W),te=a,e.style.setProperty("--scroll-draw-progress",String(a));let p=g==="reverse"?1-a:a;e.style.clipPath=ee(p),le?.(a),!F&&ne(o,B,_,l)>0&&(F=true,me?.()),a>=1&&!A?(A=true,se?.(),G<(Q==="infinite"?1/0:Q??0)&&(G++,j=setTimeout(()=>{W=-1,F=false,A=false,e.style.clipPath=ee(0);},Ae))):a<1&&!h&&(A=false),S=requestAnimationFrame(ge);return}if(x.forEach((a,p)=>{let w=p*N*O,u=Z(ne(o,B+w,_+w,l));h&&!ue&&(W=Math.max(W,u),u=W),te=u,a.style.strokeDashoffset=g==="reverse"?`${v[p]*u}`:`${v[p]*(1-u)}`,m&&(a.style.opacity=g==="reverse"?`${1-u}`:`${u}`),R&&k?a.style.stroke=Se(R,k,u):k&&(a.style.stroke=k),P!==null&&$!==null?a.style.strokeWidth=`${P+($-P)*u}`:$!==null&&(a.style.strokeWidth=`${$}`),C!==null&&M!==null?a.style.fillOpacity=`${C+(M-C)*u}`:M!==null&&(a.style.fillOpacity=`${M}`),H&&a.tagName.toLowerCase()==="path"&&q[p]&&a.setAttribute("d",Ie(q[p],H,u)),p===0&&(le?.(u),e.style.setProperty("--scroll-draw-progress",String(u))),u<1&&(D=false);}),K){let a=Z(ne(o,B,_,l));for(let p in K){let w=parseFloat(p);a>=w&&!X.has(w)&&(X.add(w),K[p]?.());}}!F&&ne(o,B,_,l)>0&&(F=true,me?.()),D&&!A?(A=true,se?.(),G<(Q==="infinite"?1/0:Q??0)&&(G++,j=setTimeout(()=>{W=-1,F=false,A=false,X.clear(),he();},Ae))):!D&&!h&&(A=false),S=requestAnimationFrame(ge);}let Me=new IntersectionObserver(t=>{t.forEach(o=>{pe=o.isIntersecting,pe&&!T?S=requestAnimationFrame(ge):cancelAnimationFrame(S);});},{root:I??null,threshold:Pe,rootMargin:Ce}),Te;function be(){clearTimeout(Te),Te=setTimeout(()=>{x.forEach((t,o)=>{v[o]=ve(t),t.style.strokeDasharray=`${v[o]}`;}),Re();},150);}return window.addEventListener("resize",be),window.addEventListener("orientationchange",be),ae>0?setTimeout(()=>Me.observe(e),ae):Me.observe(e),{destroy(){cancelAnimationFrame(S),clearTimeout(j),Me.disconnect(),window.removeEventListener("resize",be),window.removeEventListener("orientationchange",be),clearTimeout(Te),$e?.remove();},replay(){W=-1,de=-1,ye=-1,F=false,A=false,G=0,T=false,X.clear(),clearTimeout(j),he();},pause(){T=true,cancelAnimationFrame(S);},resume(){T&&(T=false,pe&&(S=requestAnimationFrame(ge)));},seek(t){let o=Math.min(1,Math.max(0,t));te=o,W=o,T=true,cancelAnimationFrame(S),Ue(o,c);},getProgress(){return te}}}function ot(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let s=typeof e=="string"?document.querySelector(e):e;return s?Ee(s,r):(console.warn("[svg-scroll-draw] Container not found:",e),n)}function gt(e=document){return Array.from(e.querySelectorAll("[data-scroll-draw]")).map(r=>{let n={};try{let s=r.dataset.scrollDrawOptions??r.dataset.scrollDrawoptions??"";s&&(n=JSON.parse(s));}catch{}return Ee(r,n)})}export{gt as initScrollDraw,ot as scrollDraw};
@@ -1,3 +1,3 @@
1
- "use strict";var SvgScrollDraw=(()=>{var Ee=Object.defineProperty;var Qe=Object.getOwnPropertyDescriptor;var Ye=Object.getOwnPropertyNames;var Ze=Object.prototype.hasOwnProperty;var et=(e,n)=>{for(var r in n)Ee(e,r,{get:n[r],enumerable:!0})},tt=(e,n,r,s)=>{if(n&&typeof n=="object"||typeof n=="function")for(let i of Ye(n))!Ze.call(e,i)&&i!==r&&Ee(e,i,{get:()=>n[i],enumerable:!(s=Qe(n,i))||s.enumerable});return e};var rt=e=>tt(Ee({},"__esModule",{value:!0}),e);var ut={};et(ut,{createBounce:()=>xe,createElastic:()=>$e,createSpring:()=>Ge,scrollDraw:()=>lt});function Ge({tension:e=2.5,friction:n=2.2}={}){return r=>1-Math.cos(r*Math.PI*e)*Math.pow(1-r,n)}function xe({bounces:e=3,decay:n=.5}={}){let r=Math.max(1,Math.round(e)),s=Math.max(.01,Math.min(.99,n)),i=Math.sqrt(s),u=0,f=[];for(let l=0;l<r;l++){let y=Math.pow(i,l);f.push(y),u+=y}let d=[0],I=0;for(let l=0;l<r;l++)I+=f[l]/u,d.push(I);return l=>{if(l<=0)return 0;if(l>=1)return 1;for(let y=0;y<r;y++)if(l<=d[y+1]){let U=(l-d[y])/(d[y+1]-d[y]);if(y===0)return U*(2-U);let b=1-Math.pow(s,y);return b+(1-b)*(2*U-1)*(2*U-1)}return 1}}function $e({amplitude:e=1,period:n=.4}={}){let r=Math.max(1,e),s=Math.max(.1,n),i=r<=1?s/4:s/(2*Math.PI)*Math.asin(1/r);return u=>u<=0?0:u>=1?1:r*Math.pow(2,-10*u)*Math.sin((u-i)*(2*Math.PI)/s)+1}var Se={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:xe(),elastic:$e()};function Ae(e="top bottom"){let n=e.trim();if(/^\d+(\.\d+)?%$/.test(n))return{element:"top",viewport:n};let[r="top",s="bottom"]=n.split(/\s+/).filter(Boolean);return{element:r,viewport:s}}function We(e,n,r,s){switch(s){case"top":return e+r;case"center":return e+r+n/2;case"bottom":return e+r+n;default:return e+r}}function He(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 Me(e){let n=e.tagName.toLowerCase();if(n==="rect"){let r=parseFloat(e.getAttribute("width")??"0"),s=parseFloat(e.getAttribute("height")??"0");return 2*(r+s)}if(n==="circle"){let r=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*r}return e.getTotalLength()}function nt(e,n,r){return Math.min(r,Math.max(n,e))}function X(e,n,r,s){return r===n?0:nt((e-n)/(r-n)*s,0,1)}function ke(e,n,r,s,i){let u=We(e.top,e.height,n,s.element)-He(s.viewport,r),f=We(e.top,e.height,n,i.element)-He(i.viewport,r);return{tStart:u,tEnd:f}}function Ve(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 s=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return s?[parseInt(s[1]),parseInt(s[2]),parseInt(s[3])]:null}function Te(e,n,r){let s=Ve(e),i=Ve(n);return!s||!i?e:`rgb(${Math.round(s[0]+(i[0]-s[0])*r)},${Math.round(s[1]+(i[1]-s[1])*r)},${Math.round(s[2]+(i[2]-s[2])*r)})`}function qe(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n)}var ze={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},st=0;function ot(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function it(e){let n=e.getAttribute("stroke"),r=e.getAttribute("fill");!n||n==="none"?qe("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&&qe("Element has a fill \u2014 it may obscure the stroke animation.",e)}function at(e,n,r){let s=document.createElement("div");s.setAttribute("data-svg-scroll-draw-debug",""),s.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function i(){let u=r==="x"?window.scrollX:window.scrollY,f=e-u,d=n-u,I=r==="x";s.innerHTML=`
2
- <div style="position:absolute;${I?`left:${f}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${f}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;${I?`left:${d}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${d}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`}return document.body.appendChild(s),window.addEventListener("scroll",i,{passive:!0}),i(),s}function Be(e,n,r){let s=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),i=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,u=>{let f=parseFloat(u),d=s[i++]??f;return String(+(f+(d-f)*r).toFixed(4))})}function pe(e,n={}){if(typeof window>"u")return{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let r=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:s="path, polyline, line, polygon, rect, circle",speed:i=1,fade:u=!1,easing:f="linear",trigger:d={},stagger:I=0,direction:l="forward",once:y=!1,debug:U=!1,axis:b="y",scrollContainer:me,autoReverse:ee=!1,delay:de=0,strokeColor:H,strokeWidth:V,fillOpacity:G,waypoints:te,velocityScale:re=!1,threshold:_e=0,rootMargin:Xe="0px",repeat:J=0,repeatDelay:Pe=0,morphTo:C,clip:ye,native:Ue=!0,onProgress:ge,onStart:he,onComplete:K}=n,q=ye===!0?"left":typeof ye=="string"?ye:!1,ne=typeof f=="function"?f:Se[f]??Se.linear,Le=Ae(d.start??"top bottom"),Ie=Ae(d.end??"bottom top"),E=typeof me=="string"?document.querySelector(me):me??null,O=Array.isArray(H)?H[0]:null,S=Array.isArray(H)?H[1]:typeof H=="string"?H:null,A=Array.isArray(V)?V[0]:null,M=Array.isArray(V)?V[1]:typeof V=="number"?V:null,k=Array.isArray(G)?G[0]:null,T=Array.isArray(G)?G[1]:typeof G=="number"?G:null;function j(t){let o=t*100;switch(q){case"right":return`inset(0 0 0 ${100-o}%)`;case"top":return`inset(0 0 ${100-o}% 0)`;case"bottom":return`inset(${100-o}% 0 0 0)`;case"center":return`circle(${t*150}% at 50% 50%)`;default:return`inset(0 ${100-o}% 0 0)`}}let x=q?[]:Array.from(e.querySelectorAll(s)),w=[],F=[],N=0,R=0,L=!1,z=!1,W=0,se=!1,D=-1,oe=-1,B=!1,ie=0,Q=0,ae,be=null,le=new Set,ue=-1,Ce=performance.now();function Y(){return E?b==="x"?E.scrollLeft:E.scrollTop:b==="x"?window.scrollX:window.scrollY}function Oe(){return E?b==="x"?E.clientWidth:E.clientHeight:b==="x"?window.innerWidth:window.innerHeight}function Fe(){let t=e.getBoundingClientRect(),o,c,h;if(E){let $=E.getBoundingClientRect();o=b==="x"?t.left-$.left+E.scrollLeft:t.top-$.top+E.scrollTop,c=b==="x"?t.width:t.height,h=Y()}else o=b==="x"?t.left:t.top,c=b==="x"?t.width:t.height,h=Y();let _=ke({top:o,height:c},h,Oe(),Le,Ie);N=_.tStart,R=_.tEnd,U&&process.env.NODE_ENV!=="production"&&(be?.remove(),be=at(N,R,b))}function je(t,o){if(e.style.setProperty("--scroll-draw-progress",String(t)),q){let c=o==="reverse"?1-t:t;e.style.clipPath=j(c);return}x.forEach((c,h)=>{c.style.strokeDashoffset=o==="reverse"?`${w[h]*t}`:`${w[h]*(1-t)}`,u&&(c.style.opacity=o==="reverse"?`${1-t}`:`${t}`),O&&S?c.style.stroke=Te(O,S,t):S&&(c.style.stroke=S),A!==null&&M!==null?c.style.strokeWidth=`${A+(M-A)*t}`:M!==null&&(c.style.strokeWidth=`${M}`),k!==null&&T!==null?c.style.fillOpacity=`${k+(T-k)*t}`:T!==null&&(c.style.fillOpacity=`${T}`),C&&c.tagName.toLowerCase()==="path"&&F[h]&&c.setAttribute("d",Be(F[h],C,t))})}function Ne(){if(e.style.setProperty("--scroll-draw-progress","0"),q){e.style.clipPath=j(0);return}x.forEach((t,o)=>{t.style.strokeDasharray=`${w[o]}`,t.style.strokeDashoffset=l==="reverse"?"0":`${w[o]}`,u?t.style.opacity=l==="reverse"?"1":"0":t.style.opacity="",O&&(t.style.stroke=O),A!==null&&(t.style.strokeWidth=`${A}`),k!==null&&(t.style.fillOpacity=`${k}`),C&&t.tagName.toLowerCase()==="path"&&F[o]&&t.setAttribute("d",F[o])})}if(x.forEach(t=>{it(t);let o=Me(t);w.push(o),t.tagName.toLowerCase()==="path"?F.push(t.getAttribute("d")??""):F.push(""),r?(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=l==="reverse"?`${o}`:"0",u&&(t.style.opacity="1"),S&&(t.style.stroke=S),M!==null&&(t.style.strokeWidth=`${M}`),T!==null&&(t.style.fillOpacity=`${T}`),C&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",C)):(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=l==="reverse"?"0":`${o}`,u?t.style.opacity=l==="reverse"?"1":"0":t.style.opacity="",O&&(t.style.stroke=O),A!==null&&(t.style.strokeWidth=`${A}`),k!==null&&(t.style.fillOpacity=`${k}`))}),q){if(r)return e.style.clipPath=j(1),K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=j(0)}else if(r)return K?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Je(){return!(Ue===!1||!ot()||!x.length||typeof f!="string"||!(f in ze)||q||b!=="y"||E||i!==1||I!==0||y||ee||re!==!1||C||te||J||de>0||ge||he||K||H!=null||V!=null||G!=null||(d.start??"top bottom").trim()!=="top bottom"||(d.end??"bottom top").trim()!=="bottom top")}function Ke(){let t=`svg-scroll-draw-${++st}`,o=l==="reverse"?"0":"var(--ssd-len)",c=l==="reverse"?"var(--ssd-len)":"0",h=`stroke-dashoffset:${o};`,_=`stroke-dashoffset:${c};`;u&&(h+=`opacity:${l==="reverse"?1:0};`,_+=`opacity:${l==="reverse"?0:1};`);let $=document.createElement("style");$.setAttribute("data-svg-scroll-draw",""),$.textContent=`@keyframes ${t}{from{${h}}to{${_}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${ze[f]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild($);function a(m,P){m.style.setProperty("--ssd-len",String(w[P])),m.style.strokeDasharray=`${w[P]}`,m.style.strokeDashoffset="",m.style.opacity="",m.style.animationPlayState="",m.classList.add(t)}x.forEach(a);let p=!1,v=-1;function g(){if(v>=0)return v;let m=e.getBoundingClientRect(),{tStart:P,tEnd:Z}=ke({top:m.top,height:m.height},Y(),Oe(),Le,Ie);return ne(X(Y(),P,Z,i))}return{destroy(){x.forEach(m=>{m.classList.remove(t),m.style.removeProperty("--ssd-len"),m.style.animationPlayState=""}),$.remove()},replay(){p=!1,v=-1,x.forEach(a)},pause(){p=!0,x.forEach(m=>{m.style.animationPlayState="paused"})},resume(){p&&(p=!1,x.forEach(m=>{m.style.animationPlayState="running"}))},seek(m){let P=Math.min(1,Math.max(0,m));v=P,p=!0,x.forEach((Z,Re)=>{Z.classList.remove(t),Z.style.strokeDashoffset=l==="reverse"?`${w[Re]*P}`:`${w[Re]*(1-P)}`,u&&(Z.style.opacity=l==="reverse"?`${1-P}`:`${P}`)})},getProgress(){return g()}}}if(Je())return Ke();Fe();function ce(){if(!se||B)return;let t=performance.now(),o=Y(),c=i;if(re!==!1){let a=t-Ce,p=a>0?Math.abs(o-(ue<0?o:ue))/a:0;c=i*Math.max(.2,1+p*(typeof re=="number"?re:1)*.04)}ue=o,Ce=t;let h=ee?oe===-1||o>=oe?"forward":"reverse":l;oe=o;let _=R-N,$=!0;if(q){let a=ne(X(o,N,R,c));y&&!ee&&(D=Math.max(D,a),a=D),ie=a,e.style.setProperty("--scroll-draw-progress",String(a));let p=h==="reverse"?1-a:a;e.style.clipPath=j(p),ge?.(a),!z&&X(o,N,R,c)>0&&(z=!0,he?.()),a>=1&&!L?(L=!0,K?.(),Q<(J==="infinite"?1/0:J??0)&&(Q++,ae=setTimeout(()=>{D=-1,z=!1,L=!1,e.style.clipPath=j(0)},Pe))):a<1&&!y&&(L=!1),W=requestAnimationFrame(ce);return}if(x.forEach((a,p)=>{let v=p*I*_,g=ne(X(o,N+v,R+v,c));y&&!ee&&(D=Math.max(D,g),g=D),ie=g,a.style.strokeDashoffset=h==="reverse"?`${w[p]*g}`:`${w[p]*(1-g)}`,u&&(a.style.opacity=h==="reverse"?`${1-g}`:`${g}`),O&&S?a.style.stroke=Te(O,S,g):S&&(a.style.stroke=S),A!==null&&M!==null?a.style.strokeWidth=`${A+(M-A)*g}`:M!==null&&(a.style.strokeWidth=`${M}`),k!==null&&T!==null?a.style.fillOpacity=`${k+(T-k)*g}`:T!==null&&(a.style.fillOpacity=`${T}`),C&&a.tagName.toLowerCase()==="path"&&F[p]&&a.setAttribute("d",Be(F[p],C,g)),p===0&&(ge?.(g),e.style.setProperty("--scroll-draw-progress",String(g))),g<1&&($=!1)}),te){let a=ne(X(o,N,R,c));for(let p in te){let v=parseFloat(p);a>=v&&!le.has(v)&&(le.add(v),te[p]?.())}}!z&&X(o,N,R,c)>0&&(z=!0,he?.()),$&&!L?(L=!0,K?.(),Q<(J==="infinite"?1/0:J??0)&&(Q++,ae=setTimeout(()=>{D=-1,z=!1,L=!1,le.clear(),Ne()},Pe))):!$&&!y&&(L=!1),W=requestAnimationFrame(ce)}let we=new IntersectionObserver(t=>{t.forEach(o=>{se=o.isIntersecting,se&&!B?W=requestAnimationFrame(ce):cancelAnimationFrame(W)})},{root:E??null,threshold:_e,rootMargin:Xe}),ve;function fe(){clearTimeout(ve),ve=setTimeout(()=>{x.forEach((t,o)=>{w[o]=Me(t),t.style.strokeDasharray=`${w[o]}`}),Fe()},150)}return window.addEventListener("resize",fe),window.addEventListener("orientationchange",fe),de>0?setTimeout(()=>we.observe(e),de):we.observe(e),{destroy(){cancelAnimationFrame(W),clearTimeout(ae),we.disconnect(),window.removeEventListener("resize",fe),window.removeEventListener("orientationchange",fe),clearTimeout(ve),be?.remove()},replay(){D=-1,oe=-1,ue=-1,z=!1,L=!1,Q=0,B=!1,le.clear(),clearTimeout(ae),Ne()},pause(){B=!0,cancelAnimationFrame(W)},resume(){B&&(B=!1,se&&(W=requestAnimationFrame(ce)))},seek(t){let o=Math.min(1,Math.max(0,t));ie=o,D=o,B=!0,cancelAnimationFrame(W),je(o,l)},getProgress(){return ie}}}function lt(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let s=typeof e=="string"?document.querySelector(e):e;return s?pe(s,n):(console.warn("[svg-scroll-draw] Container not found:",e),r)}var De=class extends HTMLElement{constructor(){super(...arguments);this.instance=null}connectedCallback(){let r={},s=this.getAttribute("speed"),i=this.getAttribute("easing"),u=this.getAttribute("stagger"),f=this.getAttribute("direction"),d=this.getAttribute("selector");s&&(r.speed=parseFloat(s)),i&&(r.easing=i),u&&(r.stagger=parseFloat(u)),f&&(r.direction=f),d&&(r.selector=d),this.hasAttribute("fade")&&(r.fade=this.getAttribute("fade")!=="false"),this.instance=pe(this,r)}disconnectedCallback(){this.instance?.destroy(),this.instance=null}};typeof customElements<"u"&&!customElements.get("scroll-draw")&&customElements.define("scroll-draw",De);return rt(ut);})();
1
+ "use strict";var SvgScrollDraw=(()=>{var Pe=Object.defineProperty;var it=Object.getOwnPropertyDescriptor;var at=Object.getOwnPropertyNames;var lt=Object.prototype.hasOwnProperty;var ct=(e,r)=>{for(var n in r)Pe(e,n,{get:r[n],enumerable:!0})},ut=(e,r,n,s)=>{if(r&&typeof r=="object"||typeof r=="function")for(let i of at(r))!lt.call(e,i)&&i!==n&&Pe(e,i,{get:()=>r[i],enumerable:!(s=it(r,i))||s.enumerable});return e};var ft=e=>ut(Pe({},"__esModule",{value:!0}),e);var Et={};ct(Et,{Cinematic:()=>ke,createBounce:()=>Ie,createElastic:()=>Ce,createSpring:()=>Ye,scrollDraw:()=>vt});function Ye({tension:e=2.5,friction:r=2.2}={}){return n=>1-Math.cos(n*Math.PI*e)*Math.pow(1-n,r)}function Ie({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),s=Math.max(.01,Math.min(.99,r)),i=Math.sqrt(s),f=0,h=[];for(let a=0;a<n;a++){let v=Math.pow(i,a);h.push(v),f+=v}let w=[0],P=0;for(let a=0;a<n;a++)P+=h[a]/f,w.push(P);return a=>{if(a<=0)return 0;if(a>=1)return 1;for(let v=0;v<n;v++)if(a<=w[v+1]){let X=(a-w[v])/(w[v+1]-w[v]);if(v===0)return X*(2-X);let T=1-Math.pow(s,v);return T+(1-T)*(2*X-1)*(2*X-1)}return 1}}function Ce({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),s=Math.max(.1,r),i=n<=1?s/4:s/(2*Math.PI)*Math.asin(1/n);return f=>f<=0?0:f>=1?1:n*Math.pow(2,-10*f)*Math.sin((f-i)*(2*Math.PI)/s)+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:Ie(),elastic:Ce()};function Fe(e="top bottom"){let r=e.trim();if(/^\d+(\.\d+)?%$/.test(r))return{element:"top",viewport:r};let[n="top",s="bottom"]=r.split(/\s+/).filter(Boolean);return{element:n,viewport:s}}function je(e,r,n,s){switch(s){case"top":return e+n;case"center":return e+n+r/2;case"bottom":return e+n+r;default:return e+n}}function Xe(e,r){if(/^\d+(\.\d+)?%$/.test(e))return r*(parseFloat(e)/100);switch(e){case"top":return 0;case"center":return r/2;case"bottom":return r;default:return r}}function Ee(e){let r=e.tagName.toLowerCase();if(r==="rect"){let n=parseFloat(e.getAttribute("width")??"0"),s=parseFloat(e.getAttribute("height")??"0");return 2*(n+s)}if(r==="circle"){let n=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*n}return e.getTotalLength()}function mt(e,r,n){return Math.min(n,Math.max(r,e))}function le(e,r,n,s){return n===r?0:mt((e-r)/(n-r)*s,0,1)}function Oe(e,r,n,s,i){let f=je(e.top,e.height,r,s.element)-Xe(s.viewport,n),h=je(e.top,e.height,r,i.element)-Xe(i.viewport,n);return{tStart:f,tEnd:h}}function Ue(e){let r=/^#([a-f\d])([a-f\d])([a-f\d])$/i.exec(e);if(r)return[parseInt(r[1]+r[1],16),parseInt(r[2]+r[2],16),parseInt(r[3]+r[3],16)];let n=/^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(n)return[parseInt(n[1],16),parseInt(n[2],16),parseInt(n[3],16)];let s=/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i.exec(e);return s?[parseInt(s[1]),parseInt(s[2]),parseInt(s[3])]:null}function Se(e,r,n){let s=Ue(e),i=Ue(r);return!s||!i?e:`rgb(${Math.round(s[0]+(i[0]-s[0])*n)},${Math.round(s[1]+(i[1]-s[1])*n)},${Math.round(s[2]+(i[2]-s[2])*n)})`}function Je(e,r){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,r)}var Ke={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},pt=0;function dt(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function yt(e){let r=e.getAttribute("stroke"),n=e.getAttribute("fill");!r||r==="none"?Je("Element has no stroke \u2014 path will not be visible.",e):n&&n!=="none"&&n!=="transparent"&&Je("Element has a fill \u2014 it may obscure the stroke animation.",e)}function ht(e,r,n){let s=document.createElement("div");s.setAttribute("data-svg-scroll-draw-debug",""),s.style.cssText="position:fixed;pointer-events:none;z-index:9999;font-family:monospace;font-size:11px;top:0;left:0;right:0;bottom:0;";function i(){let f=n==="x"?window.scrollX:window.scrollY,h=e-f,w=r-f,P=n==="x";s.innerHTML=`
2
+ <div style="position:absolute;${P?`left:${h}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${h}px;left:0;right:0;border-top:2px dashed #22c55e;`}padding:2px 6px;color:#22c55e;background:rgba(0,0,0,.6)">\u25B6 start</div>
3
+ <div style="position:absolute;${P?`left:${w}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${w}px;left:0;right:0;border-top:2px dashed #ef4444;`}padding:2px 6px;color:#ef4444;background:rgba(0,0,0,.6)">\u25A0 end</div>`}return document.body.appendChild(s),window.addEventListener("scroll",i,{passive:!0}),i(),s}function He(e,r,n){let s=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),i=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,f=>{let h=parseFloat(f),w=s[i++]??h;return String(+(h+(w-h)*n).toFixed(4))})}function Ae(e,r={}){if(typeof window>"u")return{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let n=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:s="path, polyline, line, polygon, rect, circle",speed:i=1,fade:f=!1,easing:h="linear",trigger:w={},stagger:P=0,direction:a="forward",once:v=!1,debug:X=!1,axis:T="y",scrollContainer:ce,autoReverse:re=!1,delay:x=0,strokeColor:y,strokeWidth:c,fillOpacity:E,waypoints:g,velocityScale:Y=!1,threshold:qe=0,rootMargin:We="0px",repeat:ne=0,repeatDelay:$e=0,morphTo:G,clip:Me,autoplay:Ze=!1,duration:et=1e3,native:tt=!0,onProgress:me,onStart:de,onComplete:ue}=r,J=Me===!0?"left":typeof Me=="string"?Me:!1,se=typeof h=="function"?h:te[h]??te.linear,Ve=Fe(w.start??"top bottom"),Ge=Fe(w.end??"bottom top"),N=typeof ce=="string"?document.querySelector(ce):ce??null,z=Array.isArray(y)?y[0]:null,I=Array.isArray(y)?y[1]:typeof y=="string"?y:null,R=Array.isArray(c)?c[0]:null,C=Array.isArray(c)?c[1]:typeof c=="number"?c:null,q=Array.isArray(E)?E[0]:null,F=Array.isArray(E)?E[1]:typeof E=="number"?E:null;function oe(t){let o=t*100;switch(J){case"right":return`inset(0 0 0 ${100-o}%)`;case"top":return`inset(0 0 ${100-o}% 0)`;case"bottom":return`inset(${100-o}% 0 0 0)`;case"center":return`circle(${t*150}% at 50% 50%)`;default:return`inset(0 ${100-o}% 0 0)`}}let D=J?[]:Array.from(e.querySelectorAll(s)),$=[],B=[],K=0,Q=0,L=!1,V=!1,M=0,ye=!1,_=-1,he=-1,O=!1,ie=0,U=0,Z,Te=null,ee=new Set,ge=-1,ze=performance.now();function pe(){return N?T==="x"?N.scrollLeft:N.scrollTop:T==="x"?window.scrollX:window.scrollY}function Be(){return N?T==="x"?N.clientWidth:N.clientHeight:T==="x"?window.innerWidth:window.innerHeight}function _e(){let t=e.getBoundingClientRect(),o,m,A;if(N){let H=N.getBoundingClientRect();o=T==="x"?t.left-H.left+N.scrollLeft:t.top-H.top+N.scrollTop,m=T==="x"?t.width:t.height,A=pe()}else o=T==="x"?t.left:t.top,m=T==="x"?t.width:t.height,A=pe();let W=Oe({top:o,height:m},A,Be(),Ve,Ge);K=W.tStart,Q=W.tEnd,X&&process.env.NODE_ENV!=="production"&&(Te?.remove(),Te=ht(K,Q,T))}function rt(t,o){if(e.style.setProperty("--scroll-draw-progress",String(t)),J){let m=o==="reverse"?1-t:t;e.style.clipPath=oe(m);return}D.forEach((m,A)=>{m.style.strokeDashoffset=o==="reverse"?`${$[A]*t}`:`${$[A]*(1-t)}`,f&&(m.style.opacity=o==="reverse"?`${1-t}`:`${t}`),z&&I?m.style.stroke=Se(z,I,t):I&&(m.style.stroke=I),R!==null&&C!==null?m.style.strokeWidth=`${R+(C-R)*t}`:C!==null&&(m.style.strokeWidth=`${C}`),q!==null&&F!==null?m.style.fillOpacity=`${q+(F-q)*t}`:F!==null&&(m.style.fillOpacity=`${F}`),G&&m.tagName.toLowerCase()==="path"&&B[A]&&m.setAttribute("d",He(B[A],G,t))})}function be(){if(e.style.setProperty("--scroll-draw-progress","0"),J){e.style.clipPath=oe(0);return}D.forEach((t,o)=>{t.style.strokeDasharray=`${$[o]}`,t.style.strokeDashoffset=a==="reverse"?"0":`${$[o]}`,f?t.style.opacity=a==="reverse"?"1":"0":t.style.opacity="",z&&(t.style.stroke=z),R!==null&&(t.style.strokeWidth=`${R}`),q!==null&&(t.style.fillOpacity=`${q}`),G&&t.tagName.toLowerCase()==="path"&&B[o]&&t.setAttribute("d",B[o])})}if(D.forEach(t=>{yt(t);let o=Ee(t);$.push(o),t.tagName.toLowerCase()==="path"?B.push(t.getAttribute("d")??""):B.push(""),n?(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=a==="reverse"?`${o}`:"0",f&&(t.style.opacity="1"),I&&(t.style.stroke=I),C!==null&&(t.style.strokeWidth=`${C}`),F!==null&&(t.style.fillOpacity=`${F}`),G&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",G)):(t.style.strokeDasharray=`${o}`,t.style.strokeDashoffset=a==="reverse"?"0":`${o}`,f?t.style.opacity=a==="reverse"?"1":"0":t.style.opacity="",z&&(t.style.stroke=z),R!==null&&(t.style.strokeWidth=`${R}`),q!==null&&(t.style.fillOpacity=`${q}`))}),J){if(n)return e.style.clipPath=oe(1),ue?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=oe(0)}else if(n)return ue?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function nt(){return!(tt===!1||!dt()||!D.length||typeof h!="string"||!(h in Ke)||J||T!=="y"||N||i!==1||P!==0||v||re||Y!==!1||G||g||ne||x>0||me||de||ue||y!=null||c!=null||E!=null||(w.start??"top bottom").trim()!=="top bottom"||(w.end??"bottom top").trim()!=="bottom top")}function st(){let t=`svg-scroll-draw-${++pt}`,o=a==="reverse"?"0":"var(--ssd-len)",m=a==="reverse"?"var(--ssd-len)":"0",A=`stroke-dashoffset:${o};`,W=`stroke-dashoffset:${m};`;f&&(A+=`opacity:${a==="reverse"?1:0};`,W+=`opacity:${a==="reverse"?0:1};`);let H=document.createElement("style");H.setAttribute("data-svg-scroll-draw",""),H.textContent=`@keyframes ${t}{from{${A}}to{${W}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${Ke[h]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(H);function u(l,d){l.style.setProperty("--ssd-len",String($[d])),l.style.strokeDasharray=`${$[d]}`,l.style.strokeDashoffset="",l.style.opacity="",l.style.animationPlayState="",l.classList.add(t)}D.forEach(u);let b=!1,k=-1;function p(){if(k>=0)return k;let l=e.getBoundingClientRect(),{tStart:d,tEnd:S}=Oe({top:l.top,height:l.height},pe(),Be(),Ve,Ge);return se(le(pe(),d,S,i))}return{destroy(){D.forEach(l=>{l.classList.remove(t),l.style.removeProperty("--ssd-len"),l.style.animationPlayState=""}),H.remove()},replay(){b=!1,k=-1,D.forEach(u)},pause(){b=!0,D.forEach(l=>{l.style.animationPlayState="paused"})},resume(){b&&(b=!1,D.forEach(l=>{l.style.animationPlayState="running"}))},seek(l){let d=Math.min(1,Math.max(0,l));k=d,b=!0,D.forEach((S,ae)=>{S.classList.remove(t),S.style.strokeDashoffset=a==="reverse"?`${$[ae]*d}`:`${$[ae]*(1-d)}`,f&&(S.style.opacity=a==="reverse"?`${1-d}`:`${d}`)})},getProgress(){return p()}}}if(nt())return st();function ot(){let t=Math.max(1,et),o=0,m=0;function A(p){let l=!0;if(J){let d=Math.min(1,Math.max(0,p/t)),S=se(d);ie=S,e.style.setProperty("--scroll-draw-progress",String(S)),e.style.clipPath=oe(a==="reverse"?1-S:S),me?.(S),d<1&&(l=!1)}else D.forEach((d,S)=>{let ae=S*P*t,fe=Math.min(1,Math.max(0,(p-ae)/t)),j=se(fe);d.style.strokeDashoffset=a==="reverse"?`${$[S]*j}`:`${$[S]*(1-j)}`,f&&(d.style.opacity=a==="reverse"?`${1-j}`:`${j}`),z&&I?d.style.stroke=Se(z,I,j):I&&(d.style.stroke=I),R!==null&&C!==null?d.style.strokeWidth=`${R+(C-R)*j}`:C!==null&&(d.style.strokeWidth=`${C}`),q!==null&&F!==null?d.style.fillOpacity=`${q+(F-q)*j}`:F!==null&&(d.style.fillOpacity=`${F}`),G&&d.tagName.toLowerCase()==="path"&&B[S]&&d.setAttribute("d",He(B[S],G,j)),S===0&&(me?.(j),e.style.setProperty("--scroll-draw-progress",String(j))),fe<1&&(l=!1)});if(g){let d=Math.min(1,Math.max(0,p/t)),S=se(d);for(let ae in g){let fe=parseFloat(ae);S>=fe&&!ee.has(fe)&&(ee.add(fe),g[ae]?.())}}return l}function W(p){if(O)return;let l=p-o;V||(V=!0,de?.());let d=A(l);if(d&&!L){L=!0,A(t*(1+Math.max(0,D.length-1)*P)),ue?.(),U<(ne==="infinite"?1/0:ne??0)&&(U++,Z=setTimeout(()=>{o=performance.now(),V=!1,L=!1,ee.clear(),be(),M=requestAnimationFrame(W)},$e));return}d||(M=requestAnimationFrame(W))}function H(){cancelAnimationFrame(M),clearTimeout(Z),o=performance.now(),m=0,O=!1,V=!1,L=!1,U=0,ee.clear(),be(),M=requestAnimationFrame(W)}let u=new IntersectionObserver(p=>{p.forEach(l=>{l.isIntersecting&&!(v&&L)?H():!l.isIntersecting&&!v&&!L&&(cancelAnimationFrame(M),clearTimeout(Z),o=null)})},{root:N??null,threshold:qe,rootMargin:We}),b;function k(){clearTimeout(b),b=setTimeout(()=>{D.forEach((p,l)=>{$[l]=Ee(p),p.style.strokeDasharray=`${$[l]}`})},150)}return window.addEventListener("resize",k),window.addEventListener("orientationchange",k),x>0?setTimeout(()=>u.observe(e),x):u.observe(e),{destroy(){cancelAnimationFrame(M),clearTimeout(Z),u.disconnect(),window.removeEventListener("resize",k),window.removeEventListener("orientationchange",k),clearTimeout(b)},replay(){U=0,H()},pause(){O||(O=!0,m=performance.now()-o,cancelAnimationFrame(M))},resume(){O&&(O=!1,o=performance.now()-m,M=requestAnimationFrame(W))},seek(p){let l=Math.min(1,Math.max(0,p));ie=l,O=!0,m=l*t,o=performance.now()-m,cancelAnimationFrame(M),A(m)},getProgress(){return ie}}}if(Ze)return ot();_e();function we(){if(!ye||O)return;let t=performance.now(),o=pe(),m=i;if(Y!==!1){let u=t-ze,b=u>0?Math.abs(o-(ge<0?o:ge))/u:0;m=i*Math.max(.2,1+b*(typeof Y=="number"?Y:1)*.04)}ge=o,ze=t;let A=re?he===-1||o>=he?"forward":"reverse":a;he=o;let W=Q-K,H=!0;if(J){let u=se(le(o,K,Q,m));v&&!re&&(_=Math.max(_,u),u=_),ie=u,e.style.setProperty("--scroll-draw-progress",String(u));let b=A==="reverse"?1-u:u;e.style.clipPath=oe(b),me?.(u),!V&&le(o,K,Q,m)>0&&(V=!0,de?.()),u>=1&&!L?(L=!0,ue?.(),U<(ne==="infinite"?1/0:ne??0)&&(U++,Z=setTimeout(()=>{_=-1,V=!1,L=!1,e.style.clipPath=oe(0)},$e))):u<1&&!v&&(L=!1),M=requestAnimationFrame(we);return}if(D.forEach((u,b)=>{let k=b*P*W,p=se(le(o,K+k,Q+k,m));v&&!re&&(_=Math.max(_,p),p=_),ie=p,u.style.strokeDashoffset=A==="reverse"?`${$[b]*p}`:`${$[b]*(1-p)}`,f&&(u.style.opacity=A==="reverse"?`${1-p}`:`${p}`),z&&I?u.style.stroke=Se(z,I,p):I&&(u.style.stroke=I),R!==null&&C!==null?u.style.strokeWidth=`${R+(C-R)*p}`:C!==null&&(u.style.strokeWidth=`${C}`),q!==null&&F!==null?u.style.fillOpacity=`${q+(F-q)*p}`:F!==null&&(u.style.fillOpacity=`${F}`),G&&u.tagName.toLowerCase()==="path"&&B[b]&&u.setAttribute("d",He(B[b],G,p)),b===0&&(me?.(p),e.style.setProperty("--scroll-draw-progress",String(p))),p<1&&(H=!1)}),g){let u=se(le(o,K,Q,m));for(let b in g){let k=parseFloat(b);u>=k&&!ee.has(k)&&(ee.add(k),g[b]?.())}}!V&&le(o,K,Q,m)>0&&(V=!0,de?.()),H&&!L?(L=!0,ue?.(),U<(ne==="infinite"?1/0:ne??0)&&(U++,Z=setTimeout(()=>{_=-1,V=!1,L=!1,ee.clear(),be()},$e))):!H&&!v&&(L=!1),M=requestAnimationFrame(we)}let De=new IntersectionObserver(t=>{t.forEach(o=>{ye=o.isIntersecting,ye&&!O?M=requestAnimationFrame(we):cancelAnimationFrame(M)})},{root:N??null,threshold:qe,rootMargin:We}),Le;function ve(){clearTimeout(Le),Le=setTimeout(()=>{D.forEach((t,o)=>{$[o]=Ee(t),t.style.strokeDasharray=`${$[o]}`}),_e()},150)}return window.addEventListener("resize",ve),window.addEventListener("orientationchange",ve),x>0?setTimeout(()=>De.observe(e),x):De.observe(e),{destroy(){cancelAnimationFrame(M),clearTimeout(Z),De.disconnect(),window.removeEventListener("resize",ve),window.removeEventListener("orientationchange",ve),clearTimeout(Le),Te?.remove()},replay(){_=-1,he=-1,ge=-1,V=!1,L=!1,U=0,O=!1,ee.clear(),clearTimeout(Z),be()},pause(){O=!0,cancelAnimationFrame(M)},resume(){O&&(O=!1,ye&&(M=requestAnimationFrame(we)))},seek(t){let o=Math.min(1,Math.max(0,t));ie=o,_=o,O=!0,cancelAnimationFrame(M),rt(o,a)},getProgress(){return ie}}}var Qe="http://www.w3.org/2000/svg",gt="cinematic-photo",Ne=e=>e<0?0:e>1?1:e;function xe(e){let r=parseFloat(e);return Number.isFinite(r)?Ne(r/100):0}function bt(e){return te[e]??te.linear}var wt={destroy:()=>{},getProgress:()=>0},ke=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 n=this.mount;if(typeof window>"u"||!n)return wt;n.style.position="relative",n.style.height=r.totalHeight,n.style.display="block";let s=document.createElement("div");s.setAttribute("data-cinematic-stage",""),s.style.cssText="position:sticky;top:0;height:100vh;width:100%;overflow:hidden;display:block;",n.appendChild(s);let i=[];for(let x of r.scenes){if(x.background){let c=document.createElement("img");c.id=gt,c.src=x.background,c.alt="",c.style.cssText="position:absolute;inset:0;width:100%;height:100%;object-fit:contain;opacity:0;pointer-events:none;",s.appendChild(c)}let y=x.animations.filter(c=>c.type==="draw");if(y.length){let c=document.createElementNS(Qe,"svg");c.setAttribute("viewBox",`0 0 ${r.canvas.width} ${r.canvas.height}`),c.setAttribute("preserveAspectRatio","xMidYMid meet"),c.style.cssText="position:absolute;inset:0;width:100%;height:100%;overflow:visible;",s.appendChild(c);for(let E of y){let g=document.createElementNS(Qe,"path");g.id=E.target.replace(/^#/,""),g.setAttribute("d",E.d),g.setAttribute("fill","none"),g.setAttribute("stroke",E.stroke),g.setAttribute("stroke-width",String(E.strokeWidth)),g.setAttribute("stroke-linecap","round"),g.setAttribute("stroke-linejoin","round");let Y=E.length||g.getTotalLength?.()||0;g.style.strokeDasharray=String(Y),g.style.strokeDashoffset=String(Y),c.appendChild(g),i.push({kind:"draw",el:g,start:xe(E.start),end:xe(E.end),ease:bt(E.easing),length:Y})}}for(let c of x.animations){if(c.type!=="fade")continue;let E=s.querySelector(c.target)??document.querySelector(c.target);E&&(E.style.opacity=String(c.from),i.push({kind:"fade",el:E,start:xe(c.start),end:xe(c.end),ease:te["ease-in-out"]??te.linear,from:c.from,to:c.to}))}}let f=0,h=()=>{let x=n.offsetHeight-window.innerHeight;return x<=0?n.getBoundingClientRect().top<=0?1:0:Ne(-n.getBoundingClientRect().top/x)},w=x=>{for(let y of i){let c=y.end-y.start,E=c<=0?x>=y.end?1:0:Ne((x-y.start)/c),g=y.ease(E);y.kind==="draw"?y.el.style.strokeDashoffset=String(y.length*(1-g)):y.el.style.opacity=String(y.from+(y.to-y.from)*g)}};if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return w(1),{destroy:()=>{},getProgress:()=>1};let P=0,a=!1,v=!1,X=()=>{f=h(),w(f),a&&(P=requestAnimationFrame(X))},T=()=>{a||(a=!0,P=requestAnimationFrame(X))},ce=()=>{a=!1,cancelAnimationFrame(P)},re=new IntersectionObserver(x=>{for(let y of x)v=y.isIntersecting,v?T():ce()},{threshold:0});return re.observe(s),f=h(),w(f),{destroy(){ce(),re.disconnect()},getProgress:()=>f}}};function vt(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let s=typeof e=="string"?document.querySelector(e):e;return s?Ae(s,r):(console.warn("[svg-scroll-draw] Container not found:",e),n)}var Re=class extends HTMLElement{constructor(){super(...arguments);this.instance=null}connectedCallback(){let n={},s=this.getAttribute("speed"),i=this.getAttribute("easing"),f=this.getAttribute("stagger"),h=this.getAttribute("direction"),w=this.getAttribute("selector");s&&(n.speed=parseFloat(s)),i&&(n.easing=i),f&&(n.stagger=parseFloat(f)),h&&(n.direction=h),w&&(n.selector=w),this.hasAttribute("fade")&&(n.fade=this.getAttribute("fade")!=="false"),this.instance=Ae(this,n)}disconnectedCallback(){this.instance?.destroy(),this.instance=null}};typeof customElements<"u"&&!customElements.get("scroll-draw")&&customElements.define("scroll-draw",Re);return ft(Et);})();
@@ -0,0 +1,2 @@
1
+ 'use strict';function I({bounces:e=3,decay:o=.5}={}){let s=Math.max(1,Math.round(e)),a=Math.max(.01,Math.min(.99,o)),d=Math.sqrt(a),m=0,h=[];for(let n=0;n<s;n++){let u=Math.pow(d,n);h.push(u),m+=u;}let l=[0],b=0;for(let n=0;n<s;n++)b+=h[n]/m,l.push(b);return n=>{if(n<=0)return 0;if(n>=1)return 1;for(let u=0;u<s;u++)if(n<=l[u+1]){let f=(n-l[u])/(l[u+1]-l[u]);if(u===0)return f*(2-f);let w=1-Math.pow(a,u);return w+(1-w)*(2*f-1)*(2*f-1)}return 1}}function k({amplitude:e=1,period:o=.4}={}){let s=Math.max(1,e),a=Math.max(.1,o),d=s<=1?a/4:a/(2*Math.PI)*Math.asin(1/s);return m=>m<=0?0:m>=1?1:s*Math.pow(2,-10*m)*Math.sin((m-d)*(2*Math.PI)/a)+1}var g={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:I(),elastic:k()};var A="http://www.w3.org/2000/svg",T="cinematic-photo",S=e=>e<0?0:e>1?1:e;function y(e){let o=parseFloat(e);return Number.isFinite(o)?S(o/100):0}function P(e){return g[e]??g.linear}var C={destroy:()=>{},getProgress:()=>0},E=class{constructor(o){if(typeof document>"u"){this.mount=null;return}this.mount=typeof o.wrapper=="string"?document.querySelector(o.wrapper):o.wrapper,!this.mount&&process.env.NODE_ENV!=="production"&&console.warn("[svg-scroll-draw] Cinematic: wrapper not found:",o.wrapper);}loadStory(o){let s=this.mount;if(typeof window>"u"||!s)return C;s.style.position="relative",s.style.height=o.totalHeight,s.style.display="block";let a=document.createElement("div");a.setAttribute("data-cinematic-stage",""),a.style.cssText="position:sticky;top:0;height:100vh;width:100%;overflow:hidden;display:block;",s.appendChild(a);let d=[];for(let p of o.scenes){if(p.background){let t=document.createElement("img");t.id=T,t.src=p.background,t.alt="",t.style.cssText="position:absolute;inset:0;width:100%;height:100%;object-fit:contain;opacity:0;pointer-events:none;",a.appendChild(t);}let r=p.animations.filter(t=>t.type==="draw");if(r.length){let t=document.createElementNS(A,"svg");t.setAttribute("viewBox",`0 0 ${o.canvas.width} ${o.canvas.height}`),t.setAttribute("preserveAspectRatio","xMidYMid meet"),t.style.cssText="position:absolute;inset:0;width:100%;height:100%;overflow:visible;",a.appendChild(t);for(let c of r){let i=document.createElementNS(A,"path");i.id=c.target.replace(/^#/,""),i.setAttribute("d",c.d),i.setAttribute("fill","none"),i.setAttribute("stroke",c.stroke),i.setAttribute("stroke-width",String(c.strokeWidth)),i.setAttribute("stroke-linecap","round"),i.setAttribute("stroke-linejoin","round");let M=c.length||i.getTotalLength?.()||0;i.style.strokeDasharray=String(M),i.style.strokeDashoffset=String(M),t.appendChild(i),d.push({kind:"draw",el:i,start:y(c.start),end:y(c.end),ease:P(c.easing),length:M});}}for(let t of p.animations){if(t.type!=="fade")continue;let c=a.querySelector(t.target)??document.querySelector(t.target);c&&(c.style.opacity=String(t.from),d.push({kind:"fade",el:c,start:y(t.start),end:y(t.end),ease:g["ease-in-out"]??g.linear,from:t.from,to:t.to}));}}let m=0,h=()=>{let p=s.offsetHeight-window.innerHeight;return p<=0?s.getBoundingClientRect().top<=0?1:0:S(-s.getBoundingClientRect().top/p)},l=p=>{for(let r of d){let t=r.end-r.start,c=t<=0?p>=r.end?1:0:S((p-r.start)/t),i=r.ease(c);r.kind==="draw"?r.el.style.strokeDashoffset=String(r.length*(1-i)):r.el.style.opacity=String(r.from+(r.to-r.from)*i);}};if(window.matchMedia("(prefers-reduced-motion: reduce)").matches)return l(1),{destroy:()=>{},getProgress:()=>1};let b=0,n=false,u=false,f=()=>{m=h(),l(m),n&&(b=requestAnimationFrame(f));},w=()=>{n||(n=true,b=requestAnimationFrame(f));},x=()=>{n=false,cancelAnimationFrame(b);},v=new IntersectionObserver(p=>{for(let r of p)u=r.isIntersecting,u?w():x();},{threshold:0});return v.observe(a),m=h(),l(m),{destroy(){x(),v.disconnect();},getProgress:()=>m}}};
2
+ exports.Cinematic=E;