@floor/vlist 0.7.5 → 0.7.7

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.
@@ -13,6 +13,7 @@
13
13
  * - Near-bottom interpolation — smooth blending near the end of the list
14
14
  * - Cached compression state — recalculates only when total item count changes
15
15
  * - Smooth scroll interpolation — lerp-based wheel handling for cross-browser consistency
16
+ * - Touch scroll support — finger tracking + momentum for iOS Safari / mobile browsers
16
17
  *
17
18
  * No configuration needed — compression activates automatically when the total
18
19
  * height exceeds the browser limit, and deactivates when items are removed.
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- var{defineProperty:Mj,getOwnPropertyNames:gJ,getOwnPropertyDescriptor:mJ}=Object,dJ=Object.prototype.hasOwnProperty;var pj=new WeakMap,cJ=(j)=>{var X=pj.get(j),$;if(X)return X;if(X=Mj({},"__esModule",{value:!0}),j&&typeof j==="object"||typeof j==="function")gJ(j).map((J)=>!dJ.call(X,J)&&Mj(X,J,{get:()=>j[J],enumerable:!($=mJ(j,J))||$.enumerable}));return pj.set(j,X),X};var lJ=(j,X)=>{for(var $ in X)Mj(j,$,{get:X[$],enumerable:!0,configurable:!0,set:(J)=>X[$]=()=>J})};var uj=(j,X)=>()=>(j&&(X=j(j=0)),X);var Ej=200,x2=50,gj=15,mj=2,dj=50,z2=16000000;var K4=(j,X)=>{let $=X;return{getOffset:(J)=>J*j,getHeight:(J)=>j,indexAtOffset:(J)=>{if($===0||j===0)return 0;return Math.max(0,Math.min(Math.floor(J/j),$-1))},getTotalHeight:()=>$*j,getTotal:()=>$,rebuild:(J)=>{$=J},isVariable:()=>!1}},Y4=(j,X)=>{let $=X,J=new Float64Array(0),K=(q)=>{$=q,J=new Float64Array(q+1),J[0]=0;for(let Z=0;Z<q;Z++)J[Z+1]=J[Z]+j(Z)};K(X);let Q=(q)=>{if($===0)return 0;if(q<=0)return 0;if(q>=J[$])return $-1;let Z=0,_=$-1;while(Z<_){let U=Z+_+1>>>1;if(J[U]<=q)Z=U;else _=U-1}return Z};return{getOffset:(q)=>{if(q<=0)return 0;if(q>=$)return J[$];return J[q]},getHeight:(q)=>j(q),indexAtOffset:(q)=>Q(q),getTotalHeight:()=>J[$]??0,getTotal:()=>$,rebuild:(q)=>K(q),isVariable:()=>!0}},cj=(j,X)=>{if(typeof j==="number")return K4(j,X);return Y4(j,X)},Fj=(j,X,$,J)=>{if(J===0)return 0;if(!j.isVariable())return Math.ceil($/j.getHeight(0));let K=0,Q=0,q=X;while(q<J&&Q<$)Q+=j.getHeight(q),K++,q++;return Math.max(1,K)},n2=(j,X,$)=>{if($===0)return 0;if(!j.isVariable())return Math.floor(X/j.getHeight(0));let J=0,K=0;for(let Q=$-1;Q>=0;Q--){let q=j.getHeight(Q);if(K+q>X)break;K+=q,J++}return Math.max(J,1)},Lj=(j,X,$)=>{if($===0)return 0;let J=Math.floor(X),K=X-J,Q=Math.max(0,Math.min(J,$-1));return j.getOffset(Q)+K*j.getHeight(Q)};var E2=(j,X)=>{let $=X.getTotalHeight(),J=$>z2,K=J?z2:$,Q=$>0?K/$:1;return{isCompressed:J,actualHeight:$,virtualHeight:K,ratio:Q}},o2=(j,X,$,J,K,Q)=>{if(J===0||X===0)return Q.start=0,Q.end=-1,Q;if(!K.isCompressed){let N=$.indexAtOffset(j),B=$.indexAtOffset(j+X);if(B<J-1)B++;return Q.start=Math.max(0,N),Q.end=Math.min(J-1,Math.max(0,B)),Q}let{virtualHeight:q}=K,_=j/q*J,U=Math.floor(_),D=Fj($,Math.max(0,U),X,J),L=Math.ceil(_)+D,y=q-X-j;if(y<=X&&y>=-1){let N=n2($,X,J),B=Math.max(0,J-N),W=Math.max(0,Math.min(1,1-y/X));U=Math.floor(U+(B-U)*W),L=y<=1?J-1:Math.min(J-1,U+D)}return Q.start=Math.max(0,U),Q.end=Math.min(J-1,Math.max(0,L)),Q},lj=(j,X,$,J)=>{if($===0)return J.start=0,J.end=-1,J;return J.start=Math.max(0,j.start-X),J.end=Math.min($-1,j.end+X),J},T2=(j,X,$,J,K,Q,q)=>{if(!Q.isCompressed||J===0)return $.getOffset(j);let{virtualHeight:Z}=Q,_=Z-K,U=_-X;if(U<=K&&U>=-1){if(X>=_-1){let V=$.getTotalHeight()-$.getOffset(j);return K-V}let y=n2($,K,J),N=Math.max(0,J-y),W=X/Z*J,A=Math.max(0,Math.min(1,1-U/K)),E=$.getOffset(j)-$.getOffset(N),H=$.getOffset(j)-Lj($,W,J);return H+(E-H)*A}let D=X/Z,L=$.getTotalHeight(),z=D*L;return $.getOffset(j)-z},i2=(j,X,$,J,K,Q="start")=>{if(J===0)return 0;let q;if(K.isCompressed){if(Q==="end"&&j===J-1)return Math.max(0,K.virtualHeight-$);q=j/J*K.virtualHeight}else q=X.getOffset(j);let Z=X.getHeight(j);switch(Q){case"center":q-=($-Z)/2;break;case"end":q-=$-Z;break}let _=K.virtualHeight-$;return Math.max(0,Math.min(q,_))},sj=(j,X,$,J)=>{if($===0)return 0;if(J.isCompressed){let K=j/J.virtualHeight;return Math.floor(K*$)}return X.indexAtOffset(j)},aj=(j,X)=>{if(typeof X==="number")return j*X>z2;return X.getTotalHeight()>z2},rj=(j)=>{if(j<=0)return 0;return Math.floor(z2/j)},nj=(j,X)=>{let $=E2(j,X);if(!$.isCompressed)return`No compression needed (${j} items, ${($.actualHeight/1e6).toFixed(2)}M px)`;return`Compressed to ${($.ratio*100).toFixed(1)}% (${j} items, ${($.actualHeight/1e6).toFixed(1)}M px → ${($.virtualHeight/1e6).toFixed(1)}M px virtual)`};var t2=()=>{};var P2=(j)=>{return j!==null&&typeof j==="object"&&j.__groupHeader===!0};var _J={};lJ(_J,{createGridRenderer:()=>d2});var W4=(j=200)=>{let X=[];return{acquire:()=>{let Q=X.pop();if(Q)return Q;let q=document.createElement("div");return q.setAttribute("role","option"),q},release:(Q)=>{if(X.length<j)Q.className="",Q.textContent="",Q.removeAttribute("style"),Q.removeAttribute("data-index"),Q.removeAttribute("data-id"),Q.removeAttribute("data-row"),Q.removeAttribute("data-col"),X.push(Q)},clear:()=>{X.length=0}}},d2=(j,X,$,J,K,Q,q,Z)=>{let _=W4(),U=new Map,D=Q,L=!1,z=null,y=0,N="",B=(b)=>{if(z&&y===b)return z;return z=E2(b,$),y=b,z},W={selected:!1,focused:!1},A=(b,w)=>{return W.selected=b,W.focused=w,W},E=`${K}-item ${K}-grid-item`,H=`${K}-item--selected`,V=`${K}-item--focused`,O=(b,w)=>{if(typeof w==="string")b.innerHTML=w;else b.replaceChildren(w)},M=(b,w,h)=>{b.classList.toggle(H,w),b.classList.toggle(V,h)},R=(b,w)=>{let h=J.getRow(b);if(w){let d=w.totalItems,c=B(d);if(c.isCompressed)return T2(h,w.scrollTop,$,d,w.containerHeight,c,w.rangeStart)}return $.getOffset(h)},G=(b,w,h)=>{let d=b.dataset.id?.startsWith("__group_header"),c=d?0:J.getCol(w),r=d?0:J.getColumnOffset(c,D),B2;if(L){let K2=J.getRow(w),C=0,l=new Set;for(let u=0;u<w;u++){let $2=J.getRow(u);if($2<K2&&!l.has($2)){let n=$.getHeight(u);C+=n,l.add($2)}}B2=C}else B2=R(w,h);b.style.transform=`translate(${Math.round(r)}px, ${Math.round(B2)}px)`},k=(b,w)=>{let h=b.dataset.id?.startsWith("__group_header"),d=h?D:J.getColumnWidth(D),c;if(L||h)c=$.getHeight(w)-J.gap;else{let r=J.getRow(w);c=$.getHeight(r)-J.gap}b.style.width=`${d}px`,b.style.height=`${c}px`},g=(b,w,h,d,c)=>{let r=_.acquire(),B2=A(h,d);if(r.className=E,r.dataset.index=String(b),r.dataset.id=String(w.id),r.dataset.row=String(J.getRow(b)),r.dataset.col=String(J.getCol(b)),r.ariaSelected=String(h),Z)r.id=`${Z}-item-${b}`;if(q)N=String(q()),r.setAttribute("aria-setsize",N),r.setAttribute("aria-posinset",String(b+1));k(r,b);let K2=X(w,b,B2);return O(r,K2),M(r,h,d),G(r,b,c),r},t=(b,w,h,d,c)=>{if(w.start===0&&b.length>0)L=P2(b[0]);for(let[C,l]of U)if(C<w.start||C>w.end)l.element.remove(),_.release(l.element),U.delete(C);let r=!1;if(q){let C=String(q());r=C!==N,N=C}let B2=document.createDocumentFragment(),K2=[];for(let C=w.start;C<=w.end;C++){let l=C-w.start,u=b[l];if(!u){console.warn(`⚠️ RENDER: Missing item at index ${C} (range: ${w.start}-${w.end}, items.length: ${b.length})`);continue}let $2=h.has(u.id),n=C===d,Q2=U.get(C);if(Q2){let D2=Q2.element.dataset.id,v=String(u.id);if(D2!==v){let o=A($2,n),m=X(u,C,o);O(Q2.element,m),Q2.element.dataset.id=v,Q2.element.dataset.row=String(J.getRow(C)),Q2.element.dataset.col=String(J.getCol(C)),k(Q2.element,C)}if(M(Q2.element,$2,n),Q2.element.ariaSelected=String($2),G(Q2.element,C,c),r)Q2.element.setAttribute("aria-setsize",N)}else{let D2=g(C,u,$2,n,c);B2.appendChild(D2),K2.push({index:C,element:D2})}}if(K2.length>0){j.appendChild(B2);for(let{index:C,element:l}of K2)U.set(C,{index:C,element:l})}},s=(b)=>{for(let[w,h]of U)G(h.element,w,b)},j2=(b,w,h,d)=>{let c=U.get(b);if(c){let r=A(h,d),B2=X(w,b,r);O(c.element,B2),M(c.element,h,d),c.element.dataset.id=String(w.id),c.element.ariaSelected=String(h),k(c.element,b)}},e=(b,w,h)=>{let d=U.get(b);if(d)M(d.element,w,h)},T=(b)=>{return U.get(b)?.element},S=(b)=>{if(Math.abs(b-D)<1)return;D=b;for(let[w,h]of U)k(h.element,w),G(h.element,w)},I=()=>{for(let[,b]of U)b.element.remove(),_.release(b.element);U.clear()};return{render:t,updatePositions:s,updateItem:j2,updateItemClasses:e,getElement:T,updateContainerWidth:S,clear:I,destroy:()=>{I(),_.clear()}}};var Yj=uj(()=>{t2()});var sJ=0,k2=5,aJ=100,Aj=2,rJ=(j=0)=>{let X=Array(k2);for(let $=0;$<k2;$++)X[$]={position:0,time:0};return{velocity:0,lastPosition:j,lastTime:performance.now(),samples:X,sampleIndex:0,sampleCount:0}},nJ=(j,X)=>{let $=performance.now(),J=$-j.lastTime;if(J===0)return j;if(J>aJ){j.sampleCount=0,j.sampleIndex=0,j.velocity=0;let Q=j.samples[0];return Q.position=X,Q.time=$,j.sampleIndex=1,j.sampleCount=1,j.lastPosition=X,j.lastTime=$,j}let K=j.samples[j.sampleIndex];if(K.position=X,K.time=$,j.sampleIndex=(j.sampleIndex+1)%k2,j.sampleCount=Math.min(j.sampleCount+1,k2),j.sampleCount>=Aj){let Q=(j.sampleIndex-j.sampleCount+k2)%k2,q=j.samples[Q],Z=X-q.position,_=$-q.time;j.velocity=_>0?Math.abs(Z)/_:0}return j.lastPosition=X,j.lastTime=$,j},xj=(j,X)=>{if(typeof j==="number"){let Q=X;return{getOffset:(q)=>q*j,getHeight:()=>j,indexAtOffset:(q)=>{if(Q===0||j===0)return 0;return Math.max(0,Math.min(Math.floor(q/j),Q-1))},getTotalHeight:()=>Q*j,getTotal:()=>Q,rebuild:(q)=>{Q=q},isVariable:()=>!1}}let $=X,J=new Float64Array(0),K=(Q)=>{$=Q,J=new Float64Array(Q+1),J[0]=0;for(let q=0;q<Q;q++)J[q+1]=J[q]+j(q)};return K(X),{getOffset:(Q)=>{if(Q<=0)return 0;if(Q>=$)return J[$];return J[Q]},getHeight:(Q)=>j(Q),indexAtOffset:(Q)=>{if($===0)return 0;if(Q<=0)return 0;if(Q>=J[$])return $-1;let q=0,Z=$-1;while(q<Z){let _=q+Z+1>>>1;if(J[_]<=Q)q=_;else Z=_-1}return q},getTotalHeight:()=>J[$]??0,getTotal:()=>$,rebuild:(Q)=>K(Q),isVariable:()=>!0}},oJ=()=>{let j={},X=(Q,q)=>{if(!j[Q])j[Q]=new Set;return j[Q].add(q),()=>$(Q,q)},$=(Q,q)=>{j[Q]?.delete(q)};return{on:X,off:$,emit:(Q,q)=>{j[Q]?.forEach((Z)=>{try{Z(q)}catch(_){console.error(`[vlist] Error in "${Q}" handler:`,_)}})},clear:()=>{for(let Q in j)delete j[Q]}}},iJ=(j)=>{if(typeof j==="string"){let X=document.querySelector(j);if(!X)throw Error(`[vlist/builder] Container not found: ${j}`);return X}return j},tJ=(j,X,$,J)=>{let K=document.createElement("div");if(K.className=X,J)K.classList.add(`${X}--horizontal`);if(K.setAttribute("role","listbox"),K.setAttribute("tabindex","0"),$)K.setAttribute("aria-label",$);if(J)K.setAttribute("aria-orientation","horizontal");let Q=document.createElement("div");if(Q.className=`${X}-viewport`,J)Q.style.overflowX="auto",Q.style.overflowY="hidden";else Q.style.overflow="auto";Q.style.height="100%",Q.style.width="100%";let q=document.createElement("div");if(q.className=`${X}-content`,q.style.position="relative",J)q.style.height="100%";else q.style.width="100%";let Z=document.createElement("div");if(Z.className=`${X}-items`,Z.style.position="relative",J)Z.style.height="100%";else Z.style.width="100%";return q.appendChild(Z),Q.appendChild(q),K.appendChild(Q),j.appendChild(K),{root:K,viewport:Q,content:q,items:Z}},eJ=(j=100)=>{let X=[];return{acquire:()=>{let $=X.pop();if($)return $;let J=document.createElement("div");return J.setAttribute("role","option"),J},release:($)=>{if(X.length<j)$.className="",$.textContent="",$.removeAttribute("style"),$.removeAttribute("data-index"),$.removeAttribute("data-id"),X.push($)},clear:()=>{X.length=0}}},j4=(j,X,$,J,K)=>{if(J===0||X===0){K.start=0,K.end=0;return}let Q=$.indexAtOffset(j),q=$.indexAtOffset(j+X);if(q<J-1)q++;K.start=Math.max(0,Q),K.end=Math.min(J-1,Math.max(0,q))},J4=(j,X,$,J)=>{if($===0){J.start=0,J.end=0;return}J.start=Math.max(0,j.start-X),J.end=Math.min($-1,j.end+X)},$4=(j,X,$,J,K)=>{if(J===0)return 0;let Q=Math.max(0,Math.min(j,J-1)),q=X.getOffset(Q),Z=X.getHeight(Q),_=Math.max(0,X.getTotalHeight()-$),U;switch(K){case"center":U=q-($-Z)/2;break;case"end":U=q-$+Z;break;default:U=q}return Math.max(0,Math.min(U,_))},Q4=(j)=>j<0.5?2*j*j:-1+(4-2*j)*j,X4=(j)=>{if(typeof j==="string")return{align:j,behavior:"auto",duration:300};if(j&&typeof j==="object")return{align:j.align??"start",behavior:j.behavior??"auto",duration:j.duration??300};return{align:"start",behavior:"auto",duration:300}},hj=(j)=>{if(!j.container)throw Error("[vlist/builder] Container is required");if(!j.item)throw Error("[vlist/builder] item configuration is required");let X=j.direction==="horizontal",$=X?"width":"height",J=X?j.item.width:j.item.height;if(J==null)throw Error(`[vlist/builder] item.${$} is required${X?" when direction is 'horizontal'":""}`);if(typeof J==="number"&&J<=0)throw Error(`[vlist/builder] item.${$} must be a positive number`);if(typeof J!=="number"&&typeof J!=="function")throw Error(`[vlist/builder] item.${$} must be a number or a function (index) => number`);if(!j.item.template)throw Error("[vlist/builder] item.template is required");if(X&&j.reverse)throw Error("[vlist/builder] horizontal direction cannot be combined with reverse mode");let K=new Map,Q=!1,q={use(Z){if(Q)throw Error("[vlist/builder] Cannot call .use() after .build()");return K.set(Z.name,Z),q},build(){if(Q)throw Error("[vlist/builder] .build() can only be called once");return Q=!0,q4(j,K,X,J)}};return q};function q4(j,X,$,J){let{item:K,items:Q,overscan:q=3,classPrefix:Z="vlist",ariaLabel:_,reverse:U=!1,scroll:D}=j,L=D?.wheel??!0,z=D?.wrap??!1,y=U,N=`${Z}-${sJ++}`,B=J,W=$?typeof K.height==="number"?K.height:void 0:typeof K.width==="number"?K.width:void 0,A=K.template,E={overscan:q,classPrefix:Z,reverse:y,wrap:z,horizontal:$,ariaIdPrefix:N},H=Array.from(X.values()).sort((Y,F)=>(Y.priority??50)-(F.priority??50)),V=new Set(H.map((Y)=>Y.name));for(let Y of H)if(Y.conflicts){for(let F of Y.conflicts)if(V.has(F))throw Error(`[vlist/builder] ${Y.name} and ${F} cannot be combined`)}if($){if(V.has("withGrid"))throw Error("[vlist/builder] withGrid cannot be used with direction: 'horizontal'");if(V.has("withGroups"))throw Error("[vlist/builder] withGroups cannot be used with direction: 'horizontal'")}if(y){if(V.has("withGrid"))throw Error("[vlist/builder] withGrid cannot be used with reverse: true")}let O=iJ(j.container),M=tJ(O,Z,_,$),R=oJ(),G=Q?[...Q]:[],k=xj(B,G.length),g=eJ(),t=M.viewport.clientHeight,s=M.viewport.clientWidth,j2=!1,e=!1,T=0,S=null,I=null,p=rJ(0),b={start:0,end:0},w={start:0,end:0},h={start:-1,end:-1},d={viewportState:{scrollTop:0,containerHeight:t,totalHeight:k.getTotalHeight(),actualHeight:k.getTotalHeight(),isCompressed:!1,compressionRatio:1,visibleRange:{start:0,end:0},renderRange:{start:0,end:0}},lastRenderRange:{start:-1,end:-1},isInitialized:!1,isDestroyed:!1,cachedCompression:null},c=new Map,r={selected:!1,focused:!1},B2=`${Z}-item`,K2="",C=new Map,l=()=>{C.clear();for(let Y=0;Y<G.length;Y++){let F=G[Y];if(F)C.set(F.id,Y)}};l();let u=null,$2=()=>u?u.getTotal():G.length,n=[],Q2=[],D2=[],v=[],x=[],o=[],m=new Map,q2=()=>{return $?M.viewport.scrollLeft:M.viewport.scrollTop},X2=(Y)=>{if($)M.viewport.scrollLeft=Y;else M.viewport.scrollTop=Y},M2=(Y=2)=>{let F=k.getTotalHeight();return T+t>=F-Y},A2=!1,J2,W2,L2=(Y,F,P,f,i)=>{j4(Y,F,P,f,i)},Y2=(Y,F,P,f,i)=>{return $4(Y,F,P,f,i)},_2=(Y,F)=>{if(typeof F==="string")Y.innerHTML=F;else Y.replaceChildren(F)},G2=(Y,F)=>{let P=Math.round(k.getOffset(F));if($)Y.style.transform=`translateX(${P}px)`;else Y.style.transform=`translateY(${P}px)`},H2=(Y,F)=>{let P=g.acquire();if(P.className=B2,$){if(P.style.width=`${k.getHeight(Y)}px`,W!=null)P.style.height=`${W}px`}else P.style.height=`${k.getHeight(Y)}px`;if(P.dataset.index=String(Y),P.dataset.id=String(F.id),P.ariaSelected="false",P.id=`${N}-item-${Y}`,K2=String($2()),P.setAttribute("aria-setsize",K2),P.setAttribute("aria-posinset",String(Y+1)),String(F.id).startsWith("__placeholder_"))P.classList.add(`${Z}-item--placeholder`);return _2(P,A(F,Y,r)),G2(P,Y),P},f2=()=>{let Y=`${k.getTotalHeight()}px`;if($)M.content.style.width=Y;else M.content.style.height=Y},Nj=new Set,Wj=-1,OJ=()=>{if(j2)return;let Y=$2();if(L2(T,t,k,Y,b),J4(b,q,Y,w),w.start===h.start&&w.end===h.end){if(A2)for(let[a,U2]of c)G2(U2,a);return}let F=String(Y),P=F!==K2;K2=F;for(let[a,U2]of c)if(a<w.start||a>w.end)U2.remove(),g.release(U2),c.delete(a);let f=document.createDocumentFragment(),i=[];for(let a=w.start;a<=w.end;a++){let U2=u?u.getItem(a):G[a];if(!U2)continue;let Z2=c.get(a);if(Z2){let F2=Z2.dataset.id,p2=String(U2.id);if(F2!==p2){let hJ=F2?.startsWith("__placeholder_"),Ij=p2.startsWith("__placeholder_");if(_2(Z2,A(U2,a,r)),Z2.dataset.id=p2,$)Z2.style.width=`${k.getHeight(a)}px`;else Z2.style.height=`${k.getHeight(a)}px`;if(Ij)Z2.classList.add(`${Z}-item--placeholder`);else Z2.classList.remove(`${Z}-item--placeholder`);if(hJ&&!Ij)Z2.classList.add(`${Z}-item--replaced`),setTimeout(()=>{Z2.classList.remove(`${Z}-item--replaced`)},300)}G2(Z2,a);let r2=Nj.has(U2.id),xJ=a===Wj;if(Z2.classList.toggle(`${Z}-item--selected`,r2),Z2.classList.toggle(`${Z}-item--focused`,xJ),Z2.ariaSelected=r2?"true":"false",P)Z2.setAttribute("aria-setsize",K2)}else{let F2=H2(a,U2),p2=Nj.has(U2.id),r2=a===Wj;if(p2)F2.classList.add(`${Z}-item--selected`),F2.ariaSelected="true";if(r2)F2.classList.add(`${Z}-item--focused`);f.appendChild(F2),i.push({index:a,element:F2})}}if(i.length>0){M.items.appendChild(f);for(let{index:a,element:U2}of i)c.set(a,U2)}h.start=w.start,h.end=w.end,d.lastRenderRange.start=w.start,d.lastRenderRange.end=w.end,d.viewportState.scrollTop=T,d.viewportState.visibleRange.start=b.start,d.viewportState.visibleRange.end=b.end,d.viewportState.renderRange.start=w.start,d.viewportState.renderRange.end=w.end,R.emit("range:change",{range:{start:w.start,end:w.end}})},zJ=()=>{h.start=-1,h.end=-1,J2()};J2=OJ,W2=zJ;let I2=()=>{if(j2)return;let Y=q2(),F=Y>=T?"down":"up";if(p=nJ(p,Y),!M.root.classList.contains(`${Z}--scrolling`))M.root.classList.add(`${Z}--scrolling`);T=Y,J2(),R.emit("scroll",{scrollTop:Y,direction:F}),R.emit("velocity:change",{velocity:p.velocity,reliable:p.sampleCount>=Aj});for(let P=0;P<n.length;P++)n[P](Y,F);if(I)clearTimeout(I);I=setTimeout(()=>{M.root.classList.remove(`${Z}--scrolling`),p.velocity=0,p.sampleCount=0,R.emit("velocity:change",{velocity:0,reliable:!1})},D?.idleTimeout??150)},s2=null,R2=M.viewport;if(R2.addEventListener("scroll",I2,{passive:!0}),$&&L)s2=(Y)=>{if(Y.deltaX)return;Y.preventDefault(),M.viewport.scrollLeft+=Y.deltaY},M.viewport.addEventListener("wheel",s2);let Cj=(Y)=>{let P=Y.target.closest("[data-index]");if(P){let f=parseInt(P.dataset.index??"-1",10);if(f>=0){let i=u?.getItem(f)??G[f];if(i){if(i.__groupHeader)return;R.emit("item:click",{item:i,index:f,event:Y})}}}for(let f=0;f<Q2.length;f++)Q2[f](Y)},bJ=(Y)=>{let P=Y.target.closest("[data-index]");if(P){let f=parseInt(P.dataset.index??"-1",10);if(f>=0){let i=u?.getItem(f)??G[f];if(i){if(i.__groupHeader)return;R.emit("item:dblclick",{item:i,index:f,event:Y})}}}},wj=(Y)=>{for(let F=0;F<D2.length;F++)D2[F](Y)};M.items.addEventListener("click",Cj),M.items.addEventListener("dblclick",bJ),M.root.addEventListener("keydown",wj);let Vj=!0,PJ=()=>s,yJ=()=>t,_j=new ResizeObserver((Y)=>{if(j2)return;for(let F of Y){let P=F.contentRect.height,f=F.contentRect.width,i=$?f:P;if(s=f,Math.abs(i-t)>1){if(t=i,d.viewportState.containerHeight=i,e)f2(),J2(),R.emit("resize",{height:P,width:f})}if(e)for(let a=0;a<v.length;a++)v[a](f,P)}});if(Vj)_j.observe(M.viewport);let N2={get dom(){return M},get heightCache(){return k},get emitter(){return R},get config(){return E},get rawConfig(){return j},get renderer(){return{render:(Y,F,P,f,i)=>{Nj=P,Wj=f,W2()},updateItemClasses:(Y,F,P)=>{let f=c.get(Y);if(!f)return;f.classList.toggle(`${Z}-item--selected`,F),f.classList.toggle(`${Z}-item--focused`,P),f.ariaSelected=F?"true":"false"},updatePositions:()=>{},updateItem:()=>{},getElement:(Y)=>c.get(Y)??null,clear:()=>{},destroy:()=>{}}},set renderer(Y){},get dataManager(){return u},set dataManager(Y){u=Y},get scrollController(){return Gj},set scrollController(Y){Gj=Y},state:d,getContainerWidth(){return s},afterScroll:n,clickHandlers:Q2,keydownHandlers:D2,resizeHandlers:v,contentSizeHandlers:x,destroyHandlers:o,methods:m,replaceTemplate(Y){A=Y},replaceRenderer(Y){},replaceDataManager(Y){u=Y},replaceScrollController(Y){Gj=Y},getItemsForRange(Y){let F=[];for(let P=Y.start;P<=Y.end;P++){let f=u?u.getItem(P):G[P];if(f)F.push(f)}return F},getAllLoadedItems(){if(u){let Y=u.getTotal(),F=[];for(let P=0;P<Y;P++){let f=u.getItem(P);if(f)F.push(f)}return F}return[...G]},getVirtualTotal(){return $2()},getCachedCompression(){return{isCompressed:!1,actualHeight:k.getTotalHeight(),virtualHeight:k.getTotalHeight(),ratio:1}},getCompressionContext(){return{scrollTop:T,totalItems:$2(),containerHeight:t,rangeStart:w.start}},renderIfNeeded(){J2()},forceRender(){W2()},invalidateRendered(){for(let[,Y]of c)Y.remove(),g.release(Y);c.clear()},getRenderFns(){return{renderIfNeeded:J2,forceRender:W2}},setRenderFns(Y,F){J2=Y,W2=F},setVirtualTotalFn(Y){$2=Y},rebuildHeightCache(Y){k.rebuild(Y??$2())},setHeightConfig(Y){k=xj(Y,$2())},updateContentSize(Y){let F=`${Y}px`;if($)M.content.style.width=F;else M.content.style.height=F},updateCompressionMode(){},setVisibleRangeFn(Y){L2=Y},setScrollToPosFn(Y){Y2=Y},setPositionElementFn(Y){G2=Y},setScrollFns(Y,F){q2=Y,X2=(P)=>{F(P),I2()}},setScrollTarget(Y){R2.removeEventListener("scroll",I2),R2=Y,R2.addEventListener("scroll",I2,{passive:!0})},getScrollTarget(){return R2},setContainerDimensions(Y){PJ=Y.width,yJ=Y.height,s=Y.width(),t=Y.height(),d.viewportState.containerHeight=t},disableViewportResize(){if(Vj)Vj=!1,_j.unobserve(M.viewport)}};u={getState:()=>({total:G.length,cached:G.length,isLoading:!1,pendingRanges:[],error:void 0,hasMore:!1,cursor:void 0}),getTotal:()=>G.length,getCached:()=>G.length,getIsLoading:()=>!1,getHasMore:()=>!1,getStorage:()=>null,getPlaceholders:()=>null,getItem:(Y)=>G[Y],getItemById:(Y)=>{let F=C.get(Y);return F!==void 0?G[F]:void 0},getIndexById:(Y)=>C.get(Y)??-1,isItemLoaded:(Y)=>Y>=0&&Y<G.length&&G[Y]!==void 0,getItemsInRange:(Y,F)=>{let P=[],f=Math.max(0,Y),i=Math.min(F,G.length-1);for(let a=f;a<=i;a++)P.push(G[a]);return P},setTotal:(Y)=>{},setItems:(Y,F=0,P)=>{if(F===0&&(P!==void 0||G.length===0))G=[...Y];else{let f=F+Y.length;if(G.length<f)G.length=f;for(let i=0;i<Y.length;i++)G[F+i]=Y[i]}if(l(),e){k.rebuild($2()),f2(),N2.updateCompressionMode();for(let f=0;f<x.length;f++)x[f]();W2()}},updateItem:(Y,F)=>{let P=C.get(Y);if(P===void 0)return!1;let f=G[P];if(!f)return!1;if(G[P]={...f,...F},F.id!==void 0&&F.id!==Y)C.delete(Y),C.set(F.id,P);let i=c.get(P);if(i)_2(i,A(G[P],P,r)),i.dataset.id=String(G[P].id);return!0},removeItem:(Y)=>{let F=C.get(Y);if(F===void 0)return!1;if(G.splice(F,1),l(),e){k.rebuild($2()),f2(),N2.updateCompressionMode();for(let P=0;P<x.length;P++)x[P]();W2()}return!0},loadRange:async()=>{},ensureRange:async()=>{},loadInitial:async()=>{},loadMore:async()=>!1,reload:async()=>{},evictDistant:()=>{},clear:()=>{G=[],C.clear()},reset:()=>{if(G=[],C.clear(),e)k.rebuild(0),f2(),W2()}};let Gj={getScrollTop:()=>q2(),scrollTo:(Y)=>{X2(Y),T=Y,J2()},scrollBy:(Y)=>{let F=q2()+Y;X2(F),T=F,J2()},isAtTop:()=>T<=2,isAtBottom:(Y=2)=>M2(Y),getScrollPercentage:()=>{let Y=k.getTotalHeight(),F=Math.max(0,Y-t);return F>0?T/F:0},getVelocity:()=>p.velocity,isTracking:()=>p.sampleCount>=Aj,isScrolling:()=>M.root.classList.contains(`${Z}--scrolling`),updateConfig:()=>{},enableCompression:()=>{A2=!0},disableCompression:()=>{A2=!1},isCompressed:()=>A2,isWindowMode:()=>!1,updateContainerHeight:(Y)=>{t=Y},destroy:()=>{}},Sj=new Map;for(let Y of H)if(Y.methods)for(let F of Y.methods){let P=Sj.get(F);if(P)throw Error(`[vlist/builder] Method "${F}" is registered by both "${P}" and "${Y.name}"`);Sj.set(F,Y.name)}for(let Y of H)Y.setup(N2);if(e=!0,N2.state.isInitialized=!0,f2(),J2(),y&&G.length>0){let Y=Y2(G.length-1,k,t,G.length,"end");X2(Y),T=Y,J2()}let HJ=(Y)=>{N2.dataManager.setItems(Y,0,Y.length)},RJ=y?(Y)=>{let F=M2(2),P=G.length;if(N2.dataManager.setItems(Y,P),F&&G.length>0){let f=Y2(G.length-1,k,t,G.length,"end");X2(f),T=f,J2()}}:(Y)=>{let F=G.length;N2.dataManager.setItems(Y,F)},kJ=y?(Y)=>{let F=q2(),P=k.getTotalHeight(),f=[...G];N2.dataManager.clear(),N2.dataManager.setItems([...Y,...f],0);let a=k.getTotalHeight()-P;if(a>0)X2(F+a),T=F+a}:(Y)=>{let F=[...G];N2.dataManager.clear(),N2.dataManager.setItems([...Y,...F],0)},TJ=(Y,F)=>{N2.dataManager.updateItem(Y,F)},CJ=(Y)=>{N2.dataManager.removeItem(Y)},wJ=async()=>{if(N2.dataManager.reload)await N2.dataManager.reload()},a2=()=>{if(S!==null)cancelAnimationFrame(S),S=null},SJ=(Y,F,P)=>{if(a2(),Math.abs(F-Y)<1){X2(F),T=F,J2();return}let f=performance.now(),i=(a)=>{let U2=a-f,Z2=Math.min(U2/P,1),F2=Y+(F-Y)*Q4(Z2);if(X2(F2),T=F2,J2(),Z2<1)S=requestAnimationFrame(i);else S=null};S=requestAnimationFrame(i)},vj=(Y,F)=>{let{align:P,behavior:f,duration:i}=X4(F),a=$2(),U2=Y;if(z&&a>0)U2=(U2%a+a)%a;let Z2=Y2(U2,k,t,a,P);if(f==="smooth")SJ(q2(),Z2,i);else a2(),X2(Z2)},vJ=(Y,F)=>{let P=C.get(Y)??N2.dataManager.getIndexById(Y);if(P>=0)vj(P,F)},fJ=()=>q2(),IJ=(Y,F)=>{return R.on(Y,F)},pJ=(Y,F)=>{R.off(Y,F)},uJ=()=>{if(j2)return;if(j2=!0,N2.state.isDestroyed=!0,M.items.removeEventListener("click",Cj),M.root.removeEventListener("keydown",wj),R2.removeEventListener("scroll",I2),_j.disconnect(),s2)M.viewport.removeEventListener("wheel",s2);if(I)clearTimeout(I);for(let Y=0;Y<o.length;Y++)o[Y]();for(let Y of H)if(Y.destroy)Y.destroy();a2();for(let[,Y]of c)Y.remove(),g.release(Y);c.clear(),g.clear(),R.clear(),M.root.remove()},fj={get element(){return M.root},get items(){if(m.has("_getItems"))return m.get("_getItems")();return G},get total(){if(m.has("_getTotal"))return m.get("_getTotal")();return $2()},setItems:m.has("setItems")?m.get("setItems"):HJ,appendItems:m.has("appendItems")?m.get("appendItems"):RJ,prependItems:m.has("prependItems")?m.get("prependItems"):kJ,updateItem:m.has("updateItem")?m.get("updateItem"):TJ,removeItem:m.has("removeItem")?m.get("removeItem"):CJ,reload:m.has("reload")?m.get("reload"):wJ,scrollToIndex:m.has("scrollToIndex")?m.get("scrollToIndex"):vj,scrollToItem:m.has("scrollToItem")?m.get("scrollToItem"):vJ,cancelScroll:m.has("cancelScroll")?m.get("cancelScroll"):a2,getScrollPosition:m.has("getScrollPosition")?m.get("getScrollPosition"):fJ,on:IJ,off:pJ,destroy:uJ};for(let[Y,F]of m){if(Y==="setItems"||Y==="appendItems"||Y==="prependItems"||Y==="updateItem"||Y==="removeItem"||Y==="reload"||Y==="scrollToIndex"||Y==="scrollToItem"||Y==="cancelScroll"||Y==="getScrollPosition")continue;fj[Y]=F}return fj}t2();var C2=(j,X,$={},J="vlist",K=!1)=>{let{autoHide:Q=!0,autoHideDelay:q=1000,minThumbSize:Z=30,showOnHover:_=!0,hoverZoneWidth:U=16,showOnViewportEnter:D=!0}=$,L=0,z=0,y=0,N=0,B=!1,W=!1,A=0,E=0,H=0,V=null,O=!1,M=null,R=null,G=K?"width":"height",k=K?"translateX":"translateY",g=K?(n)=>n.clientX:(n)=>n.clientY,t=K?"left":"top",s=document.createElement("div"),j2=document.createElement("div"),e=_?document.createElement("div"):null,T=()=>{if(s.className=`${J}-scrollbar`,j2.className=`${J}-scrollbar-thumb`,K)s.classList.add(`${J}-scrollbar--horizontal`);if(s.appendChild(j2),j.appendChild(s),e){if(e.className=`${J}-scrollbar-hover`,K)e.classList.add(`${J}-scrollbar-hover--horizontal`),e.style.height=`${U}px`;else e.style.width=`${U}px`;j.appendChild(e)}},S=()=>{if(V)clearTimeout(V),V=null},I=()=>{if(!Q)return;S(),V=setTimeout(b,q)},p=()=>{if(L<=z)return;if(S(),!O)s.classList.add(`${J}-scrollbar--visible`),O=!0;if(Q&&!B&&!W)I()},b=()=>{if(B||W)return;s.classList.remove(`${J}-scrollbar--visible`),O=!1},w=(n,Q2)=>{L=n,z=Q2;let D2=L>z;if(s.style.display=D2?"":"none",!D2){b();return}let v=z/L;y=Math.max(Z,v*z),j2.style[G]=`${y}px`,N=z-y,h(H)},h=(n)=>{if(H=n,L<=z||N<=0)return;let Q2=L-z,v=Math.min(1,Math.max(0,n/Q2))*N;j2.style.transform=`${k}(${v}px)`},d=(n)=>{if(n.target===j2)return;let Q2=s.getBoundingClientRect(),x=g(n)-Q2[t]-y/2,m=Math.max(0,Math.min(x,N))/N,q2=L-z,X2=m*q2;X(X2),p()},c=(n)=>{n.preventDefault(),n.stopPropagation(),B=!0,A=g(n),E=H,S(),s.classList.add(`${J}-scrollbar--dragging`),document.addEventListener("mousemove",r),document.addEventListener("mouseup",B2)},r=(n)=>{if(!B)return;let Q2=g(n)-A,D2=N>0?Q2/N:0,v=L-z,x=D2*v,o=Math.max(0,Math.min(E+x,v)),q2=o/v*N;if(j2.style.transform=`${k}(${q2}px)`,R=o,M===null)M=requestAnimationFrame(()=>{if(R!==null)X(R);M=null})},B2=()=>{if(B=!1,M!==null)cancelAnimationFrame(M),M=null;if(R!==null)X(R),R=null;if(s.classList.remove(`${J}-scrollbar--dragging`),Q&&!W)I();document.removeEventListener("mousemove",r),document.removeEventListener("mouseup",B2)},K2=()=>{if(D)p()},C=()=>{if(!B){if(W=!1,Q)I()}},l=()=>{W=!0,S(),p()},u=()=>{if(W=!1,!B&&Q)I()},$2=()=>{if(S(),M!==null)cancelAnimationFrame(M),M=null;if(s.removeEventListener("click",d),s.removeEventListener("mouseenter",l),s.removeEventListener("mouseleave",u),j2.removeEventListener("mousedown",c),j.removeEventListener("mouseenter",K2),j.removeEventListener("mouseleave",C),document.removeEventListener("mousemove",r),document.removeEventListener("mouseup",B2),e){if(e.removeEventListener("mouseenter",l),e.removeEventListener("mouseleave",u),e.parentNode)e.parentNode.removeChild(e)}if(s.parentNode)s.parentNode.removeChild(s)};if(T(),s.addEventListener("click",d),s.addEventListener("mouseenter",l),s.addEventListener("mouseleave",u),j2.addEventListener("mousedown",c),j.addEventListener("mouseenter",K2),j.addEventListener("mouseleave",C),e)e.addEventListener("mouseenter",l),e.addEventListener("mouseleave",u);return{show:p,hide:b,updateBounds:w,updatePosition:h,isVisible:()=>O,destroy:$2}};var oj=(j)=>{let X=null;return{name:"withScrollbar",priority:30,setup($){let{dom:J,config:K}=$,{classPrefix:Q,horizontal:q}=K;if(X=C2(J.viewport,(U)=>$.scrollController.scrollTo(U),j??{},Q,q),!J.viewport.classList.contains(`${Q}-viewport--custom-scrollbar`))J.viewport.classList.add(`${Q}-viewport--custom-scrollbar`);let Z=$.getCachedCompression();X.updateBounds(Z.virtualHeight,$.state.viewportState.containerHeight);let _=X;$.afterScroll.push((U,D)=>{_.updatePosition(U),_.show()}),$.resizeHandlers.push((U,D)=>{if(_){let L=$.getCachedCompression();_.updateBounds(L.virtualHeight,$.state.viewportState.containerHeight)}}),$.contentSizeHandlers.push(()=>{if(_){let U=$.getCachedCompression();_.updateBounds(U.virtualHeight,$.state.viewportState.containerHeight)}}),$.destroyHandlers.push(()=>{if(_)_.destroy()})},destroy(){if(X)X.destroy(),X=null}}};var ij=(j=0)=>{let X=[,,,,,,,,];for(let $=0;$<8;$++)X[$]={position:0,time:0};return{velocity:0,lastPosition:j,lastTime:performance.now(),samples:X,sampleIndex:0,sampleCount:0}},e2=(j,X)=>{let $=performance.now(),J=$-j.lastTime;if(J===0)return j;if(J>100){j.sampleCount=0,j.sampleIndex=0,j.velocity=0;let Q=j.samples[0];return Q.position=X,Q.time=$,j.sampleIndex=1,j.sampleCount=1,j.lastPosition=X,j.lastTime=$,j}let K=j.samples[j.sampleIndex];if(K.position=X,K.time=$,j.sampleIndex=(j.sampleIndex+1)%8,j.sampleCount=Math.min(j.sampleCount+1,8),j.sampleCount>=2){let Q=(j.sampleIndex-j.sampleCount+8)%8,q=j.samples[Q],Z=X-q.position,_=$-q.time;j.velocity=_>0?Z/_:0}return j.lastPosition=X,j.lastTime=$,j},Z4=(j)=>j.sampleCount>=3,tj=(j,X={})=>{let{wheel:$=!0,sensitivity:J=1,smoothing:K=!1,idleTimeout:Q=150,onScroll:q,onIdle:Z,scrollElement:_,horizontal:U=!1}=X,D=!!_,L=0,z=0,y=D?U?window.innerWidth:window.innerHeight:U?j.clientWidth:j.clientHeight,N=X.compressed??!1,B=X.compression,W=ij(),A=!1,E=null,V=jj(()=>{let C=U?j.scrollLeft:j.scrollTop,l=C>=L?"down":"up";if(W=e2(W,C),L=C,q)q({scrollTop:L,direction:l,velocity:W.velocity});g()}),M=jj(()=>{let C=j.getBoundingClientRect(),l=U?Math.max(0,-C.left):Math.max(0,-C.top),u=l>=L?"down":"up";if(W=e2(W,l),L=l,!A)A=!0;if(q)q({scrollTop:L,direction:u,velocity:W.velocity});g()}),R=(C)=>{C.preventDefault()},G=(C)=>{if(C.deltaX)return;C.preventDefault(),j.scrollLeft+=C.deltaY},k=(C)=>{if(!N)return;C.preventDefault();let l=(U?C.deltaX||C.deltaY:C.deltaY)*J,u=L+l;if(K)u=L+l*0.3;if(u=Math.max(0,Math.min(u,z)),u!==L){let n=u>=L?"down":"up";if(W=e2(W,u),L=u,!A)A=!0;if(q)q({scrollTop:L,direction:n,velocity:W.velocity});g()}},g=()=>{if(E)clearTimeout(E);E=setTimeout(()=>{if(A=!1,W=ij(L),Z)Z()},Q)},t=(C)=>{if(N)return;if(N=!0,B=C,z=C.virtualHeight-y,D)return;if(V.cancel(),j.removeEventListener("scroll",V),!$)j.removeEventListener("wheel",R);else if(U)j.removeEventListener("wheel",G);if(U)j.style.overflowX="hidden";else j.style.overflow="hidden";if($)j.addEventListener("wheel",k,{passive:!1});let l=U?j.scrollLeft:j.scrollTop;if(l>0){let u=U?B?.actualHeight??j.scrollWidth:B?.actualHeight??j.scrollHeight;L=l/u*z}if(U)j.scrollLeft=0;else j.scrollTop=0},s=()=>{if(!N)return;if(N=!1,D){B=void 0;return}if(j.removeEventListener("wheel",k),U)j.style.overflowX="auto";else j.style.overflow="auto";if(j.addEventListener("scroll",V,{passive:!0}),!$)j.addEventListener("wheel",R,{passive:!1});else if(U)j.addEventListener("wheel",G,{passive:!1});if(B&&L>0){let l=L/z*(B.actualHeight-y);if(U)j.scrollLeft=l;else j.scrollTop=l}B=void 0},j2=()=>{if(D||N)return L;return U?j.scrollLeft:j.scrollTop},e=(C,l=!1)=>{let u=Math.max(0,Math.min(C,z||1/0));if(D){let $2=j.getBoundingClientRect();if(U){let n=$2.left+window.scrollX;window.scrollTo({left:n+u,behavior:l?"smooth":"auto"})}else{let n=$2.top+window.scrollY;window.scrollTo({top:n+u,behavior:l?"smooth":"auto"})}}else if(N){if(u===L)return;let n=u>=L?"down":"up";if(W=e2(W,u),L=u,!A)A=!0;if(q)q({scrollTop:L,direction:n,velocity:W.velocity});g()}else if(U)j.scrollTo({left:u,behavior:l?"smooth":"auto"});else j.scrollTo({top:u,behavior:l?"smooth":"auto"})},T=(C)=>{e(j2()+C)},S=()=>{return j2()<=0},I=(C=0)=>{let l=j2(),u=D||N?z:U?j.scrollWidth-j.clientWidth:j.scrollHeight-j.clientHeight;return l>=u-C},p=()=>{let C=j2(),l=D||N?z:U?j.scrollWidth-j.clientWidth:j.scrollHeight-j.clientHeight;if(l<=0)return 0;return Math.min(1,Math.max(0,C/l))},b=(C)=>{if(C.compression)B=C.compression,z=B.virtualHeight-y},w=()=>N,h=()=>Math.abs(W.velocity),d=()=>Z4(W),c=()=>A,r=()=>D,B2=(C)=>{if(y=C,B)z=B.virtualHeight-y},K2=()=>{if(E)clearTimeout(E);if(D)M.cancel(),window.removeEventListener("scroll",M);else V.cancel(),j.removeEventListener("scroll",V),j.removeEventListener("wheel",k),j.removeEventListener("wheel",R),j.removeEventListener("wheel",G)};if(D){if(N&&B)z=B.virtualHeight-y;window.addEventListener("scroll",M,{passive:!0})}else if(N&&B){if(z=B.virtualHeight-y,U)j.style.overflowX="hidden";else j.style.overflow="hidden";if($)j.addEventListener("wheel",k,{passive:!1})}else{if(U)j.style.overflowX="auto",j.style.overflowY="hidden";else j.style.overflow="auto";if(j.addEventListener("scroll",V,{passive:!0}),!$)j.addEventListener("wheel",R,{passive:!1});else if(U)j.addEventListener("wheel",G,{passive:!1})}return{getScrollTop:j2,scrollTo:e,scrollBy:T,isAtTop:S,isAtBottom:I,getScrollPercentage:p,getVelocity:h,isTracking:d,isScrolling:c,updateConfig:b,enableCompression:t,disableCompression:s,isCompressed:w,isWindowMode:r,updateContainerHeight:B2,destroy:K2}},jj=(j)=>{let X=null,$=null,J=(...K)=>{if($=K,X===null)X=requestAnimationFrame(()=>{if(X=null,$)j(...$)})};return J.cancel=()=>{if(X!==null)cancelAnimationFrame(X),X=null},J};var B4=0.65,U4=0.5,ej=()=>{let j=null,X=0,$=!1,J=0,K=null;return{name:"withScale",priority:20,setup(Q){let{dom:q,config:Z}=Q,{classPrefix:_,horizontal:U}=Z,D=()=>{let N=Q.getVirtualTotal(),B=E2(N,Q.heightCache);if(B.isCompressed&&!$){$=!0,Q.scrollController.enableCompression(B),Q.updateContentSize(B.virtualHeight),Q.setScrollFns(()=>X,(V)=>{if(X=V,J=V,K!==null)cancelAnimationFrame(K),K=null});let W=()=>{let V=J-X;if(Math.abs(V)<U4)X=J,K=null;else X+=V*B4,K=requestAnimationFrame(W);Q.scrollController.scrollTo(X)},A=q.viewport,E=(V)=>{V.preventDefault();let M=Q.getCachedCompression().virtualHeight-Q.state.viewportState.containerHeight;if(J=Math.max(0,Math.min(J+V.deltaY,M)),K===null)K=requestAnimationFrame(W)};if(A.addEventListener("wheel",E,{passive:!1}),Q.destroyHandlers.push(()=>{if(A.removeEventListener("wheel",E),K!==null)cancelAnimationFrame(K),K=null}),!q.viewport.querySelector(`.${_}-scrollbar-track`)){if(j=C2(q.viewport,(O)=>Q.scrollController.scrollTo(O),{},_,U),!q.viewport.classList.contains(`${_}-viewport--custom-scrollbar`))q.viewport.classList.add(`${_}-viewport--custom-scrollbar`);j.updateBounds(B.virtualHeight,Q.state.viewportState.containerHeight);let V=j;Q.afterScroll.push((O,M)=>{if(V)V.updatePosition(O),V.show()}),Q.resizeHandlers.push((O,M)=>{if(V){let R=Q.getCachedCompression();V.updateBounds(R.virtualHeight,Q.state.viewportState.containerHeight)}})}}else if(!B.isCompressed&&$)$=!1,Q.scrollController.disableCompression(),Q.updateContentSize(B.actualHeight);else if(B.isCompressed)Q.scrollController.updateConfig({compression:B}),Q.updateContentSize(B.virtualHeight);if(j)j.updateBounds(B.virtualHeight,Q.state.viewportState.containerHeight);Q.state.cachedCompression={state:B,totalItems:N}};Q.updateCompressionMode=D;let L=Q.getCachedCompression.bind(Q);Q.getCachedCompression=()=>{if(Q.state.cachedCompression)return Q.state.cachedCompression.state;return L()},Q.setVisibleRangeFn((N,B,W,A,E)=>{z=null,y=null;let H=E2(A,W);o2(N,B,W,A,H,E)}),Q.setScrollToPosFn((N,B,W,A,E)=>{let H=E2(A,B);return i2(N,B,W,A,H,E)});let z=null,y=null;Q.setPositionElementFn((N,B)=>{let W=Q.getVirtualTotal(),A=E2(W,Q.heightCache);if(A.isCompressed){let E=Q.scrollController.getScrollTop();if(z===null||B<y)y=B,z=Math.round(T2(B,E,Q.heightCache,W,Q.state.viewportState.containerHeight,A));let H=z+Q.heightCache.getOffset(B)-Q.heightCache.getOffset(y),V=Q.config.horizontal;N.style.transform=V?`translateX(${H}px)`:`translateY(${H}px)`}else{let E=Math.round(Q.heightCache.getOffset(B)),H=Q.config.horizontal;N.style.transform=H?`translateX(${E}px)`:`translateY(${E}px)`}}),D(),Q.destroyHandlers.push(()=>{if(j)j.destroy(),j=null;if(K!==null)cancelAnimationFrame(K),K=null})},destroy(){if(j)j.destroy(),j=null;if(K!==null)cancelAnimationFrame(K),K=null}}};var Jj=(j={})=>{let{chunkSize:X=100,maxCachedItems:$=5000,evictionBuffer:J=200,onEvict:K}=j,Q=new Map,q=0,Z=0,_=(T)=>{let S=Q.get(T);if(!S)S={items:Array(X),count:0,lastAccess:Date.now()},Q.set(T,S);else S.lastAccess=Date.now();return S},U=(T)=>{return Math.floor(T/X)},D=(T)=>{return T%X},L=()=>q,z=(T)=>{q=T},y=(T)=>{if(T<0||T>=q)return;let S=U(T),I=Q.get(S);if(!I)return;return I.items[D(T)]},N=(T)=>{if(T<0||T>=q)return!1;let S=U(T),I=Q.get(S);if(!I)return!1;return I.items[D(T)]!==void 0},B=(T,S)=>{let I=U(T),p=_(I),b=D(T),w=p.items[b]===void 0;if(p.items[b]=S,w)p.count++,Z++;if(T>=q)q=T+1},W=(T,S)=>{for(let I=0;I<S.length;I++){let p=S[I];if(p!==void 0)B(T+I,p)}},A=(T)=>{if(T<0||T>=q)return!1;let S=U(T),I=Q.get(S);if(!I)return!1;let p=D(T);if(I.items[p]===void 0)return!1;if(I.items[p]=void 0,I.count--,Z--,I.count===0)Q.delete(S);return!0},E=(T,S)=>{let I=[];for(let p=T;p<=S&&p<q;p++)I.push(y(p));return I},H=(T,S)=>{for(let I=T;I<=S&&I<q;I++)if(!N(I))return!1;return!0},V=()=>{let T=[],S=null,I=Array.from(Q.keys()).sort((p,b)=>p-b);for(let p of I){let b=Q.get(p);if(!b)continue;let w=p*X;for(let h=0;h<X;h++){let d=w+h;if(d>=q)break;if(b.items[h]!==void 0)if(S===null)S={start:d,end:d};else if(d===S.end+1)S.end=d;else T.push(S),S={start:d,end:d};else if(S!==null)T.push(S),S=null}}if(S!==null)T.push(S);return T},O=(T,S)=>{let I=[],p=null;for(let b=T;b<=S&&b<q;b++)if(!N(b))if(p===null)p={start:b,end:b};else p.end=b;else if(p!==null)I.push(p),p=null;if(p!==null)I.push(p);return I},M=(T)=>{return Q.has(T)},R=(T)=>{let S=Q.get(T);if(S)S.lastAccess=Date.now()},G=(T,S)=>{if(T>S||Q.size===0)return;let I=Date.now(),p=U(Math.max(0,T)),b=U(Math.min(q-1,S));for(let w=p;w<=b;w++){let h=Q.get(w);if(h)h.lastAccess=I}},k=(T,S)=>{if(Z<=$)return 0;let I=Math.max(0,T-J),p=Math.min(q-1,S+J),b=U(I),w=U(p),h=0,d=[];for(let[c,r]of Q)if(c<b||c>w)h+=r.count,d.push(c),Z-=r.count,Q.delete(c);if(h>0&&K)K(h,d);return h},g=()=>{if(Z<=$)return 0;let T=Array.from(Q.entries()).sort(([,p],[,b])=>p.lastAccess-b.lastAccess),S=0,I=[];for(let[p,b]of T){if(Z<=$)break;S+=b.count,Z-=b.count,I.push(p),Q.delete(p)}if(S>0&&K)K(S,I);return S},t=()=>{return{totalItems:q,cachedItems:Z,cachedChunks:Q.size,chunkSize:X,maxCachedItems:$,memoryEfficiency:q>0?1-Z/q:1}},s=()=>Z,j2=()=>{Q.clear(),Z=0};return{chunkSize:X,maxCachedItems:$,getTotal:L,setTotal:z,get:y,has:N,set:B,setRange:W,delete:A,getRange:E,isRangeLoaded:H,getLoadedRanges:V,findUnloadedRanges:O,getChunkIndex:U,isChunkLoaded:M,touchChunk:R,touchChunksForRange:G,evictDistant:k,evictToLimit:g,getStats:t,getCachedCount:s,clear:j2,reset:()=>{j2(),q=0}}},$j=(j)=>{if(j.length===0)return[];let X=[...j].sort((J,K)=>J.start-K.start),$=[{...X[0]}];for(let J=1;J<X.length;J++){let K=X[J],Q=$[$.length-1];if(K.start<=Q.end+1)Q.end=Math.max(Q.end,K.end);else $.push({...K})}return $},h2=(j,X,$)=>{let J=Math.floor(j.start/$)*$,K=Math.ceil((j.end+1)/$)*$-1,Q={start:J,end:K};if(X.length===0)return[Q];let q=[],Z=$j(X),_=Q.start;for(let U of Z){if(U.end<_)continue;if(U.start>Q.end)break;if(U.start>_)q.push({start:_,end:Math.min(U.start-1,Q.end)});if(_=U.end+1,_>Q.end)break}if(_<=Q.end)q.push({start:_,end:Q.end});return q};var Qj=(j={})=>{let{enabled:X=!0,maskCharacter:$="█",randomVariance:J=!0,maxSampleSize:K=20,customGenerator:Q}=j,q=null,Z=!1,_=0,U=(A)=>{if(!X||Z||A.length===0)return;let E=new Map,H=new Map,V=Math.min(A.length,K);for(let O=0;O<V;O++){let M=A[O];if(!M||typeof M!=="object")continue;for(let[R,G]of Object.entries(M)){if(R.startsWith("_")||R==="id")continue;if(!H.has(R))H.set(R,{lengths:[],types:new Set});let k=H.get(R),g=Array.isArray(G)?"array":typeof G;if(k.types.add(g),typeof G==="string")k.lengths.push(G.length);else if(G!==null&&G!==void 0)k.lengths.push(String(G).length)}}for(let[O,M]of H){if(M.lengths.length===0)continue;let R=Math.min(...M.lengths),G=Math.max(...M.lengths),k=Math.round(M.lengths.reduce((t,s)=>t+s,0)/M.lengths.length),g="string";if(M.types.has("number")&&M.types.size===1)g="number";else if(M.types.has("boolean")&&M.types.size===1)g="boolean";else if(M.types.has("array"))g="array";else if(M.types.has("object")&&!M.types.has("string"))g="object";E.set(O,{minLength:R,maxLength:G,avgLength:k,type:g})}q=E,Z=!0},D=()=>Z,L=(A)=>{let E=A.avgLength;if(J&&A.minLength!==A.maxLength){if(E=Math.floor(Math.random()*(A.maxLength-A.minLength+1)+A.minLength),Math.random()<0.3)E=Math.max(1,E+Math.floor(Math.random()*3)-1)}return $.repeat(Math.max(1,E))},z=(A)=>{if(Q)return{...Q(A),["_isPlaceholder"]:!0};let E={id:`__placeholder_${_++}`,["_isPlaceholder"]:!0,_index:A};if(!q||q.size===0)return E.label=$.repeat(12),E;for(let[H,V]of q)switch(V.type){case"string":E[H]=L(V);break;case"number":E[H]=0;break;case"boolean":E[H]=!1;break;case"array":E[H]=[];break;case"object":E[H]={};break;default:E[H]=L(V)}return E};return{analyzeStructure:U,hasAnalyzedStructure:D,generate:z,generateRange:(A,E)=>{let H=[];for(let V=A;V<=E;V++)H.push(z(V));return H},isPlaceholder:(A)=>{if(!A||typeof A!=="object")return!1;return A._isPlaceholder===!0},getPlaceholderKey:()=>"_isPlaceholder",clear:()=>{q=null,Z=!1,_=0}}},b2=(j)=>{if(!j||typeof j!=="object")return!1;return j._isPlaceholder===!0},Oj=(j)=>{return j.filter((X)=>!b2(X))};var N4=50,Xj=(j={})=>{let{adapter:X,initialItems:$,initialTotal:J,storage:K,placeholder:Q,pageSize:q=N4,onStateChange:Z,onItemsLoaded:_,onItemsEvicted:U}=j,D=Jj({...K,onEvict:(v,x)=>{U?.(v),O()}}),L=null,z=()=>{if(!L)L=Qj(Q);return L},y=new Map,N=!1,B,W=!0,A,E=[],H=0,V=new Map,O=()=>{Z?.(e())},M=()=>{y.clear();let v=D.getLoadedRanges();for(let x of v)for(let o=x.start;o<=x.end;o++){let m=D.get(o);if(m&&!b2(m))y.set(m.id,o)}},R=(v,x)=>{if(!b2(x))y.set(x.id,v)},G=(v)=>{y.delete(v)},k=(v,x)=>{return`${v}-${x}`},g=()=>D.getTotal(),t=()=>D.getCachedCount(),s=()=>N,j2=()=>W,e=()=>({total:D.getTotal(),cached:D.getCachedCount(),isLoading:N,pendingRanges:E,error:B,hasMore:W,cursor:A}),T=()=>D,S=()=>z(),I=(v)=>{let x=D.get(v);if(x!==void 0)return x;if(v>=0&&v<D.getTotal())return z().generate(v);return},p=(v)=>{let x=y.get(v);if(x===void 0)return;return D.get(x)},b=(v)=>{return y.get(v)??-1},w=(v)=>{let x=D.get(v);return x!==void 0&&!b2(x)},h=(v,x)=>{let o=[],m=D.getTotal(),q2=0,X2=0;D.touchChunksForRange(v,Math.min(x,m-1));for(let M2=v;M2<=x&&M2<m;M2++){let A2=D.get(M2);if(A2!==void 0)o.push(A2),q2++;else o.push(z().generate(M2)),X2++}return o},d=(v)=>{D.setTotal(v),W=D.getCachedCount()<v,O()},c=(v,x=0,o)=>{if(L&&!L.hasAnalyzedStructure()&&v.length>0)L.analyzeStructure(v);for(let m=0;m<v.length;m++){let q2=v[m];if(q2!==void 0){let X2=x+m;D.set(X2,q2),R(X2,q2)}}if(o!==void 0)D.setTotal(o);else if(x+v.length>D.getTotal())D.setTotal(x+v.length);if(D.getCachedCount()>=D.getTotal()&&D.getTotal()>0)W=!1;_?.(v,x,D.getTotal()),O()},r=(v,x)=>{let o=y.get(v);if(o===void 0)return!1;let m=D.get(o);if(!m)return!1;let q2={...m,...x};if(D.set(o,q2),x.id!==void 0&&x.id!==v)G(v),R(o,q2);return O(),!0},B2=(v)=>{let x=y.get(v);if(x===void 0)return!1;D.delete(x),G(v);let o=D.getTotal();if(o>0)D.setTotal(o-1);return O(),!0},K2=async(v,x)=>{if(!X)return;let o=k(v,x);if(V.has(o))return;let m=D.getLoadedRanges(),q2=h2({start:v,end:x},m,D.chunkSize);if(q2.length===0)return;let X2=D.chunkSize,M2=[];for(let J2 of q2){let W2=Math.floor(J2.start/X2),L2=Math.floor(J2.end/X2);for(let Y2=W2;Y2<=L2;Y2++){let _2=Y2*X2,V2=_2+X2-1,G2=k(_2,V2);if(!M2.some((H2)=>H2.start===_2)&&!V.has(G2))M2.push({start:_2,end:V2})}}let A2=[];for(let J2 of q2){let W2=Math.floor(J2.start/X2),L2=Math.floor(J2.end/X2);for(let Y2=W2;Y2<=L2;Y2++){let _2=Y2*X2,V2=_2+X2-1,G2=k(_2,V2);if(V.has(G2)){let H2=V.get(G2);if(!A2.includes(H2))A2.push(H2)}}}for(let J2 of M2){let W2=k(J2.start,J2.end),L2=(async()=>{E.push(J2),N=!0,B=void 0,O();try{let Y2=J2.end-J2.start+1,_2={offset:J2.start,limit:Y2,cursor:void 0},V2=await X.read(_2);if(c(V2.items,J2.start,V2.total),V2.cursor)A=V2.cursor;let G2=J2.start+V2.items.length;if(G2>=H){if(H=G2,V2.hasMore!==void 0)W=V2.hasMore;else if(V2.total!==void 0)W=G2<V2.total}}catch(Y2){B=Y2 instanceof Error?Y2:Error(String(Y2))}finally{V.delete(W2),E=E.filter((Y2)=>Y2.start!==J2.start||Y2.end!==J2.end),N=V.size>0,O()}})();V.set(W2,L2),A2.push(L2)}await Promise.all(A2)},C=async(v,x)=>{if(D.isRangeLoaded(v,x))return;await K2(v,x)},l=async()=>{if(!X)return;await K2(0,q-1)},u=async()=>{if(!X||N||!W)return!1;let v=D.getCachedCount(),x=D.getTotal(),o=v,m=Math.min(o+q-1,x>0?x-1:o+q-1);if(o>=x&&x>0)return W=!1,!1;return await K2(o,m),D.getCachedCount()>v},$2=async()=>{if(D.clear(),y.clear(),L)L.clear();V.clear(),E=[],N=!1,A=void 0,W=!0,H=0,B=void 0,O()},n=(v,x)=>{if(D.evictDistant(v,x)>0)M()},Q2=()=>{D.clear(),y.clear(),A=void 0,B=void 0,E=[],N=!1,O()},D2=()=>{if(D.reset(),y.clear(),L)L.clear();A=void 0,W=!0,H=0,B=void 0,E=[],N=!1,O()};if($&&$.length>0)c($,0,J??$.length);else if(J!==void 0)D.setTotal(J);return{getState:e,getTotal:g,getCached:t,getIsLoading:s,getHasMore:j2,getStorage:T,getPlaceholders:S,getItem:I,getItemById:p,getIndexById:b,isItemLoaded:w,getItemsInRange:h,setTotal:d,setItems:c,updateItem:r,removeItem:B2,loadRange:K2,ensureRange:C,loadInitial:l,loadMore:u,reload:$2,evictDistant:n,clear:Q2,reset:D2}};var jJ=(j)=>{let{adapter:X,loading:$}=j,J=$?.cancelThreshold??gj,K=$?.preloadThreshold??mj,Q=$?.preloadAhead??dj;return{name:"withAsync",priority:20,methods:["reload"],setup(q){let{emitter:Z}=q,_=q.config.reverse,U=Xj({adapter:X,pageSize:x2,onStateChange:()=>{if(q.state.isInitialized){q.heightCache.rebuild(q.getVirtualTotal()),q.updateCompressionMode();let W=q.getCachedCompression();q.state.viewportState.totalHeight=W.virtualHeight,q.state.viewportState.actualHeight=W.actualHeight,q.state.viewportState.isCompressed=W.isCompressed,q.state.viewportState.compressionRatio=W.ratio,q.updateContentSize(W.virtualHeight),q.renderIfNeeded()}},onItemsLoaded:(W,A,E)=>{if(q.state.isInitialized)q.heightCache.rebuild(q.getVirtualTotal()),q.forceRender(),Z.emit("load:end",{items:W,total:E})}});q.replaceDataManager(U);let D=null,L=null,z=0,y=()=>{if(L){let W=L;L=null,q.dataManager.ensureRange(W.start,W.end).catch((A)=>{Z.emit("error",{error:A,context:"ensureRange"})})}};q.afterScroll.push((W,A)=>{if(q.state.isDestroyed)return;let E=q.scrollController.getVelocity(),V=q.scrollController.isTracking()&&E<=J;if(L&&z>J&&E<=J){let R=L;L=null,q.dataManager.ensureRange(R.start,R.end).catch((G)=>{Z.emit("error",{error:G,context:"ensureRange"})})}if(z=E,V&&!q.dataManager.getIsLoading()&&q.dataManager.getHasMore()){if(_){if(W<Ej)Z.emit("load:start",{offset:q.dataManager.getCached(),limit:x2}),q.dataManager.loadMore().catch((R)=>{Z.emit("error",{error:R,context:"loadMore"})})}else if(q.state.viewportState.totalHeight-W-q.state.viewportState.containerHeight<Ej)Z.emit("load:start",{offset:q.dataManager.getCached(),limit:x2}),q.dataManager.loadMore().catch((G)=>{Z.emit("error",{error:G,context:"loadMore"})})}let{renderRange:O}=q.state.viewportState;if(!D||O.start!==D.start||O.end!==D.end)if(D={start:O.start,end:O.end},V){L=null;let{start:R,end:G}=O,k=q.getVirtualTotal();if(E>K)if(A==="down")G=Math.min(O.end+Q,k-1);else R=Math.max(O.start-Q,0);q.dataManager.ensureRange(R,G).catch((g)=>{Z.emit("error",{error:g,context:"ensureRange"})})}else L={start:O.start,end:O.end}});let N=200,B=null;q.afterScroll.push((W,A)=>{if(B!==null)clearTimeout(B);B=setTimeout(()=>{B=null,y()},N)}),q.destroyHandlers.push(()=>{if(B!==null)clearTimeout(B),B=null}),Z.on("load:start",()=>{q.dom.root.setAttribute("aria-busy","true")}),Z.on("load:end",()=>{q.dom.root.removeAttribute("aria-busy")}),q.methods.set("reload",async()=>{D=null,L=null,q.invalidateRendered(),await q.dataManager.reload(),q.forceRender();let{renderRange:W}=q.state.viewportState;if(W.end>0)await q.dataManager.ensureRange(W.start,W.end)}),Z.emit("load:start",{offset:0,limit:x2}),q.dataManager.loadInitial().catch((W)=>{Z.emit("error",{error:W,context:"loadInitial"})})}}};var JJ=()=>{let j=null;return{name:"withPage",priority:5,setup(X){let{dom:$,state:J,config:K,emitter:Q}=X;$.root.style.overflow="visible",$.root.style.height="auto",$.viewport.classList.remove(`${K.classPrefix}-viewport--custom-scrollbar`),X.disableViewportResize(),X.setScrollTarget(window),X.setScrollFns(()=>{let U=$.viewport.getBoundingClientRect();if(K.horizontal)return Math.max(0,-U.left);else return Math.max(0,-U.top)},(U)=>{let D=$.viewport.getBoundingClientRect();if(K.horizontal){let L=D.left+window.scrollX;window.scrollTo(L+U,window.scrollY)}else{let L=D.top+window.scrollY;window.scrollTo(window.scrollX,L+U)}}),X.setContainerDimensions({width:()=>window.innerWidth,height:()=>window.innerHeight}),J.viewportState.containerHeight=window.innerHeight;let{innerHeight:q,innerWidth:Z}=window,_=()=>{let{innerWidth:U,innerHeight:D}=window,L=K.horizontal?U:D,z=K.horizontal?Z:q;if(Math.abs(L-z)<=1)return;q=D,Z=U,J.viewportState.containerHeight=D,Q.emit("resize",{width:U,height:D});for(let y=0;y<X.resizeHandlers.length;y++)X.resizeHandlers[y](U,D);X.renderIfNeeded()};window.addEventListener("resize",_,{passive:!0}),j=()=>{window.removeEventListener("resize",_)},X.destroyHandlers.push(j)},destroy(){if(j)j(),j=null}}};var zj=(j,X)=>{let $=0,J=j.length-1;while($<J){let K=$+J+1>>>1;if(j[K].headerLayoutIndex<=X)$=K;else J=K-1}return $},$J=(j,X)=>{let $=0,J=j.length-1;while($<J){let K=$+J+1>>>1;if(j[K].firstDataIndex<=X)$=K;else J=K-1}return $},QJ=(j,X)=>{if(j===0)return[];let $=[],J=X(0),K=0,Q=0;for(let q=1;q<j;q++){let Z=X(q);if(Z!==J){let _=q-K;$.push({key:J,groupIndex:$.length,headerLayoutIndex:Q,firstDataIndex:K,count:_}),Q=Q+1+_,J=Z,K=q}}return $.push({key:J,groupIndex:$.length,headerLayoutIndex:Q,firstDataIndex:K,count:j-K}),$},g2=(j,X)=>{if(j.length===0||X.length===0)return[];let $=j.length+X.length,J=Array($),K=0;for(let Q of X){J[K]={id:`__group_header_${Q.groupIndex}`,__groupHeader:!0,groupKey:Q.key,groupIndex:Q.groupIndex},K++;for(let q=0;q<Q.count;q++)J[K]=j[Q.firstDataIndex+q],K++}return J},m2=(j,X)=>{let $=typeof X==="number"?(J)=>X:X;return(J)=>{let K=j.getEntry(J);if(K.type==="header")return j.getHeaderHeight(K.group.groupIndex);return $(K.dataIndex)}},qj=(j,X)=>{let $=QJ(j,X.getGroupForIndex),J=j+$.length,K=X.headerHeight;return{get totalEntries(){return J},get groupCount(){return $.length},get groups(){return $},getEntry:(z)=>{if($.length===0)return{type:"item",dataIndex:z,group:{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0}};let y=zj($,z),N=$[y];if(z===N.headerLayoutIndex)return{type:"header",group:N};let B=z-N.headerLayoutIndex-1;return{type:"item",dataIndex:N.firstDataIndex+B,group:N}},layoutToDataIndex:(z)=>{if($.length===0)return z;let y=zj($,z),N=$[y];if(z===N.headerLayoutIndex)return-1;let B=z-N.headerLayoutIndex-1;return N.firstDataIndex+B},dataToLayoutIndex:(z)=>{if($.length===0)return z;let y=$J($,z),N=$[y],B=z-N.firstDataIndex;return N.headerLayoutIndex+1+B},getGroupAtLayoutIndex:(z)=>{if($.length===0)return{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0};let y=zj($,z);return $[y]},getGroupAtDataIndex:(z)=>{if($.length===0)return{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0};let y=$J($,z);return $[y]},getHeaderHeight:typeof K==="number"?(z)=>K:(z)=>{let y=$[z];if(!y)return 0;return K(y.key,z)},rebuild:(z)=>{$=QJ(z,X.getGroupForIndex),J=z+$.length}}};var Kj=(j,X,$,J,K)=>{let Q=document.createElement("div");Q.className=`${K}-sticky-header`,Q.setAttribute("role","presentation"),Q.setAttribute("aria-hidden","true"),Q.style.position="absolute",Q.style.top="0",Q.style.left="0",Q.style.right="0",Q.style.zIndex="5",Q.style.pointerEvents="none",Q.style.willChange="transform",Q.style.overflow="hidden",j.insertBefore(Q,j.firstChild);let q=-1,Z=!1,_=0,U=(B)=>{if(B===q)return;q=B;let W=X.groups;if(B<0||B>=W.length){Q.textContent="";return}let A=W[B],E=J.headerTemplate(A.key,A.groupIndex),H=X.getHeaderHeight(B);if(Q.style.height=`${H}px`,typeof E==="string")Q.innerHTML=E;else Q.replaceChildren(E)},D=(B)=>{let W=X.groups;if(W.length===0){z();return}let A=0;for(let M=W.length-1;M>=0;M--)if($.getOffset(W[M].headerLayoutIndex)<=B){A=M;break}let E=$.getOffset(W[0].headerLayoutIndex);if(B<E){z();return}if(!Z)L();U(A);let H=X.getHeaderHeight(A),V=0,O=A+1;if(O<W.length){let R=$.getOffset(W[O].headerLayoutIndex)-B;if(R<H)V=R-H}if(V!==_)_=V,Q.style.transform=V===0?"":`translateY(${Math.round(V)}px)`},L=()=>{if(Z)return;Z=!0,Q.style.display=""},z=()=>{if(!Z)return;Z=!1,Q.style.display="none",q=-1,_=0,Q.style.transform=""},y=()=>{let B=q;if(q=-1,B>=0)U(B)},N=()=>{Q.remove(),q=-1,Z=!1};return Q.style.display="none",{update:D,refresh:y,show:L,hide:z,destroy:N}};var XJ=(j,X,$,J,K,Q)=>{if(J===0||X===0)return Q.start=0,Q.end=-1,Q;let q=$.indexAtOffset(j),Z=$.indexAtOffset(j+X);if(Z<J-1)Z++;return Q.start=Math.max(0,q),Q.end=Math.min(J-1,Math.max(0,Z)),Q},qJ=(j,X,$,J)=>{if($===0)return J.start=0,J.end=-1,J;return J.start=Math.max(0,j.start-X),J.end=Math.min($-1,j.end+X),J},KJ=(j,X,$,J,K,Q)=>{if(J===0)return 0;let q=Math.max(0,Math.min(j,J-1)),Z=X.getOffset(q),_=X.getHeight(q),U=X.getTotalHeight(),D=Math.max(0,U-$),L;switch(Q){case"center":L=Z-$/2+_/2;break;case"end":L=Z-$+_;break;case"start":default:L=Z;break}return Math.max(0,Math.min(L,D))},YJ=(j,X,$)=>{if($&&$.isCompressed)return $.virtualHeight;return X.getTotalHeight()},ZJ=(j,X)=>{return X.getTotalHeight()},BJ=(j,X)=>{return X.getOffset(j)},UJ=(j,X,$)=>{let J=Math.max(0,X-$);return Math.max(0,Math.min(j,J))};var y2=(j,X,$,J,K="start",Q,q=KJ)=>{return q(j,X,$,J,Q,K)},DJ=(j,X)=>{return j.start===X.start&&j.end===X.end},NJ=(j,X)=>{return j>=X.start&&j<=X.end},WJ=(j)=>{if(j.end<j.start)return 0;return j.end-j.start+1};var VJ=(j,X)=>{let $=[],J=[];for(let K=j.start;K<=j.end;K++)if(K<X.start||K>X.end)J.push(K);for(let K=X.start;K<=X.end;K++)if(K<j.start||K>j.end)$.push(K);return{add:$,remove:J}};t2();var GJ=(j)=>{if(!j.getGroupForIndex)throw Error("[vlist/builder] withGroups: getGroupForIndex is required");if(j.headerHeight==null||j.headerHeight<=0)throw Error("[vlist/builder] withGroups: headerHeight must be a positive number");if(!j.headerTemplate)throw Error("[vlist/builder] withGroups: headerTemplate is required");let X=null,$=null,J=[],K=[];return{name:"withSections",priority:10,setup(Q){let{dom:q,config:Z,rawConfig:_}=Q,{classPrefix:U}=Z;if(Z.horizontal)throw Error("[vlist/builder] withGroups cannot be used with direction: 'horizontal'");let L=_.item.height;J=_.items?[..._.items]:[];let z=J.length,y={getGroupForIndex:j.getGroupForIndex,headerHeight:j.headerHeight,headerTemplate:j.headerTemplate,sticky:j.sticky??!1};X=qj(z,y),K=g2(J,X.groups);let N=m2(X,L);Q.setHeightConfig(N),Q.rebuildHeightCache(K.length),Q.dataManager.setItems(K,0,K.length);let B=_.item.template,{headerTemplate:W}=j,A=(G,k,g)=>{if(P2(G))return W(G.groupKey,G.groupIndex);return B(G,k,g)},E=Q.methods.get("_getGridLayout"),H=Q.methods.get("_replaceGridRenderer"),V=Q.methods.get("_updateGridLayoutForGroups");if(E&&H){if(V)V((t)=>{let s=K[t];return!!(s&&P2(s))});let{createGridRenderer:G}=(Yj(),cJ(_J)),k=E(),g=G(q.items,A,Q.heightCache,k,U,Q.getContainerWidth(),()=>Q.dataManager.getTotal(),Z.ariaIdPrefix);H(g)}else Q.replaceTemplate(A);if(q.root.classList.add(`${U}--grouped`),j.sticky!==!1){$=Kj(q.root,X,Q.heightCache,{...y,sticky:y.sticky??!1},U);let G=$;Q.afterScroll.push((k,g)=>{G.update(k)}),$.update(Q.scrollController.getScrollTop())}let O=()=>{if(!X)return;X.rebuild(J.length),K=g2(J,X.groups);let G=m2(X,L);if(Q.setHeightConfig(G),Q.rebuildHeightCache(K.length),Q.dataManager.setItems(K,0,K.length),$)$.refresh()};Q.methods.set("setItems",(G)=>{J=[...G],O()}),Q.methods.set("appendItems",(G)=>{J=[...J,...G],O()}),Q.methods.set("prependItems",(G)=>{J=[...G,...J],O()}),Q.methods.set("removeItem",(G)=>{J=J.filter((k)=>k.id!==G),O()});let{animateScroll:M,cancelScroll:R}=_4(Q.scrollController,Q.renderIfNeeded);Q.methods.set("scrollToIndex",(G,k)=>{let g=X.dataToLayoutIndex(G),{align:t,behavior:s,duration:j2}=G4(k),e=Q.dataManager.getTotal(),T=y2(g,Q.heightCache,Q.state.viewportState.containerHeight,e,t,Q.getCachedCompression());if(s==="smooth")M(Q.scrollController.getScrollTop(),T,j2);else R(),Q.scrollController.scrollTo(T)}),Q.methods.set("_getItems",()=>J),Q.methods.set("_getTotal",()=>J.length),Q.destroyHandlers.push(()=>{if(O2!==null)cancelAnimationFrame(O2),O2=null;if($)$.destroy(),$=null;q.root.classList.remove(`${U}--grouped`)})},destroy(){if($)$.destroy(),$=null}}},bj=300,V4=(j)=>j<0.5?2*j*j:-1+(4-2*j)*j,O2=null,_4=(j,X)=>{let $=()=>{if(O2!==null)cancelAnimationFrame(O2),O2=null};return{animateScroll:(K,Q,q)=>{if($(),Math.abs(Q-K)<1){j.scrollTo(Q);return}let Z=performance.now(),_=(U)=>{let D=U-Z,L=Math.min(D/q,1),z=K+(Q-K)*V4(L);if(j.scrollTo(z),X(),L<1)O2=requestAnimationFrame(_);else O2=null};O2=requestAnimationFrame(_)},cancelScroll:$}},G4=(j)=>{if(typeof j==="string")return{align:j,behavior:"auto",duration:bj};if(j&&typeof j==="object")return{align:j.align??"start",behavior:j.behavior??"auto",duration:j.duration??bj};return{align:"start",behavior:"auto",duration:bj}};var Zj=(j)=>{let X=Math.max(1,Math.floor(j.columns)),$=j.gap??0,J=j.isHeaderFn,K={row:0,col:0},Q=(N)=>{if(N<=0)return 0;if(!J)return Math.ceil(N/X);let B=0,W=0,A=0;for(let E=0;E<N;E++)if(J(E)){if(A++,W>0)B++,W=0;B++,W=0}else if(W++,W>=X)B++,W=0;if(W>0)B++;return B},q=(N)=>{return K.row=Z(N),K.col=_(N),K},Z=(N)=>{if(!J)return Math.floor(N/X);let B=0,W=0;for(let A=0;A<=N;A++)if(J(A)){if(W>0)B++,W=0;if(A===N)return B;B++,W=0}else{if(A===N)return B;if(W++,W>=X)B++,W=0}return console.warn(`⚠️ getRow(${N}) fell through - returning ${B}`),B},_=(N)=>{if(!J)return N%X;if(J(N))return 0;let B=0;for(let W=0;W<=N;W++)if(J(W))B=0;else{if(W===N)return B;if(B++,B>=X)B=0}return B},U=(N,B,W)=>{if(W<=0)return{start:0,end:-1};if(!J){let O=Math.max(0,N*X),M=Math.min(W-1,(B+1)*X-1);return{start:O,end:M}}let A=-1,E=-1,H=0,V=0;for(let O=0;O<W;O++){if(J(O)){if(V>0)H++,V=0;if(H>=N&&H<=B){if(A===-1)A=O;E=O}H++,V=0}else{if(H>=N&&H<=B){if(A===-1)A=O;E=O}if(V++,V>=X)H++,V=0}if(H>B&&V===0)break}if(A===-1)return{start:0,end:-1};return{start:A,end:E}},D=(N,B,W)=>{if(B<0||B>=X)return-1;let A=N*X+B;if(A<0||A>=W)return-1;return A},L=(N)=>{let B=(X-1)*$;return Math.max(0,(N-B)/X)};return{get columns(){return X},get gap(){return $},update:(N)=>{if(N.columns!==void 0)X=Math.max(1,Math.floor(N.columns));if(N.gap!==void 0)$=N.gap;if(N.isHeaderFn!==void 0)J=N.isHeaderFn},getTotalRows:Q,getPosition:q,getRow:Z,getCol:_,getItemRange:U,getItemIndex:D,getColumnWidth:L,getColumnOffset:(N,B)=>{let W=L(B);return N*(W+$)}}};Yj();var MJ=(j)=>{if(!j.columns||j.columns<1)throw Error("[vlist/builder] withGrid: columns must be a positive integer >= 1");let X=null,$=null;return{name:"withGrid",priority:10,setup(J){let{dom:K,emitter:Q,config:q,rawConfig:Z}=J,{classPrefix:_}=q;if(q.horizontal)throw Error("[vlist/builder] withGrid cannot be used with direction: 'horizontal'");if(q.reverse)throw Error("[vlist/builder] withGrid cannot be used with reverse: true");let U=Z.items?.some((V)=>V.__groupHeader===!0),D={columns:j.columns,gap:j.gap??0};if(U)D.isHeaderFn=(V)=>{let O=J.dataManager.getItem(V);return!!(O&&O.__groupHeader===!0)};X=Zj(D);let L=X.gap;J.setVirtualTotalFn(()=>{let V=J.dataManager.getTotal();return X.getTotalRows(V)});let z=Z.item,y=q.horizontal?z.width:z.height,N={containerWidth:J.getContainerWidth(),columns:X.columns,gap:X.gap};if(typeof y==="function")J.setHeightConfig((V)=>{let O=N.containerWidth-2,M=(N.columns-1)*N.gap,R=(O-M)/N.columns,G={containerWidth:N.containerWidth,columns:N.columns,gap:N.gap,columnWidth:R,row:X.getRow(V),column:X.getCol(V),totalRows:X.getTotalRows(J.dataManager.getTotal()),totalColumns:N.columns};return y(V,G)+N.gap});else if(L>0)J.setHeightConfig(y+L);J.rebuildHeightCache(),K.root.classList.add(`${_}--grid`);let B=J.getContainerWidth(),W=Z.item.template,A=()=>{$=d2(K.items,W,J.heightCache,X,_,B,()=>J.dataManager.getTotal(),q.ariaIdPrefix),J.replaceRenderer($)};A(),J.methods.set("_getGridLayout",()=>X),J.methods.set("_getGridConfig",()=>D),J.methods.set("_replaceGridRenderer",(V)=>{$=V}),J.methods.set("_updateGridLayoutForGroups",(V)=>{X.update({isHeaderFn:V});let O=J.dataManager.getTotal(),M=0;for(let R=0;R<O;R++)if(X.getCol(R)===0){let G=J.heightCache.getHeight(R);M+=G}J.heightCache.getTotalHeight=()=>M,J.dom.content.style.height=`${M}px`,A()}),J.methods.set("updateGrid",(V)=>{if(V.columns!==void 0){if(!Number.isInteger(V.columns)||V.columns<1)throw Error("[vlist/builder] updateGrid: columns must be a positive integer >= 1");D.columns=V.columns}if(V.gap!==void 0){if(V.gap<0)throw Error("[vlist/builder] updateGrid: gap must be non-negative");D.gap=V.gap}if(X)X.update(D);let O=J.getContainerWidth();if(N.containerWidth=O,N.columns=D.columns,N.gap=D.gap??0,$)$.updateContainerWidth(O);J.rebuildHeightCache(),J.updateContentSize(J.heightCache.getTotalHeight()),J.updateCompressionMode();for(let M=0;M<J.contentSizeHandlers.length;M++)J.contentSizeHandlers[M]();if($)$.clear();J.forceRender()});let E=()=>{if(J.state.isDestroyed)return;let V=J.scrollController.getScrollTop(),O=J.state.viewportState.containerHeight,M=J.getVirtualTotal(),R={start:0,end:0};if(M===0||O===0)R.start=0,R.end=0;else{R.start=Math.max(0,J.heightCache.indexAtOffset(V));let S=J.heightCache.indexAtOffset(V+O);if(S<M-1)S++;R.end=Math.min(M-1,Math.max(0,S))}let G=q.overscan??3,k={start:Math.max(0,R.start-G),end:Math.min(M-1,R.end+G)};J.state.viewportState.scrollTop=V,J.state.viewportState.visibleRange=R,J.state.viewportState.renderRange=k;let g=J.state.lastRenderRange,t=J.state.viewportState.isCompressed;if(k.start===g.start&&k.end===g.end){if(t)$.updatePositions(J.getCompressionContext());return}let s=J.dataManager.getTotal(),j2=X.getItemRange(k.start,k.end,s),e=J.dataManager.getItemsInRange(j2.start,j2.end),T=t?J.getCompressionContext():void 0;$.render(e,j2,new Set,-1,T),J.state.lastRenderRange={...k},Q.emit("range:change",{range:k})},H=()=>{if(J.state.isDestroyed)return;J.state.lastRenderRange={start:-1,end:-1},E()};if(J.setRenderFns(E,H),J.resizeHandlers.push((V,O)=>{if($)$.updateContainerWidth(V)}),J.methods.set("scrollToIndex",(V,O)=>{let M=Math.floor(V/j.columns),{align:R,behavior:G}=M4(O),k=J.dataManager.getState(),g=X.getTotalRows(k.total),t=Math.max(0,Math.min(M,g-1)),s=y2(t,J.heightCache,J.state.viewportState.containerHeight,g,R,J.getCachedCompression());if(G==="smooth")J.scrollController.scrollTo(s);else J.scrollController.scrollTo(s)}),!J.methods.has("_getTotal"))J.methods.set("_getTotal",()=>J.dataManager.getTotal());J.destroyHandlers.push(()=>{if($)$.destroy(),$=null;K.root.classList.remove(`${_}--grid`)})},destroy(){if($)$.destroy(),$=null}}},Pj=300,M4=(j)=>{if(typeof j==="string")return{align:j,behavior:"auto",duration:Pj};if(j&&typeof j==="object")return{align:j.align??"start",behavior:j.behavior??"auto",duration:j.duration??Pj};return{align:"start",behavior:"auto",duration:Pj}};Yj();var Bj=(j)=>({selected:new Set(j??[]),focusedIndex:-1}),c2=(j,X,$)=>{if($==="none")return j;let J=new Set(j.selected);if($==="single"){if(J.clear(),X.length>0)J.add(X[0])}else for(let K of X)J.add(K);return{...j,selected:J}},l2=(j,X)=>{let $=new Set(j.selected);for(let J of X)$.delete(J);return{...j,selected:$}},w2=(j,X,$)=>{if($==="none")return j;if(j.selected.has(X))return l2(j,[X]);else return c2(j,[X],$)},Uj=(j,X,$)=>{if($!=="multiple")return j;return{...j,selected:new Set(X.map((J)=>J.id))}},Dj=(j)=>({...j,selected:new Set}),yj=(j,X)=>{return j.focusedIndex=X,j},Hj=(j,X,$=!0)=>{if(X===0)return j;let J=j.focusedIndex-1;if(J<0)J=$?X-1:0;return j.focusedIndex=J,j},Rj=(j,X,$=!0)=>{if(X===0)return j;let J=j.focusedIndex+1;if(J>=X)J=$?0:X-1;return j.focusedIndex=J,j},kj=(j,X)=>{if(X===0)return j;return j.focusedIndex=0,j},Tj=(j,X)=>{if(X===0)return j;return j.focusedIndex=X-1,j};var AJ=(j,X)=>{return j.selected.has(X)},S2=(j)=>{return Array.from(j.selected)},v2=(j,X)=>{let $=[];for(let J of j.selected){let K=X(J);if(K)$.push(K)}return $};var EJ=(j)=>{let X=j?.mode??"single",$=j?.initial,J=Bj($),K=null;return{name:"withSelection",priority:50,methods:["select","deselect","toggleSelect","selectAll","clearSelection","getSelected","getSelectedItems"],setup(Q){let{dom:q,emitter:Z,config:_}=Q,{classPrefix:U,ariaIdPrefix:D}=_;if(X==="none"){Q.methods.set("select",()=>{}),Q.methods.set("deselect",()=>{}),Q.methods.set("toggleSelect",()=>{}),Q.methods.set("selectAll",()=>{}),Q.methods.set("clearSelection",()=>{}),Q.methods.set("getSelected",()=>[]),Q.methods.set("getSelectedItems",()=>[]),Q.methods.set("setSelectionMode",()=>{});return}let{renderIfNeeded:L,forceRender:z}=Q.getRenderFns(),y=()=>{Q.dom.items.querySelectorAll("[data-index]").forEach((H)=>{let V=H,O=V.dataset.id;if(O!==void 0){let M=/^\d+$/.test(O)?parseInt(O,10):O,R=J.selected.has(M),k=parseInt(V.dataset.index??"-1",10)===J.focusedIndex;V.classList.toggle(`${U}-item--selected`,R),V.classList.toggle(`${U}-item--focused`,k),V.ariaSelected=R?"true":"false"}})},N=()=>{if(Q.state.isDestroyed)return;L(),y()},B=()=>{if(Q.state.isDestroyed)return;z(),y()};Q.setRenderFns(N,B);let W=()=>{y(),Z.emit("selection:change",{selected:S2(J),items:v2(J,(E)=>Q.dataManager.getItemById(E))})};K=document.createElement("div"),K.setAttribute("aria-live","polite"),K.setAttribute("aria-atomic","true"),K.className=`${U}-live-region`,K.style.cssText="position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0",q.root.appendChild(K);let A=K;Z.on("selection:change",({selected:E})=>{let H=E.length;if(H===0)A.textContent="";else if(H===1)A.textContent="1 item selected";else A.textContent=`${H} items selected`}),Q.clickHandlers.push((E)=>{if(Q.state.isDestroyed)return;let V=E.target.closest("[data-index]");if(!V)return;let O=parseInt(V.dataset.index??"-1",10);if(O<0)return;let M=Q.dataManager.getItem(O);if(!M)return;Z.emit("item:click",{item:M,index:O,event:E}),J=yj(J,O),q.root.setAttribute("aria-activedescendant",`${D}-item-${O}`),J=w2(J,M.id,X),W()}),Q.keydownHandlers.push((E)=>{if(Q.state.isDestroyed)return;let H=Q.dataManager.getTotal(),V=J.focusedIndex,O=!1,M=!1,R=J;switch(E.key){case"ArrowUp":R=Hj(J,H),O=!0,M=!0;break;case"ArrowDown":R=Rj(J,H),O=!0,M=!0;break;case"Home":R=kj(J,H),O=!0,M=!0;break;case"End":R=Tj(J,H),O=!0,M=!0;break;case" ":case"Enter":if(J.focusedIndex>=0){let G=Q.dataManager.getItem(J.focusedIndex);if(G)R=w2(J,G.id,X);O=!0}break}if(O){E.preventDefault(),J=R;let G=J.focusedIndex;if(G>=0){let k=Q.dataManager.getState(),g=y2(G,Q.heightCache,Q.state.viewportState.containerHeight,k.total,"center",Q.getCachedCompression());Q.scrollController.scrollTo(g),q.root.setAttribute("aria-activedescendant",`${D}-item-${G}`)}else q.root.removeAttribute("aria-activedescendant");if(M){let{selected:k}=J;if(V>=0&&V!==G){let g=Q.dataManager.getItem(V);if(g)Q.renderer.updateItemClasses(V,k.has(g.id),!1)}if(G>=0){let g=Q.dataManager.getItem(G);if(g)Q.renderer.updateItemClasses(G,k.has(g.id),!0)}}else B(),Z.emit("selection:change",{selected:S2(J),items:v2(J,(k)=>Q.dataManager.getItemById(k))})}}),Q.methods.set("select",(...E)=>{J=c2(J,E,X),W()}),Q.methods.set("deselect",(...E)=>{J=l2(J,E),W()}),Q.methods.set("toggleSelect",(E)=>{J=w2(J,E,X),W()}),Q.methods.set("selectAll",()=>{if(X!=="multiple")return;let E=Q.getAllLoadedItems();J=Uj(J,E,X),W()}),Q.methods.set("clearSelection",()=>{J=Dj(J);let{renderRange:E,isCompressed:H}=Q.state.viewportState,V=Q.getItemsForRange(E),O=H?Q.getCompressionContext():void 0;Q.renderer.render(V,E,J.selected,J.focusedIndex,O),Z.emit("selection:change",{selected:[],items:[]})}),Q.methods.set("getSelected",()=>{return S2(J)}),Q.methods.set("getSelectedItems",()=>{return v2(J,(E)=>Q.dataManager.getItemById(E))}),Q.destroyHandlers.push(()=>{if(A&&A.parentNode)A.remove()})},destroy(){if(K&&K.parentNode)K.remove();K=null}}};var FJ=()=>{return{name:"withSnapshots",priority:50,methods:["getScrollSnapshot","restoreScroll"],setup(j){j.methods.set("getScrollSnapshot",()=>{let X=j.scrollController.getScrollTop(),$=j.getCachedCompression(),J=j.getVirtualTotal(),K=j.methods.get("getSelected"),Q=K&&K().length>0?K():void 0;if(J===0){let U={index:0,offsetInItem:0};if(Q)U.selectedIds=Q;return U}let q,Z;if($.isCompressed){let D=X/$.virtualHeight*J;q=Math.max(0,Math.min(Math.floor(D),J-1)),Z=(D-q)*j.heightCache.getHeight(q)}else q=j.heightCache.indexAtOffset(X),Z=X-j.heightCache.getOffset(q);Z=Math.max(0,Z);let _={index:q,offsetInItem:Z};if(Q)_.selectedIds=Q;return _}),j.methods.set("restoreScroll",(X)=>{let{index:$,offsetInItem:J,selectedIds:K}=X,Q=j.getCachedCompression(),q=j.getVirtualTotal();if(q===0)return;let Z=Math.max(0,Math.min($,q-1)),_;if(Q.isCompressed){let D=j.heightCache.getHeight(Z),L=D>0?J/D:0;_=(Z+L)/q*Q.virtualHeight}else _=j.heightCache.getOffset(Z)+J;let U=Math.max(0,Q.virtualHeight-j.state.viewportState.containerHeight);if(_=Math.max(0,Math.min(_,U)),j.scrollController.scrollTo(_),K&&K.length>0){let D=j.methods.get("select");if(D)D(...K)}})}}};var LJ=()=>{let j={},X=(Z,_)=>{if(!j[Z])j[Z]=new Set;return j[Z].add(_),()=>$(Z,_)},$=(Z,_)=>{j[Z]?.delete(_)};return{on:X,off:$,emit:(Z,_)=>{j[Z]?.forEach((U)=>{try{U(_)}catch(D){console.error(`[vlist] Error in event handler for "${String(Z)}":`,D)}})},once:(Z,_)=>{let U=(D)=>{$(Z,U),_(D)};return X(Z,U)},clear:(Z)=>{if(Z)delete j[Z];else for(let _ in j)delete j[_]},listenerCount:(Z)=>{return j[Z]?.size??0}}};export{FJ as withSnapshots,EJ as withSelection,GJ as withSections,oj as withScrollbar,ej as withScale,JJ as withPage,MJ as withGrid,jJ as withAsync,hj as vlist,w2 as toggleSelection,XJ as simpleVisibleRange,c2 as selectItems,Uj as selectAll,DJ as rangesEqual,jj as rafThrottle,aj as needsScaling,$j as mergeRanges,AJ as isSelected,P2 as isSectionHeader,b2 as isPlaceholderItem,NJ as isInRange,v2 as getSelectedItems,S2 as getSelectedIds,E2 as getScaleState,nj as getScaleInfo,E2 as getScale,WJ as getRangeCount,rj as getMaxItemsWithoutScaling,Oj as filterPlaceholders,VJ as diffRanges,l2 as deselectItems,Kj as createStickyHeader,Jj as createSparseStorage,Bj as createSelectionState,m2 as createSectionedHeightFn,qj as createSectionLayout,C2 as createScrollbar,tj as createScrollController,Qj as createPlaceholderManager,cj as createHeightCache,d2 as createGridRenderer,Zj as createGridLayout,LJ as createEmitter,Xj as createAsyncManager,Dj as clearSelection,UJ as clampScrollPosition,YJ as calculateTotalHeight,y2 as calculateScrollToIndex,o2 as calculateScaledVisibleRange,i2 as calculateScaledScrollToIndex,lj as calculateScaledRenderRange,T2 as calculateScaledItemPosition,qJ as calculateRenderRange,h2 as calculateMissingRanges,BJ as calculateItemOffset,sj as calculateIndexFromScrollPosition,ZJ as calculateActualHeight,g2 as buildLayoutItems,z2 as MAX_VIRTUAL_HEIGHT};
1
+ var{defineProperty:Mj,getOwnPropertyNames:gJ,getOwnPropertyDescriptor:mJ}=Object,dJ=Object.prototype.hasOwnProperty;var pj=new WeakMap,cJ=(j)=>{var Q=pj.get(j),$;if(Q)return Q;if(Q=Mj({},"__esModule",{value:!0}),j&&typeof j==="object"||typeof j==="function")gJ(j).map((J)=>!dJ.call(Q,J)&&Mj(Q,J,{get:()=>j[J],enumerable:!($=mJ(j,J))||$.enumerable}));return pj.set(j,Q),Q};var lJ=(j,Q)=>{for(var $ in Q)Mj(j,$,{get:Q[$],enumerable:!0,configurable:!0,set:(J)=>Q[$]=()=>J})};var uj=(j,Q)=>()=>(j&&(Q=j(j=0)),Q);var Ej=200,x2=50,gj=15,mj=2,dj=50,z2=16000000;var K4=(j,Q)=>{let $=Q;return{getOffset:(J)=>J*j,getHeight:(J)=>j,indexAtOffset:(J)=>{if($===0||j===0)return 0;return Math.max(0,Math.min(Math.floor(J/j),$-1))},getTotalHeight:()=>$*j,getTotal:()=>$,rebuild:(J)=>{$=J},isVariable:()=>!1}},Y4=(j,Q)=>{let $=Q,J=new Float64Array(0),K=(q)=>{$=q,J=new Float64Array(q+1),J[0]=0;for(let Z=0;Z<q;Z++)J[Z+1]=J[Z]+j(Z)};K(Q);let X=(q)=>{if($===0)return 0;if(q<=0)return 0;if(q>=J[$])return $-1;let Z=0,V=$-1;while(Z<V){let B=Z+V+1>>>1;if(J[B]<=q)Z=B;else V=B-1}return Z};return{getOffset:(q)=>{if(q<=0)return 0;if(q>=$)return J[$];return J[q]},getHeight:(q)=>j(q),indexAtOffset:(q)=>X(q),getTotalHeight:()=>J[$]??0,getTotal:()=>$,rebuild:(q)=>K(q),isVariable:()=>!0}},cj=(j,Q)=>{if(typeof j==="number")return K4(j,Q);return Y4(j,Q)},Fj=(j,Q,$,J)=>{if(J===0)return 0;if(!j.isVariable())return Math.ceil($/j.getHeight(0));let K=0,X=0,q=Q;while(q<J&&X<$)X+=j.getHeight(q),K++,q++;return Math.max(1,K)},n2=(j,Q,$)=>{if($===0)return 0;if(!j.isVariable())return Math.floor(Q/j.getHeight(0));let J=0,K=0;for(let X=$-1;X>=0;X--){let q=j.getHeight(X);if(K+q>Q)break;K+=q,J++}return Math.max(J,1)},Lj=(j,Q,$)=>{if($===0)return 0;let J=Math.floor(Q),K=Q-J,X=Math.max(0,Math.min(J,$-1));return j.getOffset(X)+K*j.getHeight(X)};var E2=(j,Q)=>{let $=Q.getTotalHeight(),J=$>z2,K=J?z2:$,X=$>0?K/$:1;return{isCompressed:J,actualHeight:$,virtualHeight:K,ratio:X}},o2=(j,Q,$,J,K,X)=>{if(J===0||Q===0)return X.start=0,X.end=-1,X;if(!K.isCompressed){let W=$.indexAtOffset(j),M=$.indexAtOffset(j+Q);if(M<J-1)M++;return X.start=Math.max(0,W),X.end=Math.min(J-1,Math.max(0,M)),X}let{virtualHeight:q}=K,V=j/q*J,B=Math.floor(V),U=Fj($,Math.max(0,B),Q,J),L=Math.ceil(V)+U,T=q-Q-j;if(T<=Q&&T>=-1){let W=n2($,Q,J),M=Math.max(0,J-W),N=Math.max(0,Math.min(1,1-T/Q));B=Math.floor(B+(M-B)*N),L=T<=1?J-1:Math.min(J-1,B+U)}return X.start=Math.max(0,B),X.end=Math.min(J-1,Math.max(0,L)),X},lj=(j,Q,$,J)=>{if($===0)return J.start=0,J.end=-1,J;return J.start=Math.max(0,j.start-Q),J.end=Math.min($-1,j.end+Q),J},C2=(j,Q,$,J,K,X,q)=>{if(!X.isCompressed||J===0)return $.getOffset(j);let{virtualHeight:Z}=X,V=Z-K,B=V-Q;if(B<=K&&B>=-1){if(Q>=V-1){let _=$.getTotalHeight()-$.getOffset(j);return K-_}let T=n2($,K,J),W=Math.max(0,J-T),N=Q/Z*J,O=Math.max(0,Math.min(1,1-B/K)),F=$.getOffset(j)-$.getOffset(W),b=$.getOffset(j)-Lj($,N,J);return b+(F-b)*O}let U=Q/Z,L=$.getTotalHeight(),y=U*L;return $.getOffset(j)-y},i2=(j,Q,$,J,K,X="start")=>{if(J===0)return 0;let q;if(K.isCompressed){if(X==="end"&&j===J-1)return Math.max(0,K.virtualHeight-$);q=j/J*K.virtualHeight}else q=Q.getOffset(j);let Z=Q.getHeight(j);switch(X){case"center":q-=($-Z)/2;break;case"end":q-=$-Z;break}let V=K.virtualHeight-$;return Math.max(0,Math.min(q,V))},sj=(j,Q,$,J)=>{if($===0)return 0;if(J.isCompressed){let K=j/J.virtualHeight;return Math.floor(K*$)}return Q.indexAtOffset(j)},aj=(j,Q)=>{if(typeof Q==="number")return j*Q>z2;return Q.getTotalHeight()>z2},rj=(j)=>{if(j<=0)return 0;return Math.floor(z2/j)},nj=(j,Q)=>{let $=E2(j,Q);if(!$.isCompressed)return`No compression needed (${j} items, ${($.actualHeight/1e6).toFixed(2)}M px)`;return`Compressed to ${($.ratio*100).toFixed(1)}% (${j} items, ${($.actualHeight/1e6).toFixed(1)}M px → ${($.virtualHeight/1e6).toFixed(1)}M px virtual)`};var t2=()=>{};var P2=(j)=>{return j!==null&&typeof j==="object"&&j.__groupHeader===!0};var VJ={};lJ(VJ,{createGridRenderer:()=>d2});var M4=(j=200)=>{let Q=[];return{acquire:()=>{let X=Q.pop();if(X)return X;let q=document.createElement("div");return q.setAttribute("role","option"),q},release:(X)=>{if(Q.length<j)X.className="",X.textContent="",X.removeAttribute("style"),X.removeAttribute("data-index"),X.removeAttribute("data-id"),X.removeAttribute("data-row"),X.removeAttribute("data-col"),Q.push(X)},clear:()=>{Q.length=0}}},d2=(j,Q,$,J,K,X,q,Z)=>{let V=M4(),B=new Map,U=X,L=!1,y=null,T=0,W="",M=(z)=>{if(y&&T===z)return y;return y=E2(z,$),T=z,y},N={selected:!1,focused:!1},O=(z,H)=>{return N.selected=z,N.focused=H,N},F=`${K}-item ${K}-grid-item`,b=`${K}-item--selected`,_=`${K}-item--focused`,A=(z,H)=>{if(typeof H==="string")z.innerHTML=H;else z.replaceChildren(H)},G=(z,H,m)=>{z.classList.toggle(b,H),z.classList.toggle(_,m)},P=(z,H)=>{let m=J.getRow(z);if(H){let s=H.totalItems,a=M(s);if(a.isCompressed)return C2(m,H.scrollTop,$,s,H.containerHeight,a,H.rangeStart)}return $.getOffset(m)},D=(z,H,m)=>{let s=z.dataset.id?.startsWith("__group_header"),a=s?0:J.getCol(H),o=s?0:J.getColumnOffset(a,U),B2;if(L){let K2=J.getRow(H),v=0,r=new Set;for(let h=0;h<H;h++){let $2=J.getRow(h);if($2<K2&&!r.has($2)){let i=$.getHeight(h);v+=i,r.add($2)}}B2=v}else B2=P(H,m);z.style.transform=`translate(${Math.round(o)}px, ${Math.round(B2)}px)`},k=(z,H)=>{let m=z.dataset.id?.startsWith("__group_header"),s=m?U:J.getColumnWidth(U),a;if(L||m)a=$.getHeight(H)-J.gap;else{let o=J.getRow(H);a=$.getHeight(o)-J.gap}z.style.width=`${s}px`,z.style.height=`${a}px`},x=(z,H,m,s,a)=>{let o=V.acquire(),B2=O(m,s);if(o.className=F,o.dataset.index=String(z),o.dataset.id=String(H.id),o.dataset.row=String(J.getRow(z)),o.dataset.col=String(J.getCol(z)),o.ariaSelected=String(m),Z)o.id=`${Z}-item-${z}`;if(q)W=String(q()),o.setAttribute("aria-setsize",W),o.setAttribute("aria-posinset",String(z+1));k(o,z);let K2=Q(H,z,B2);return A(o,K2),G(o,m,s),D(o,z,a),o},j2=(z,H,m,s,a)=>{if(H.start===0&&z.length>0)L=P2(z[0]);for(let[v,r]of B)if(v<H.start||v>H.end)r.element.remove(),V.release(r.element),B.delete(v);let o=!1;if(q){let v=String(q());o=v!==W,W=v}let B2=document.createDocumentFragment(),K2=[];for(let v=H.start;v<=H.end;v++){let r=v-H.start,h=z[r];if(!h){console.warn(`⚠️ RENDER: Missing item at index ${v} (range: ${H.start}-${H.end}, items.length: ${z.length})`);continue}let $2=m.has(h.id),i=v===s,Q2=B.get(v);if(Q2){let D2=Q2.element.dataset.id,S=String(h.id);if(D2!==S){let t=O($2,i),c=Q(h,v,t);A(Q2.element,c),Q2.element.dataset.id=S,Q2.element.dataset.row=String(J.getRow(v)),Q2.element.dataset.col=String(J.getCol(v)),k(Q2.element,v)}if(G(Q2.element,$2,i),Q2.element.ariaSelected=String($2),D(Q2.element,v,a),o)Q2.element.setAttribute("aria-setsize",W)}else{let D2=x(v,h,$2,i,a);B2.appendChild(D2),K2.push({index:v,element:D2})}}if(K2.length>0){j.appendChild(B2);for(let{index:v,element:r}of K2)B.set(v,{index:v,element:r})}},f=(z)=>{for(let[H,m]of B)D(m.element,H,z)},l=(z,H,m,s)=>{let a=B.get(z);if(a){let o=O(m,s),B2=Q(H,z,o);A(a.element,B2),G(a.element,m,s),a.element.dataset.id=String(H.id),a.element.ariaSelected=String(m),k(a.element,z)}},d=(z,H,m)=>{let s=B.get(z);if(s)G(s.element,H,m)},R=(z)=>{return B.get(z)?.element},w=(z)=>{if(Math.abs(z-U)<1)return;U=z;for(let[H,m]of B)k(m.element,H),D(m.element,H)},p=()=>{for(let[,z]of B)z.element.remove(),V.release(z.element);B.clear()};return{render:j2,updatePositions:f,updateItem:l,updateItemClasses:d,getElement:R,updateContainerWidth:w,clear:p,destroy:()=>{p(),V.clear()}}};var Yj=uj(()=>{t2()});var sJ=0,k2=5,aJ=100,Aj=2,rJ=(j=0)=>{let Q=Array(k2);for(let $=0;$<k2;$++)Q[$]={position:0,time:0};return{velocity:0,lastPosition:j,lastTime:performance.now(),samples:Q,sampleIndex:0,sampleCount:0}},nJ=(j,Q)=>{let $=performance.now(),J=$-j.lastTime;if(J===0)return j;if(J>aJ){j.sampleCount=0,j.sampleIndex=0,j.velocity=0;let X=j.samples[0];return X.position=Q,X.time=$,j.sampleIndex=1,j.sampleCount=1,j.lastPosition=Q,j.lastTime=$,j}let K=j.samples[j.sampleIndex];if(K.position=Q,K.time=$,j.sampleIndex=(j.sampleIndex+1)%k2,j.sampleCount=Math.min(j.sampleCount+1,k2),j.sampleCount>=Aj){let X=(j.sampleIndex-j.sampleCount+k2)%k2,q=j.samples[X],Z=Q-q.position,V=$-q.time;j.velocity=V>0?Math.abs(Z)/V:0}return j.lastPosition=Q,j.lastTime=$,j},xj=(j,Q)=>{if(typeof j==="number"){let X=Q;return{getOffset:(q)=>q*j,getHeight:()=>j,indexAtOffset:(q)=>{if(X===0||j===0)return 0;return Math.max(0,Math.min(Math.floor(q/j),X-1))},getTotalHeight:()=>X*j,getTotal:()=>X,rebuild:(q)=>{X=q},isVariable:()=>!1}}let $=Q,J=new Float64Array(0),K=(X)=>{$=X,J=new Float64Array(X+1),J[0]=0;for(let q=0;q<X;q++)J[q+1]=J[q]+j(q)};return K(Q),{getOffset:(X)=>{if(X<=0)return 0;if(X>=$)return J[$];return J[X]},getHeight:(X)=>j(X),indexAtOffset:(X)=>{if($===0)return 0;if(X<=0)return 0;if(X>=J[$])return $-1;let q=0,Z=$-1;while(q<Z){let V=q+Z+1>>>1;if(J[V]<=X)q=V;else Z=V-1}return q},getTotalHeight:()=>J[$]??0,getTotal:()=>$,rebuild:(X)=>K(X),isVariable:()=>!0}},oJ=()=>{let j={},Q=(X,q)=>{if(!j[X])j[X]=new Set;return j[X].add(q),()=>$(X,q)},$=(X,q)=>{j[X]?.delete(q)};return{on:Q,off:$,emit:(X,q)=>{j[X]?.forEach((Z)=>{try{Z(q)}catch(V){console.error(`[vlist] Error in "${X}" handler:`,V)}})},clear:()=>{for(let X in j)delete j[X]}}},iJ=(j)=>{if(typeof j==="string"){let Q=document.querySelector(j);if(!Q)throw Error(`[vlist/builder] Container not found: ${j}`);return Q}return j},tJ=(j,Q,$,J)=>{let K=document.createElement("div");if(K.className=Q,J)K.classList.add(`${Q}--horizontal`);if(K.setAttribute("role","listbox"),K.setAttribute("tabindex","0"),$)K.setAttribute("aria-label",$);if(J)K.setAttribute("aria-orientation","horizontal");let X=document.createElement("div");if(X.className=`${Q}-viewport`,J)X.style.overflowX="auto",X.style.overflowY="hidden";else X.style.overflow="auto";X.style.height="100%",X.style.width="100%";let q=document.createElement("div");if(q.className=`${Q}-content`,q.style.position="relative",J)q.style.height="100%";else q.style.width="100%";let Z=document.createElement("div");if(Z.className=`${Q}-items`,Z.style.position="relative",J)Z.style.height="100%";else Z.style.width="100%";return q.appendChild(Z),X.appendChild(q),K.appendChild(X),j.appendChild(K),{root:K,viewport:X,content:q,items:Z}},eJ=(j=100)=>{let Q=[];return{acquire:()=>{let $=Q.pop();if($)return $;let J=document.createElement("div");return J.setAttribute("role","option"),J},release:($)=>{if(Q.length<j)$.className="",$.textContent="",$.removeAttribute("style"),$.removeAttribute("data-index"),$.removeAttribute("data-id"),Q.push($)},clear:()=>{Q.length=0}}},j4=(j,Q,$,J,K)=>{if(J===0||Q===0){K.start=0,K.end=0;return}let X=$.indexAtOffset(j),q=$.indexAtOffset(j+Q);if(q<J-1)q++;K.start=Math.max(0,X),K.end=Math.min(J-1,Math.max(0,q))},J4=(j,Q,$,J)=>{if($===0){J.start=0,J.end=0;return}J.start=Math.max(0,j.start-Q),J.end=Math.min($-1,j.end+Q)},$4=(j,Q,$,J,K)=>{if(J===0)return 0;let X=Math.max(0,Math.min(j,J-1)),q=Q.getOffset(X),Z=Q.getHeight(X),V=Math.max(0,Q.getTotalHeight()-$),B;switch(K){case"center":B=q-($-Z)/2;break;case"end":B=q-$+Z;break;default:B=q}return Math.max(0,Math.min(B,V))},Q4=(j)=>j<0.5?2*j*j:-1+(4-2*j)*j,X4=(j)=>{if(typeof j==="string")return{align:j,behavior:"auto",duration:300};if(j&&typeof j==="object")return{align:j.align??"start",behavior:j.behavior??"auto",duration:j.duration??300};return{align:"start",behavior:"auto",duration:300}},hj=(j)=>{if(!j.container)throw Error("[vlist/builder] Container is required");if(!j.item)throw Error("[vlist/builder] item configuration is required");let Q=j.direction==="horizontal",$=Q?"width":"height",J=Q?j.item.width:j.item.height;if(J==null)throw Error(`[vlist/builder] item.${$} is required${Q?" when direction is 'horizontal'":""}`);if(typeof J==="number"&&J<=0)throw Error(`[vlist/builder] item.${$} must be a positive number`);if(typeof J!=="number"&&typeof J!=="function")throw Error(`[vlist/builder] item.${$} must be a number or a function (index) => number`);if(!j.item.template)throw Error("[vlist/builder] item.template is required");if(Q&&j.reverse)throw Error("[vlist/builder] horizontal direction cannot be combined with reverse mode");let K=new Map,X=!1,q={use(Z){if(X)throw Error("[vlist/builder] Cannot call .use() after .build()");return K.set(Z.name,Z),q},build(){if(X)throw Error("[vlist/builder] .build() can only be called once");return X=!0,q4(j,K,Q,J)}};return q};function q4(j,Q,$,J){let{item:K,items:X,overscan:q=3,classPrefix:Z="vlist",ariaLabel:V,reverse:B=!1,scroll:U}=j,L=U?.wheel??!0,y=U?.wrap??!1,T=B,W=`${Z}-${sJ++}`,M=J,N=$?typeof K.height==="number"?K.height:void 0:typeof K.width==="number"?K.width:void 0,O=K.template,F={overscan:q,classPrefix:Z,reverse:T,wrap:y,horizontal:$,ariaIdPrefix:W},b=Array.from(Q.values()).sort((Y,E)=>(Y.priority??50)-(E.priority??50)),_=new Set(b.map((Y)=>Y.name));for(let Y of b)if(Y.conflicts){for(let E of Y.conflicts)if(_.has(E))throw Error(`[vlist/builder] ${Y.name} and ${E} cannot be combined`)}if($){if(_.has("withGrid"))throw Error("[vlist/builder] withGrid cannot be used with direction: 'horizontal'");if(_.has("withGroups"))throw Error("[vlist/builder] withGroups cannot be used with direction: 'horizontal'")}if(T){if(_.has("withGrid"))throw Error("[vlist/builder] withGrid cannot be used with reverse: true")}let A=iJ(j.container),G=tJ(A,Z,V,$),P=oJ(),D=X?[...X]:[],k=xj(M,D.length),x=eJ(),j2=G.viewport.clientHeight,f=G.viewport.clientWidth,l=!1,d=!1,R=0,w=null,p=null,I=rJ(0),z={start:0,end:0},H={start:0,end:0},m={start:-1,end:-1},s={viewportState:{scrollTop:0,containerHeight:j2,totalHeight:k.getTotalHeight(),actualHeight:k.getTotalHeight(),isCompressed:!1,compressionRatio:1,visibleRange:{start:0,end:0},renderRange:{start:0,end:0}},lastRenderRange:{start:-1,end:-1},isInitialized:!1,isDestroyed:!1,cachedCompression:null},a=new Map,o={selected:!1,focused:!1},B2=`${Z}-item`,K2="",v=new Map,r=()=>{v.clear();for(let Y=0;Y<D.length;Y++){let E=D[Y];if(E)v.set(E.id,Y)}};r();let h=null,$2=()=>h?h.getTotal():D.length,i=[],Q2=[],D2=[],S=[],g=[],t=[],c=new Map,q2=()=>{return $?G.viewport.scrollLeft:G.viewport.scrollTop},X2=(Y)=>{if($)G.viewport.scrollLeft=Y;else G.viewport.scrollTop=Y},M2=(Y=2)=>{let E=k.getTotalHeight();return R+j2>=E-Y},A2=!1,J2,N2,L2=(Y,E,C,u,e)=>{j4(Y,E,C,u,e)},Y2=(Y,E,C,u,e)=>{return $4(Y,E,C,u,e)},V2=(Y,E)=>{if(typeof E==="string")Y.innerHTML=E;else Y.replaceChildren(E)},_2=(Y,E)=>{let C=Math.round(k.getOffset(E));if($)Y.style.transform=`translateX(${C}px)`;else Y.style.transform=`translateY(${C}px)`},H2=(Y,E)=>{let C=x.acquire();if(C.className=B2,$){if(C.style.width=`${k.getHeight(Y)}px`,N!=null)C.style.height=`${N}px`}else C.style.height=`${k.getHeight(Y)}px`;if(C.dataset.index=String(Y),C.dataset.id=String(E.id),C.ariaSelected="false",C.id=`${W}-item-${Y}`,K2=String($2()),C.setAttribute("aria-setsize",K2),C.setAttribute("aria-posinset",String(Y+1)),String(E.id).startsWith("__placeholder_"))C.classList.add(`${Z}-item--placeholder`);return V2(C,O(E,Y,o)),_2(C,Y),C},f2=()=>{let Y=`${k.getTotalHeight()}px`;if($)G.content.style.width=Y;else G.content.style.height=Y},Wj=new Set,Nj=-1,OJ=()=>{if(l)return;let Y=$2();if(L2(R,j2,k,Y,z),J4(z,q,Y,H),H.start===m.start&&H.end===m.end){if(A2)for(let[n,U2]of a)_2(U2,n);return}let E=String(Y),C=E!==K2;K2=E;for(let[n,U2]of a)if(n<H.start||n>H.end)U2.remove(),x.release(U2),a.delete(n);let u=document.createDocumentFragment(),e=[];for(let n=H.start;n<=H.end;n++){let U2=h?h.getItem(n):D[n];if(!U2)continue;let Z2=a.get(n);if(Z2){let F2=Z2.dataset.id,p2=String(U2.id);if(F2!==p2){let hJ=F2?.startsWith("__placeholder_"),Ij=p2.startsWith("__placeholder_");if(V2(Z2,O(U2,n,o)),Z2.dataset.id=p2,$)Z2.style.width=`${k.getHeight(n)}px`;else Z2.style.height=`${k.getHeight(n)}px`;if(Ij)Z2.classList.add(`${Z}-item--placeholder`);else Z2.classList.remove(`${Z}-item--placeholder`);if(hJ&&!Ij)Z2.classList.add(`${Z}-item--replaced`),setTimeout(()=>{Z2.classList.remove(`${Z}-item--replaced`)},300)}_2(Z2,n);let r2=Wj.has(U2.id),xJ=n===Nj;if(Z2.classList.toggle(`${Z}-item--selected`,r2),Z2.classList.toggle(`${Z}-item--focused`,xJ),Z2.ariaSelected=r2?"true":"false",C)Z2.setAttribute("aria-setsize",K2)}else{let F2=H2(n,U2),p2=Wj.has(U2.id),r2=n===Nj;if(p2)F2.classList.add(`${Z}-item--selected`),F2.ariaSelected="true";if(r2)F2.classList.add(`${Z}-item--focused`);u.appendChild(F2),e.push({index:n,element:F2})}}if(e.length>0){G.items.appendChild(u);for(let{index:n,element:U2}of e)a.set(n,U2)}m.start=H.start,m.end=H.end,s.lastRenderRange.start=H.start,s.lastRenderRange.end=H.end,s.viewportState.scrollTop=R,s.viewportState.visibleRange.start=z.start,s.viewportState.visibleRange.end=z.end,s.viewportState.renderRange.start=H.start,s.viewportState.renderRange.end=H.end,P.emit("range:change",{range:{start:H.start,end:H.end}})},zJ=()=>{m.start=-1,m.end=-1,J2()};J2=OJ,N2=zJ;let I2=()=>{if(l)return;let Y=q2(),E=Y>=R?"down":"up";if(I=nJ(I,Y),!G.root.classList.contains(`${Z}--scrolling`))G.root.classList.add(`${Z}--scrolling`);R=Y,J2(),P.emit("scroll",{scrollTop:Y,direction:E}),P.emit("velocity:change",{velocity:I.velocity,reliable:I.sampleCount>=Aj});for(let C=0;C<i.length;C++)i[C](Y,E);if(p)clearTimeout(p);p=setTimeout(()=>{G.root.classList.remove(`${Z}--scrolling`),I.velocity=0,I.sampleCount=0,P.emit("velocity:change",{velocity:0,reliable:!1})},U?.idleTimeout??150)},s2=null,R2=G.viewport;if(R2.addEventListener("scroll",I2,{passive:!0}),$&&L)s2=(Y)=>{if(Y.deltaX)return;Y.preventDefault(),G.viewport.scrollLeft+=Y.deltaY},G.viewport.addEventListener("wheel",s2);let Tj=(Y)=>{let C=Y.target.closest("[data-index]");if(C){let u=parseInt(C.dataset.index??"-1",10);if(u>=0){let e=h?.getItem(u)??D[u];if(e){if(e.__groupHeader)return;P.emit("item:click",{item:e,index:u,event:Y})}}}for(let u=0;u<Q2.length;u++)Q2[u](Y)},bJ=(Y)=>{let C=Y.target.closest("[data-index]");if(C){let u=parseInt(C.dataset.index??"-1",10);if(u>=0){let e=h?.getItem(u)??D[u];if(e){if(e.__groupHeader)return;P.emit("item:dblclick",{item:e,index:u,event:Y})}}}},wj=(Y)=>{for(let E=0;E<D2.length;E++)D2[E](Y)};G.items.addEventListener("click",Tj),G.items.addEventListener("dblclick",bJ),G.root.addEventListener("keydown",wj);let Gj=!0,PJ=()=>f,yJ=()=>j2,Vj=new ResizeObserver((Y)=>{if(l)return;for(let E of Y){let C=E.contentRect.height,u=E.contentRect.width,e=$?u:C;if(f=u,Math.abs(e-j2)>1){if(j2=e,s.viewportState.containerHeight=e,d)f2(),J2(),P.emit("resize",{height:C,width:u})}if(d)for(let n=0;n<S.length;n++)S[n](u,C)}});if(Gj)Vj.observe(G.viewport);let W2={get dom(){return G},get heightCache(){return k},get emitter(){return P},get config(){return F},get rawConfig(){return j},get renderer(){return{render:(Y,E,C,u,e)=>{Wj=C,Nj=u,N2()},updateItemClasses:(Y,E,C)=>{let u=a.get(Y);if(!u)return;u.classList.toggle(`${Z}-item--selected`,E),u.classList.toggle(`${Z}-item--focused`,C),u.ariaSelected=E?"true":"false"},updatePositions:()=>{},updateItem:()=>{},getElement:(Y)=>a.get(Y)??null,clear:()=>{},destroy:()=>{}}},set renderer(Y){},get dataManager(){return h},set dataManager(Y){h=Y},get scrollController(){return _j},set scrollController(Y){_j=Y},state:s,getContainerWidth(){return f},afterScroll:i,clickHandlers:Q2,keydownHandlers:D2,resizeHandlers:S,contentSizeHandlers:g,destroyHandlers:t,methods:c,replaceTemplate(Y){O=Y},replaceRenderer(Y){},replaceDataManager(Y){h=Y},replaceScrollController(Y){_j=Y},getItemsForRange(Y){let E=[];for(let C=Y.start;C<=Y.end;C++){let u=h?h.getItem(C):D[C];if(u)E.push(u)}return E},getAllLoadedItems(){if(h){let Y=h.getTotal(),E=[];for(let C=0;C<Y;C++){let u=h.getItem(C);if(u)E.push(u)}return E}return[...D]},getVirtualTotal(){return $2()},getCachedCompression(){return{isCompressed:!1,actualHeight:k.getTotalHeight(),virtualHeight:k.getTotalHeight(),ratio:1}},getCompressionContext(){return{scrollTop:R,totalItems:$2(),containerHeight:j2,rangeStart:H.start}},renderIfNeeded(){J2()},forceRender(){N2()},invalidateRendered(){for(let[,Y]of a)Y.remove(),x.release(Y);a.clear()},getRenderFns(){return{renderIfNeeded:J2,forceRender:N2}},setRenderFns(Y,E){J2=Y,N2=E},setVirtualTotalFn(Y){$2=Y},rebuildHeightCache(Y){k.rebuild(Y??$2())},setHeightConfig(Y){k=xj(Y,$2())},updateContentSize(Y){let E=`${Y}px`;if($)G.content.style.width=E;else G.content.style.height=E},updateCompressionMode(){},setVisibleRangeFn(Y){L2=Y},setScrollToPosFn(Y){Y2=Y},setPositionElementFn(Y){_2=Y},setScrollFns(Y,E){q2=Y,X2=(C)=>{E(C),I2()}},setScrollTarget(Y){R2.removeEventListener("scroll",I2),R2=Y,R2.addEventListener("scroll",I2,{passive:!0})},getScrollTarget(){return R2},setContainerDimensions(Y){PJ=Y.width,yJ=Y.height,f=Y.width(),j2=Y.height(),s.viewportState.containerHeight=j2},disableViewportResize(){if(Gj)Gj=!1,Vj.unobserve(G.viewport)}};h={getState:()=>({total:D.length,cached:D.length,isLoading:!1,pendingRanges:[],error:void 0,hasMore:!1,cursor:void 0}),getTotal:()=>D.length,getCached:()=>D.length,getIsLoading:()=>!1,getHasMore:()=>!1,getStorage:()=>null,getPlaceholders:()=>null,getItem:(Y)=>D[Y],getItemById:(Y)=>{let E=v.get(Y);return E!==void 0?D[E]:void 0},getIndexById:(Y)=>v.get(Y)??-1,isItemLoaded:(Y)=>Y>=0&&Y<D.length&&D[Y]!==void 0,getItemsInRange:(Y,E)=>{let C=[],u=Math.max(0,Y),e=Math.min(E,D.length-1);for(let n=u;n<=e;n++)C.push(D[n]);return C},setTotal:(Y)=>{},setItems:(Y,E=0,C)=>{if(E===0&&(C!==void 0||D.length===0))D=[...Y];else{let u=E+Y.length;if(D.length<u)D.length=u;for(let e=0;e<Y.length;e++)D[E+e]=Y[e]}if(r(),d){k.rebuild($2()),f2(),W2.updateCompressionMode();for(let u=0;u<g.length;u++)g[u]();N2()}},updateItem:(Y,E)=>{let C=v.get(Y);if(C===void 0)return!1;let u=D[C];if(!u)return!1;if(D[C]={...u,...E},E.id!==void 0&&E.id!==Y)v.delete(Y),v.set(E.id,C);let e=a.get(C);if(e)V2(e,O(D[C],C,o)),e.dataset.id=String(D[C].id);return!0},removeItem:(Y)=>{let E=v.get(Y);if(E===void 0)return!1;if(D.splice(E,1),r(),d){k.rebuild($2()),f2(),W2.updateCompressionMode();for(let C=0;C<g.length;C++)g[C]();N2()}return!0},loadRange:async()=>{},ensureRange:async()=>{},loadInitial:async()=>{},loadMore:async()=>!1,reload:async()=>{},evictDistant:()=>{},clear:()=>{D=[],v.clear()},reset:()=>{if(D=[],v.clear(),d)k.rebuild(0),f2(),N2()}};let _j={getScrollTop:()=>q2(),scrollTo:(Y)=>{X2(Y),R=Y,J2()},scrollBy:(Y)=>{let E=q2()+Y;X2(E),R=E,J2()},isAtTop:()=>R<=2,isAtBottom:(Y=2)=>M2(Y),getScrollPercentage:()=>{let Y=k.getTotalHeight(),E=Math.max(0,Y-j2);return E>0?R/E:0},getVelocity:()=>I.velocity,isTracking:()=>I.sampleCount>=Aj,isScrolling:()=>G.root.classList.contains(`${Z}--scrolling`),updateConfig:()=>{},enableCompression:()=>{A2=!0},disableCompression:()=>{A2=!1},isCompressed:()=>A2,isWindowMode:()=>!1,updateContainerHeight:(Y)=>{j2=Y},destroy:()=>{}},vj=new Map;for(let Y of b)if(Y.methods)for(let E of Y.methods){let C=vj.get(E);if(C)throw Error(`[vlist/builder] Method "${E}" is registered by both "${C}" and "${Y.name}"`);vj.set(E,Y.name)}for(let Y of b)Y.setup(W2);if(d=!0,W2.state.isInitialized=!0,f2(),J2(),T&&D.length>0){let Y=Y2(D.length-1,k,j2,D.length,"end");X2(Y),R=Y,J2()}let HJ=(Y)=>{W2.dataManager.setItems(Y,0,Y.length)},RJ=T?(Y)=>{let E=M2(2),C=D.length;if(W2.dataManager.setItems(Y,C),E&&D.length>0){let u=Y2(D.length-1,k,j2,D.length,"end");X2(u),R=u,J2()}}:(Y)=>{let E=D.length;W2.dataManager.setItems(Y,E)},kJ=T?(Y)=>{let E=q2(),C=k.getTotalHeight(),u=[...D];W2.dataManager.clear(),W2.dataManager.setItems([...Y,...u],0);let n=k.getTotalHeight()-C;if(n>0)X2(E+n),R=E+n}:(Y)=>{let E=[...D];W2.dataManager.clear(),W2.dataManager.setItems([...Y,...E],0)},CJ=(Y,E)=>{W2.dataManager.updateItem(Y,E)},TJ=(Y)=>{W2.dataManager.removeItem(Y)},wJ=async()=>{if(W2.dataManager.reload)await W2.dataManager.reload()},a2=()=>{if(w!==null)cancelAnimationFrame(w),w=null},vJ=(Y,E,C)=>{if(a2(),Math.abs(E-Y)<1){X2(E),R=E,J2();return}let u=performance.now(),e=(n)=>{let U2=n-u,Z2=Math.min(U2/C,1),F2=Y+(E-Y)*Q4(Z2);if(X2(F2),R=F2,J2(),Z2<1)w=requestAnimationFrame(e);else w=null};w=requestAnimationFrame(e)},Sj=(Y,E)=>{let{align:C,behavior:u,duration:e}=X4(E),n=$2(),U2=Y;if(y&&n>0)U2=(U2%n+n)%n;let Z2=Y2(U2,k,j2,n,C);if(u==="smooth")vJ(q2(),Z2,e);else a2(),X2(Z2)},SJ=(Y,E)=>{let C=v.get(Y)??W2.dataManager.getIndexById(Y);if(C>=0)Sj(C,E)},fJ=()=>q2(),IJ=(Y,E)=>{return P.on(Y,E)},pJ=(Y,E)=>{P.off(Y,E)},uJ=()=>{if(l)return;if(l=!0,W2.state.isDestroyed=!0,G.items.removeEventListener("click",Tj),G.root.removeEventListener("keydown",wj),R2.removeEventListener("scroll",I2),Vj.disconnect(),s2)G.viewport.removeEventListener("wheel",s2);if(p)clearTimeout(p);for(let Y=0;Y<t.length;Y++)t[Y]();for(let Y of b)if(Y.destroy)Y.destroy();a2();for(let[,Y]of a)Y.remove(),x.release(Y);a.clear(),x.clear(),P.clear(),G.root.remove()},fj={get element(){return G.root},get items(){if(c.has("_getItems"))return c.get("_getItems")();return D},get total(){if(c.has("_getTotal"))return c.get("_getTotal")();return $2()},setItems:c.has("setItems")?c.get("setItems"):HJ,appendItems:c.has("appendItems")?c.get("appendItems"):RJ,prependItems:c.has("prependItems")?c.get("prependItems"):kJ,updateItem:c.has("updateItem")?c.get("updateItem"):CJ,removeItem:c.has("removeItem")?c.get("removeItem"):TJ,reload:c.has("reload")?c.get("reload"):wJ,scrollToIndex:c.has("scrollToIndex")?c.get("scrollToIndex"):Sj,scrollToItem:c.has("scrollToItem")?c.get("scrollToItem"):SJ,cancelScroll:c.has("cancelScroll")?c.get("cancelScroll"):a2,getScrollPosition:c.has("getScrollPosition")?c.get("getScrollPosition"):fJ,on:IJ,off:pJ,destroy:uJ};for(let[Y,E]of c){if(Y==="setItems"||Y==="appendItems"||Y==="prependItems"||Y==="updateItem"||Y==="removeItem"||Y==="reload"||Y==="scrollToIndex"||Y==="scrollToItem"||Y==="cancelScroll"||Y==="getScrollPosition")continue;fj[Y]=E}return fj}t2();var T2=(j,Q,$={},J="vlist",K=!1)=>{let{autoHide:X=!0,autoHideDelay:q=1000,minThumbSize:Z=30,showOnHover:V=!0,hoverZoneWidth:B=16,showOnViewportEnter:U=!0}=$,L=0,y=0,T=0,W=0,M=!1,N=!1,O=0,F=0,b=0,_=null,A=!1,G=null,P=null,D=K?"width":"height",k=K?"translateX":"translateY",x=K?(i)=>i.clientX:(i)=>i.clientY,j2=K?"left":"top",f=document.createElement("div"),l=document.createElement("div"),d=V?document.createElement("div"):null,R=()=>{if(f.className=`${J}-scrollbar`,l.className=`${J}-scrollbar-thumb`,K)f.classList.add(`${J}-scrollbar--horizontal`);if(f.appendChild(l),j.appendChild(f),d){if(d.className=`${J}-scrollbar-hover`,K)d.classList.add(`${J}-scrollbar-hover--horizontal`),d.style.height=`${B}px`;else d.style.width=`${B}px`;j.appendChild(d)}},w=()=>{if(_)clearTimeout(_),_=null},p=()=>{if(!X)return;w(),_=setTimeout(z,q)},I=()=>{if(L<=y)return;if(w(),!A)f.classList.add(`${J}-scrollbar--visible`),A=!0;if(X&&!M&&!N)p()},z=()=>{if(M||N)return;f.classList.remove(`${J}-scrollbar--visible`),A=!1},H=(i,Q2)=>{L=i,y=Q2;let D2=L>y;if(f.style.display=D2?"":"none",!D2){z();return}let S=y/L;T=Math.max(Z,S*y),l.style[D]=`${T}px`,W=y-T,m(b)},m=(i)=>{if(b=i,L<=y||W<=0)return;let Q2=L-y,S=Math.min(1,Math.max(0,i/Q2))*W;l.style.transform=`${k}(${S}px)`},s=(i)=>{if(i.target===l)return;let Q2=f.getBoundingClientRect(),g=x(i)-Q2[j2]-T/2,c=Math.max(0,Math.min(g,W))/W,q2=L-y,X2=c*q2;Q(X2),I()},a=(i)=>{i.preventDefault(),i.stopPropagation(),M=!0,O=x(i),F=b,w(),f.classList.add(`${J}-scrollbar--dragging`),document.addEventListener("mousemove",o),document.addEventListener("mouseup",B2)},o=(i)=>{if(!M)return;let Q2=x(i)-O,D2=W>0?Q2/W:0,S=L-y,g=D2*S,t=Math.max(0,Math.min(F+g,S)),q2=t/S*W;if(l.style.transform=`${k}(${q2}px)`,P=t,G===null)G=requestAnimationFrame(()=>{if(P!==null)Q(P);G=null})},B2=()=>{if(M=!1,G!==null)cancelAnimationFrame(G),G=null;if(P!==null)Q(P),P=null;if(f.classList.remove(`${J}-scrollbar--dragging`),X&&!N)p();document.removeEventListener("mousemove",o),document.removeEventListener("mouseup",B2)},K2=()=>{if(U)I()},v=()=>{if(!M){if(N=!1,X)p()}},r=()=>{N=!0,w(),I()},h=()=>{if(N=!1,!M&&X)p()},$2=()=>{if(w(),G!==null)cancelAnimationFrame(G),G=null;if(f.removeEventListener("click",s),f.removeEventListener("mouseenter",r),f.removeEventListener("mouseleave",h),l.removeEventListener("mousedown",a),j.removeEventListener("mouseenter",K2),j.removeEventListener("mouseleave",v),document.removeEventListener("mousemove",o),document.removeEventListener("mouseup",B2),d){if(d.removeEventListener("mouseenter",r),d.removeEventListener("mouseleave",h),d.parentNode)d.parentNode.removeChild(d)}if(f.parentNode)f.parentNode.removeChild(f)};if(R(),f.addEventListener("click",s),f.addEventListener("mouseenter",r),f.addEventListener("mouseleave",h),l.addEventListener("mousedown",a),j.addEventListener("mouseenter",K2),j.addEventListener("mouseleave",v),d)d.addEventListener("mouseenter",r),d.addEventListener("mouseleave",h);return{show:I,hide:z,updateBounds:H,updatePosition:m,isVisible:()=>A,destroy:$2}};var oj=(j)=>{let Q=null;return{name:"withScrollbar",priority:30,setup($){let{dom:J,config:K}=$,{classPrefix:X,horizontal:q}=K;if(Q=T2(J.viewport,(B)=>$.scrollController.scrollTo(B),j??{},X,q),!J.viewport.classList.contains(`${X}-viewport--custom-scrollbar`))J.viewport.classList.add(`${X}-viewport--custom-scrollbar`);let Z=$.getCachedCompression();Q.updateBounds(Z.virtualHeight,$.state.viewportState.containerHeight);let V=Q;$.afterScroll.push((B,U)=>{V.updatePosition(B),V.show()}),$.resizeHandlers.push((B,U)=>{if(V){let L=$.getCachedCompression();V.updateBounds(L.virtualHeight,$.state.viewportState.containerHeight)}}),$.contentSizeHandlers.push(()=>{if(V){let B=$.getCachedCompression();V.updateBounds(B.virtualHeight,$.state.viewportState.containerHeight)}}),$.destroyHandlers.push(()=>{if(V)V.destroy()})},destroy(){if(Q)Q.destroy(),Q=null}}};var ij=(j=0)=>{let Q=[,,,,,,,,];for(let $=0;$<8;$++)Q[$]={position:0,time:0};return{velocity:0,lastPosition:j,lastTime:performance.now(),samples:Q,sampleIndex:0,sampleCount:0}},e2=(j,Q)=>{let $=performance.now(),J=$-j.lastTime;if(J===0)return j;if(J>100){j.sampleCount=0,j.sampleIndex=0,j.velocity=0;let X=j.samples[0];return X.position=Q,X.time=$,j.sampleIndex=1,j.sampleCount=1,j.lastPosition=Q,j.lastTime=$,j}let K=j.samples[j.sampleIndex];if(K.position=Q,K.time=$,j.sampleIndex=(j.sampleIndex+1)%8,j.sampleCount=Math.min(j.sampleCount+1,8),j.sampleCount>=2){let X=(j.sampleIndex-j.sampleCount+8)%8,q=j.samples[X],Z=Q-q.position,V=$-q.time;j.velocity=V>0?Z/V:0}return j.lastPosition=Q,j.lastTime=$,j},Z4=(j)=>j.sampleCount>=3,tj=(j,Q={})=>{let{wheel:$=!0,sensitivity:J=1,smoothing:K=!1,idleTimeout:X=150,onScroll:q,onIdle:Z,scrollElement:V,horizontal:B=!1}=Q,U=!!V,L=0,y=0,T=U?B?window.innerWidth:window.innerHeight:B?j.clientWidth:j.clientHeight,W=Q.compressed??!1,M=Q.compression,N=ij(),O=!1,F=null,_=jj(()=>{let v=B?j.scrollLeft:j.scrollTop,r=v>=L?"down":"up";if(N=e2(N,v),L=v,q)q({scrollTop:L,direction:r,velocity:N.velocity});x()}),G=jj(()=>{let v=j.getBoundingClientRect(),r=B?Math.max(0,-v.left):Math.max(0,-v.top),h=r>=L?"down":"up";if(N=e2(N,r),L=r,!O)O=!0;if(q)q({scrollTop:L,direction:h,velocity:N.velocity});x()}),P=(v)=>{v.preventDefault()},D=(v)=>{if(v.deltaX)return;v.preventDefault(),j.scrollLeft+=v.deltaY},k=(v)=>{if(!W)return;v.preventDefault();let r=(B?v.deltaX||v.deltaY:v.deltaY)*J,h=L+r;if(K)h=L+r*0.3;if(h=Math.max(0,Math.min(h,y)),h!==L){let i=h>=L?"down":"up";if(N=e2(N,h),L=h,!O)O=!0;if(q)q({scrollTop:L,direction:i,velocity:N.velocity});x()}},x=()=>{if(F)clearTimeout(F);F=setTimeout(()=>{if(O=!1,N=ij(L),Z)Z()},X)},j2=(v)=>{if(W)return;if(W=!0,M=v,y=v.virtualHeight-T,U)return;if(_.cancel(),j.removeEventListener("scroll",_),!$)j.removeEventListener("wheel",P);else if(B)j.removeEventListener("wheel",D);if(B)j.style.overflowX="hidden";else j.style.overflow="hidden";if($)j.addEventListener("wheel",k,{passive:!1});let r=B?j.scrollLeft:j.scrollTop;if(r>0){let h=B?M?.actualHeight??j.scrollWidth:M?.actualHeight??j.scrollHeight;L=r/h*y}if(B)j.scrollLeft=0;else j.scrollTop=0},f=()=>{if(!W)return;if(W=!1,U){M=void 0;return}if(j.removeEventListener("wheel",k),B)j.style.overflowX="auto";else j.style.overflow="auto";if(j.addEventListener("scroll",_,{passive:!0}),!$)j.addEventListener("wheel",P,{passive:!1});else if(B)j.addEventListener("wheel",D,{passive:!1});if(M&&L>0){let r=L/y*(M.actualHeight-T);if(B)j.scrollLeft=r;else j.scrollTop=r}M=void 0},l=()=>{if(U||W)return L;return B?j.scrollLeft:j.scrollTop},d=(v,r=!1)=>{let h=Math.max(0,Math.min(v,y||1/0));if(U){let $2=j.getBoundingClientRect();if(B){let i=$2.left+window.scrollX;window.scrollTo({left:i+h,behavior:r?"smooth":"auto"})}else{let i=$2.top+window.scrollY;window.scrollTo({top:i+h,behavior:r?"smooth":"auto"})}}else if(W){if(h===L)return;let i=h>=L?"down":"up";if(N=e2(N,h),L=h,!O)O=!0;if(q)q({scrollTop:L,direction:i,velocity:N.velocity});x()}else if(B)j.scrollTo({left:h,behavior:r?"smooth":"auto"});else j.scrollTo({top:h,behavior:r?"smooth":"auto"})},R=(v)=>{d(l()+v)},w=()=>{return l()<=0},p=(v=0)=>{let r=l(),h=U||W?y:B?j.scrollWidth-j.clientWidth:j.scrollHeight-j.clientHeight;return r>=h-v},I=()=>{let v=l(),r=U||W?y:B?j.scrollWidth-j.clientWidth:j.scrollHeight-j.clientHeight;if(r<=0)return 0;return Math.min(1,Math.max(0,v/r))},z=(v)=>{if(v.compression)M=v.compression,y=M.virtualHeight-T},H=()=>W,m=()=>Math.abs(N.velocity),s=()=>Z4(N),a=()=>O,o=()=>U,B2=(v)=>{if(T=v,M)y=M.virtualHeight-T},K2=()=>{if(F)clearTimeout(F);if(U)G.cancel(),window.removeEventListener("scroll",G);else _.cancel(),j.removeEventListener("scroll",_),j.removeEventListener("wheel",k),j.removeEventListener("wheel",P),j.removeEventListener("wheel",D)};if(U){if(W&&M)y=M.virtualHeight-T;window.addEventListener("scroll",G,{passive:!0})}else if(W&&M){if(y=M.virtualHeight-T,B)j.style.overflowX="hidden";else j.style.overflow="hidden";if($)j.addEventListener("wheel",k,{passive:!1})}else{if(B)j.style.overflowX="auto",j.style.overflowY="hidden";else j.style.overflow="auto";if(j.addEventListener("scroll",_,{passive:!0}),!$)j.addEventListener("wheel",P,{passive:!1});else if(B)j.addEventListener("wheel",D,{passive:!1})}return{getScrollTop:l,scrollTo:d,scrollBy:R,isAtTop:w,isAtBottom:p,getScrollPercentage:I,getVelocity:m,isTracking:s,isScrolling:a,updateConfig:z,enableCompression:j2,disableCompression:f,isCompressed:H,isWindowMode:o,updateContainerHeight:B2,destroy:K2}},jj=(j)=>{let Q=null,$=null,J=(...K)=>{if($=K,Q===null)Q=requestAnimationFrame(()=>{if(Q=null,$)j(...$)})};return J.cancel=()=>{if(Q!==null)cancelAnimationFrame(Q),Q=null},J};var B4=0.65,U4=0.5,D4=0.95,W4=0.1,N4=5,G4=100,ej=()=>{let j=null,Q=0,$=!1,J=0,K=null,X=0,q=0,Z=null,V=[];return{name:"withScale",priority:20,setup(B){let{dom:U,config:L}=B,{classPrefix:y,horizontal:T}=L,W=()=>{let F=B.getVirtualTotal(),b=E2(F,B.heightCache);if(b.isCompressed&&!$){$=!0,B.scrollController.enableCompression(b),B.updateContentSize(b.virtualHeight),B.setScrollFns(()=>Q,(f)=>{if(Q=f,J=f,K!==null)cancelAnimationFrame(K),K=null});let _=()=>{let f=J-Q;if(Math.abs(f)<U4)Q=J,K=null;else Q+=f*B4,K=requestAnimationFrame(_);B.scrollController.scrollTo(Q)},A=U.viewport,G=(f)=>{f.preventDefault();let d=B.getCachedCompression().virtualHeight-B.state.viewportState.containerHeight;if(J=Math.max(0,Math.min(J+f.deltaY,d)),K===null)K=requestAnimationFrame(_)};A.addEventListener("wheel",G,{passive:!1});let P=()=>{if(Z!==null)cancelAnimationFrame(Z),Z=null},D=(f)=>{if(P(),K!==null)cancelAnimationFrame(K),K=null;let l=f.touches[0];if(!l)return;let d=T?l.clientX:l.clientY;X=d,q=Q,V=[{time:performance.now(),y:d}]},k=(f)=>{f.preventDefault();let l=f.touches[0];if(!l)return;let d=T?l.clientX:l.clientY,R=performance.now();if(V.push({time:R,y:d}),V.length>N4)V.shift();let w=X-d,I=B.getCachedCompression().virtualHeight-B.state.viewportState.containerHeight,z=Math.max(0,Math.min(q+w,I));Q=z,J=z,B.scrollController.scrollTo(z)},x=(f)=>{let l=performance.now(),d=V.filter((I)=>l-I.time<G4),R=0;if(d.length>=2){let I=d[0],z=d[d.length-1],H=z.time-I.time;if(H>0)R=(I.y-z.y)/H}if(V=[],Math.abs(R)<W4)return;let w=R*16,p=()=>{if(w*=D4,Math.abs(w)<0.5){Z=null;return}let z=B.getCachedCompression().virtualHeight-B.state.viewportState.containerHeight,H=Q+w;if(H=Math.max(0,Math.min(H,z)),H<=0&&w<0||H>=z&&w>0){Q=H,J=H,B.scrollController.scrollTo(H),Z=null;return}Q=H,J=H,B.scrollController.scrollTo(H),Z=requestAnimationFrame(p)};Z=requestAnimationFrame(p)};if(A.addEventListener("touchstart",D,{passive:!0}),A.addEventListener("touchmove",k,{passive:!1}),A.addEventListener("touchend",x,{passive:!0}),A.addEventListener("touchcancel",x,{passive:!0}),B.destroyHandlers.push(()=>{if(A.removeEventListener("wheel",G),A.removeEventListener("touchstart",D),A.removeEventListener("touchmove",k),A.removeEventListener("touchend",x),A.removeEventListener("touchcancel",x),P(),K!==null)cancelAnimationFrame(K),K=null}),!U.viewport.querySelector(`.${y}-scrollbar-track`)){if(j=T2(U.viewport,(l)=>B.scrollController.scrollTo(l),{},y,T),!U.viewport.classList.contains(`${y}-viewport--custom-scrollbar`))U.viewport.classList.add(`${y}-viewport--custom-scrollbar`);j.updateBounds(b.virtualHeight,B.state.viewportState.containerHeight);let f=j;B.afterScroll.push((l,d)=>{if(f)f.updatePosition(l),f.show()}),B.resizeHandlers.push((l,d)=>{if(f){let R=B.getCachedCompression();f.updateBounds(R.virtualHeight,B.state.viewportState.containerHeight)}})}}else if(!b.isCompressed&&$)$=!1,B.scrollController.disableCompression(),B.updateContentSize(b.actualHeight);else if(b.isCompressed)B.scrollController.updateConfig({compression:b}),B.updateContentSize(b.virtualHeight);if(j)j.updateBounds(b.virtualHeight,B.state.viewportState.containerHeight);B.state.cachedCompression={state:b,totalItems:F}};B.updateCompressionMode=W;let M=B.getCachedCompression.bind(B);B.getCachedCompression=()=>{if(B.state.cachedCompression)return B.state.cachedCompression.state;return M()},B.setVisibleRangeFn((F,b,_,A,G)=>{N=null,O=null;let P=E2(A,_);o2(F,b,_,A,P,G)}),B.setScrollToPosFn((F,b,_,A,G)=>{let P=E2(A,b);return i2(F,b,_,A,P,G)});let N=null,O=null;B.setPositionElementFn((F,b)=>{let _=B.getVirtualTotal(),A=E2(_,B.heightCache);if(A.isCompressed){let G=B.scrollController.getScrollTop();if(N===null||b<O)O=b,N=Math.round(C2(b,G,B.heightCache,_,B.state.viewportState.containerHeight,A));let P=N+B.heightCache.getOffset(b)-B.heightCache.getOffset(O),D=B.config.horizontal;F.style.transform=D?`translateX(${P}px)`:`translateY(${P}px)`}else{let G=Math.round(B.heightCache.getOffset(b)),P=B.config.horizontal;F.style.transform=P?`translateX(${G}px)`:`translateY(${G}px)`}}),W(),B.destroyHandlers.push(()=>{if(j)j.destroy(),j=null;if(K!==null)cancelAnimationFrame(K),K=null})},destroy(){if(j)j.destroy(),j=null;if(K!==null)cancelAnimationFrame(K),K=null;if(Z!==null)cancelAnimationFrame(Z),Z=null}}};var Jj=(j={})=>{let{chunkSize:Q=100,maxCachedItems:$=5000,evictionBuffer:J=200,onEvict:K}=j,X=new Map,q=0,Z=0,V=(R)=>{let w=X.get(R);if(!w)w={items:Array(Q),count:0,lastAccess:Date.now()},X.set(R,w);else w.lastAccess=Date.now();return w},B=(R)=>{return Math.floor(R/Q)},U=(R)=>{return R%Q},L=()=>q,y=(R)=>{q=R},T=(R)=>{if(R<0||R>=q)return;let w=B(R),p=X.get(w);if(!p)return;return p.items[U(R)]},W=(R)=>{if(R<0||R>=q)return!1;let w=B(R),p=X.get(w);if(!p)return!1;return p.items[U(R)]!==void 0},M=(R,w)=>{let p=B(R),I=V(p),z=U(R),H=I.items[z]===void 0;if(I.items[z]=w,H)I.count++,Z++;if(R>=q)q=R+1},N=(R,w)=>{for(let p=0;p<w.length;p++){let I=w[p];if(I!==void 0)M(R+p,I)}},O=(R)=>{if(R<0||R>=q)return!1;let w=B(R),p=X.get(w);if(!p)return!1;let I=U(R);if(p.items[I]===void 0)return!1;if(p.items[I]=void 0,p.count--,Z--,p.count===0)X.delete(w);return!0},F=(R,w)=>{let p=[];for(let I=R;I<=w&&I<q;I++)p.push(T(I));return p},b=(R,w)=>{for(let p=R;p<=w&&p<q;p++)if(!W(p))return!1;return!0},_=()=>{let R=[],w=null,p=Array.from(X.keys()).sort((I,z)=>I-z);for(let I of p){let z=X.get(I);if(!z)continue;let H=I*Q;for(let m=0;m<Q;m++){let s=H+m;if(s>=q)break;if(z.items[m]!==void 0)if(w===null)w={start:s,end:s};else if(s===w.end+1)w.end=s;else R.push(w),w={start:s,end:s};else if(w!==null)R.push(w),w=null}}if(w!==null)R.push(w);return R},A=(R,w)=>{let p=[],I=null;for(let z=R;z<=w&&z<q;z++)if(!W(z))if(I===null)I={start:z,end:z};else I.end=z;else if(I!==null)p.push(I),I=null;if(I!==null)p.push(I);return p},G=(R)=>{return X.has(R)},P=(R)=>{let w=X.get(R);if(w)w.lastAccess=Date.now()},D=(R,w)=>{if(R>w||X.size===0)return;let p=Date.now(),I=B(Math.max(0,R)),z=B(Math.min(q-1,w));for(let H=I;H<=z;H++){let m=X.get(H);if(m)m.lastAccess=p}},k=(R,w)=>{if(Z<=$)return 0;let p=Math.max(0,R-J),I=Math.min(q-1,w+J),z=B(p),H=B(I),m=0,s=[];for(let[a,o]of X)if(a<z||a>H)m+=o.count,s.push(a),Z-=o.count,X.delete(a);if(m>0&&K)K(m,s);return m},x=()=>{if(Z<=$)return 0;let R=Array.from(X.entries()).sort(([,I],[,z])=>I.lastAccess-z.lastAccess),w=0,p=[];for(let[I,z]of R){if(Z<=$)break;w+=z.count,Z-=z.count,p.push(I),X.delete(I)}if(w>0&&K)K(w,p);return w},j2=()=>{return{totalItems:q,cachedItems:Z,cachedChunks:X.size,chunkSize:Q,maxCachedItems:$,memoryEfficiency:q>0?1-Z/q:1}},f=()=>Z,l=()=>{X.clear(),Z=0};return{chunkSize:Q,maxCachedItems:$,getTotal:L,setTotal:y,get:T,has:W,set:M,setRange:N,delete:O,getRange:F,isRangeLoaded:b,getLoadedRanges:_,findUnloadedRanges:A,getChunkIndex:B,isChunkLoaded:G,touchChunk:P,touchChunksForRange:D,evictDistant:k,evictToLimit:x,getStats:j2,getCachedCount:f,clear:l,reset:()=>{l(),q=0}}},$j=(j)=>{if(j.length===0)return[];let Q=[...j].sort((J,K)=>J.start-K.start),$=[{...Q[0]}];for(let J=1;J<Q.length;J++){let K=Q[J],X=$[$.length-1];if(K.start<=X.end+1)X.end=Math.max(X.end,K.end);else $.push({...K})}return $},h2=(j,Q,$)=>{let J=Math.floor(j.start/$)*$,K=Math.ceil((j.end+1)/$)*$-1,X={start:J,end:K};if(Q.length===0)return[X];let q=[],Z=$j(Q),V=X.start;for(let B of Z){if(B.end<V)continue;if(B.start>X.end)break;if(B.start>V)q.push({start:V,end:Math.min(B.start-1,X.end)});if(V=B.end+1,V>X.end)break}if(V<=X.end)q.push({start:V,end:X.end});return q};var Qj=(j={})=>{let{enabled:Q=!0,maskCharacter:$="█",randomVariance:J=!0,maxSampleSize:K=20,customGenerator:X}=j,q=null,Z=!1,V=0,B=(O)=>{if(!Q||Z||O.length===0)return;let F=new Map,b=new Map,_=Math.min(O.length,K);for(let A=0;A<_;A++){let G=O[A];if(!G||typeof G!=="object")continue;for(let[P,D]of Object.entries(G)){if(P.startsWith("_")||P==="id")continue;if(!b.has(P))b.set(P,{lengths:[],types:new Set});let k=b.get(P),x=Array.isArray(D)?"array":typeof D;if(k.types.add(x),typeof D==="string")k.lengths.push(D.length);else if(D!==null&&D!==void 0)k.lengths.push(String(D).length)}}for(let[A,G]of b){if(G.lengths.length===0)continue;let P=Math.min(...G.lengths),D=Math.max(...G.lengths),k=Math.round(G.lengths.reduce((j2,f)=>j2+f,0)/G.lengths.length),x="string";if(G.types.has("number")&&G.types.size===1)x="number";else if(G.types.has("boolean")&&G.types.size===1)x="boolean";else if(G.types.has("array"))x="array";else if(G.types.has("object")&&!G.types.has("string"))x="object";F.set(A,{minLength:P,maxLength:D,avgLength:k,type:x})}q=F,Z=!0},U=()=>Z,L=(O)=>{let F=O.avgLength;if(J&&O.minLength!==O.maxLength){if(F=Math.floor(Math.random()*(O.maxLength-O.minLength+1)+O.minLength),Math.random()<0.3)F=Math.max(1,F+Math.floor(Math.random()*3)-1)}return $.repeat(Math.max(1,F))},y=(O)=>{if(X)return{...X(O),["_isPlaceholder"]:!0};let F={id:`__placeholder_${V++}`,["_isPlaceholder"]:!0,_index:O};if(!q||q.size===0)return F.label=$.repeat(12),F;for(let[b,_]of q)switch(_.type){case"string":F[b]=L(_);break;case"number":F[b]=0;break;case"boolean":F[b]=!1;break;case"array":F[b]=[];break;case"object":F[b]={};break;default:F[b]=L(_)}return F};return{analyzeStructure:B,hasAnalyzedStructure:U,generate:y,generateRange:(O,F)=>{let b=[];for(let _=O;_<=F;_++)b.push(y(_));return b},isPlaceholder:(O)=>{if(!O||typeof O!=="object")return!1;return O._isPlaceholder===!0},getPlaceholderKey:()=>"_isPlaceholder",clear:()=>{q=null,Z=!1,V=0}}},b2=(j)=>{if(!j||typeof j!=="object")return!1;return j._isPlaceholder===!0},Oj=(j)=>{return j.filter((Q)=>!b2(Q))};var _4=50,Xj=(j={})=>{let{adapter:Q,initialItems:$,initialTotal:J,storage:K,placeholder:X,pageSize:q=_4,onStateChange:Z,onItemsLoaded:V,onItemsEvicted:B}=j,U=Jj({...K,onEvict:(S,g)=>{B?.(S),A()}}),L=null,y=()=>{if(!L)L=Qj(X);return L},T=new Map,W=!1,M,N=!0,O,F=[],b=0,_=new Map,A=()=>{Z?.(d())},G=()=>{T.clear();let S=U.getLoadedRanges();for(let g of S)for(let t=g.start;t<=g.end;t++){let c=U.get(t);if(c&&!b2(c))T.set(c.id,t)}},P=(S,g)=>{if(!b2(g))T.set(g.id,S)},D=(S)=>{T.delete(S)},k=(S,g)=>{return`${S}-${g}`},x=()=>U.getTotal(),j2=()=>U.getCachedCount(),f=()=>W,l=()=>N,d=()=>({total:U.getTotal(),cached:U.getCachedCount(),isLoading:W,pendingRanges:F,error:M,hasMore:N,cursor:O}),R=()=>U,w=()=>y(),p=(S)=>{let g=U.get(S);if(g!==void 0)return g;if(S>=0&&S<U.getTotal())return y().generate(S);return},I=(S)=>{let g=T.get(S);if(g===void 0)return;return U.get(g)},z=(S)=>{return T.get(S)??-1},H=(S)=>{let g=U.get(S);return g!==void 0&&!b2(g)},m=(S,g)=>{let t=[],c=U.getTotal(),q2=0,X2=0;U.touchChunksForRange(S,Math.min(g,c-1));for(let M2=S;M2<=g&&M2<c;M2++){let A2=U.get(M2);if(A2!==void 0)t.push(A2),q2++;else t.push(y().generate(M2)),X2++}return t},s=(S)=>{U.setTotal(S),N=U.getCachedCount()<S,A()},a=(S,g=0,t)=>{if(L&&!L.hasAnalyzedStructure()&&S.length>0)L.analyzeStructure(S);for(let c=0;c<S.length;c++){let q2=S[c];if(q2!==void 0){let X2=g+c;U.set(X2,q2),P(X2,q2)}}if(t!==void 0)U.setTotal(t);else if(g+S.length>U.getTotal())U.setTotal(g+S.length);if(U.getCachedCount()>=U.getTotal()&&U.getTotal()>0)N=!1;V?.(S,g,U.getTotal()),A()},o=(S,g)=>{let t=T.get(S);if(t===void 0)return!1;let c=U.get(t);if(!c)return!1;let q2={...c,...g};if(U.set(t,q2),g.id!==void 0&&g.id!==S)D(S),P(t,q2);return A(),!0},B2=(S)=>{let g=T.get(S);if(g===void 0)return!1;U.delete(g),D(S);let t=U.getTotal();if(t>0)U.setTotal(t-1);return A(),!0},K2=async(S,g)=>{if(!Q)return;let t=k(S,g);if(_.has(t))return;let c=U.getLoadedRanges(),q2=h2({start:S,end:g},c,U.chunkSize);if(q2.length===0)return;let X2=U.chunkSize,M2=[];for(let J2 of q2){let N2=Math.floor(J2.start/X2),L2=Math.floor(J2.end/X2);for(let Y2=N2;Y2<=L2;Y2++){let V2=Y2*X2,G2=V2+X2-1,_2=k(V2,G2);if(!M2.some((H2)=>H2.start===V2)&&!_.has(_2))M2.push({start:V2,end:G2})}}let A2=[];for(let J2 of q2){let N2=Math.floor(J2.start/X2),L2=Math.floor(J2.end/X2);for(let Y2=N2;Y2<=L2;Y2++){let V2=Y2*X2,G2=V2+X2-1,_2=k(V2,G2);if(_.has(_2)){let H2=_.get(_2);if(!A2.includes(H2))A2.push(H2)}}}for(let J2 of M2){let N2=k(J2.start,J2.end),L2=(async()=>{F.push(J2),W=!0,M=void 0,A();try{let Y2=J2.end-J2.start+1,V2={offset:J2.start,limit:Y2,cursor:void 0},G2=await Q.read(V2);if(a(G2.items,J2.start,G2.total),G2.cursor)O=G2.cursor;let _2=J2.start+G2.items.length;if(_2>=b){if(b=_2,G2.hasMore!==void 0)N=G2.hasMore;else if(G2.total!==void 0)N=_2<G2.total}}catch(Y2){M=Y2 instanceof Error?Y2:Error(String(Y2))}finally{_.delete(N2),F=F.filter((Y2)=>Y2.start!==J2.start||Y2.end!==J2.end),W=_.size>0,A()}})();_.set(N2,L2),A2.push(L2)}await Promise.all(A2)},v=async(S,g)=>{if(U.isRangeLoaded(S,g))return;await K2(S,g)},r=async()=>{if(!Q)return;await K2(0,q-1)},h=async()=>{if(!Q||W||!N)return!1;let S=U.getCachedCount(),g=U.getTotal(),t=S,c=Math.min(t+q-1,g>0?g-1:t+q-1);if(t>=g&&g>0)return N=!1,!1;return await K2(t,c),U.getCachedCount()>S},$2=async()=>{if(U.clear(),T.clear(),L)L.clear();_.clear(),F=[],W=!1,O=void 0,N=!0,b=0,M=void 0,A()},i=(S,g)=>{if(U.evictDistant(S,g)>0)G()},Q2=()=>{U.clear(),T.clear(),O=void 0,M=void 0,F=[],W=!1,A()},D2=()=>{if(U.reset(),T.clear(),L)L.clear();O=void 0,N=!0,b=0,M=void 0,F=[],W=!1,A()};if($&&$.length>0)a($,0,J??$.length);else if(J!==void 0)U.setTotal(J);return{getState:d,getTotal:x,getCached:j2,getIsLoading:f,getHasMore:l,getStorage:R,getPlaceholders:w,getItem:p,getItemById:I,getIndexById:z,isItemLoaded:H,getItemsInRange:m,setTotal:s,setItems:a,updateItem:o,removeItem:B2,loadRange:K2,ensureRange:v,loadInitial:r,loadMore:h,reload:$2,evictDistant:i,clear:Q2,reset:D2}};var jJ=(j)=>{let{adapter:Q,loading:$}=j,J=$?.cancelThreshold??gj,K=$?.preloadThreshold??mj,X=$?.preloadAhead??dj;return{name:"withAsync",priority:20,methods:["reload"],setup(q){let{emitter:Z}=q,V=q.config.reverse,B=Xj({adapter:Q,pageSize:x2,onStateChange:()=>{if(q.state.isInitialized){q.heightCache.rebuild(q.getVirtualTotal()),q.updateCompressionMode();let N=q.getCachedCompression();q.state.viewportState.totalHeight=N.virtualHeight,q.state.viewportState.actualHeight=N.actualHeight,q.state.viewportState.isCompressed=N.isCompressed,q.state.viewportState.compressionRatio=N.ratio,q.updateContentSize(N.virtualHeight),q.renderIfNeeded()}},onItemsLoaded:(N,O,F)=>{if(q.state.isInitialized)q.heightCache.rebuild(q.getVirtualTotal()),q.forceRender(),Z.emit("load:end",{items:N,total:F})}});q.replaceDataManager(B);let U=null,L=null,y=0,T=()=>{if(L){let N=L;L=null,q.dataManager.ensureRange(N.start,N.end).catch((O)=>{Z.emit("error",{error:O,context:"ensureRange"})})}};q.afterScroll.push((N,O)=>{if(q.state.isDestroyed)return;let F=q.scrollController.getVelocity(),_=q.scrollController.isTracking()&&F<=J;if(L&&y>J&&F<=J){let P=L;L=null,q.dataManager.ensureRange(P.start,P.end).catch((D)=>{Z.emit("error",{error:D,context:"ensureRange"})})}if(y=F,_&&!q.dataManager.getIsLoading()&&q.dataManager.getHasMore()){if(V){if(N<Ej)Z.emit("load:start",{offset:q.dataManager.getCached(),limit:x2}),q.dataManager.loadMore().catch((P)=>{Z.emit("error",{error:P,context:"loadMore"})})}else if(q.state.viewportState.totalHeight-N-q.state.viewportState.containerHeight<Ej)Z.emit("load:start",{offset:q.dataManager.getCached(),limit:x2}),q.dataManager.loadMore().catch((D)=>{Z.emit("error",{error:D,context:"loadMore"})})}let{renderRange:A}=q.state.viewportState;if(!U||A.start!==U.start||A.end!==U.end)if(U={start:A.start,end:A.end},_){L=null;let{start:P,end:D}=A,k=q.getVirtualTotal();if(F>K)if(O==="down")D=Math.min(A.end+X,k-1);else P=Math.max(A.start-X,0);q.dataManager.ensureRange(P,D).catch((x)=>{Z.emit("error",{error:x,context:"ensureRange"})})}else L={start:A.start,end:A.end}});let W=200,M=null;q.afterScroll.push((N,O)=>{if(M!==null)clearTimeout(M);M=setTimeout(()=>{M=null,T()},W)}),q.destroyHandlers.push(()=>{if(M!==null)clearTimeout(M),M=null}),Z.on("load:start",()=>{q.dom.root.setAttribute("aria-busy","true")}),Z.on("load:end",()=>{q.dom.root.removeAttribute("aria-busy")}),q.methods.set("reload",async()=>{U=null,L=null,q.invalidateRendered(),await q.dataManager.reload(),q.forceRender();let{renderRange:N}=q.state.viewportState;if(N.end>0)await q.dataManager.ensureRange(N.start,N.end)}),Z.emit("load:start",{offset:0,limit:x2}),q.dataManager.loadInitial().catch((N)=>{Z.emit("error",{error:N,context:"loadInitial"})})}}};var JJ=()=>{let j=null;return{name:"withPage",priority:5,setup(Q){let{dom:$,state:J,config:K,emitter:X}=Q;$.root.style.overflow="visible",$.root.style.height="auto",$.viewport.classList.remove(`${K.classPrefix}-viewport--custom-scrollbar`),Q.disableViewportResize(),Q.setScrollTarget(window),Q.setScrollFns(()=>{let B=$.viewport.getBoundingClientRect();if(K.horizontal)return Math.max(0,-B.left);else return Math.max(0,-B.top)},(B)=>{let U=$.viewport.getBoundingClientRect();if(K.horizontal){let L=U.left+window.scrollX;window.scrollTo(L+B,window.scrollY)}else{let L=U.top+window.scrollY;window.scrollTo(window.scrollX,L+B)}}),Q.setContainerDimensions({width:()=>window.innerWidth,height:()=>window.innerHeight}),J.viewportState.containerHeight=window.innerHeight;let{innerHeight:q,innerWidth:Z}=window,V=()=>{let{innerWidth:B,innerHeight:U}=window,L=K.horizontal?B:U,y=K.horizontal?Z:q;if(Math.abs(L-y)<=1)return;q=U,Z=B,J.viewportState.containerHeight=U,X.emit("resize",{width:B,height:U});for(let T=0;T<Q.resizeHandlers.length;T++)Q.resizeHandlers[T](B,U);Q.renderIfNeeded()};window.addEventListener("resize",V,{passive:!0}),j=()=>{window.removeEventListener("resize",V)},Q.destroyHandlers.push(j)},destroy(){if(j)j(),j=null}}};var zj=(j,Q)=>{let $=0,J=j.length-1;while($<J){let K=$+J+1>>>1;if(j[K].headerLayoutIndex<=Q)$=K;else J=K-1}return $},$J=(j,Q)=>{let $=0,J=j.length-1;while($<J){let K=$+J+1>>>1;if(j[K].firstDataIndex<=Q)$=K;else J=K-1}return $},QJ=(j,Q)=>{if(j===0)return[];let $=[],J=Q(0),K=0,X=0;for(let q=1;q<j;q++){let Z=Q(q);if(Z!==J){let V=q-K;$.push({key:J,groupIndex:$.length,headerLayoutIndex:X,firstDataIndex:K,count:V}),X=X+1+V,J=Z,K=q}}return $.push({key:J,groupIndex:$.length,headerLayoutIndex:X,firstDataIndex:K,count:j-K}),$},g2=(j,Q)=>{if(j.length===0||Q.length===0)return[];let $=j.length+Q.length,J=Array($),K=0;for(let X of Q){J[K]={id:`__group_header_${X.groupIndex}`,__groupHeader:!0,groupKey:X.key,groupIndex:X.groupIndex},K++;for(let q=0;q<X.count;q++)J[K]=j[X.firstDataIndex+q],K++}return J},m2=(j,Q)=>{let $=typeof Q==="number"?(J)=>Q:Q;return(J)=>{let K=j.getEntry(J);if(K.type==="header")return j.getHeaderHeight(K.group.groupIndex);return $(K.dataIndex)}},qj=(j,Q)=>{let $=QJ(j,Q.getGroupForIndex),J=j+$.length,K=Q.headerHeight;return{get totalEntries(){return J},get groupCount(){return $.length},get groups(){return $},getEntry:(y)=>{if($.length===0)return{type:"item",dataIndex:y,group:{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0}};let T=zj($,y),W=$[T];if(y===W.headerLayoutIndex)return{type:"header",group:W};let M=y-W.headerLayoutIndex-1;return{type:"item",dataIndex:W.firstDataIndex+M,group:W}},layoutToDataIndex:(y)=>{if($.length===0)return y;let T=zj($,y),W=$[T];if(y===W.headerLayoutIndex)return-1;let M=y-W.headerLayoutIndex-1;return W.firstDataIndex+M},dataToLayoutIndex:(y)=>{if($.length===0)return y;let T=$J($,y),W=$[T],M=y-W.firstDataIndex;return W.headerLayoutIndex+1+M},getGroupAtLayoutIndex:(y)=>{if($.length===0)return{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0};let T=zj($,y);return $[T]},getGroupAtDataIndex:(y)=>{if($.length===0)return{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0};let T=$J($,y);return $[T]},getHeaderHeight:typeof K==="number"?(y)=>K:(y)=>{let T=$[y];if(!T)return 0;return K(T.key,y)},rebuild:(y)=>{$=QJ(y,Q.getGroupForIndex),J=y+$.length}}};var Kj=(j,Q,$,J,K)=>{let X=document.createElement("div");X.className=`${K}-sticky-header`,X.setAttribute("role","presentation"),X.setAttribute("aria-hidden","true"),X.style.position="absolute",X.style.top="0",X.style.left="0",X.style.right="0",X.style.zIndex="5",X.style.pointerEvents="none",X.style.willChange="transform",X.style.overflow="hidden",j.insertBefore(X,j.firstChild);let q=-1,Z=!1,V=0,B=(M)=>{if(M===q)return;q=M;let N=Q.groups;if(M<0||M>=N.length){X.textContent="";return}let O=N[M],F=J.headerTemplate(O.key,O.groupIndex),b=Q.getHeaderHeight(M);if(X.style.height=`${b}px`,typeof F==="string")X.innerHTML=F;else X.replaceChildren(F)},U=(M)=>{let N=Q.groups;if(N.length===0){y();return}let O=0;for(let G=N.length-1;G>=0;G--)if($.getOffset(N[G].headerLayoutIndex)<=M){O=G;break}let F=$.getOffset(N[0].headerLayoutIndex);if(M<F){y();return}if(!Z)L();B(O);let b=Q.getHeaderHeight(O),_=0,A=O+1;if(A<N.length){let P=$.getOffset(N[A].headerLayoutIndex)-M;if(P<b)_=P-b}if(_!==V)V=_,X.style.transform=_===0?"":`translateY(${Math.round(_)}px)`},L=()=>{if(Z)return;Z=!0,X.style.display=""},y=()=>{if(!Z)return;Z=!1,X.style.display="none",q=-1,V=0,X.style.transform=""},T=()=>{let M=q;if(q=-1,M>=0)B(M)},W=()=>{X.remove(),q=-1,Z=!1};return X.style.display="none",{update:U,refresh:T,show:L,hide:y,destroy:W}};var XJ=(j,Q,$,J,K,X)=>{if(J===0||Q===0)return X.start=0,X.end=-1,X;let q=$.indexAtOffset(j),Z=$.indexAtOffset(j+Q);if(Z<J-1)Z++;return X.start=Math.max(0,q),X.end=Math.min(J-1,Math.max(0,Z)),X},qJ=(j,Q,$,J)=>{if($===0)return J.start=0,J.end=-1,J;return J.start=Math.max(0,j.start-Q),J.end=Math.min($-1,j.end+Q),J},KJ=(j,Q,$,J,K,X)=>{if(J===0)return 0;let q=Math.max(0,Math.min(j,J-1)),Z=Q.getOffset(q),V=Q.getHeight(q),B=Q.getTotalHeight(),U=Math.max(0,B-$),L;switch(X){case"center":L=Z-$/2+V/2;break;case"end":L=Z-$+V;break;case"start":default:L=Z;break}return Math.max(0,Math.min(L,U))},YJ=(j,Q,$)=>{if($&&$.isCompressed)return $.virtualHeight;return Q.getTotalHeight()},ZJ=(j,Q)=>{return Q.getTotalHeight()},BJ=(j,Q)=>{return Q.getOffset(j)},UJ=(j,Q,$)=>{let J=Math.max(0,Q-$);return Math.max(0,Math.min(j,J))};var y2=(j,Q,$,J,K="start",X,q=KJ)=>{return q(j,Q,$,J,X,K)},DJ=(j,Q)=>{return j.start===Q.start&&j.end===Q.end},WJ=(j,Q)=>{return j>=Q.start&&j<=Q.end},NJ=(j)=>{if(j.end<j.start)return 0;return j.end-j.start+1};var GJ=(j,Q)=>{let $=[],J=[];for(let K=j.start;K<=j.end;K++)if(K<Q.start||K>Q.end)J.push(K);for(let K=Q.start;K<=Q.end;K++)if(K<j.start||K>j.end)$.push(K);return{add:$,remove:J}};t2();var _J=(j)=>{if(!j.getGroupForIndex)throw Error("[vlist/builder] withGroups: getGroupForIndex is required");if(j.headerHeight==null||j.headerHeight<=0)throw Error("[vlist/builder] withGroups: headerHeight must be a positive number");if(!j.headerTemplate)throw Error("[vlist/builder] withGroups: headerTemplate is required");let Q=null,$=null,J=[],K=[];return{name:"withSections",priority:10,setup(X){let{dom:q,config:Z,rawConfig:V}=X,{classPrefix:B}=Z;if(Z.horizontal)throw Error("[vlist/builder] withGroups cannot be used with direction: 'horizontal'");let L=V.item.height;J=V.items?[...V.items]:[];let y=J.length,T={getGroupForIndex:j.getGroupForIndex,headerHeight:j.headerHeight,headerTemplate:j.headerTemplate,sticky:j.sticky??!1};Q=qj(y,T),K=g2(J,Q.groups);let W=m2(Q,L);X.setHeightConfig(W),X.rebuildHeightCache(K.length),X.dataManager.setItems(K,0,K.length);let M=V.item.template,{headerTemplate:N}=j,O=(D,k,x)=>{if(P2(D))return N(D.groupKey,D.groupIndex);return M(D,k,x)},F=X.methods.get("_getGridLayout"),b=X.methods.get("_replaceGridRenderer"),_=X.methods.get("_updateGridLayoutForGroups");if(F&&b){if(_)_((j2)=>{let f=K[j2];return!!(f&&P2(f))});let{createGridRenderer:D}=(Yj(),cJ(VJ)),k=F(),x=D(q.items,O,X.heightCache,k,B,X.getContainerWidth(),()=>X.dataManager.getTotal(),Z.ariaIdPrefix);b(x)}else X.replaceTemplate(O);if(q.root.classList.add(`${B}--grouped`),j.sticky!==!1){$=Kj(q.root,Q,X.heightCache,{...T,sticky:T.sticky??!1},B);let D=$;X.afterScroll.push((k,x)=>{D.update(k)}),$.update(X.scrollController.getScrollTop())}let A=()=>{if(!Q)return;Q.rebuild(J.length),K=g2(J,Q.groups);let D=m2(Q,L);if(X.setHeightConfig(D),X.rebuildHeightCache(K.length),X.dataManager.setItems(K,0,K.length),$)$.refresh()};X.methods.set("setItems",(D)=>{J=[...D],A()}),X.methods.set("appendItems",(D)=>{J=[...J,...D],A()}),X.methods.set("prependItems",(D)=>{J=[...D,...J],A()}),X.methods.set("removeItem",(D)=>{J=J.filter((k)=>k.id!==D),A()});let{animateScroll:G,cancelScroll:P}=E4(X.scrollController,X.renderIfNeeded);X.methods.set("scrollToIndex",(D,k)=>{let x=Q.dataToLayoutIndex(D),{align:j2,behavior:f,duration:l}=F4(k),d=X.dataManager.getTotal(),R=y2(x,X.heightCache,X.state.viewportState.containerHeight,d,j2,X.getCachedCompression());if(f==="smooth")G(X.scrollController.getScrollTop(),R,l);else P(),X.scrollController.scrollTo(R)}),X.methods.set("_getItems",()=>J),X.methods.set("_getTotal",()=>J.length),X.destroyHandlers.push(()=>{if(O2!==null)cancelAnimationFrame(O2),O2=null;if($)$.destroy(),$=null;q.root.classList.remove(`${B}--grouped`)})},destroy(){if($)$.destroy(),$=null}}},bj=300,A4=(j)=>j<0.5?2*j*j:-1+(4-2*j)*j,O2=null,E4=(j,Q)=>{let $=()=>{if(O2!==null)cancelAnimationFrame(O2),O2=null};return{animateScroll:(K,X,q)=>{if($(),Math.abs(X-K)<1){j.scrollTo(X);return}let Z=performance.now(),V=(B)=>{let U=B-Z,L=Math.min(U/q,1),y=K+(X-K)*A4(L);if(j.scrollTo(y),Q(),L<1)O2=requestAnimationFrame(V);else O2=null};O2=requestAnimationFrame(V)},cancelScroll:$}},F4=(j)=>{if(typeof j==="string")return{align:j,behavior:"auto",duration:bj};if(j&&typeof j==="object")return{align:j.align??"start",behavior:j.behavior??"auto",duration:j.duration??bj};return{align:"start",behavior:"auto",duration:bj}};var Zj=(j)=>{let Q=Math.max(1,Math.floor(j.columns)),$=j.gap??0,J=j.isHeaderFn,K={row:0,col:0},X=(W)=>{if(W<=0)return 0;if(!J)return Math.ceil(W/Q);let M=0,N=0,O=0;for(let F=0;F<W;F++)if(J(F)){if(O++,N>0)M++,N=0;M++,N=0}else if(N++,N>=Q)M++,N=0;if(N>0)M++;return M},q=(W)=>{return K.row=Z(W),K.col=V(W),K},Z=(W)=>{if(!J)return Math.floor(W/Q);let M=0,N=0;for(let O=0;O<=W;O++)if(J(O)){if(N>0)M++,N=0;if(O===W)return M;M++,N=0}else{if(O===W)return M;if(N++,N>=Q)M++,N=0}return console.warn(`⚠️ getRow(${W}) fell through - returning ${M}`),M},V=(W)=>{if(!J)return W%Q;if(J(W))return 0;let M=0;for(let N=0;N<=W;N++)if(J(N))M=0;else{if(N===W)return M;if(M++,M>=Q)M=0}return M},B=(W,M,N)=>{if(N<=0)return{start:0,end:-1};if(!J){let A=Math.max(0,W*Q),G=Math.min(N-1,(M+1)*Q-1);return{start:A,end:G}}let O=-1,F=-1,b=0,_=0;for(let A=0;A<N;A++){if(J(A)){if(_>0)b++,_=0;if(b>=W&&b<=M){if(O===-1)O=A;F=A}b++,_=0}else{if(b>=W&&b<=M){if(O===-1)O=A;F=A}if(_++,_>=Q)b++,_=0}if(b>M&&_===0)break}if(O===-1)return{start:0,end:-1};return{start:O,end:F}},U=(W,M,N)=>{if(M<0||M>=Q)return-1;let O=W*Q+M;if(O<0||O>=N)return-1;return O},L=(W)=>{let M=(Q-1)*$;return Math.max(0,(W-M)/Q)};return{get columns(){return Q},get gap(){return $},update:(W)=>{if(W.columns!==void 0)Q=Math.max(1,Math.floor(W.columns));if(W.gap!==void 0)$=W.gap;if(W.isHeaderFn!==void 0)J=W.isHeaderFn},getTotalRows:X,getPosition:q,getRow:Z,getCol:V,getItemRange:B,getItemIndex:U,getColumnWidth:L,getColumnOffset:(W,M)=>{let N=L(M);return W*(N+$)}}};Yj();var MJ=(j)=>{if(!j.columns||j.columns<1)throw Error("[vlist/builder] withGrid: columns must be a positive integer >= 1");let Q=null,$=null;return{name:"withGrid",priority:10,setup(J){let{dom:K,emitter:X,config:q,rawConfig:Z}=J,{classPrefix:V}=q;if(q.horizontal)throw Error("[vlist/builder] withGrid cannot be used with direction: 'horizontal'");if(q.reverse)throw Error("[vlist/builder] withGrid cannot be used with reverse: true");let B=Z.items?.some((_)=>_.__groupHeader===!0),U={columns:j.columns,gap:j.gap??0};if(B)U.isHeaderFn=(_)=>{let A=J.dataManager.getItem(_);return!!(A&&A.__groupHeader===!0)};Q=Zj(U);let L=Q.gap;J.setVirtualTotalFn(()=>{let _=J.dataManager.getTotal();return Q.getTotalRows(_)});let y=Z.item,T=q.horizontal?y.width:y.height,W={containerWidth:J.getContainerWidth(),columns:Q.columns,gap:Q.gap};if(typeof T==="function")J.setHeightConfig((_)=>{let A=W.containerWidth-2,G=(W.columns-1)*W.gap,P=(A-G)/W.columns,D={containerWidth:W.containerWidth,columns:W.columns,gap:W.gap,columnWidth:P,row:Q.getRow(_),column:Q.getCol(_),totalRows:Q.getTotalRows(J.dataManager.getTotal()),totalColumns:W.columns};return T(_,D)+W.gap});else if(L>0)J.setHeightConfig(T+L);J.rebuildHeightCache(),K.root.classList.add(`${V}--grid`);let M=J.getContainerWidth(),N=Z.item.template,O=()=>{$=d2(K.items,N,J.heightCache,Q,V,M,()=>J.dataManager.getTotal(),q.ariaIdPrefix),J.replaceRenderer($)};O(),J.methods.set("_getGridLayout",()=>Q),J.methods.set("_getGridConfig",()=>U),J.methods.set("_replaceGridRenderer",(_)=>{$=_}),J.methods.set("_updateGridLayoutForGroups",(_)=>{Q.update({isHeaderFn:_});let A=J.dataManager.getTotal(),G=0;for(let P=0;P<A;P++)if(Q.getCol(P)===0){let D=J.heightCache.getHeight(P);G+=D}J.heightCache.getTotalHeight=()=>G,J.dom.content.style.height=`${G}px`,O()}),J.methods.set("updateGrid",(_)=>{if(_.columns!==void 0){if(!Number.isInteger(_.columns)||_.columns<1)throw Error("[vlist/builder] updateGrid: columns must be a positive integer >= 1");U.columns=_.columns}if(_.gap!==void 0){if(_.gap<0)throw Error("[vlist/builder] updateGrid: gap must be non-negative");U.gap=_.gap}if(Q)Q.update(U);let A=J.getContainerWidth();if(W.containerWidth=A,W.columns=U.columns,W.gap=U.gap??0,$)$.updateContainerWidth(A);J.rebuildHeightCache(),J.updateContentSize(J.heightCache.getTotalHeight()),J.updateCompressionMode();for(let G=0;G<J.contentSizeHandlers.length;G++)J.contentSizeHandlers[G]();if($)$.clear();J.forceRender()});let F=()=>{if(J.state.isDestroyed)return;let _=J.scrollController.getScrollTop(),A=J.state.viewportState.containerHeight,G=J.getVirtualTotal(),P={start:0,end:0};if(G===0||A===0)P.start=0,P.end=0;else{P.start=Math.max(0,J.heightCache.indexAtOffset(_));let w=J.heightCache.indexAtOffset(_+A);if(w<G-1)w++;P.end=Math.min(G-1,Math.max(0,w))}let D=q.overscan??3,k={start:Math.max(0,P.start-D),end:Math.min(G-1,P.end+D)};J.state.viewportState.scrollTop=_,J.state.viewportState.visibleRange=P,J.state.viewportState.renderRange=k;let x=J.state.lastRenderRange,j2=J.state.viewportState.isCompressed;if(k.start===x.start&&k.end===x.end){if(j2)$.updatePositions(J.getCompressionContext());return}let f=J.dataManager.getTotal(),l=Q.getItemRange(k.start,k.end,f),d=J.dataManager.getItemsInRange(l.start,l.end),R=j2?J.getCompressionContext():void 0;$.render(d,l,new Set,-1,R),J.state.lastRenderRange={...k},X.emit("range:change",{range:k})},b=()=>{if(J.state.isDestroyed)return;J.state.lastRenderRange={start:-1,end:-1},F()};if(J.setRenderFns(F,b),J.resizeHandlers.push((_,A)=>{if($)$.updateContainerWidth(_)}),J.methods.set("scrollToIndex",(_,A)=>{let G=Math.floor(_/j.columns),{align:P,behavior:D}=L4(A),k=J.dataManager.getState(),x=Q.getTotalRows(k.total),j2=Math.max(0,Math.min(G,x-1)),f=y2(j2,J.heightCache,J.state.viewportState.containerHeight,x,P,J.getCachedCompression());if(D==="smooth")J.scrollController.scrollTo(f);else J.scrollController.scrollTo(f)}),!J.methods.has("_getTotal"))J.methods.set("_getTotal",()=>J.dataManager.getTotal());J.destroyHandlers.push(()=>{if($)$.destroy(),$=null;K.root.classList.remove(`${V}--grid`)})},destroy(){if($)$.destroy(),$=null}}},Pj=300,L4=(j)=>{if(typeof j==="string")return{align:j,behavior:"auto",duration:Pj};if(j&&typeof j==="object")return{align:j.align??"start",behavior:j.behavior??"auto",duration:j.duration??Pj};return{align:"start",behavior:"auto",duration:Pj}};Yj();var Bj=(j)=>({selected:new Set(j??[]),focusedIndex:-1}),c2=(j,Q,$)=>{if($==="none")return j;let J=new Set(j.selected);if($==="single"){if(J.clear(),Q.length>0)J.add(Q[0])}else for(let K of Q)J.add(K);return{...j,selected:J}},l2=(j,Q)=>{let $=new Set(j.selected);for(let J of Q)$.delete(J);return{...j,selected:$}},w2=(j,Q,$)=>{if($==="none")return j;if(j.selected.has(Q))return l2(j,[Q]);else return c2(j,[Q],$)},Uj=(j,Q,$)=>{if($!=="multiple")return j;return{...j,selected:new Set(Q.map((J)=>J.id))}},Dj=(j)=>({...j,selected:new Set}),yj=(j,Q)=>{return j.focusedIndex=Q,j},Hj=(j,Q,$=!0)=>{if(Q===0)return j;let J=j.focusedIndex-1;if(J<0)J=$?Q-1:0;return j.focusedIndex=J,j},Rj=(j,Q,$=!0)=>{if(Q===0)return j;let J=j.focusedIndex+1;if(J>=Q)J=$?0:Q-1;return j.focusedIndex=J,j},kj=(j,Q)=>{if(Q===0)return j;return j.focusedIndex=0,j},Cj=(j,Q)=>{if(Q===0)return j;return j.focusedIndex=Q-1,j};var AJ=(j,Q)=>{return j.selected.has(Q)},v2=(j)=>{return Array.from(j.selected)},S2=(j,Q)=>{let $=[];for(let J of j.selected){let K=Q(J);if(K)$.push(K)}return $};var EJ=(j)=>{let Q=j?.mode??"single",$=j?.initial,J=Bj($),K=null;return{name:"withSelection",priority:50,methods:["select","deselect","toggleSelect","selectAll","clearSelection","getSelected","getSelectedItems"],setup(X){let{dom:q,emitter:Z,config:V}=X,{classPrefix:B,ariaIdPrefix:U}=V;if(Q==="none"){X.methods.set("select",()=>{}),X.methods.set("deselect",()=>{}),X.methods.set("toggleSelect",()=>{}),X.methods.set("selectAll",()=>{}),X.methods.set("clearSelection",()=>{}),X.methods.set("getSelected",()=>[]),X.methods.set("getSelectedItems",()=>[]),X.methods.set("setSelectionMode",()=>{});return}let{renderIfNeeded:L,forceRender:y}=X.getRenderFns(),T=()=>{X.dom.items.querySelectorAll("[data-index]").forEach((b)=>{let _=b,A=_.dataset.id;if(A!==void 0){let G=/^\d+$/.test(A)?parseInt(A,10):A,P=J.selected.has(G),k=parseInt(_.dataset.index??"-1",10)===J.focusedIndex;_.classList.toggle(`${B}-item--selected`,P),_.classList.toggle(`${B}-item--focused`,k),_.ariaSelected=P?"true":"false"}})},W=()=>{if(X.state.isDestroyed)return;L(),T()},M=()=>{if(X.state.isDestroyed)return;y(),T()};X.setRenderFns(W,M);let N=()=>{T(),Z.emit("selection:change",{selected:v2(J),items:S2(J,(F)=>X.dataManager.getItemById(F))})};K=document.createElement("div"),K.setAttribute("aria-live","polite"),K.setAttribute("aria-atomic","true"),K.className=`${B}-live-region`,K.style.cssText="position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0",q.root.appendChild(K);let O=K;Z.on("selection:change",({selected:F})=>{let b=F.length;if(b===0)O.textContent="";else if(b===1)O.textContent="1 item selected";else O.textContent=`${b} items selected`}),X.clickHandlers.push((F)=>{if(X.state.isDestroyed)return;let _=F.target.closest("[data-index]");if(!_)return;let A=parseInt(_.dataset.index??"-1",10);if(A<0)return;let G=X.dataManager.getItem(A);if(!G)return;Z.emit("item:click",{item:G,index:A,event:F}),J=yj(J,A),q.root.setAttribute("aria-activedescendant",`${U}-item-${A}`),J=w2(J,G.id,Q),N()}),X.keydownHandlers.push((F)=>{if(X.state.isDestroyed)return;let b=X.dataManager.getTotal(),_=J.focusedIndex,A=!1,G=!1,P=J;switch(F.key){case"ArrowUp":P=Hj(J,b),A=!0,G=!0;break;case"ArrowDown":P=Rj(J,b),A=!0,G=!0;break;case"Home":P=kj(J,b),A=!0,G=!0;break;case"End":P=Cj(J,b),A=!0,G=!0;break;case" ":case"Enter":if(J.focusedIndex>=0){let D=X.dataManager.getItem(J.focusedIndex);if(D)P=w2(J,D.id,Q);A=!0}break}if(A){F.preventDefault(),J=P;let D=J.focusedIndex;if(D>=0){let k=X.dataManager.getState(),x=y2(D,X.heightCache,X.state.viewportState.containerHeight,k.total,"center",X.getCachedCompression());X.scrollController.scrollTo(x),q.root.setAttribute("aria-activedescendant",`${U}-item-${D}`)}else q.root.removeAttribute("aria-activedescendant");if(G){let{selected:k}=J;if(_>=0&&_!==D){let x=X.dataManager.getItem(_);if(x)X.renderer.updateItemClasses(_,k.has(x.id),!1)}if(D>=0){let x=X.dataManager.getItem(D);if(x)X.renderer.updateItemClasses(D,k.has(x.id),!0)}}else M(),Z.emit("selection:change",{selected:v2(J),items:S2(J,(k)=>X.dataManager.getItemById(k))})}}),X.methods.set("select",(...F)=>{J=c2(J,F,Q),N()}),X.methods.set("deselect",(...F)=>{J=l2(J,F),N()}),X.methods.set("toggleSelect",(F)=>{J=w2(J,F,Q),N()}),X.methods.set("selectAll",()=>{if(Q!=="multiple")return;let F=X.getAllLoadedItems();J=Uj(J,F,Q),N()}),X.methods.set("clearSelection",()=>{J=Dj(J);let{renderRange:F,isCompressed:b}=X.state.viewportState,_=X.getItemsForRange(F),A=b?X.getCompressionContext():void 0;X.renderer.render(_,F,J.selected,J.focusedIndex,A),Z.emit("selection:change",{selected:[],items:[]})}),X.methods.set("getSelected",()=>{return v2(J)}),X.methods.set("getSelectedItems",()=>{return S2(J,(F)=>X.dataManager.getItemById(F))}),X.destroyHandlers.push(()=>{if(O&&O.parentNode)O.remove()})},destroy(){if(K&&K.parentNode)K.remove();K=null}}};var FJ=()=>{return{name:"withSnapshots",priority:50,methods:["getScrollSnapshot","restoreScroll"],setup(j){j.methods.set("getScrollSnapshot",()=>{let Q=j.scrollController.getScrollTop(),$=j.getCachedCompression(),J=j.getVirtualTotal(),K=j.methods.get("getSelected"),X=K&&K().length>0?K():void 0;if(J===0){let B={index:0,offsetInItem:0};if(X)B.selectedIds=X;return B}let q,Z;if($.isCompressed){let U=Q/$.virtualHeight*J;q=Math.max(0,Math.min(Math.floor(U),J-1)),Z=(U-q)*j.heightCache.getHeight(q)}else q=j.heightCache.indexAtOffset(Q),Z=Q-j.heightCache.getOffset(q);Z=Math.max(0,Z);let V={index:q,offsetInItem:Z};if(X)V.selectedIds=X;return V}),j.methods.set("restoreScroll",(Q)=>{let{index:$,offsetInItem:J,selectedIds:K}=Q,X=j.getCachedCompression(),q=j.getVirtualTotal();if(q===0)return;let Z=Math.max(0,Math.min($,q-1)),V;if(X.isCompressed){let U=j.heightCache.getHeight(Z),L=U>0?J/U:0;V=(Z+L)/q*X.virtualHeight}else V=j.heightCache.getOffset(Z)+J;let B=Math.max(0,X.virtualHeight-j.state.viewportState.containerHeight);if(V=Math.max(0,Math.min(V,B)),j.scrollController.scrollTo(V),K&&K.length>0){let U=j.methods.get("select");if(U)U(...K)}})}}};var LJ=()=>{let j={},Q=(Z,V)=>{if(!j[Z])j[Z]=new Set;return j[Z].add(V),()=>$(Z,V)},$=(Z,V)=>{j[Z]?.delete(V)};return{on:Q,off:$,emit:(Z,V)=>{j[Z]?.forEach((B)=>{try{B(V)}catch(U){console.error(`[vlist] Error in event handler for "${String(Z)}":`,U)}})},once:(Z,V)=>{let B=(U)=>{$(Z,B),V(U)};return Q(Z,B)},clear:(Z)=>{if(Z)delete j[Z];else for(let V in j)delete j[V]},listenerCount:(Z)=>{return j[Z]?.size??0}}};export{FJ as withSnapshots,EJ as withSelection,_J as withSections,oj as withScrollbar,ej as withScale,JJ as withPage,MJ as withGrid,jJ as withAsync,hj as vlist,w2 as toggleSelection,XJ as simpleVisibleRange,c2 as selectItems,Uj as selectAll,DJ as rangesEqual,jj as rafThrottle,aj as needsScaling,$j as mergeRanges,AJ as isSelected,P2 as isSectionHeader,b2 as isPlaceholderItem,WJ as isInRange,S2 as getSelectedItems,v2 as getSelectedIds,E2 as getScaleState,nj as getScaleInfo,E2 as getScale,NJ as getRangeCount,rj as getMaxItemsWithoutScaling,Oj as filterPlaceholders,GJ as diffRanges,l2 as deselectItems,Kj as createStickyHeader,Jj as createSparseStorage,Bj as createSelectionState,m2 as createSectionedHeightFn,qj as createSectionLayout,T2 as createScrollbar,tj as createScrollController,Qj as createPlaceholderManager,cj as createHeightCache,d2 as createGridRenderer,Zj as createGridLayout,LJ as createEmitter,Xj as createAsyncManager,Dj as clearSelection,UJ as clampScrollPosition,YJ as calculateTotalHeight,y2 as calculateScrollToIndex,o2 as calculateScaledVisibleRange,i2 as calculateScaledScrollToIndex,lj as calculateScaledRenderRange,C2 as calculateScaledItemPosition,qJ as calculateRenderRange,h2 as calculateMissingRanges,BJ as calculateItemOffset,sj as calculateIndexFromScrollPosition,ZJ as calculateActualHeight,g2 as buildLayoutItems,z2 as MAX_VIRTUAL_HEIGHT};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@floor/vlist",
3
- "version": "0.7.5",
3
+ "version": "0.7.7",
4
4
  "description": "Lightweight, high-performance virtual list with zero dependencies",
