svg-scroll-draw 1.2.0 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/angular/index.cjs +3 -3
- package/dist/angular/index.d.mts +19 -0
- package/dist/angular/index.d.ts +19 -0
- package/dist/angular/index.mjs +3 -3
- package/dist/astro/index.cjs +3 -3
- package/dist/astro/index.d.mts +19 -0
- package/dist/astro/index.d.ts +19 -0
- package/dist/astro/index.mjs +3 -3
- package/dist/cdn/svg-scroll-draw.global.js +3 -3
- package/dist/group/index.cjs +3 -3
- package/dist/group/index.d.mts +19 -0
- package/dist/group/index.d.ts +19 -0
- package/dist/group/index.mjs +3 -3
- package/dist/index.cjs +3 -3
- package/dist/index.d.mts +19 -0
- package/dist/index.d.ts +19 -0
- package/dist/index.mjs +3 -3
- package/dist/nuxt/index.cjs +3 -3
- package/dist/nuxt/index.d.mts +19 -0
- package/dist/nuxt/index.d.ts +19 -0
- package/dist/nuxt/index.mjs +3 -3
- package/dist/react/index.cjs +3 -3
- package/dist/react/index.d.mts +19 -0
- package/dist/react/index.d.ts +19 -0
- package/dist/react/index.mjs +3 -3
- package/dist/solid/index.cjs +3 -3
- package/dist/solid/index.d.mts +19 -0
- package/dist/solid/index.d.ts +19 -0
- package/dist/solid/index.mjs +3 -3
- package/dist/svelte/index.cjs +3 -3
- package/dist/svelte/index.d.mts +19 -0
- package/dist/svelte/index.d.ts +19 -0
- package/dist/svelte/index.mjs +3 -3
- package/dist/vue/index.cjs +3 -3
- package/dist/vue/index.d.mts +19 -0
- package/dist/vue/index.d.ts +19 -0
- package/dist/vue/index.mjs +3 -3
- package/dist/web-component/index.cjs +3 -3
- package/dist/web-component/index.mjs +3 -3
- package/package.json +1 -1
package/dist/angular/index.cjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';function
|
|
2
|
-
<div style="position:absolute;${
|
|
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;
|
package/dist/angular/index.d.mts
CHANGED
|
@@ -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
|
package/dist/angular/index.d.ts
CHANGED
|
@@ -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
|
package/dist/angular/index.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
function
|
|
2
|
-
<div style="position:absolute;${
|
|
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};
|
package/dist/astro/index.cjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';function
|
|
2
|
-
<div style="position:absolute;${
|
|
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 Ve({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),o=Math.max(.01,Math.min(.99,r)),d=Math.sqrt(o),m=0,b=[];for(let u=0;u<n;u++){let h=Math.pow(d,u);b.push(h),m+=h;}let x=[0],N=0;for(let u=0;u<n;u++)N+=b[u]/m,x.push(N);return u=>{if(u<=0)return 0;if(u>=1)return 1;for(let h=0;h<n;h++)if(u<=x[h+1]){let se=(u-x[h])/(x[h+1]-x[h]);if(h===0)return se*(2-se);let L=1-Math.pow(o,h);return L+(1-L)*(2*se-1)*(2*se-1)}return 1}}function Ge({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),o=Math.max(.1,r),d=n<=1?o/4:o/(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)/o)+1}var ke={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:Ve(),elastic:Ge()};function De(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 We(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 qe(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 we(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 Ze(e,r,n){return Math.min(n,Math.max(r,e))}function ne(e,r,n,o){return n===r?0:Ze((e-r)/(n-r)*o,0,1)}function Le(e,r,n,o,d){let m=We(e.top,e.height,r,o.element)-qe(o.viewport,n),b=We(e.top,e.height,r,d.element)-qe(d.viewport,n);return {tStart:m,tEnd:b}}function ze(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 ve(e,r,n){let o=ze(e),d=ze(r);return !o||!d?e:`rgb(${Math.round(o[0]+(d[0]-o[0])*n)},${Math.round(o[1]+(d[1]-o[1])*n)},${Math.round(o[2]+(d[2]-o[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 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=n==="x"?window.scrollX:window.scrollY,b=e-m,x=r-m,N=n==="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:${x}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${x}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,r,n){let o=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),d=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,m=>{let b=parseFloat(m),x=o[d++]??b;return String(+(b+(x-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:o="path, polyline, line, polygon, rect, circle",speed:d=1,fade:m=false,easing:b="linear",trigger:x={},stagger:N=0,direction:u="forward",once:h=false,debug:se=false,axis:L="y",scrollContainer:xe,autoReverse:ce=false,delay:ie=0,strokeColor:U,strokeWidth:j,fillOpacity:K,waypoints:Q,velocityScale:fe=false,threshold:Ie=0,rootMargin:Oe="0px",repeat:Y=0,repeatDelay:$e=0,morphTo:R,clip:Se,autoplay:Xe=false,duration:Je=1e3,native:Ue=true,onProgress:le,onStart:me,onComplete:oe}=r,G=Se===true?"left":typeof Se=="string"?Se:false,Z=typeof b=="function"?b:ke[b]??ke.linear,Fe=De(x.start??"top bottom"),Ce=De(x.end??"bottom top"),P=typeof xe=="string"?document.querySelector(xe):xe??null,H=Array.isArray(U)?U[0]:null,M=Array.isArray(U)?U[1]:typeof U=="string"?U:null,I=Array.isArray(j)?j[0]:null,A=Array.isArray(j)?j[1]:typeof j=="number"?j:null,O=Array.isArray(K)?K[0]:null,T=Array.isArray(K)?K[1]:typeof K=="number"?K:null;function ee(t){let s=t*100;switch(G){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 $=G?[]:Array.from(e.querySelectorAll(o)),v=[],W=[],B=0,_=0,S=false,C=false,E=0,pe=false,q=-1,de=-1,k=false,te=0,V=0,X,Me=null,J=new Set,ye=-1,Ne=performance.now();function ue(){return P?L==="x"?P.scrollLeft:P.scrollTop:L==="x"?window.scrollX:window.scrollY}function Re(){return P?L==="x"?P.clientWidth:P.clientHeight:L==="x"?window.innerWidth:window.innerHeight}function He(){let t=e.getBoundingClientRect(),s,l,g;if(P){let D=P.getBoundingClientRect();s=L==="x"?t.left-D.left+P.scrollLeft:t.top-D.top+P.scrollTop,l=L==="x"?t.width:t.height,g=ue();}else s=L==="x"?t.left:t.top,l=L==="x"?t.width:t.height,g=ue();let F=Le({top:s,height:l},g,Re(),Fe,Ce);B=F.tStart,_=F.tEnd,se&&process.env.NODE_ENV!=="production"&&(Me?.remove(),Me=nt(B,_,L));}function je(t,s){if(e.style.setProperty("--scroll-draw-progress",String(t)),G){let l=s==="reverse"?1-t:t;e.style.clipPath=ee(l);return}$.forEach((l,g)=>{l.style.strokeDashoffset=s==="reverse"?`${v[g]*t}`:`${v[g]*(1-t)}`,m&&(l.style.opacity=s==="reverse"?`${1-t}`:`${t}`),H&&M?l.style.stroke=ve(H,M,t):M&&(l.style.stroke=M),I!==null&&A!==null?l.style.strokeWidth=`${I+(A-I)*t}`:A!==null&&(l.style.strokeWidth=`${A}`),O!==null&&T!==null?l.style.fillOpacity=`${O+(T-O)*t}`:T!==null&&(l.style.fillOpacity=`${T}`),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}$.forEach((t,s)=>{t.style.strokeDasharray=`${v[s]}`,t.style.strokeDashoffset=u==="reverse"?"0":`${v[s]}`,m?t.style.opacity=u==="reverse"?"1":"0":t.style.opacity="",H&&(t.style.stroke=H),I!==null&&(t.style.strokeWidth=`${I}`),O!==null&&(t.style.fillOpacity=`${O}`),R&&t.tagName.toLowerCase()==="path"&&W[s]&&t.setAttribute("d",W[s]);});}if($.forEach(t=>{rt(t);let s=we(t);v.push(s),t.tagName.toLowerCase()==="path"?W.push(t.getAttribute("d")??""):W.push(""),n?(t.style.strokeDasharray=`${s}`,t.style.strokeDashoffset=u==="reverse"?`${s}`:"0",m&&(t.style.opacity="1"),M&&(t.style.stroke=M),A!==null&&(t.style.strokeWidth=`${A}`),T!==null&&(t.style.fillOpacity=`${T}`),R&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",R)):(t.style.strokeDasharray=`${s}`,t.style.strokeDashoffset=u==="reverse"?"0":`${s}`,m?t.style.opacity=u==="reverse"?"1":"0":t.style.opacity="",H&&(t.style.stroke=H),I!==null&&(t.style.strokeWidth=`${I}`),O!==null&&(t.style.fillOpacity=`${O}`));}),G){if(n)return e.style.clipPath=ee(1),oe?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ee(0);}else if(n)return oe?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Ke(){return !(Ue===false||!tt()||!$.length||typeof b!="string"||!(b in _e)||G||L!=="y"||P||d!==1||N!==0||h||ce||fe!==false||R||Q||Y||ie>0||le||me||oe||U!=null||j!=null||K!=null||(x.start??"top bottom").trim()!=="top bottom"||(x.end??"bottom top").trim()!=="bottom top")}function Qe(){let t=`svg-scroll-draw-${++et}`,s=u==="reverse"?"0":"var(--ssd-len)",l=u==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${s};`,F=`stroke-dashoffset:${l};`;m&&(g+=`opacity:${u==="reverse"?1:0};`,F+=`opacity:${u==="reverse"?0:1};`);let D=document.createElement("style");D.setAttribute("data-svg-scroll-draw",""),D.textContent=`@keyframes ${t}{from{${g}}to{${F}}}.${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 i(a,f){a.style.setProperty("--ssd-len",String(v[f])),a.style.strokeDasharray=`${v[f]}`,a.style.strokeDashoffset="",a.style.opacity="",a.style.animationPlayState="",a.classList.add(t);}$.forEach(i);let p=false,w=-1;function c(){if(w>=0)return w;let a=e.getBoundingClientRect(),{tStart:f,tEnd:y}=Le({top:a.top,height:a.height},ue(),Re(),Fe,Ce);return Z(ne(ue(),f,y,d))}return {destroy(){$.forEach(a=>{a.classList.remove(t),a.style.removeProperty("--ssd-len"),a.style.animationPlayState="";}),D.remove();},replay(){p=false,w=-1,$.forEach(i);},pause(){p=true,$.forEach(a=>{a.style.animationPlayState="paused";});},resume(){p&&(p=false,$.forEach(a=>{a.style.animationPlayState="running";}));},seek(a){let f=Math.min(1,Math.max(0,a));w=f,p=true,$.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(Ke())return Qe();function Ye(){let t=Math.max(1,Je),s=0,l=0;function g(c){let a=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&&(a=false);}else $.forEach((f,y)=>{let re=y*N*t,ae=Math.min(1,Math.max(0,(c-re)/t)),z=Z(ae);f.style.strokeDashoffset=u==="reverse"?`${v[y]*z}`:`${v[y]*(1-z)}`,m&&(f.style.opacity=u==="reverse"?`${1-z}`:`${z}`),H&&M?f.style.stroke=ve(H,M,z):M&&(f.style.stroke=M),I!==null&&A!==null?f.style.strokeWidth=`${I+(A-I)*z}`:A!==null&&(f.style.strokeWidth=`${A}`),O!==null&&T!==null?f.style.fillOpacity=`${O+(T-O)*z}`:T!==null&&(f.style.fillOpacity=`${T}`),R&&f.tagName.toLowerCase()==="path"&&W[y]&&f.setAttribute("d",Pe(W[y],R,z)),y===0&&(le?.(z),e.style.setProperty("--scroll-draw-progress",String(z))),ae<1&&(a=false);});if(Q){let f=Math.min(1,Math.max(0,c/t)),y=Z(f);for(let re in Q){let ae=parseFloat(re);y>=ae&&!J.has(ae)&&(J.add(ae),Q[re]?.());}}return a}function F(c){if(k)return;let a=c-s;C||(C=true,me?.());let f=g(a);if(f&&!S){S=true,g(t*(1+Math.max(0,$.length-1)*N)),oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{s=performance.now(),C=false,S=false,J.clear(),he(),E=requestAnimationFrame(F);},$e));return}f||(E=requestAnimationFrame(F));}function D(){cancelAnimationFrame(E),clearTimeout(X),s=performance.now(),l=0,k=false,C=false,S=false,V=0,J.clear(),he(),E=requestAnimationFrame(F);}let i=new IntersectionObserver(c=>{c.forEach(a=>{a.isIntersecting&&!(h&&S)?D():!a.isIntersecting&&!h&&!S&&(cancelAnimationFrame(E),clearTimeout(X),s=null);});},{root:P??null,threshold:Ie,rootMargin:Oe}),p;function w(){clearTimeout(p),p=setTimeout(()=>{$.forEach((c,a)=>{v[a]=we(c),c.style.strokeDasharray=`${v[a]}`;});},150);}return window.addEventListener("resize",w),window.addEventListener("orientationchange",w),ie>0?setTimeout(()=>i.observe(e),ie):i.observe(e),{destroy(){cancelAnimationFrame(E),clearTimeout(X),i.disconnect(),window.removeEventListener("resize",w),window.removeEventListener("orientationchange",w),clearTimeout(p);},replay(){V=0,D();},pause(){k||(k=true,l=performance.now()-s,cancelAnimationFrame(E));},resume(){k&&(k=false,s=performance.now()-l,E=requestAnimationFrame(F));},seek(c){let a=Math.min(1,Math.max(0,c));te=a,k=true,l=a*t,s=performance.now()-l,cancelAnimationFrame(E),g(l);},getProgress(){return te}}}if(Xe)return Ye();He();function ge(){if(!pe||k)return;let t=performance.now(),s=ue(),l=d;if(fe!==false){let i=t-Ne,p=i>0?Math.abs(s-(ye<0?s:ye))/i:0;l=d*Math.max(.2,1+p*(typeof fe=="number"?fe:1)*.04);}ye=s,Ne=t;let g=ce?de===-1||s>=de?"forward":"reverse":u;de=s;let F=_-B,D=true;if(G){let i=Z(ne(s,B,_,l));h&&!ce&&(q=Math.max(q,i),i=q),te=i,e.style.setProperty("--scroll-draw-progress",String(i));let p=g==="reverse"?1-i:i;e.style.clipPath=ee(p),le?.(i),!C&&ne(s,B,_,l)>0&&(C=true,me?.()),i>=1&&!S?(S=true,oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{q=-1,C=false,S=false,e.style.clipPath=ee(0);},$e))):i<1&&!h&&(S=false),E=requestAnimationFrame(ge);return}if($.forEach((i,p)=>{let w=p*N*F,c=Z(ne(s,B+w,_+w,l));h&&!ce&&(q=Math.max(q,c),c=q),te=c,i.style.strokeDashoffset=g==="reverse"?`${v[p]*c}`:`${v[p]*(1-c)}`,m&&(i.style.opacity=g==="reverse"?`${1-c}`:`${c}`),H&&M?i.style.stroke=ve(H,M,c):M&&(i.style.stroke=M),I!==null&&A!==null?i.style.strokeWidth=`${I+(A-I)*c}`:A!==null&&(i.style.strokeWidth=`${A}`),O!==null&&T!==null?i.style.fillOpacity=`${O+(T-O)*c}`:T!==null&&(i.style.fillOpacity=`${T}`),R&&i.tagName.toLowerCase()==="path"&&W[p]&&i.setAttribute("d",Pe(W[p],R,c)),p===0&&(le?.(c),e.style.setProperty("--scroll-draw-progress",String(c))),c<1&&(D=false);}),Q){let i=Z(ne(s,B,_,l));for(let p in Q){let w=parseFloat(p);i>=w&&!J.has(w)&&(J.add(w),Q[p]?.());}}!C&&ne(s,B,_,l)>0&&(C=true,me?.()),D&&!S?(S=true,oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{q=-1,C=false,S=false,J.clear(),he();},$e))):!D&&!h&&(S=false),E=requestAnimationFrame(ge);}let Ae=new IntersectionObserver(t=>{t.forEach(s=>{pe=s.isIntersecting,pe&&!k?E=requestAnimationFrame(ge):cancelAnimationFrame(E);});},{root:P??null,threshold:Ie,rootMargin:Oe}),Te;function be(){clearTimeout(Te),Te=setTimeout(()=>{$.forEach((t,s)=>{v[s]=we(t),t.style.strokeDasharray=`${v[s]}`;}),He();},150);}return window.addEventListener("resize",be),window.addEventListener("orientationchange",be),ie>0?setTimeout(()=>Ae.observe(e),ie):Ae.observe(e),{destroy(){cancelAnimationFrame(E),clearTimeout(X),Ae.disconnect(),window.removeEventListener("resize",be),window.removeEventListener("orientationchange",be),clearTimeout(Te),Me?.remove();},replay(){q=-1,de=-1,ye=-1,C=false,S=false,V=0,k=false,J.clear(),clearTimeout(X),he();},pause(){k=true,cancelAnimationFrame(E);},resume(){k&&(k=false,pe&&(E=requestAnimationFrame(ge)));},seek(t){let s=Math.min(1,Math.max(0,t));te=s,q=s,k=true,cancelAnimationFrame(E),je(s,u);},getProgress(){return te}}}function st(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let o=typeof e=="string"?document.querySelector(e):e;return o?Ee(o,r):(console.warn("[svg-scroll-draw] Container not found:",e),n)}function pt(e=document){return Array.from(e.querySelectorAll("[data-scroll-draw]")).map(r=>{let n={};try{let o=r.dataset.scrollDrawOptions??r.dataset.scrollDrawoptions??"";o&&(n=JSON.parse(o));}catch{}return Ee(r,n)})}exports.initScrollDraw=pt;exports.scrollDraw=st;
|
package/dist/astro/index.d.mts
CHANGED
|
@@ -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
|
package/dist/astro/index.d.ts
CHANGED
|
@@ -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
|
package/dist/astro/index.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
function
|
|
2
|
-
<div style="position:absolute;${
|
|
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 Ve({bounces:e=3,decay:r=.5}={}){let n=Math.max(1,Math.round(e)),o=Math.max(.01,Math.min(.99,r)),d=Math.sqrt(o),m=0,b=[];for(let u=0;u<n;u++){let h=Math.pow(d,u);b.push(h),m+=h;}let x=[0],N=0;for(let u=0;u<n;u++)N+=b[u]/m,x.push(N);return u=>{if(u<=0)return 0;if(u>=1)return 1;for(let h=0;h<n;h++)if(u<=x[h+1]){let se=(u-x[h])/(x[h+1]-x[h]);if(h===0)return se*(2-se);let L=1-Math.pow(o,h);return L+(1-L)*(2*se-1)*(2*se-1)}return 1}}function Ge({amplitude:e=1,period:r=.4}={}){let n=Math.max(1,e),o=Math.max(.1,r),d=n<=1?o/4:o/(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)/o)+1}var ke={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:Ve(),elastic:Ge()};function De(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 We(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 qe(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 we(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 Ze(e,r,n){return Math.min(n,Math.max(r,e))}function ne(e,r,n,o){return n===r?0:Ze((e-r)/(n-r)*o,0,1)}function Le(e,r,n,o,d){let m=We(e.top,e.height,r,o.element)-qe(o.viewport,n),b=We(e.top,e.height,r,d.element)-qe(d.viewport,n);return {tStart:m,tEnd:b}}function ze(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 ve(e,r,n){let o=ze(e),d=ze(r);return !o||!d?e:`rgb(${Math.round(o[0]+(d[0]-o[0])*n)},${Math.round(o[1]+(d[1]-o[1])*n)},${Math.round(o[2]+(d[2]-o[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 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=n==="x"?window.scrollX:window.scrollY,b=e-m,x=r-m,N=n==="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:${x}px;top:0;bottom:0;border-left:2px dashed #ef4444;`:`top:${x}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,r,n){let o=(r.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),d=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,m=>{let b=parseFloat(m),x=o[d++]??b;return String(+(b+(x-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:o="path, polyline, line, polygon, rect, circle",speed:d=1,fade:m=false,easing:b="linear",trigger:x={},stagger:N=0,direction:u="forward",once:h=false,debug:se=false,axis:L="y",scrollContainer:xe,autoReverse:ce=false,delay:ie=0,strokeColor:U,strokeWidth:j,fillOpacity:K,waypoints:Q,velocityScale:fe=false,threshold:Ie=0,rootMargin:Oe="0px",repeat:Y=0,repeatDelay:$e=0,morphTo:R,clip:Se,autoplay:Xe=false,duration:Je=1e3,native:Ue=true,onProgress:le,onStart:me,onComplete:oe}=r,G=Se===true?"left":typeof Se=="string"?Se:false,Z=typeof b=="function"?b:ke[b]??ke.linear,Fe=De(x.start??"top bottom"),Ce=De(x.end??"bottom top"),P=typeof xe=="string"?document.querySelector(xe):xe??null,H=Array.isArray(U)?U[0]:null,M=Array.isArray(U)?U[1]:typeof U=="string"?U:null,I=Array.isArray(j)?j[0]:null,A=Array.isArray(j)?j[1]:typeof j=="number"?j:null,O=Array.isArray(K)?K[0]:null,T=Array.isArray(K)?K[1]:typeof K=="number"?K:null;function ee(t){let s=t*100;switch(G){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 $=G?[]:Array.from(e.querySelectorAll(o)),v=[],W=[],B=0,_=0,S=false,C=false,E=0,pe=false,q=-1,de=-1,k=false,te=0,V=0,X,Me=null,J=new Set,ye=-1,Ne=performance.now();function ue(){return P?L==="x"?P.scrollLeft:P.scrollTop:L==="x"?window.scrollX:window.scrollY}function Re(){return P?L==="x"?P.clientWidth:P.clientHeight:L==="x"?window.innerWidth:window.innerHeight}function He(){let t=e.getBoundingClientRect(),s,l,g;if(P){let D=P.getBoundingClientRect();s=L==="x"?t.left-D.left+P.scrollLeft:t.top-D.top+P.scrollTop,l=L==="x"?t.width:t.height,g=ue();}else s=L==="x"?t.left:t.top,l=L==="x"?t.width:t.height,g=ue();let F=Le({top:s,height:l},g,Re(),Fe,Ce);B=F.tStart,_=F.tEnd,se&&process.env.NODE_ENV!=="production"&&(Me?.remove(),Me=nt(B,_,L));}function je(t,s){if(e.style.setProperty("--scroll-draw-progress",String(t)),G){let l=s==="reverse"?1-t:t;e.style.clipPath=ee(l);return}$.forEach((l,g)=>{l.style.strokeDashoffset=s==="reverse"?`${v[g]*t}`:`${v[g]*(1-t)}`,m&&(l.style.opacity=s==="reverse"?`${1-t}`:`${t}`),H&&M?l.style.stroke=ve(H,M,t):M&&(l.style.stroke=M),I!==null&&A!==null?l.style.strokeWidth=`${I+(A-I)*t}`:A!==null&&(l.style.strokeWidth=`${A}`),O!==null&&T!==null?l.style.fillOpacity=`${O+(T-O)*t}`:T!==null&&(l.style.fillOpacity=`${T}`),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}$.forEach((t,s)=>{t.style.strokeDasharray=`${v[s]}`,t.style.strokeDashoffset=u==="reverse"?"0":`${v[s]}`,m?t.style.opacity=u==="reverse"?"1":"0":t.style.opacity="",H&&(t.style.stroke=H),I!==null&&(t.style.strokeWidth=`${I}`),O!==null&&(t.style.fillOpacity=`${O}`),R&&t.tagName.toLowerCase()==="path"&&W[s]&&t.setAttribute("d",W[s]);});}if($.forEach(t=>{rt(t);let s=we(t);v.push(s),t.tagName.toLowerCase()==="path"?W.push(t.getAttribute("d")??""):W.push(""),n?(t.style.strokeDasharray=`${s}`,t.style.strokeDashoffset=u==="reverse"?`${s}`:"0",m&&(t.style.opacity="1"),M&&(t.style.stroke=M),A!==null&&(t.style.strokeWidth=`${A}`),T!==null&&(t.style.fillOpacity=`${T}`),R&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",R)):(t.style.strokeDasharray=`${s}`,t.style.strokeDashoffset=u==="reverse"?"0":`${s}`,m?t.style.opacity=u==="reverse"?"1":"0":t.style.opacity="",H&&(t.style.stroke=H),I!==null&&(t.style.strokeWidth=`${I}`),O!==null&&(t.style.fillOpacity=`${O}`));}),G){if(n)return e.style.clipPath=ee(1),oe?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ee(0);}else if(n)return oe?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Ke(){return !(Ue===false||!tt()||!$.length||typeof b!="string"||!(b in _e)||G||L!=="y"||P||d!==1||N!==0||h||ce||fe!==false||R||Q||Y||ie>0||le||me||oe||U!=null||j!=null||K!=null||(x.start??"top bottom").trim()!=="top bottom"||(x.end??"bottom top").trim()!=="bottom top")}function Qe(){let t=`svg-scroll-draw-${++et}`,s=u==="reverse"?"0":"var(--ssd-len)",l=u==="reverse"?"var(--ssd-len)":"0",g=`stroke-dashoffset:${s};`,F=`stroke-dashoffset:${l};`;m&&(g+=`opacity:${u==="reverse"?1:0};`,F+=`opacity:${u==="reverse"?0:1};`);let D=document.createElement("style");D.setAttribute("data-svg-scroll-draw",""),D.textContent=`@keyframes ${t}{from{${g}}to{${F}}}.${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 i(a,f){a.style.setProperty("--ssd-len",String(v[f])),a.style.strokeDasharray=`${v[f]}`,a.style.strokeDashoffset="",a.style.opacity="",a.style.animationPlayState="",a.classList.add(t);}$.forEach(i);let p=false,w=-1;function c(){if(w>=0)return w;let a=e.getBoundingClientRect(),{tStart:f,tEnd:y}=Le({top:a.top,height:a.height},ue(),Re(),Fe,Ce);return Z(ne(ue(),f,y,d))}return {destroy(){$.forEach(a=>{a.classList.remove(t),a.style.removeProperty("--ssd-len"),a.style.animationPlayState="";}),D.remove();},replay(){p=false,w=-1,$.forEach(i);},pause(){p=true,$.forEach(a=>{a.style.animationPlayState="paused";});},resume(){p&&(p=false,$.forEach(a=>{a.style.animationPlayState="running";}));},seek(a){let f=Math.min(1,Math.max(0,a));w=f,p=true,$.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(Ke())return Qe();function Ye(){let t=Math.max(1,Je),s=0,l=0;function g(c){let a=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&&(a=false);}else $.forEach((f,y)=>{let re=y*N*t,ae=Math.min(1,Math.max(0,(c-re)/t)),z=Z(ae);f.style.strokeDashoffset=u==="reverse"?`${v[y]*z}`:`${v[y]*(1-z)}`,m&&(f.style.opacity=u==="reverse"?`${1-z}`:`${z}`),H&&M?f.style.stroke=ve(H,M,z):M&&(f.style.stroke=M),I!==null&&A!==null?f.style.strokeWidth=`${I+(A-I)*z}`:A!==null&&(f.style.strokeWidth=`${A}`),O!==null&&T!==null?f.style.fillOpacity=`${O+(T-O)*z}`:T!==null&&(f.style.fillOpacity=`${T}`),R&&f.tagName.toLowerCase()==="path"&&W[y]&&f.setAttribute("d",Pe(W[y],R,z)),y===0&&(le?.(z),e.style.setProperty("--scroll-draw-progress",String(z))),ae<1&&(a=false);});if(Q){let f=Math.min(1,Math.max(0,c/t)),y=Z(f);for(let re in Q){let ae=parseFloat(re);y>=ae&&!J.has(ae)&&(J.add(ae),Q[re]?.());}}return a}function F(c){if(k)return;let a=c-s;C||(C=true,me?.());let f=g(a);if(f&&!S){S=true,g(t*(1+Math.max(0,$.length-1)*N)),oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{s=performance.now(),C=false,S=false,J.clear(),he(),E=requestAnimationFrame(F);},$e));return}f||(E=requestAnimationFrame(F));}function D(){cancelAnimationFrame(E),clearTimeout(X),s=performance.now(),l=0,k=false,C=false,S=false,V=0,J.clear(),he(),E=requestAnimationFrame(F);}let i=new IntersectionObserver(c=>{c.forEach(a=>{a.isIntersecting&&!(h&&S)?D():!a.isIntersecting&&!h&&!S&&(cancelAnimationFrame(E),clearTimeout(X),s=null);});},{root:P??null,threshold:Ie,rootMargin:Oe}),p;function w(){clearTimeout(p),p=setTimeout(()=>{$.forEach((c,a)=>{v[a]=we(c),c.style.strokeDasharray=`${v[a]}`;});},150);}return window.addEventListener("resize",w),window.addEventListener("orientationchange",w),ie>0?setTimeout(()=>i.observe(e),ie):i.observe(e),{destroy(){cancelAnimationFrame(E),clearTimeout(X),i.disconnect(),window.removeEventListener("resize",w),window.removeEventListener("orientationchange",w),clearTimeout(p);},replay(){V=0,D();},pause(){k||(k=true,l=performance.now()-s,cancelAnimationFrame(E));},resume(){k&&(k=false,s=performance.now()-l,E=requestAnimationFrame(F));},seek(c){let a=Math.min(1,Math.max(0,c));te=a,k=true,l=a*t,s=performance.now()-l,cancelAnimationFrame(E),g(l);},getProgress(){return te}}}if(Xe)return Ye();He();function ge(){if(!pe||k)return;let t=performance.now(),s=ue(),l=d;if(fe!==false){let i=t-Ne,p=i>0?Math.abs(s-(ye<0?s:ye))/i:0;l=d*Math.max(.2,1+p*(typeof fe=="number"?fe:1)*.04);}ye=s,Ne=t;let g=ce?de===-1||s>=de?"forward":"reverse":u;de=s;let F=_-B,D=true;if(G){let i=Z(ne(s,B,_,l));h&&!ce&&(q=Math.max(q,i),i=q),te=i,e.style.setProperty("--scroll-draw-progress",String(i));let p=g==="reverse"?1-i:i;e.style.clipPath=ee(p),le?.(i),!C&&ne(s,B,_,l)>0&&(C=true,me?.()),i>=1&&!S?(S=true,oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{q=-1,C=false,S=false,e.style.clipPath=ee(0);},$e))):i<1&&!h&&(S=false),E=requestAnimationFrame(ge);return}if($.forEach((i,p)=>{let w=p*N*F,c=Z(ne(s,B+w,_+w,l));h&&!ce&&(q=Math.max(q,c),c=q),te=c,i.style.strokeDashoffset=g==="reverse"?`${v[p]*c}`:`${v[p]*(1-c)}`,m&&(i.style.opacity=g==="reverse"?`${1-c}`:`${c}`),H&&M?i.style.stroke=ve(H,M,c):M&&(i.style.stroke=M),I!==null&&A!==null?i.style.strokeWidth=`${I+(A-I)*c}`:A!==null&&(i.style.strokeWidth=`${A}`),O!==null&&T!==null?i.style.fillOpacity=`${O+(T-O)*c}`:T!==null&&(i.style.fillOpacity=`${T}`),R&&i.tagName.toLowerCase()==="path"&&W[p]&&i.setAttribute("d",Pe(W[p],R,c)),p===0&&(le?.(c),e.style.setProperty("--scroll-draw-progress",String(c))),c<1&&(D=false);}),Q){let i=Z(ne(s,B,_,l));for(let p in Q){let w=parseFloat(p);i>=w&&!J.has(w)&&(J.add(w),Q[p]?.());}}!C&&ne(s,B,_,l)>0&&(C=true,me?.()),D&&!S?(S=true,oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{q=-1,C=false,S=false,J.clear(),he();},$e))):!D&&!h&&(S=false),E=requestAnimationFrame(ge);}let Ae=new IntersectionObserver(t=>{t.forEach(s=>{pe=s.isIntersecting,pe&&!k?E=requestAnimationFrame(ge):cancelAnimationFrame(E);});},{root:P??null,threshold:Ie,rootMargin:Oe}),Te;function be(){clearTimeout(Te),Te=setTimeout(()=>{$.forEach((t,s)=>{v[s]=we(t),t.style.strokeDasharray=`${v[s]}`;}),He();},150);}return window.addEventListener("resize",be),window.addEventListener("orientationchange",be),ie>0?setTimeout(()=>Ae.observe(e),ie):Ae.observe(e),{destroy(){cancelAnimationFrame(E),clearTimeout(X),Ae.disconnect(),window.removeEventListener("resize",be),window.removeEventListener("orientationchange",be),clearTimeout(Te),Me?.remove();},replay(){q=-1,de=-1,ye=-1,C=false,S=false,V=0,k=false,J.clear(),clearTimeout(X),he();},pause(){k=true,cancelAnimationFrame(E);},resume(){k&&(k=false,pe&&(E=requestAnimationFrame(ge)));},seek(t){let s=Math.min(1,Math.max(0,t));te=s,q=s,k=true,cancelAnimationFrame(E),je(s,u);},getProgress(){return te}}}function st(e,r){let n={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return n;let o=typeof e=="string"?document.querySelector(e):e;return o?Ee(o,r):(console.warn("[svg-scroll-draw] Container not found:",e),n)}function pt(e=document){return Array.from(e.querySelectorAll("[data-scroll-draw]")).map(r=>{let n={};try{let o=r.dataset.scrollDrawOptions??r.dataset.scrollDrawoptions??"";o&&(n=JSON.parse(o));}catch{}return Ee(r,n)})}export{pt as initScrollDraw,st as scrollDraw};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";var SvgScrollDraw=(()=>{var
|
|
2
|
-
<div style="position:absolute;${
|
|
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 Te=Object.defineProperty;var rt=Object.getOwnPropertyDescriptor;var nt=Object.getOwnPropertyNames;var st=Object.prototype.hasOwnProperty;var ot=(e,n)=>{for(var r in n)Te(e,r,{get:n[r],enumerable:!0})},it=(e,n,r,o)=>{if(n&&typeof n=="object"||typeof n=="function")for(let u of nt(n))!st.call(e,u)&&u!==r&&Te(e,u,{get:()=>n[u],enumerable:!(o=rt(n,u))||o.enumerable});return e};var at=e=>it(Te({},"__esModule",{value:!0}),e);var dt={};ot(dt,{createBounce:()=>De,createElastic:()=>Le,createSpring:()=>Xe,scrollDraw:()=>pt});function Xe({tension:e=2.5,friction:n=2.2}={}){return r=>1-Math.cos(r*Math.PI*e)*Math.pow(1-r,n)}function De({bounces:e=3,decay:n=.5}={}){let r=Math.max(1,Math.round(e)),o=Math.max(.01,Math.min(.99,n)),u=Math.sqrt(o),p=0,y=[];for(let c=0;c<r;c++){let g=Math.pow(u,c);y.push(g),p+=g}let w=[0],R=0;for(let c=0;c<r;c++)R+=y[c]/p,w.push(R);return c=>{if(c<=0)return 0;if(c>=1)return 1;for(let g=0;g<r;g++)if(c<=w[g+1]){let se=(c-w[g])/(w[g+1]-w[g]);if(g===0)return se*(2-se);let L=1-Math.pow(o,g);return L+(1-L)*(2*se-1)*(2*se-1)}return 1}}function Le({amplitude:e=1,period:n=.4}={}){let r=Math.max(1,e),o=Math.max(.1,n),u=r<=1?o/4:o/(2*Math.PI)*Math.asin(1/r);return p=>p<=0?0:p>=1?1:r*Math.pow(2,-10*p)*Math.sin((p-u)*(2*Math.PI)/o)+1}var Pe={linear:e=>e,"ease-in":e=>e*e,"ease-out":e=>e*(2-e),"ease-in-out":e=>e<.5?2*e*e:-1+(4-2*e)*e,spring:e=>1-Math.cos(e*Math.PI*2.5)*Math.pow(1-e,2.2),bounce:De(),elastic:Le()};function Ie(e="top bottom"){let n=e.trim();if(/^\d+(\.\d+)?%$/.test(n))return{element:"top",viewport:n};let[r="top",o="bottom"]=n.split(/\s+/).filter(Boolean);return{element:r,viewport:o}}function Ge(e,n,r,o){switch(o){case"top":return e+r;case"center":return e+r+n/2;case"bottom":return e+r+n;default:return e+r}}function Be(e,n){if(/^\d+(\.\d+)?%$/.test(e))return n*(parseFloat(e)/100);switch(e){case"top":return 0;case"center":return n/2;case"bottom":return n;default:return n}}function we(e){let n=e.tagName.toLowerCase();if(n==="rect"){let r=parseFloat(e.getAttribute("width")??"0"),o=parseFloat(e.getAttribute("height")??"0");return 2*(r+o)}if(n==="circle"){let r=parseFloat(e.getAttribute("r")??"0");return 2*Math.PI*r}return e.getTotalLength()}function lt(e,n,r){return Math.min(r,Math.max(n,e))}function ne(e,n,r,o){return r===n?0:lt((e-n)/(r-n)*o,0,1)}function Fe(e,n,r,o,u){let p=Ge(e.top,e.height,n,o.element)-Be(o.viewport,r),y=Ge(e.top,e.height,n,u.element)-Be(u.viewport,r);return{tStart:p,tEnd:y}}function _e(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 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,r){let o=_e(e),u=_e(n);return!o||!u?e:`rgb(${Math.round(o[0]+(u[0]-o[0])*r)},${Math.round(o[1]+(u[1]-o[1])*r)},${Math.round(o[2]+(u[2]-o[2])*r)})`}function Ue(e,n){process.env.NODE_ENV!=="production"&&console.warn(`[svg-scroll-draw] ${e}`,n)}var je={linear:"linear","ease-in":"ease-in","ease-out":"ease-out","ease-in-out":"ease-in-out"},ut=0;function ct(){return typeof CSS<"u"&&typeof CSS.supports=="function"&&CSS.supports("animation-timeline: view()")}function ft(e){let n=e.getAttribute("stroke"),r=e.getAttribute("fill");!n||n==="none"?Ue("Element has no stroke \u2014 path will not be visible.",e):r&&r!=="none"&&r!=="transparent"&&Ue("Element has a fill \u2014 it may obscure the stroke animation.",e)}function mt(e,n,r){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 u(){let p=r==="x"?window.scrollX:window.scrollY,y=e-p,w=n-p,R=r==="x";o.innerHTML=`
|
|
2
|
+
<div style="position:absolute;${R?`left:${y}px;top:0;bottom:0;border-left:2px dashed #22c55e;`:`top:${y}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;${R?`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(o),window.addEventListener("scroll",u,{passive:!0}),u(),o}function Ce(e,n,r){let o=(n.match(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g)??[]).map(Number),u=0;return e.replace(/[-+]?(?:\d*\.)?\d+(?:[eE][-+]?\d+)?/g,p=>{let y=parseFloat(p),w=o[u++]??y;return String(+(y+(w-y)*r).toFixed(4))})}function Ee(e,n={}){if(typeof window>"u")return{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};let r=window.matchMedia("(prefers-reduced-motion: reduce)").matches,{selector:o="path, polyline, line, polygon, rect, circle",speed:u=1,fade:p=!1,easing:y="linear",trigger:w={},stagger:R=0,direction:c="forward",once:g=!1,debug:se=!1,axis:L="y",scrollContainer:xe,autoReverse:ce=!1,delay:ae=0,strokeColor:j,strokeWidth:J,fillOpacity:K,waypoints:Q,velocityScale:fe=!1,threshold:Re=0,rootMargin:Ne="0px",repeat:Y=0,repeatDelay:$e=0,morphTo:N,clip:Se,autoplay:Je=!1,duration:Ke=1e3,native:Qe=!0,onProgress:le,onStart:me,onComplete:oe}=n,G=Se===!0?"left":typeof Se=="string"?Se:!1,Z=typeof y=="function"?y:Pe[y]??Pe.linear,He=Ie(w.start??"top bottom"),We=Ie(w.end??"bottom top"),P=typeof xe=="string"?document.querySelector(xe):xe??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,M=Array.isArray(J)?J[1]:typeof J=="number"?J:null,F=Array.isArray(K)?K[0]:null,k=Array.isArray(K)?K[1]:typeof K=="number"?K:null;function ee(t){let s=t*100;switch(G){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 $=G?[]:Array.from(e.querySelectorAll(o)),E=[],W=[],B=0,_=0,S=!1,O=!1,x=0,pe=!1,q=-1,de=-1,T=!1,te=0,V=0,X,Ae=null,U=new Set,ye=-1,qe=performance.now();function ue(){return P?L==="x"?P.scrollLeft:P.scrollTop:L==="x"?window.scrollX:window.scrollY}function ze(){return P?L==="x"?P.clientWidth:P.clientHeight:L==="x"?window.innerWidth:window.innerHeight}function Ve(){let t=e.getBoundingClientRect(),s,l,b;if(P){let D=P.getBoundingClientRect();s=L==="x"?t.left-D.left+P.scrollLeft:t.top-D.top+P.scrollTop,l=L==="x"?t.width:t.height,b=ue()}else s=L==="x"?t.left:t.top,l=L==="x"?t.width:t.height,b=ue();let C=Fe({top:s,height:l},b,ze(),He,We);B=C.tStart,_=C.tEnd,se&&process.env.NODE_ENV!=="production"&&(Ae?.remove(),Ae=mt(B,_,L))}function Ye(t,s){if(e.style.setProperty("--scroll-draw-progress",String(t)),G){let l=s==="reverse"?1-t:t;e.style.clipPath=ee(l);return}$.forEach((l,b)=>{l.style.strokeDashoffset=s==="reverse"?`${E[b]*t}`:`${E[b]*(1-t)}`,p&&(l.style.opacity=s==="reverse"?`${1-t}`:`${t}`),H&&A?l.style.stroke=ve(H,A,t):A&&(l.style.stroke=A),I!==null&&M!==null?l.style.strokeWidth=`${I+(M-I)*t}`:M!==null&&(l.style.strokeWidth=`${M}`),F!==null&&k!==null?l.style.fillOpacity=`${F+(k-F)*t}`:k!==null&&(l.style.fillOpacity=`${k}`),N&&l.tagName.toLowerCase()==="path"&&W[b]&&l.setAttribute("d",Ce(W[b],N,t))})}function he(){if(e.style.setProperty("--scroll-draw-progress","0"),G){e.style.clipPath=ee(0);return}$.forEach((t,s)=>{t.style.strokeDasharray=`${E[s]}`,t.style.strokeDashoffset=c==="reverse"?"0":`${E[s]}`,p?t.style.opacity=c==="reverse"?"1":"0":t.style.opacity="",H&&(t.style.stroke=H),I!==null&&(t.style.strokeWidth=`${I}`),F!==null&&(t.style.fillOpacity=`${F}`),N&&t.tagName.toLowerCase()==="path"&&W[s]&&t.setAttribute("d",W[s])})}if($.forEach(t=>{ft(t);let s=we(t);E.push(s),t.tagName.toLowerCase()==="path"?W.push(t.getAttribute("d")??""):W.push(""),r?(t.style.strokeDasharray=`${s}`,t.style.strokeDashoffset=c==="reverse"?`${s}`:"0",p&&(t.style.opacity="1"),A&&(t.style.stroke=A),M!==null&&(t.style.strokeWidth=`${M}`),k!==null&&(t.style.fillOpacity=`${k}`),N&&t.tagName.toLowerCase()==="path"&&t.setAttribute("d",N)):(t.style.strokeDasharray=`${s}`,t.style.strokeDashoffset=c==="reverse"?"0":`${s}`,p?t.style.opacity=c==="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(r)return e.style.clipPath=ee(1),oe?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};e.style.clipPath=ee(0)}else if(r)return oe?.(),{destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>1};function Ze(){return!(Qe===!1||!ct()||!$.length||typeof y!="string"||!(y in je)||G||L!=="y"||P||u!==1||R!==0||g||ce||fe!==!1||N||Q||Y||ae>0||le||me||oe||j!=null||J!=null||K!=null||(w.start??"top bottom").trim()!=="top bottom"||(w.end??"bottom top").trim()!=="bottom top")}function et(){let t=`svg-scroll-draw-${++ut}`,s=c==="reverse"?"0":"var(--ssd-len)",l=c==="reverse"?"var(--ssd-len)":"0",b=`stroke-dashoffset:${s};`,C=`stroke-dashoffset:${l};`;p&&(b+=`opacity:${c==="reverse"?1:0};`,C+=`opacity:${c==="reverse"?0:1};`);let D=document.createElement("style");D.setAttribute("data-svg-scroll-draw",""),D.textContent=`@keyframes ${t}{from{${b}}to{${C}}}.${t}{animation-name:${t};animation-duration:auto;animation-timing-function:${je[y]};animation-fill-mode:both;animation-timeline:view();animation-range:cover 0% cover 100%;}`,document.head.appendChild(D);function a(i,m){i.style.setProperty("--ssd-len",String(E[m])),i.style.strokeDasharray=`${E[m]}`,i.style.strokeDashoffset="",i.style.opacity="",i.style.animationPlayState="",i.classList.add(t)}$.forEach(a);let d=!1,v=-1;function f(){if(v>=0)return v;let i=e.getBoundingClientRect(),{tStart:m,tEnd:h}=Fe({top:i.top,height:i.height},ue(),ze(),He,We);return Z(ne(ue(),m,h,u))}return{destroy(){$.forEach(i=>{i.classList.remove(t),i.style.removeProperty("--ssd-len"),i.style.animationPlayState=""}),D.remove()},replay(){d=!1,v=-1,$.forEach(a)},pause(){d=!0,$.forEach(i=>{i.style.animationPlayState="paused"})},resume(){d&&(d=!1,$.forEach(i=>{i.style.animationPlayState="running"}))},seek(i){let m=Math.min(1,Math.max(0,i));v=m,d=!0,$.forEach((h,re)=>{h.classList.remove(t),h.style.strokeDashoffset=c==="reverse"?`${E[re]*m}`:`${E[re]*(1-m)}`,p&&(h.style.opacity=c==="reverse"?`${1-m}`:`${m}`)})},getProgress(){return f()}}}if(Ze())return et();function tt(){let t=Math.max(1,Ke),s=0,l=0;function b(f){let i=!0;if(G){let m=Math.min(1,Math.max(0,f/t)),h=Z(m);te=h,e.style.setProperty("--scroll-draw-progress",String(h)),e.style.clipPath=ee(c==="reverse"?1-h:h),le?.(h),m<1&&(i=!1)}else $.forEach((m,h)=>{let re=h*R*t,ie=Math.min(1,Math.max(0,(f-re)/t)),z=Z(ie);m.style.strokeDashoffset=c==="reverse"?`${E[h]*z}`:`${E[h]*(1-z)}`,p&&(m.style.opacity=c==="reverse"?`${1-z}`:`${z}`),H&&A?m.style.stroke=ve(H,A,z):A&&(m.style.stroke=A),I!==null&&M!==null?m.style.strokeWidth=`${I+(M-I)*z}`:M!==null&&(m.style.strokeWidth=`${M}`),F!==null&&k!==null?m.style.fillOpacity=`${F+(k-F)*z}`:k!==null&&(m.style.fillOpacity=`${k}`),N&&m.tagName.toLowerCase()==="path"&&W[h]&&m.setAttribute("d",Ce(W[h],N,z)),h===0&&(le?.(z),e.style.setProperty("--scroll-draw-progress",String(z))),ie<1&&(i=!1)});if(Q){let m=Math.min(1,Math.max(0,f/t)),h=Z(m);for(let re in Q){let ie=parseFloat(re);h>=ie&&!U.has(ie)&&(U.add(ie),Q[re]?.())}}return i}function C(f){if(T)return;let i=f-s;O||(O=!0,me?.());let m=b(i);if(m&&!S){S=!0,b(t*(1+Math.max(0,$.length-1)*R)),oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{s=performance.now(),O=!1,S=!1,U.clear(),he(),x=requestAnimationFrame(C)},$e));return}m||(x=requestAnimationFrame(C))}function D(){cancelAnimationFrame(x),clearTimeout(X),s=performance.now(),l=0,T=!1,O=!1,S=!1,V=0,U.clear(),he(),x=requestAnimationFrame(C)}let a=new IntersectionObserver(f=>{f.forEach(i=>{i.isIntersecting&&!(g&&S)?D():!i.isIntersecting&&!g&&!S&&(cancelAnimationFrame(x),clearTimeout(X),s=null)})},{root:P??null,threshold:Re,rootMargin:Ne}),d;function v(){clearTimeout(d),d=setTimeout(()=>{$.forEach((f,i)=>{E[i]=we(f),f.style.strokeDasharray=`${E[i]}`})},150)}return window.addEventListener("resize",v),window.addEventListener("orientationchange",v),ae>0?setTimeout(()=>a.observe(e),ae):a.observe(e),{destroy(){cancelAnimationFrame(x),clearTimeout(X),a.disconnect(),window.removeEventListener("resize",v),window.removeEventListener("orientationchange",v),clearTimeout(d)},replay(){V=0,D()},pause(){T||(T=!0,l=performance.now()-s,cancelAnimationFrame(x))},resume(){T&&(T=!1,s=performance.now()-l,x=requestAnimationFrame(C))},seek(f){let i=Math.min(1,Math.max(0,f));te=i,T=!0,l=i*t,s=performance.now()-l,cancelAnimationFrame(x),b(l)},getProgress(){return te}}}if(Je)return tt();Ve();function ge(){if(!pe||T)return;let t=performance.now(),s=ue(),l=u;if(fe!==!1){let a=t-qe,d=a>0?Math.abs(s-(ye<0?s:ye))/a:0;l=u*Math.max(.2,1+d*(typeof fe=="number"?fe:1)*.04)}ye=s,qe=t;let b=ce?de===-1||s>=de?"forward":"reverse":c;de=s;let C=_-B,D=!0;if(G){let a=Z(ne(s,B,_,l));g&&!ce&&(q=Math.max(q,a),a=q),te=a,e.style.setProperty("--scroll-draw-progress",String(a));let d=b==="reverse"?1-a:a;e.style.clipPath=ee(d),le?.(a),!O&&ne(s,B,_,l)>0&&(O=!0,me?.()),a>=1&&!S?(S=!0,oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{q=-1,O=!1,S=!1,e.style.clipPath=ee(0)},$e))):a<1&&!g&&(S=!1),x=requestAnimationFrame(ge);return}if($.forEach((a,d)=>{let v=d*R*C,f=Z(ne(s,B+v,_+v,l));g&&!ce&&(q=Math.max(q,f),f=q),te=f,a.style.strokeDashoffset=b==="reverse"?`${E[d]*f}`:`${E[d]*(1-f)}`,p&&(a.style.opacity=b==="reverse"?`${1-f}`:`${f}`),H&&A?a.style.stroke=ve(H,A,f):A&&(a.style.stroke=A),I!==null&&M!==null?a.style.strokeWidth=`${I+(M-I)*f}`:M!==null&&(a.style.strokeWidth=`${M}`),F!==null&&k!==null?a.style.fillOpacity=`${F+(k-F)*f}`:k!==null&&(a.style.fillOpacity=`${k}`),N&&a.tagName.toLowerCase()==="path"&&W[d]&&a.setAttribute("d",Ce(W[d],N,f)),d===0&&(le?.(f),e.style.setProperty("--scroll-draw-progress",String(f))),f<1&&(D=!1)}),Q){let a=Z(ne(s,B,_,l));for(let d in Q){let v=parseFloat(d);a>=v&&!U.has(v)&&(U.add(v),Q[d]?.())}}!O&&ne(s,B,_,l)>0&&(O=!0,me?.()),D&&!S?(S=!0,oe?.(),V<(Y==="infinite"?1/0:Y??0)&&(V++,X=setTimeout(()=>{q=-1,O=!1,S=!1,U.clear(),he()},$e))):!D&&!g&&(S=!1),x=requestAnimationFrame(ge)}let Me=new IntersectionObserver(t=>{t.forEach(s=>{pe=s.isIntersecting,pe&&!T?x=requestAnimationFrame(ge):cancelAnimationFrame(x)})},{root:P??null,threshold:Re,rootMargin:Ne}),ke;function be(){clearTimeout(ke),ke=setTimeout(()=>{$.forEach((t,s)=>{E[s]=we(t),t.style.strokeDasharray=`${E[s]}`}),Ve()},150)}return window.addEventListener("resize",be),window.addEventListener("orientationchange",be),ae>0?setTimeout(()=>Me.observe(e),ae):Me.observe(e),{destroy(){cancelAnimationFrame(x),clearTimeout(X),Me.disconnect(),window.removeEventListener("resize",be),window.removeEventListener("orientationchange",be),clearTimeout(ke),Ae?.remove()},replay(){q=-1,de=-1,ye=-1,O=!1,S=!1,V=0,T=!1,U.clear(),clearTimeout(X),he()},pause(){T=!0,cancelAnimationFrame(x)},resume(){T&&(T=!1,pe&&(x=requestAnimationFrame(ge)))},seek(t){let s=Math.min(1,Math.max(0,t));te=s,q=s,T=!0,cancelAnimationFrame(x),Ye(s,c)},getProgress(){return te}}}function pt(e,n){let r={destroy:()=>{},replay:()=>{},pause:()=>{},resume:()=>{},seek:()=>{},getProgress:()=>0};if(typeof window>"u")return r;let o=typeof e=="string"?document.querySelector(e):e;return o?Ee(o,n):(console.warn("[svg-scroll-draw] Container not found:",e),r)}var Oe=class extends HTMLElement{constructor(){super(...arguments);this.instance=null}connectedCallback(){let r={},o=this.getAttribute("speed"),u=this.getAttribute("easing"),p=this.getAttribute("stagger"),y=this.getAttribute("direction"),w=this.getAttribute("selector");o&&(r.speed=parseFloat(o)),u&&(r.easing=u),p&&(r.stagger=parseFloat(p)),y&&(r.direction=y),w&&(r.selector=w),this.hasAttribute("fade")&&(r.fade=this.getAttribute("fade")!=="false"),this.instance=Ee(this,r)}disconnectedCallback(){this.instance?.destroy(),this.instance=null}};typeof customElements<"u"&&!customElements.get("scroll-draw")&&customElements.define("scroll-draw",Oe);return at(dt);})();
|