5
5
  "author": {
6
6
  "name": "Floor IO",
@@ -39,12 +39,13 @@
39
39
  "./package.json": "./package.json"
40
40
  },
41
41
  "files": [
42
- "dist/**/*.js",
42
+ "dist/index.js",
43
43
  "dist/**/*.d.ts",
44
44
  "dist/**/*.css",
45
45
  "!dist/**/*.d.ts.map",
46
46
  "!dist/core/lite.d.ts",
47
47
  "!dist/core/minimal.d.ts",
48
+ "!dist/core/full.d.ts",
48
49
  "!dist/adapters/**"
49
50
  ],
50
51
  "sideEffects": [
@@ -55,14 +56,7 @@
55
56
  "dev": "bun run build.ts --watch",
56
57
  "test": "bun test",
57
58
  "typecheck": "tsc --noEmit",
58
- "prepublishOnly": "bun run build --types",
59
- "analyze:deps": "madge --circular --extensions ts src",
60
- "analyze:orphans": "madge --orphans --extensions ts src",
61
- "analyze:tree": "madge --extensions ts src",
62
- "analyze:graph": "madge --image deps-graph.svg --extensions ts src",
63
- "analyze:graph:circular": "madge --circular --image deps-circular.svg --extensions ts src",
64
- "analyze:graphs": "bun run analyze:graph && bun run analyze:graph:circular",
65
- "analyze:all": "bun run analyze:deps && bun run analyze:orphans"
59
+ "prepublishOnly": "bun run build --types"
66
60
  },
67
61
  "bugs": {
68
62
  "url": "https://github.com/floor/vlist/issues"
@@ -71,12 +65,7 @@
71
65
  "devDependencies": {
72
66
  "@types/bun": "^1.0.0",
73
67
  "@types/jsdom": "^27.0.0",
74
- "@types/react": "^19.2.13",
75
- "esbuild": "^0.27.3",
76
68
  "jsdom": "^28.0.0",
77
- "madge": "^8.0.0",
78
- "react": "^19.2.4",
79
- "typescript": "^5.0.0",
80
- "vue": "^3.5.28"
69
+ "typescript": "^5.0.0"
81
70
  }
82
71
  }
@@ -1 +0,0 @@
1
- var Yj=(b={})=>{let{chunkSize:Z=100,maxCachedItems:K=5000,evictionBuffer:P=200,onEvict:M}=b,U=new Map,j=0,F=0,S=(J)=>{let X=U.get(J);if(!X)X={items:Array(Z),count:0,lastAccess:Date.now()},U.set(J,X);else X.lastAccess=Date.now();return X},O=(J)=>{return Math.floor(J/Z)},q=(J)=>{return J%Z},H=()=>j,g=(J)=>{j=J},T=(J)=>{if(J<0||J>=j)return;let X=O(J),Y=U.get(X);if(!Y)return;return Y.items[q(J)]},R=(J)=>{if(J<0||J>=j)return!1;let X=O(J),Y=U.get(X);if(!Y)return!1;return Y.items[q(J)]!==void 0},v=(J,X)=>{let Y=O(J),w=S(Y),N=q(J),u=w.items[N]===void 0;if(w.items[N]=X,u)w.count++,F++;if(J>=j)j=J+1},G=(J,X)=>{for(let Y=0;Y<X.length;Y++){let w=X[Y];if(w!==void 0)v(J+Y,w)}},W=(J)=>{if(J<0||J>=j)return!1;let X=O(J),Y=U.get(X);if(!Y)return!1;let w=q(J);if(Y.items[w]===void 0)return!1;if(Y.items[w]=void 0,Y.count--,F--,Y.count===0)U.delete(X);return!0},B=(J,X)=>{let Y=[];for(let w=J;w<=X&&w<j;w++)Y.push(T(w));return Y},_=(J,X)=>{for(let Y=J;Y<=X&&Y<j;Y++)if(!R(Y))return!1;return!0},A=()=>{let J=[],X=null,Y=Array.from(U.keys()).sort((w,N)=>w-N);for(let w of Y){let N=U.get(w);if(!N)continue;let u=w*Z;for(let k=0;k<Z;k++){let h=u+k;if(h>=j)break;if(N.items[k]!==void 0)if(X===null)X={start:h,end:h};else if(h===X.end+1)X.end=h;else J.push(X),X={start:h,end:h};else if(X!==null)J.push(X),X=null}}if(X!==null)J.push(X);return J},V=(J,X)=>{let Y=[],w=null;for(let N=J;N<=X&&N<j;N++)if(!R(N))if(w===null)w={start:N,end:N};else w.end=N;else if(w!==null)Y.push(w),w=null;if(w!==null)Y.push(w);return Y},z=(J)=>{return U.has(J)},y=(J)=>{let X=U.get(J);if(X)X.lastAccess=Date.now()},E=(J,X)=>{if(J>X||U.size===0)return;let Y=Date.now(),w=O(Math.max(0,J)),N=O(Math.min(j-1,X));for(let u=w;u<=N;u++){let k=U.get(u);if(k)k.lastAccess=Y}},p=(J,X)=>{if(F<=K)return 0;let Y=Math.max(0,J-P),w=Math.min(j-1,X+P),N=O(Y),u=O(w),k=0,h=[];for(let[d,Jj]of U)if(d<N||d>u)k+=Jj.count,h.push(d),F-=Jj.count,U.delete(d);if(k>0&&M)M(k,h);return k},m=()=>{if(F<=K)return 0;let J=Array.from(U.entries()).sort(([,w],[,N])=>w.lastAccess-N.lastAccess),X=0,Y=[];for(let[w,N]of J){if(F<=K)break;X+=N.count,F-=N.count,Y.push(w),U.delete(w)}if(X>0&&M)M(X,Y);return X},t=()=>{return{totalItems:j,cachedItems:F,cachedChunks:U.size,chunkSize:Z,maxCachedItems:K,memoryEfficiency:j>0?1-F/j:1}},e=()=>F,qj=()=>{U.clear(),F=0};return{chunkSize:Z,maxCachedItems:K,getTotal:H,setTotal:g,get:T,has:R,set:v,setRange:G,delete:W,getRange:B,isRangeLoaded:_,getLoadedRanges:A,findUnloadedRanges:V,getChunkIndex:O,isChunkLoaded:z,touchChunk:y,touchChunksForRange:E,evictDistant:p,evictToLimit:m,getStats:t,getCachedCount:e,clear:qj,reset:()=>{qj(),j=0}}},wj=(b)=>{if(b.length===0)return[];let Z=[...b].sort((P,M)=>P.start-M.start),K=[{...Z[0]}];for(let P=1;P<Z.length;P++){let M=Z[P],U=K[K.length-1];if(M.start<=U.end+1)U.end=Math.max(U.end,M.end);else K.push({...M})}return K},$j=(b,Z,K)=>{let P=Math.floor(b.start/K)*K,M=Math.ceil((b.end+1)/K)*K-1,U={start:P,end:M};if(Z.length===0)return[U];let j=[],F=wj(Z),S=U.start;for(let O of F){if(O.end<S)continue;if(O.start>U.end)break;if(O.start>S)j.push({start:S,end:Math.min(O.start-1,U.end)});if(S=O.end+1,S>U.end)break}if(S<=U.end)j.push({start:S,end:U.end});return j};var Bj=(b={})=>{let{enabled:Z=!0,maskCharacter:K="█",randomVariance:P=!0,maxSampleSize:M=20,customGenerator:U}=b,j=null,F=!1,S=0,O=(W)=>{if(!Z||F||W.length===0)return;let B=new Map,_=new Map,A=Math.min(W.length,M);for(let V=0;V<A;V++){let z=W[V];if(!z||typeof z!=="object")continue;for(let[y,E]of Object.entries(z)){if(y.startsWith("_")||y==="id")continue;if(!_.has(y))_.set(y,{lengths:[],types:new Set});let p=_.get(y),m=Array.isArray(E)?"array":typeof E;if(p.types.add(m),typeof E==="string")p.lengths.push(E.length);else if(E!==null&&E!==void 0)p.lengths.push(String(E).length)}}for(let[V,z]of _){if(z.lengths.length===0)continue;let y=Math.min(...z.lengths),E=Math.max(...z.lengths),p=Math.round(z.lengths.reduce((t,e)=>t+e,0)/z.lengths.length),m="string";if(z.types.has("number")&&z.types.size===1)m="number";else if(z.types.has("boolean")&&z.types.size===1)m="boolean";else if(z.types.has("array"))m="array";else if(z.types.has("object")&&!z.types.has("string"))m="object";B.set(V,{minLength:y,maxLength:E,avgLength:p,type:m})}j=B,F=!0},q=()=>F,H=(W)=>{let B=W.avgLength;if(P&&W.minLength!==W.maxLength){if(B=Math.floor(Math.random()*(W.maxLength-W.minLength+1)+W.minLength),Math.random()<0.3)B=Math.max(1,B+Math.floor(Math.random()*3)-1)}return K.repeat(Math.max(1,B))},g=(W)=>{if(U)return{...U(W),["_isPlaceholder"]:!0};let B={id:`__placeholder_${S++}`,["_isPlaceholder"]:!0,_index:W};if(!j||j.size===0)return B.label=K.repeat(12),B;for(let[_,A]of j)switch(A.type){case"string":B[_]=H(A);break;case"number":B[_]=0;break;case"boolean":B[_]=!1;break;case"array":B[_]=[];break;case"object":B[_]={};break;default:B[_]=H(A)}return B};return{analyzeStructure:O,hasAnalyzedStructure:q,generate:g,generateRange:(W,B)=>{let _=[];for(let A=W;A<=B;A++)_.push(g(A));return _},isPlaceholder:(W)=>{if(!W||typeof W!=="object")return!1;return W._isPlaceholder===!0},getPlaceholderKey:()=>"_isPlaceholder",clear:()=>{j=null,F=!1,S=0}}},o=(b)=>{if(!b||typeof b!=="object")return!1;return b._isPlaceholder===!0},Wj=(b)=>{return b.filter((Z)=>!o(Z))},Kj=(b)=>{let Z=0;for(let K of b)if(K!==void 0&&!o(K))Z++;return Z},zj=(b,Z,K)=>{let P=0;for(let M=0;M<Z.length;M++){let U=K+M,j=b[U];if(j===void 0||o(j)){if(b[U]=Z[M],o(j))P++}}return P};var yj=50,Gj=(b={})=>{let{adapter:Z,initialItems:K,initialTotal:P,storage:M,placeholder:U,pageSize:j=yj,onStateChange:F,onItemsLoaded:S,onItemsEvicted:O}=b,q=Yj({...M,onEvict:(Q,$)=>{O?.(Q),V()}}),H=null,g=()=>{if(!H)H=Bj(U);return H},T=new Map,R=!1,v,G=!0,W,B=[],_=0,A=new Map,V=()=>{F?.(Uj())},z=()=>{T.clear();let Q=q.getLoadedRanges();for(let $ of Q)for(let D=$.start;D<=$.end;D++){let L=q.get(D);if(L&&!o(L))T.set(L.id,D)}},y=(Q,$)=>{if(!o($))T.set($.id,Q)},E=(Q)=>{T.delete(Q)},p=(Q,$)=>{return`${Q}-${$}`},m=()=>q.getTotal(),t=()=>q.getCachedCount(),e=()=>R,qj=()=>G,Uj=()=>({total:q.getTotal(),cached:q.getCachedCount(),isLoading:R,pendingRanges:B,error:v,hasMore:G,cursor:W}),J=()=>q,X=()=>g(),Y=(Q)=>{let $=q.get(Q);if($!==void 0)return $;if(Q>=0&&Q<q.getTotal())return g().generate(Q);return},w=(Q)=>{let $=T.get(Q);if($===void 0)return;return q.get($)},N=(Q)=>{return T.get(Q)??-1},u=(Q)=>{let $=q.get(Q);return $!==void 0&&!o($)},k=(Q,$)=>{let D=[],L=q.getTotal(),l=0,x=0;q.touchChunksForRange(Q,Math.min($,L-1));for(let c=Q;c<=$&&c<L;c++){let i=q.get(c);if(i!==void 0)D.push(i),l++;else D.push(g().generate(c)),x++}return D},h=(Q)=>{q.setTotal(Q),G=q.getCachedCount()<Q,V()},d=(Q,$=0,D)=>{if(H&&!H.hasAnalyzedStructure()&&Q.length>0)H.analyzeStructure(Q);for(let L=0;L<Q.length;L++){let l=Q[L];if(l!==void 0){let x=$+L;q.set(x,l),y(x,l)}}if(D!==void 0)q.setTotal(D);else if($+Q.length>q.getTotal())q.setTotal($+Q.length);if(q.getCachedCount()>=q.getTotal()&&q.getTotal()>0)G=!1;S?.(Q,$,q.getTotal()),V()},Jj=(Q,$)=>{let D=T.get(Q);if(D===void 0)return!1;let L=q.get(D);if(!L)return!1;let l={...L,...$};if(q.set(D,l),$.id!==void 0&&$.id!==Q)E(Q),y(D,l);return V(),!0},Nj=(Q)=>{let $=T.get(Q);if($===void 0)return!1;q.delete($),E(Q);let D=q.getTotal();if(D>0)q.setTotal(D-1);return V(),!0},Qj=async(Q,$)=>{if(!Z)return;let D=p(Q,$);if(A.has(D))return;let L=q.getLoadedRanges(),l=$j({start:Q,end:$},L,q.chunkSize);if(l.length===0)return;let x=q.chunkSize,c=[];for(let f of l){let a=Math.floor(f.start/x),n=Math.floor(f.end/x);for(let C=a;C<=n;C++){let s=C*x,I=s+x-1,r=p(s,I);if(!c.some((Xj)=>Xj.start===s)&&!A.has(r))c.push({start:s,end:I})}}let i=[];for(let f of l){let a=Math.floor(f.start/x),n=Math.floor(f.end/x);for(let C=a;C<=n;C++){let s=C*x,I=s+x-1,r=p(s,I);if(A.has(r)){let Xj=A.get(r);if(!i.includes(Xj))i.push(Xj)}}}for(let f of c){let a=p(f.start,f.end),n=(async()=>{B.push(f),R=!0,v=void 0,V();try{let C=f.end-f.start+1,s={offset:f.start,limit:C,cursor:void 0},I=await Z.read(s);if(d(I.items,f.start,I.total),I.cursor)W=I.cursor;let r=f.start+I.items.length;if(r>=_){if(_=r,I.hasMore!==void 0)G=I.hasMore;else if(I.total!==void 0)G=r<I.total}}catch(C){v=C instanceof Error?C:Error(String(C))}finally{A.delete(a),B=B.filter((C)=>C.start!==f.start||C.end!==f.end),R=A.size>0,V()}})();A.set(a,n),i.push(n)}await Promise.all(i)},Hj=async(Q,$)=>{if(q.isRangeLoaded(Q,$))return;await Qj(Q,$)},bj=async()=>{if(!Z)return;await Qj(0,j-1)},Pj=async()=>{if(!Z||R||!G)return!1;let Q=q.getCachedCount(),$=q.getTotal(),D=Q,L=Math.min(D+j-1,$>0?$-1:D+j-1);if(D>=$&&$>0)return G=!1,!1;return await Qj(D,L),q.getCachedCount()>Q},Mj=async()=>{if(q.clear(),T.clear(),H)H.clear();A.clear(),B=[],R=!1,W=void 0,G=!0,_=0,v=void 0,V()},_j=(Q,$)=>{if(q.evictDistant(Q,$)>0)z()},Aj=()=>{q.clear(),T.clear(),W=void 0,v=void 0,B=[],R=!1,V()},Oj=()=>{if(q.reset(),T.clear(),H)H.clear();W=void 0,G=!0,_=0,v=void 0,B=[],R=!1,V()};if(K&&K.length>0)d(K,0,P??K.length);else if(P!==void 0)q.setTotal(P);return{getState:Uj,getTotal:m,getCached:t,getIsLoading:e,getHasMore:qj,getStorage:J,getPlaceholders:X,getItem:Y,getItemById:w,getIndexById:N,isItemLoaded:u,getItemsInRange:k,setTotal:h,setItems:d,updateItem:Jj,removeItem:Nj,loadRange:Qj,ensureRange:Hj,loadInitial:bj,loadMore:Pj,reload:Mj,evictDistant:_j,clear:Aj,reset:Oj}};var Fj=200,jj=50;var Zj=15,Vj=2,Dj=50;var Ej=(b)=>{let{adapter:Z,loading:K}=b,P=K?.cancelThreshold??Zj,M=K?.preloadThreshold??Vj,U=K?.preloadAhead??Dj;return{name:"withAsync",priority:20,methods:["reload"],setup(j){let{emitter:F}=j,S=j.config.reverse,O=Gj({adapter:Z,pageSize:jj,onStateChange:()=>{if(j.state.isInitialized){j.heightCache.rebuild(j.getVirtualTotal()),j.updateCompressionMode();let G=j.getCachedCompression();j.state.viewportState.totalHeight=G.virtualHeight,j.state.viewportState.actualHeight=G.actualHeight,j.state.viewportState.isCompressed=G.isCompressed,j.state.viewportState.compressionRatio=G.ratio,j.updateContentSize(G.virtualHeight),j.renderIfNeeded()}},onItemsLoaded:(G,W,B)=>{if(j.state.isInitialized)j.heightCache.rebuild(j.getVirtualTotal()),j.forceRender(),F.emit("load:end",{items:G,total:B})}});j.replaceDataManager(O);let q=null,H=null,g=0,T=()=>{if(H){let G=H;H=null,j.dataManager.ensureRange(G.start,G.end).catch((W)=>{F.emit("error",{error:W,context:"ensureRange"})})}};j.afterScroll.push((G,W)=>{if(j.state.isDestroyed)return;let B=j.scrollController.getVelocity(),A=j.scrollController.isTracking()&&B<=P;if(H&&g>P&&B<=P){let y=H;H=null,j.dataManager.ensureRange(y.start,y.end).catch((E)=>{F.emit("error",{error:E,context:"ensureRange"})})}if(g=B,A&&!j.dataManager.getIsLoading()&&j.dataManager.getHasMore()){if(S){if(G<Fj)F.emit("load:start",{offset:j.dataManager.getCached(),limit:jj}),j.dataManager.loadMore().catch((y)=>{F.emit("error",{error:y,context:"loadMore"})})}else if(j.state.viewportState.totalHeight-G-j.state.viewportState.containerHeight<Fj)F.emit("load:start",{offset:j.dataManager.getCached(),limit:jj}),j.dataManager.loadMore().catch((E)=>{F.emit("error",{error:E,context:"loadMore"})})}let{renderRange:V}=j.state.viewportState;if(!q||V.start!==q.start||V.end!==q.end)if(q={start:V.start,end:V.end},A){H=null;let{start:y,end:E}=V,p=j.getVirtualTotal();if(B>M)if(W==="down")E=Math.min(V.end+U,p-1);else y=Math.max(V.start-U,0);j.dataManager.ensureRange(y,E).catch((m)=>{F.emit("error",{error:m,context:"ensureRange"})})}else H={start:V.start,end:V.end}});let R=200,v=null;j.afterScroll.push((G,W)=>{if(v!==null)clearTimeout(v);v=setTimeout(()=>{v=null,T()},R)}),j.destroyHandlers.push(()=>{if(v!==null)clearTimeout(v),v=null}),F.on("load:start",()=>{j.dom.root.setAttribute("aria-busy","true")}),F.on("load:end",()=>{j.dom.root.removeAttribute("aria-busy")}),j.methods.set("reload",async()=>{q=null,H=null,j.invalidateRendered(),await j.dataManager.reload(),j.forceRender();let{renderRange:G}=j.state.viewportState;if(G.end>0)await j.dataManager.ensureRange(G.start,G.end)}),F.emit("load:start",{offset:0,limit:jj}),j.dataManager.loadInitial().catch((G)=>{F.emit("error",{error:G,context:"loadInitial"})})}}};export{Ej as withAsync,zj as replacePlaceholders,wj as mergeRanges,o as isPlaceholderItem,Wj as filterPlaceholders,Yj as createSparseStorage,Bj as createPlaceholderManager,Gj as createDataManager,Kj as countRealItems,$j as calculateMissingRanges};
@@ -1 +0,0 @@
1
- var KJ=0,m=5,UJ=100,Rj=2,YJ=(X=0)=>{let U=Array(m);for(let $=0;$<m;$++)U[$]={position:0,time:0};return{velocity:0,lastPosition:X,lastTime:performance.now(),samples:U,sampleIndex:0,sampleCount:0}},BJ=(X,U)=>{let $=performance.now(),Y=$-X.lastTime;if(Y===0)return X;if(Y>UJ){X.sampleCount=0,X.sampleIndex=0,X.velocity=0;let Q=X.samples[0];return Q.position=U,Q.time=$,X.sampleIndex=1,X.sampleCount=1,X.lastPosition=U,X.lastTime=$,X}let V=X.samples[X.sampleIndex];if(V.position=U,V.time=$,X.sampleIndex=(X.sampleIndex+1)%m,X.sampleCount=Math.min(X.sampleCount+1,m),X.sampleCount>=Rj){let Q=(X.sampleIndex-X.sampleCount+m)%m,K=X.samples[Q],W=U-K.position,C=$-K.time;X.velocity=C>0?Math.abs(W)/C:0}return X.lastPosition=U,X.lastTime=$,X},Tj=(X,U)=>{if(typeof X==="number"){let Q=U;return{getOffset:(K)=>K*X,getHeight:()=>X,indexAtOffset:(K)=>{if(Q===0||X===0)return 0;return Math.max(0,Math.min(Math.floor(K/X),Q-1))},getTotalHeight:()=>Q*X,getTotal:()=>Q,rebuild:(K)=>{Q=K},isVariable:()=>!1}}let $=U,Y=new Float64Array(0),V=(Q)=>{$=Q,Y=new Float64Array(Q+1),Y[0]=0;for(let K=0;K<Q;K++)Y[K+1]=Y[K]+X(K)};return V(U),{getOffset:(Q)=>{if(Q<=0)return 0;if(Q>=$)return Y[$];return Y[Q]},getHeight:(Q)=>X(Q),indexAtOffset:(Q)=>{if($===0)return 0;if(Q<=0)return 0;if(Q>=Y[$])return $-1;let K=0,W=$-1;while(K<W){let C=K+W+1>>>1;if(Y[C]<=Q)K=C;else W=C-1}return K},getTotalHeight:()=>Y[$]??0,getTotal:()=>$,rebuild:(Q)=>V(Q),isVariable:()=>!0}},GJ=()=>{let X={},U=(Q,K)=>{if(!X[Q])X[Q]=new Set;return X[Q].add(K),()=>$(Q,K)},$=(Q,K)=>{X[Q]?.delete(K)};return{on:U,off:$,emit:(Q,K)=>{X[Q]?.forEach((W)=>{try{W(K)}catch(C){console.error(`[vlist] Error in "${Q}" handler:`,C)}})},clear:()=>{for(let Q in X)delete X[Q]}}},WJ=(X)=>{if(typeof X==="string"){let U=document.querySelector(X);if(!U)throw Error(`[vlist/builder] Container not found: ${X}`);return U}return X},DJ=(X,U,$,Y)=>{let V=document.createElement("div");if(V.className=U,Y)V.classList.add(`${U}--horizontal`);if(V.setAttribute("role","listbox"),V.setAttribute("tabindex","0"),$)V.setAttribute("aria-label",$);if(Y)V.setAttribute("aria-orientation","horizontal");let Q=document.createElement("div");if(Q.className=`${U}-viewport`,Y)Q.style.overflowX="auto",Q.style.overflowY="hidden";else Q.style.overflow="auto";Q.style.height="100%",Q.style.width="100%";let K=document.createElement("div");if(K.className=`${U}-content`,K.style.position="relative",Y)K.style.height="100%";else K.style.width="100%";let W=document.createElement("div");if(W.className=`${U}-items`,W.style.position="relative",Y)W.style.height="100%";else W.style.width="100%";return K.appendChild(W),Q.appendChild(K),V.appendChild(Q),X.appendChild(V),{root:V,viewport:Q,content:K,items:W}},VJ=(X=100)=>{let U=[];return{acquire:()=>{let $=U.pop();if($)return $;let Y=document.createElement("div");return Y.setAttribute("role","option"),Y},release:($)=>{if(U.length<X)$.className="",$.textContent="",$.removeAttribute("style"),$.removeAttribute("data-index"),$.removeAttribute("data-id"),U.push($)},clear:()=>{U.length=0}}},_J=(X,U,$,Y,V)=>{if(Y===0||U===0){V.start=0,V.end=0;return}let Q=$.indexAtOffset(X),K=$.indexAtOffset(X+U);if(K<Y-1)K++;V.start=Math.max(0,Q),V.end=Math.min(Y-1,Math.max(0,K))},LJ=(X,U,$,Y)=>{if($===0){Y.start=0,Y.end=0;return}Y.start=Math.max(0,X.start-U),Y.end=Math.min($-1,X.end+U)},NJ=(X,U,$,Y,V)=>{if(Y===0)return 0;let Q=Math.max(0,Math.min(X,Y-1)),K=U.getOffset(Q),W=U.getHeight(Q),C=Math.max(0,U.getTotalHeight()-$),f;switch(V){case"center":f=K-($-W)/2;break;case"end":f=K-$+W;break;default:f=K}return Math.max(0,Math.min(f,C))},MJ=(X)=>X<0.5?2*X*X:-1+(4-2*X)*X,AJ=(X)=>{if(typeof X==="string")return{align:X,behavior:"auto",duration:300};if(X&&typeof X==="object")return{align:X.align??"start",behavior:X.behavior??"auto",duration:X.duration??300};return{align:"start",behavior:"auto",duration:300}},bJ=(X)=>{if(!X.container)throw Error("[vlist/builder] Container is required");if(!X.item)throw Error("[vlist/builder] item configuration is required");let U=X.direction==="horizontal",$=U?"width":"height",Y=U?X.item.width:X.item.height;if(Y==null)throw Error(`[vlist/builder] item.${$} is required${U?" when direction is 'horizontal'":""}`);if(typeof Y==="number"&&Y<=0)throw Error(`[vlist/builder] item.${$} must be a positive number`);if(typeof Y!=="number"&&typeof Y!=="function")throw Error(`[vlist/builder] item.${$} must be a number or a function (index) => number`);if(!X.item.template)throw Error("[vlist/builder] item.template is required");if(U&&X.reverse)throw Error("[vlist/builder] horizontal direction cannot be combined with reverse mode");let V=new Map,Q=!1,K={use(W){if(Q)throw Error("[vlist/builder] Cannot call .use() after .build()");return V.set(W.name,W),K},build(){if(Q)throw Error("[vlist/builder] .build() can only be called once");return Q=!0,EJ(X,V,U,Y)}};return K};function EJ(X,U,$,Y){let{item:V,items:Q,overscan:K=3,classPrefix:W="vlist",ariaLabel:C,reverse:f=!1,scroll:Yj}=X,uj=Yj?.wheel??!0,Fj=Yj?.wrap??!1,c=f,yj=`${W}-${KJ++}`,fj=Y,Cj=$?typeof V.height==="number"?V.height:void 0:typeof V.width==="number"?V.width:void 0,e=V.template,pj={overscan:K,classPrefix:W,reverse:c,wrap:Fj,horizontal:$,ariaIdPrefix:yj},d=Array.from(U.values()).sort((j,J)=>(j.priority??50)-(J.priority??50)),jj=new Set(d.map((j)=>j.name));for(let j of d)if(j.conflicts){for(let J of j.conflicts)if(jj.has(J))throw Error(`[vlist/builder] ${j.name} and ${J} cannot be combined`)}if($){if(jj.has("withGrid"))throw Error("[vlist/builder] withGrid cannot be used with direction: 'horizontal'");if(jj.has("withGroups"))throw Error("[vlist/builder] withGroups cannot be used with direction: 'horizontal'")}if(c){if(jj.has("withGrid"))throw Error("[vlist/builder] withGrid cannot be used with reverse: true")}let xj=WJ(X.container),_=DJ(xj,W,C,$),z=GJ(),B=Q?[...Q]:[],N=Tj(fj,B.length),s=VJ(),F=_.viewport.clientHeight,Jj=_.viewport.clientWidth,l=!1,p=!1,O=0,x=null,a=null,I=YJ(0),Xj={start:0,end:0},E={start:0,end:0},h={start:-1,end:-1},v={viewportState:{scrollTop:0,containerHeight:F,totalHeight:N.getTotalHeight(),actualHeight:N.getTotalHeight(),isCompressed:!1,compressionRatio:1,visibleRange:{start:0,end:0},renderRange:{start:0,end:0}},lastRenderRange:{start:-1,end:-1},isInitialized:!1,isDestroyed:!1,cachedCompression:null},k=new Map,Bj={selected:!1,focused:!1},hj=`${W}-item`,r="",H=new Map,Gj=()=>{H.clear();for(let j=0;j<B.length;j++){let J=B[j];if(J)H.set(J.id,j)}};Gj();let R=null,P=()=>R?R.getTotal():B.length,Wj=[],Dj=[],Vj=[],_j=[],o=[],Lj=[],L=new Map,u=()=>{return $?_.viewport.scrollLeft:_.viewport.scrollTop},S=(j)=>{if($)_.viewport.scrollLeft=j;else _.viewport.scrollTop=j},kj=(j=2)=>{let J=N.getTotalHeight();return O+F>=J-j},Zj=!1,y,T,zj=(j,J,Z,q,D)=>{_J(j,J,Z,q,D)},$j=(j,J,Z,q,D)=>{return NJ(j,J,Z,q,D)},Nj=(j,J)=>{if(typeof J==="string")j.innerHTML=J;else j.replaceChildren(J)},Qj=(j,J)=>{let Z=Math.round(N.getOffset(J));if($)j.style.transform=`translateX(${Z}px)`;else j.style.transform=`translateY(${Z}px)`},gj=(j,J)=>{let Z=s.acquire();if(Z.className=hj,$){if(Z.style.width=`${N.getHeight(j)}px`,Cj!=null)Z.style.height=`${Cj}px`}else Z.style.height=`${N.getHeight(j)}px`;if(Z.dataset.index=String(j),Z.dataset.id=String(J.id),Z.ariaSelected="false",Z.id=`${yj}-item-${j}`,r=String(P()),Z.setAttribute("aria-setsize",r),Z.setAttribute("aria-posinset",String(j+1)),String(J.id).startsWith("__placeholder_"))Z.classList.add(`${W}-item--placeholder`);return Nj(Z,e(J,j,Bj)),Qj(Z,j),Z},n=()=>{let j=`${N.getTotalHeight()}px`;if($)_.content.style.width=j;else _.content.style.height=j},Mj=new Set,Aj=-1,mj=()=>{if(l)return;let j=P();if(zj(O,F,N,j,Xj),LJ(Xj,K,j,E),E.start===h.start&&E.end===h.end){if(Zj)for(let[G,A]of k)Qj(A,G);return}let J=String(j),Z=J!==r;r=J;for(let[G,A]of k)if(G<E.start||G>E.end)A.remove(),s.release(A),k.delete(G);let q=document.createDocumentFragment(),D=[];for(let G=E.start;G<=E.end;G++){let A=R?R.getItem(G):B[G];if(!A)continue;let M=k.get(G);if(M){let w=M.dataset.id,t=String(A.id);if(w!==t){let qJ=w?.startsWith("__placeholder_"),Ij=t.startsWith("__placeholder_");if(Nj(M,e(A,G,Bj)),M.dataset.id=t,$)M.style.width=`${N.getHeight(G)}px`;else M.style.height=`${N.getHeight(G)}px`;if(Ij)M.classList.add(`${W}-item--placeholder`);else M.classList.remove(`${W}-item--placeholder`);if(qJ&&!Ij)M.classList.add(`${W}-item--replaced`),setTimeout(()=>{M.classList.remove(`${W}-item--replaced`)},300)}Qj(M,G);let Uj=Mj.has(A.id),QJ=G===Aj;if(M.classList.toggle(`${W}-item--selected`,Uj),M.classList.toggle(`${W}-item--focused`,QJ),M.ariaSelected=Uj?"true":"false",Z)M.setAttribute("aria-setsize",r)}else{let w=gj(G,A),t=Mj.has(A.id),Uj=G===Aj;if(t)w.classList.add(`${W}-item--selected`),w.ariaSelected="true";if(Uj)w.classList.add(`${W}-item--focused`);q.appendChild(w),D.push({index:G,element:w})}}if(D.length>0){_.items.appendChild(q);for(let{index:G,element:A}of D)k.set(G,A)}h.start=E.start,h.end=E.end,v.lastRenderRange.start=E.start,v.lastRenderRange.end=E.end,v.viewportState.scrollTop=O,v.viewportState.visibleRange.start=Xj.start,v.viewportState.visibleRange.end=Xj.end,v.viewportState.renderRange.start=E.start,v.viewportState.renderRange.end=E.end,z.emit("range:change",{range:{start:E.start,end:E.end}})},cj=()=>{h.start=-1,h.end=-1,y()};y=mj,T=cj;let i=()=>{if(l)return;let j=u(),J=j>=O?"down":"up";if(I=BJ(I,j),!_.root.classList.contains(`${W}--scrolling`))_.root.classList.add(`${W}--scrolling`);O=j,y(),z.emit("scroll",{scrollTop:j,direction:J}),z.emit("velocity:change",{velocity:I.velocity,reliable:I.sampleCount>=Rj});for(let Z=0;Z<Wj.length;Z++)Wj[Z](j,J);if(a)clearTimeout(a);a=setTimeout(()=>{_.root.classList.remove(`${W}--scrolling`),I.velocity=0,I.sampleCount=0,z.emit("velocity:change",{velocity:0,reliable:!1})},Yj?.idleTimeout??150)},qj=null,g=_.viewport;if(g.addEventListener("scroll",i,{passive:!0}),$&&uj)qj=(j)=>{if(j.deltaX)return;j.preventDefault(),_.viewport.scrollLeft+=j.deltaY},_.viewport.addEventListener("wheel",qj);let Hj=(j)=>{let Z=j.target.closest("[data-index]");if(Z){let q=parseInt(Z.dataset.index??"-1",10);if(q>=0){let D=R?.getItem(q)??B[q];if(D){if(D.__groupHeader)return;z.emit("item:click",{item:D,index:q,event:j})}}}for(let q=0;q<Dj.length;q++)Dj[q](j)},dj=(j)=>{let Z=j.target.closest("[data-index]");if(Z){let q=parseInt(Z.dataset.index??"-1",10);if(q>=0){let D=R?.getItem(q)??B[q];if(D){if(D.__groupHeader)return;z.emit("item:dblclick",{item:D,index:q,event:j})}}}},Pj=(j)=>{for(let J=0;J<Vj.length;J++)Vj[J](j)};_.items.addEventListener("click",Hj),_.items.addEventListener("dblclick",dj),_.root.addEventListener("keydown",Pj);let bj=!0,sj=()=>Jj,lj=()=>F,Ej=new ResizeObserver((j)=>{if(l)return;for(let J of j){let Z=J.contentRect.height,q=J.contentRect.width,D=$?q:Z;if(Jj=q,Math.abs(D-F)>1){if(F=D,v.viewportState.containerHeight=D,p)n(),y(),z.emit("resize",{height:Z,width:q})}if(p)for(let G=0;G<_j.length;G++)_j[G](q,Z)}});if(bj)Ej.observe(_.viewport);let b={get dom(){return _},get heightCache(){return N},get emitter(){return z},get config(){return pj},get rawConfig(){return X},get renderer(){return{render:(j,J,Z,q,D)=>{Mj=Z,Aj=q,T()},updateItemClasses:(j,J,Z)=>{let q=k.get(j);if(!q)return;q.classList.toggle(`${W}-item--selected`,J),q.classList.toggle(`${W}-item--focused`,Z),q.ariaSelected=J?"true":"false"},updatePositions:()=>{},updateItem:()=>{},getElement:(j)=>k.get(j)??null,clear:()=>{},destroy:()=>{}}},set renderer(j){},get dataManager(){return R},set dataManager(j){R=j},get scrollController(){return Oj},set scrollController(j){Oj=j},state:v,getContainerWidth(){return Jj},afterScroll:Wj,clickHandlers:Dj,keydownHandlers:Vj,resizeHandlers:_j,contentSizeHandlers:o,destroyHandlers:Lj,methods:L,replaceTemplate(j){e=j},replaceRenderer(j){},replaceDataManager(j){R=j},replaceScrollController(j){Oj=j},getItemsForRange(j){let J=[];for(let Z=j.start;Z<=j.end;Z++){let q=R?R.getItem(Z):B[Z];if(q)J.push(q)}return J},getAllLoadedItems(){if(R){let j=R.getTotal(),J=[];for(let Z=0;Z<j;Z++){let q=R.getItem(Z);if(q)J.push(q)}return J}return[...B]},getVirtualTotal(){return P()},getCachedCompression(){return{isCompressed:!1,actualHeight:N.getTotalHeight(),virtualHeight:N.getTotalHeight(),ratio:1}},getCompressionContext(){return{scrollTop:O,totalItems:P(),containerHeight:F,rangeStart:E.start}},renderIfNeeded(){y()},forceRender(){T()},invalidateRendered(){for(let[,j]of k)j.remove(),s.release(j);k.clear()},getRenderFns(){return{renderIfNeeded:y,forceRender:T}},setRenderFns(j,J){y=j,T=J},setVirtualTotalFn(j){P=j},rebuildHeightCache(j){N.rebuild(j??P())},setHeightConfig(j){N=Tj(j,P())},updateContentSize(j){let J=`${j}px`;if($)_.content.style.width=J;else _.content.style.height=J},updateCompressionMode(){},setVisibleRangeFn(j){zj=j},setScrollToPosFn(j){$j=j},setPositionElementFn(j){Qj=j},setScrollFns(j,J){u=j,S=(Z)=>{J(Z),i()}},setScrollTarget(j){g.removeEventListener("scroll",i),g=j,g.addEventListener("scroll",i,{passive:!0})},getScrollTarget(){return g},setContainerDimensions(j){sj=j.width,lj=j.height,Jj=j.width(),F=j.height(),v.viewportState.containerHeight=F},disableViewportResize(){if(bj)bj=!1,Ej.unobserve(_.viewport)}};R={getState:()=>({total:B.length,cached:B.length,isLoading:!1,pendingRanges:[],error:void 0,hasMore:!1,cursor:void 0}),getTotal:()=>B.length,getCached:()=>B.length,getIsLoading:()=>!1,getHasMore:()=>!1,getStorage:()=>null,getPlaceholders:()=>null,getItem:(j)=>B[j],getItemById:(j)=>{let J=H.get(j);return J!==void 0?B[J]:void 0},getIndexById:(j)=>H.get(j)??-1,isItemLoaded:(j)=>j>=0&&j<B.length&&B[j]!==void 0,getItemsInRange:(j,J)=>{let Z=[],q=Math.max(0,j),D=Math.min(J,B.length-1);for(let G=q;G<=D;G++)Z.push(B[G]);return Z},setTotal:(j)=>{},setItems:(j,J=0,Z)=>{if(J===0&&(Z!==void 0||B.length===0))B=[...j];else{let q=J+j.length;if(B.length<q)B.length=q;for(let D=0;D<j.length;D++)B[J+D]=j[D]}if(Gj(),p){N.rebuild(P()),n(),b.updateCompressionMode();for(let q=0;q<o.length;q++)o[q]();T()}},updateItem:(j,J)=>{let Z=H.get(j);if(Z===void 0)return!1;let q=B[Z];if(!q)return!1;if(B[Z]={...q,...J},J.id!==void 0&&J.id!==j)H.delete(j),H.set(J.id,Z);let D=k.get(Z);if(D)Nj(D,e(B[Z],Z,Bj)),D.dataset.id=String(B[Z].id);return!0},removeItem:(j)=>{let J=H.get(j);if(J===void 0)return!1;if(B.splice(J,1),Gj(),p){N.rebuild(P()),n(),b.updateCompressionMode();for(let Z=0;Z<o.length;Z++)o[Z]();T()}return!0},loadRange:async()=>{},ensureRange:async()=>{},loadInitial:async()=>{},loadMore:async()=>!1,reload:async()=>{},evictDistant:()=>{},clear:()=>{B=[],H.clear()},reset:()=>{if(B=[],H.clear(),p)N.rebuild(0),n(),T()}};let Oj={getScrollTop:()=>u(),scrollTo:(j)=>{S(j),O=j,y()},scrollBy:(j)=>{let J=u()+j;S(J),O=J,y()},isAtTop:()=>O<=2,isAtBottom:(j=2)=>kj(j),getScrollPercentage:()=>{let j=N.getTotalHeight(),J=Math.max(0,j-F);return J>0?O/J:0},getVelocity:()=>I.velocity,isTracking:()=>I.sampleCount>=Rj,isScrolling:()=>_.root.classList.contains(`${W}--scrolling`),updateConfig:()=>{},enableCompression:()=>{Zj=!0},disableCompression:()=>{Zj=!1},isCompressed:()=>Zj,isWindowMode:()=>!1,updateContainerHeight:(j)=>{F=j},destroy:()=>{}},wj=new Map;for(let j of d)if(j.methods)for(let J of j.methods){let Z=wj.get(J);if(Z)throw Error(`[vlist/builder] Method "${J}" is registered by both "${Z}" and "${j.name}"`);wj.set(J,j.name)}for(let j of d)j.setup(b);if(p=!0,b.state.isInitialized=!0,n(),y(),c&&B.length>0){let j=$j(B.length-1,N,F,B.length,"end");S(j),O=j,y()}let aj=(j)=>{b.dataManager.setItems(j,0,j.length)},rj=c?(j)=>{let J=kj(2),Z=B.length;if(b.dataManager.setItems(j,Z),J&&B.length>0){let q=$j(B.length-1,N,F,B.length,"end");S(q),O=q,y()}}:(j)=>{let J=B.length;b.dataManager.setItems(j,J)},oj=c?(j)=>{let J=u(),Z=N.getTotalHeight(),q=[...B];b.dataManager.clear(),b.dataManager.setItems([...j,...q],0);let G=N.getTotalHeight()-Z;if(G>0)S(J+G),O=J+G}:(j)=>{let J=[...B];b.dataManager.clear(),b.dataManager.setItems([...j,...J],0)},nj=(j,J)=>{b.dataManager.updateItem(j,J)},ij=(j)=>{b.dataManager.removeItem(j)},tj=async()=>{if(b.dataManager.reload)await b.dataManager.reload()},Kj=()=>{if(x!==null)cancelAnimationFrame(x),x=null},ej=(j,J,Z)=>{if(Kj(),Math.abs(J-j)<1){S(J),O=J,y();return}let q=performance.now(),D=(G)=>{let A=G-q,M=Math.min(A/Z,1),w=j+(J-j)*MJ(M);if(S(w),O=w,y(),M<1)x=requestAnimationFrame(D);else x=null};x=requestAnimationFrame(D)},vj=(j,J)=>{let{align:Z,behavior:q,duration:D}=AJ(J),G=P(),A=j;if(Fj&&G>0)A=(A%G+G)%G;let M=$j(A,N,F,G,Z);if(q==="smooth")ej(u(),M,D);else Kj(),S(M)},jJ=(j,J)=>{let Z=H.get(j)??b.dataManager.getIndexById(j);if(Z>=0)vj(Z,J)},JJ=()=>u(),XJ=(j,J)=>{return z.on(j,J)},ZJ=(j,J)=>{z.off(j,J)},$J=()=>{if(l)return;if(l=!0,b.state.isDestroyed=!0,_.items.removeEventListener("click",Hj),_.root.removeEventListener("keydown",Pj),g.removeEventListener("scroll",i),Ej.disconnect(),qj)_.viewport.removeEventListener("wheel",qj);if(a)clearTimeout(a);for(let j=0;j<Lj.length;j++)Lj[j]();for(let j of d)if(j.destroy)j.destroy();Kj();for(let[,j]of k)j.remove(),s.release(j);k.clear(),s.clear(),z.clear(),_.root.remove()},Sj={get element(){return _.root},get items(){if(L.has("_getItems"))return L.get("_getItems")();return B},get total(){if(L.has("_getTotal"))return L.get("_getTotal")();return P()},setItems:L.has("setItems")?L.get("setItems"):aj,appendItems:L.has("appendItems")?L.get("appendItems"):rj,prependItems:L.has("prependItems")?L.get("prependItems"):oj,updateItem:L.has("updateItem")?L.get("updateItem"):nj,removeItem:L.has("removeItem")?L.get("removeItem"):ij,reload:L.has("reload")?L.get("reload"):tj,scrollToIndex:L.has("scrollToIndex")?L.get("scrollToIndex"):vj,scrollToItem:L.has("scrollToItem")?L.get("scrollToItem"):jJ,cancelScroll:L.has("cancelScroll")?L.get("cancelScroll"):Kj,getScrollPosition:L.has("getScrollPosition")?L.get("getScrollPosition"):JJ,on:XJ,off:ZJ,destroy:$J};for(let[j,J]of L){if(j==="setItems"||j==="appendItems"||j==="prependItems"||j==="updateItem"||j==="removeItem"||j==="reload"||j==="scrollToIndex"||j==="scrollToItem"||j==="cancelScroll"||j==="getScrollPosition")continue;Sj[j]=J}return Sj}export{bJ as vlist};
@@ -1,24 +0,0 @@
1
- /**
2
- * vlist - Full API with Convenience Wrapper
3
- *
4
- * This file provides `createVList()` - a convenience wrapper around the builder pattern
5
- * that automatically applies plugins based on configuration, maintaining backwards
6
- * compatibility with monolithic-style API while leveraging the modular builder internally.
7
- *
8
- * Import: `import { createVList } from '@floor/vlist'` or `import { createVList } from '@floor/vlist/vlist'`
9
- *
10
- * For the modular builder API, use `import { vlist } from '@floor/vlist'` instead.
11
- */
12
- import type { VListConfig, VListItem, VList } from "../types";
13
- /**
14
- * Create a virtual list instance.
15
- *
16
- * This is a convenience wrapper around the builder pattern that automatically
17
- * includes plugins based on the configuration provided, maintaining full backwards
18
- * compatibility with the monolithic API.
19
- *
20
- * @param config - Virtual list configuration
21
- * @returns Virtual list instance with full API
22
- */
23
- export declare const createVList: <T extends VListItem = VListItem>(config: VListConfig<T>) => VList<T>;
24
- //# sourceMappingURL=full.d.ts.map
@@ -1 +0,0 @@
1
- var a=(Y)=>{let q=Math.max(1,Math.floor(Y.columns)),J=Y.gap??0,j=Y.isHeaderFn,D={row:0,col:0},X=(K)=>{if(K<=0)return 0;if(!j)return Math.ceil(K/q);let k=0,N=0,B=0;for(let y=0;y<K;y++)if(j(y)){if(B++,N>0)k++,N=0;k++,N=0}else if(N++,N>=q)k++,N=0;if(N>0)k++;return k},G=(K)=>{return D.row=O(K),D.col=F(K),D},O=(K)=>{if(!j)return Math.floor(K/q);let k=0,N=0;for(let B=0;B<=K;B++)if(j(B)){if(N>0)k++,N=0;if(B===K)return k;k++,N=0}else{if(B===K)return k;if(N++,N>=q)k++,N=0}return console.warn(`⚠️ getRow(${K}) fell through - returning ${k}`),k},F=(K)=>{if(!j)return K%q;if(j(K))return 0;let k=0;for(let N=0;N<=K;N++)if(j(N))k=0;else{if(N===K)return k;if(k++,k>=q)k=0}return k},W=(K,k,N)=>{if(N<=0)return{start:0,end:-1};if(!j){let M=Math.max(0,K*q),V=Math.min(N-1,(k+1)*q-1);return{start:M,end:V}}let B=-1,y=-1,v=0,$=0;for(let M=0;M<N;M++){if(j(M)){if($>0)v++,$=0;if(v>=K&&v<=k){if(B===-1)B=M;y=M}v++,$=0}else{if(v>=K&&v<=k){if(B===-1)B=M;y=M}if($++,$>=q)v++,$=0}if(v>k&&$===0)break}if(B===-1)return{start:0,end:-1};return{start:B,end:y}},E=(K,k,N)=>{if(k<0||k>=q)return-1;let B=K*q+k;if(B<0||B>=N)return-1;return B},b=(K)=>{let k=(q-1)*J;return Math.max(0,(K-k)/q)};return{get columns(){return q},get gap(){return J},update:(K)=>{if(K.columns!==void 0)q=Math.max(1,Math.floor(K.columns));if(K.gap!==void 0)J=K.gap;if(K.isHeaderFn!==void 0)j=K.isHeaderFn},getTotalRows:X,getPosition:G,getRow:O,getCol:F,getItemRange:W,getItemIndex:E,getColumnWidth:b,getColumnOffset:(K,k)=>{let N=b(k);return K*(N+J)}}};var n=16000000;var q2=(Y,q,J)=>{if(J===0)return 0;if(!Y.isVariable())return Math.floor(q/Y.getHeight(0));let j=0,D=0;for(let X=J-1;X>=0;X--){let G=Y.getHeight(X);if(D+G>q)break;D+=G,j++}return Math.max(j,1)},J2=(Y,q,J)=>{if(J===0)return 0;let j=Math.floor(q),D=q-j,X=Math.max(0,Math.min(j,J-1));return Y.getOffset(X)+D*Y.getHeight(X)};var K2=(Y,q)=>{let J=q.getTotalHeight(),j=J>n,D=j?n:J,X=J>0?D/J:1;return{isCompressed:j,actualHeight:J,virtualHeight:D,ratio:X}};var Q2=(Y,q,J,j,D,X,G)=>{if(!X.isCompressed||j===0)return J.getOffset(Y);let{virtualHeight:O}=X,F=O-D,W=F-q;if(W<=D&&W>=-1){if(q>=F-1){let $=J.getTotalHeight()-J.getOffset(Y);return D-$}let C=q2(J,D,j),K=Math.max(0,j-C),N=q/O*j,B=Math.max(0,Math.min(1,1-W/D)),y=J.getOffset(Y)-J.getOffset(K),v=J.getOffset(Y)-J2(J,N,j);return v+(y-v)*B}let E=q/O,b=J.getTotalHeight(),w=E*b;return J.getOffset(Y)-w};var Y2=(Y)=>{return Y!==null&&typeof Y==="object"&&Y.__groupHeader===!0};var N2=(Y=200)=>{let q=[];return{acquire:()=>{let X=q.pop();if(X)return X;let G=document.createElement("div");return G.setAttribute("role","option"),G},release:(X)=>{if(q.length<Y)X.className="",X.textContent="",X.removeAttribute("style"),X.removeAttribute("data-index"),X.removeAttribute("data-id"),X.removeAttribute("data-row"),X.removeAttribute("data-col"),q.push(X)},clear:()=>{q.length=0}}},o=(Y,q,J,j,D,X,G,O)=>{let F=N2(),W=new Map,E=X,b=!1,w=null,C=0,K="",k=(Q)=>{if(w&&C===Q)return w;return w=K2(Q,J),C=Q,w},N={selected:!1,focused:!1},B=(Q,Z)=>{return N.selected=Q,N.focused=Z,N},y=`${D}-item ${D}-grid-item`,v=`${D}-item--selected`,$=`${D}-item--focused`,M=(Q,Z)=>{if(typeof Z==="string")Q.innerHTML=Z;else Q.replaceChildren(Z)},V=(Q,Z,U)=>{Q.classList.toggle(v,Z),Q.classList.toggle($,U)},A=(Q,Z)=>{let U=j.getRow(Q);if(Z){let L=Z.totalItems,P=k(L);if(P.isCompressed)return Q2(U,Z.scrollTop,J,L,Z.containerHeight,P,Z.rangeStart)}return J.getOffset(U)},S=(Q,Z,U)=>{let L=Q.dataset.id?.startsWith("__group_header"),P=L?0:j.getCol(Z),_=L?0:j.getColumnOffset(P,E),f;if(b){let x=j.getRow(Z),z=0,u=new Set;for(let R=0;R<Z;R++){let p=j.getRow(R);if(p<x&&!u.has(p)){let l=J.getHeight(R);z+=l,u.add(p)}}f=z}else f=A(Z,U);Q.style.transform=`translate(${Math.round(_)}px, ${Math.round(f)}px)`},T=(Q,Z)=>{let U=Q.dataset.id?.startsWith("__group_header"),L=U?E:j.getColumnWidth(E),P;if(b||U)P=J.getHeight(Z)-j.gap;else{let _=j.getRow(Z);P=J.getHeight(_)-j.gap}Q.style.width=`${L}px`,Q.style.height=`${P}px`},I=(Q,Z,U,L,P)=>{let _=F.acquire(),f=B(U,L);if(_.className=y,_.dataset.index=String(Q),_.dataset.id=String(Z.id),_.dataset.row=String(j.getRow(Q)),_.dataset.col=String(j.getCol(Q)),_.ariaSelected=String(U),O)_.id=`${O}-item-${Q}`;if(G)K=String(G()),_.setAttribute("aria-setsize",K),_.setAttribute("aria-posinset",String(Q+1));T(_,Q);let x=q(Z,Q,f);return M(_,x),V(_,U,L),S(_,Q,P),_},d=(Q,Z,U,L,P)=>{if(Z.start===0&&Q.length>0)b=Y2(Q[0]);for(let[z,u]of W)if(z<Z.start||z>Z.end)u.element.remove(),F.release(u.element),W.delete(z);let _=!1;if(G){let z=String(G());_=z!==K,K=z}let f=document.createDocumentFragment(),x=[];for(let z=Z.start;z<=Z.end;z++){let u=z-Z.start,R=Q[u];if(!R){console.warn(`⚠️ RENDER: Missing item at index ${z} (range: ${Z.start}-${Z.end}, items.length: ${Q.length})`);continue}let p=U.has(R.id),l=z===L,H=W.get(z);if(H){let c=H.element.dataset.id,j2=String(R.id);if(c!==j2){let $2=B(p,l),k2=q(R,z,$2);M(H.element,k2),H.element.dataset.id=j2,H.element.dataset.row=String(j.getRow(z)),H.element.dataset.col=String(j.getCol(z)),T(H.element,z)}if(V(H.element,p,l),H.element.ariaSelected=String(p),S(H.element,z,P),_)H.element.setAttribute("aria-setsize",K)}else{let c=I(z,R,p,l,P);f.appendChild(c),x.push({index:z,element:c})}}if(x.length>0){Y.appendChild(f);for(let{index:z,element:u}of x)W.set(z,{index:z,element:u})}},m=(Q)=>{for(let[Z,U]of W)S(U.element,Z,Q)},h=(Q,Z,U,L)=>{let P=W.get(Q);if(P){let _=B(U,L),f=q(Z,Q,_);M(P.element,f),V(P.element,U,L),P.element.dataset.id=String(Z.id),P.element.ariaSelected=String(U),T(P.element,Q)}},r=(Q,Z,U)=>{let L=W.get(Q);if(L)V(L.element,Z,U)},s=(Q)=>{return W.get(Q)?.element},g=(Q)=>{if(Math.abs(Q-E)<1)return;E=Q;for(let[Z,U]of W)T(U.element,Z),S(U.element,Z)},e=()=>{for(let[,Q]of W)Q.element.remove(),F.release(Q.element);W.clear()};return{render:d,updatePositions:m,updateItem:h,updateItemClasses:r,getElement:s,updateContainerWidth:g,clear:e,destroy:()=>{e(),F.clear()}}};var Z2=(Y,q,J,j,D,X)=>{if(j===0)return 0;let G=Math.max(0,Math.min(Y,j-1)),O=q.getOffset(G),F=q.getHeight(G),W=q.getTotalHeight(),E=Math.max(0,W-J),b;switch(X){case"center":b=O-J/2+F/2;break;case"end":b=O-J+F;break;case"start":default:b=O;break}return Math.max(0,Math.min(b,E))};var i=(Y,q,J,j,D="start",X,G=Z2)=>{return G(Y,q,J,j,X,D)};var X2=(Y)=>{if(!Y.columns||Y.columns<1)throw Error("[vlist/builder] withGrid: columns must be a positive integer >= 1");let q=null,J=null;return{name:"withGrid",priority:10,setup(j){let{dom:D,emitter:X,config:G,rawConfig:O}=j,{classPrefix:F}=G;if(G.horizontal)throw Error("[vlist/builder] withGrid cannot be used with direction: 'horizontal'");if(G.reverse)throw Error("[vlist/builder] withGrid cannot be used with reverse: true");let W=O.items?.some(($)=>$.__groupHeader===!0),E={columns:Y.columns,gap:Y.gap??0};if(W)E.isHeaderFn=($)=>{let M=j.dataManager.getItem($);return!!(M&&M.__groupHeader===!0)};q=a(E);let b=q.gap;j.setVirtualTotalFn(()=>{let $=j.dataManager.getTotal();return q.getTotalRows($)});let w=O.item,C=G.horizontal?w.width:w.height,K={containerWidth:j.getContainerWidth(),columns:q.columns,gap:q.gap};if(typeof C==="function")j.setHeightConfig(($)=>{let M=K.containerWidth-2,V=(K.columns-1)*K.gap,A=(M-V)/K.columns,S={containerWidth:K.containerWidth,columns:K.columns,gap:K.gap,columnWidth:A,row:q.getRow($),column:q.getCol($),totalRows:q.getTotalRows(j.dataManager.getTotal()),totalColumns:K.columns};return C($,S)+K.gap});else if(b>0)j.setHeightConfig(C+b);j.rebuildHeightCache(),D.root.classList.add(`${F}--grid`);let k=j.getContainerWidth(),N=O.item.template,B=()=>{J=o(D.items,N,j.heightCache,q,F,k,()=>j.dataManager.getTotal(),G.ariaIdPrefix),j.replaceRenderer(J)};B(),j.methods.set("_getGridLayout",()=>q),j.methods.set("_getGridConfig",()=>E),j.methods.set("_replaceGridRenderer",($)=>{J=$}),j.methods.set("_updateGridLayoutForGroups",($)=>{q.update({isHeaderFn:$});let M=j.dataManager.getTotal(),V=0;for(let A=0;A<M;A++)if(q.getCol(A)===0){let S=j.heightCache.getHeight(A);V+=S}j.heightCache.getTotalHeight=()=>V,j.dom.content.style.height=`${V}px`,B()}),j.methods.set("updateGrid",($)=>{if($.columns!==void 0){if(!Number.isInteger($.columns)||$.columns<1)throw Error("[vlist/builder] updateGrid: columns must be a positive integer >= 1");E.columns=$.columns}if($.gap!==void 0){if($.gap<0)throw Error("[vlist/builder] updateGrid: gap must be non-negative");E.gap=$.gap}if(q)q.update(E);let M=j.getContainerWidth();if(K.containerWidth=M,K.columns=E.columns,K.gap=E.gap??0,J)J.updateContainerWidth(M);j.rebuildHeightCache(),j.updateContentSize(j.heightCache.getTotalHeight()),j.updateCompressionMode();for(let V=0;V<j.contentSizeHandlers.length;V++)j.contentSizeHandlers[V]();if(J)J.clear();j.forceRender()});let y=()=>{if(j.state.isDestroyed)return;let $=j.scrollController.getScrollTop(),M=j.state.viewportState.containerHeight,V=j.getVirtualTotal(),A={start:0,end:0};if(V===0||M===0)A.start=0,A.end=0;else{A.start=Math.max(0,j.heightCache.indexAtOffset($));let g=j.heightCache.indexAtOffset($+M);if(g<V-1)g++;A.end=Math.min(V-1,Math.max(0,g))}let S=G.overscan??3,T={start:Math.max(0,A.start-S),end:Math.min(V-1,A.end+S)};j.state.viewportState.scrollTop=$,j.state.viewportState.visibleRange=A,j.state.viewportState.renderRange=T;let I=j.state.lastRenderRange,d=j.state.viewportState.isCompressed;if(T.start===I.start&&T.end===I.end){if(d)J.updatePositions(j.getCompressionContext());return}let m=j.dataManager.getTotal(),h=q.getItemRange(T.start,T.end,m),r=j.dataManager.getItemsInRange(h.start,h.end),s=d?j.getCompressionContext():void 0;J.render(r,h,new Set,-1,s),j.state.lastRenderRange={...T},X.emit("range:change",{range:T})},v=()=>{if(j.state.isDestroyed)return;j.state.lastRenderRange={start:-1,end:-1},y()};if(j.setRenderFns(y,v),j.resizeHandlers.push(($,M)=>{if(J)J.updateContainerWidth($)}),j.methods.set("scrollToIndex",($,M)=>{let V=Math.floor($/Y.columns),{align:A,behavior:S}=D2(M),T=j.dataManager.getState(),I=q.getTotalRows(T.total),d=Math.max(0,Math.min(V,I-1)),m=i(d,j.heightCache,j.state.viewportState.containerHeight,I,A,j.getCachedCompression());if(S==="smooth")j.scrollController.scrollTo(m);else j.scrollController.scrollTo(m)}),!j.methods.has("_getTotal"))j.methods.set("_getTotal",()=>j.dataManager.getTotal());j.destroyHandlers.push(()=>{if(J)J.destroy(),J=null;D.root.classList.remove(`${F}--grid`)})},destroy(){if(J)J.destroy(),J=null}}},t=300,D2=(Y)=>{if(typeof Y==="string")return{align:Y,behavior:"auto",duration:t};if(Y&&typeof Y==="object")return{align:Y.align??"start",behavior:Y.behavior??"auto",duration:Y.duration??t};return{align:"start",behavior:"auto",duration:t}};export{X2 as withGrid,o as createGridRenderer,a as createGridLayout};
@@ -1 +0,0 @@
1
- var K=()=>{let E=null;return{name:"withPage",priority:5,setup(P){let{dom:S,state:q,config:V,emitter:I}=P;S.root.style.overflow="visible",S.root.style.height="auto",S.viewport.classList.remove(`${V.classPrefix}-viewport--custom-scrollbar`),P.disableViewportResize(),P.setScrollTarget(window),P.setScrollFns(()=>{let y=S.viewport.getBoundingClientRect();if(V.horizontal)return Math.max(0,-y.left);else return Math.max(0,-y.top)},(y)=>{let b=S.viewport.getBoundingClientRect();if(V.horizontal){let j=b.left+window.scrollX;window.scrollTo(j+y,window.scrollY)}else{let j=b.top+window.scrollY;window.scrollTo(window.scrollX,j+y)}}),P.setContainerDimensions({width:()=>window.innerWidth,height:()=>window.innerHeight}),q.viewportState.containerHeight=window.innerHeight;let{innerHeight:B,innerWidth:F}=window,G=()=>{let{innerWidth:y,innerHeight:b}=window,j=V.horizontal?y:b,J=V.horizontal?F:B;if(Math.abs(j-J)<=1)return;B=b,F=y,q.viewportState.containerHeight=b,I.emit("resize",{width:y,height:b});for(let k=0;k<P.resizeHandlers.length;k++)P.resizeHandlers[k](y,b);P.renderIfNeeded()};window.addEventListener("resize",G,{passive:!0}),E=()=>{window.removeEventListener("resize",G)},P.destroyHandlers.push(E)},destroy(){if(E)E(),E=null}}};export{K as withPage};
@@ -1 +0,0 @@
1
- var b=16000000;var Ky=(j,Y,K,J)=>{if(J===0)return 0;if(!j.isVariable())return Math.ceil(K/j.getHeight(0));let Q=0,y=0,N=Y;while(N<J&&y<K)y+=j.getHeight(N),Q++,N++;return Math.max(1,Q)},s=(j,Y,K)=>{if(K===0)return 0;if(!j.isVariable())return Math.floor(Y/j.getHeight(0));let J=0,Q=0;for(let y=K-1;y>=0;y--){let N=j.getHeight(y);if(Q+N>Y)break;Q+=N,J++}return Math.max(J,1)},Qy=(j,Y,K)=>{if(K===0)return 0;let J=Math.floor(Y),Q=Y-J,y=Math.max(0,Math.min(J,K-1));return j.getOffset(y)+Q*j.getHeight(y)};var v=(j,Y)=>{let K=Y.getTotalHeight(),J=K>b,Q=J?b:K,y=K>0?Q/K:1;return{isCompressed:J,actualHeight:K,virtualHeight:Q,ratio:y}},c=(j,Y,K,J,Q,y)=>{if(J===0||Y===0)return y.start=0,y.end=-1,y;if(!Q.isCompressed){let W=K.indexAtOffset(j),$=K.indexAtOffset(j+Y);if($<J-1)$++;return y.start=Math.max(0,W),y.end=Math.min(J-1,Math.max(0,$)),y}let{virtualHeight:N}=Q,M=j/N*J,_=Math.floor(M),F=Ky(K,Math.max(0,_),Y,J),V=Math.ceil(M)+F,E=N-Y-j;if(E<=Y&&E>=-1){let W=s(K,Y,J),$=Math.max(0,J-W),q=Math.max(0,Math.min(1,1-E/Y));_=Math.floor(_+($-_)*q),V=E<=1?J-1:Math.min(J-1,_+F)}return y.start=Math.max(0,_),y.end=Math.min(J-1,Math.max(0,V)),y},Gy=(j,Y,K,J)=>{if(K===0)return J.start=0,J.end=-1,J;return J.start=Math.max(0,j.start-Y),J.end=Math.min(K-1,j.end+Y),J},r=(j,Y,K,J,Q,y,N)=>{if(!y.isCompressed||J===0)return K.getOffset(j);let{virtualHeight:k}=y,M=k-Q,_=M-Y;if(_<=Q&&_>=-1){if(Y>=M-1){let X=K.getTotalHeight()-K.getOffset(j);return Q-X}let E=s(K,Q,J),W=Math.max(0,J-E),q=Y/k*J,L=Math.max(0,Math.min(1,1-_/Q)),O=K.getOffset(j)-K.getOffset(W),B=K.getOffset(j)-Qy(K,q,J);return B+(O-B)*L}let F=Y/k,V=K.getTotalHeight(),U=F*V;return K.getOffset(j)-U},l=(j,Y,K,J,Q,y="start")=>{if(J===0)return 0;let N;if(Q.isCompressed){if(y==="end"&&j===J-1)return Math.max(0,Q.virtualHeight-K);N=j/J*Q.virtualHeight}else N=Y.getOffset(j);let k=Y.getHeight(j);switch(y){case"center":N-=(K-k)/2;break;case"end":N-=K-k;break}let M=Q.virtualHeight-K;return Math.max(0,Math.min(N,M))},Uy=(j,Y,K,J)=>{if(K===0)return 0;if(J.isCompressed){let Q=j/J.virtualHeight;return Math.floor(Q*K)}return Y.indexAtOffset(j)},Dy=(j,Y)=>{if(typeof Y==="number")return j*Y>b;return Y.getTotalHeight()>b},_y=(j)=>{if(j<=0)return 0;return Math.floor(b/j)},Ey=(j,Y)=>{let K=v(j,Y);if(!K.isCompressed)return`No compression needed (${j} items, ${(K.actualHeight/1e6).toFixed(2)}M px)`;return`Compressed to ${(K.ratio*100).toFixed(1)}% (${j} items, ${(K.actualHeight/1e6).toFixed(1)}M px → ${(K.virtualHeight/1e6).toFixed(1)}M px virtual)`};var a=(j,Y,K={},J="vlist",Q=!1)=>{let{autoHide:y=!0,autoHideDelay:N=1000,minThumbSize:k=30,showOnHover:M=!0,hoverZoneWidth:_=16,showOnViewportEnter:F=!0}=K,V=0,U=0,E=0,W=0,$=!1,q=!1,L=0,O=0,B=0,X=null,A=!1,R=null,w=null,Yy=Q?"width":"height",i=Q?"translateX":"translateY",u=Q?(D)=>D.clientX:(D)=>D.clientY,$y=Q?"left":"top",G=document.createElement("div"),z=document.createElement("div"),Z=M?document.createElement("div"):null,Ny=()=>{if(G.className=`${J}-scrollbar`,z.className=`${J}-scrollbar-thumb`,Q)G.classList.add(`${J}-scrollbar--horizontal`);if(G.appendChild(z),j.appendChild(G),Z){if(Z.className=`${J}-scrollbar-hover`,Q)Z.classList.add(`${J}-scrollbar-hover--horizontal`),Z.style.height=`${_}px`;else Z.style.width=`${_}px`;j.appendChild(Z)}},f=()=>{if(X)clearTimeout(X),X=null},T=()=>{if(!y)return;f(),X=setTimeout(x,N)},H=()=>{if(V<=U)return;if(f(),!A)G.classList.add(`${J}-scrollbar--visible`),A=!0;if(y&&!$&&!q)T()},x=()=>{if($||q)return;G.classList.remove(`${J}-scrollbar--visible`),A=!1},Wy=(D,C)=>{V=D,U=C;let S=V>U;if(G.style.display=S?"":"none",!S){x();return}let P=U/V;E=Math.max(k,P*U),z.style[Yy]=`${E}px`,W=U-E,o(B)},o=(D)=>{if(B=D,V<=U||W<=0)return;let C=V-U,P=Math.min(1,Math.max(0,D/C))*W;z.style.transform=`${i}(${P}px)`},e=(D)=>{if(D.target===z)return;let C=G.getBoundingClientRect(),m=u(D)-C[$y]-E/2,Jy=Math.max(0,Math.min(m,W))/W,n=V-U,qy=Jy*n;Y(qy),H()},t=(D)=>{D.preventDefault(),D.stopPropagation(),$=!0,L=u(D),O=B,f(),G.classList.add(`${J}-scrollbar--dragging`),document.addEventListener("mousemove",d),document.addEventListener("mouseup",g)},d=(D)=>{if(!$)return;let C=u(D)-L,S=W>0?C/W:0,P=V-U,m=S*P,h=Math.max(0,Math.min(O+m,P)),n=h/P*W;if(z.style.transform=`${i}(${n}px)`,w=h,R===null)R=requestAnimationFrame(()=>{if(w!==null)Y(w);R=null})},g=()=>{if($=!1,R!==null)cancelAnimationFrame(R),R=null;if(w!==null)Y(w),w=null;if(G.classList.remove(`${J}-scrollbar--dragging`),y&&!q)T();document.removeEventListener("mousemove",d),document.removeEventListener("mouseup",g)},yy=()=>{if(F)H()},jy=()=>{if(!$){if(q=!1,y)T()}},p=()=>{q=!0,f(),H()},I=()=>{if(q=!1,!$&&y)T()},Xy=()=>{if(f(),R!==null)cancelAnimationFrame(R),R=null;if(G.removeEventListener("click",e),G.removeEventListener("mouseenter",p),G.removeEventListener("mouseleave",I),z.removeEventListener("mousedown",t),j.removeEventListener("mouseenter",yy),j.removeEventListener("mouseleave",jy),document.removeEventListener("mousemove",d),document.removeEventListener("mouseup",g),Z){if(Z.removeEventListener("mouseenter",p),Z.removeEventListener("mouseleave",I),Z.parentNode)Z.parentNode.removeChild(Z)}if(G.parentNode)G.parentNode.removeChild(G)};if(Ny(),G.addEventListener("click",e),G.addEventListener("mouseenter",p),G.addEventListener("mouseleave",I),z.addEventListener("mousedown",t),j.addEventListener("mouseenter",yy),j.addEventListener("mouseleave",jy),Z)Z.addEventListener("mouseenter",p),Z.addEventListener("mouseleave",I);return{show:H,hide:x,updateBounds:Wy,updatePosition:o,isVisible:()=>A,destroy:Xy}};var Ly=0.65,Oy=0.5,By=()=>{let j=null,Y=0,K=!1,J=0,Q=null;return{name:"withScale",priority:20,setup(y){let{dom:N,config:k}=y,{classPrefix:M,horizontal:_}=k,F=()=>{let W=y.getVirtualTotal(),$=v(W,y.heightCache);if($.isCompressed&&!K){K=!0,y.scrollController.enableCompression($),y.updateContentSize($.virtualHeight),y.setScrollFns(()=>Y,(X)=>{if(Y=X,J=X,Q!==null)cancelAnimationFrame(Q),Q=null});let q=()=>{let X=J-Y;if(Math.abs(X)<Oy)Y=J,Q=null;else Y+=X*Ly,Q=requestAnimationFrame(q);y.scrollController.scrollTo(Y)},L=N.viewport,O=(X)=>{X.preventDefault();let R=y.getCachedCompression().virtualHeight-y.state.viewportState.containerHeight;if(J=Math.max(0,Math.min(J+X.deltaY,R)),Q===null)Q=requestAnimationFrame(q)};if(L.addEventListener("wheel",O,{passive:!1}),y.destroyHandlers.push(()=>{if(L.removeEventListener("wheel",O),Q!==null)cancelAnimationFrame(Q),Q=null}),!N.viewport.querySelector(`.${M}-scrollbar-track`)){if(j=a(N.viewport,(A)=>y.scrollController.scrollTo(A),{},M,_),!N.viewport.classList.contains(`${M}-viewport--custom-scrollbar`))N.viewport.classList.add(`${M}-viewport--custom-scrollbar`);j.updateBounds($.virtualHeight,y.state.viewportState.containerHeight);let X=j;y.afterScroll.push((A,R)=>{if(X)X.updatePosition(A),X.show()}),y.resizeHandlers.push((A,R)=>{if(X){let w=y.getCachedCompression();X.updateBounds(w.virtualHeight,y.state.viewportState.containerHeight)}})}}else if(!$.isCompressed&&K)K=!1,y.scrollController.disableCompression(),y.updateContentSize($.actualHeight);else if($.isCompressed)y.scrollController.updateConfig({compression:$}),y.updateContentSize($.virtualHeight);if(j)j.updateBounds($.virtualHeight,y.state.viewportState.containerHeight);y.state.cachedCompression={state:$,totalItems:W}};y.updateCompressionMode=F;let V=y.getCachedCompression.bind(y);y.getCachedCompression=()=>{if(y.state.cachedCompression)return y.state.cachedCompression.state;return V()},y.setVisibleRangeFn((W,$,q,L,O)=>{U=null,E=null;let B=v(L,q);c(W,$,q,L,B,O)}),y.setScrollToPosFn((W,$,q,L,O)=>{let B=v(L,$);return l(W,$,q,L,B,O)});let U=null,E=null;y.setPositionElementFn((W,$)=>{let q=y.getVirtualTotal(),L=v(q,y.heightCache);if(L.isCompressed){let O=y.scrollController.getScrollTop();if(U===null||$<E)E=$,U=Math.round(r($,O,y.heightCache,q,y.state.viewportState.containerHeight,L));let B=U+y.heightCache.getOffset($)-y.heightCache.getOffset(E),X=y.config.horizontal;W.style.transform=X?`translateX(${B}px)`:`translateY(${B}px)`}else{let O=Math.round(y.heightCache.getOffset($)),B=y.config.horizontal;W.style.transform=B?`translateX(${O}px)`:`translateY(${O}px)`}}),F(),y.destroyHandlers.push(()=>{if(j)j.destroy(),j=null;if(Q!==null)cancelAnimationFrame(Q),Q=null})},destroy(){if(j)j.destroy(),j=null;if(Q!==null)cancelAnimationFrame(Q),Q=null}}};export{By as withScale,Dy as needsCompression,_y as getMaxItemsWithoutCompression,v as getCompressionState,Ey as getCompressionInfo,Uy as calculateIndexFromScrollPosition,c as calculateCompressedVisibleRange,l as calculateCompressedScrollToIndex,Gy as calculateCompressedRenderRange,r as calculateCompressedItemPosition,b as MAX_VIRTUAL_HEIGHT};