@floor/vlist 0.7.4 → 0.7.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/async/index.js +1 -1
- package/dist/builder/index.js +1 -1
- package/dist/builder/types.d.ts +6 -0
- package/dist/index.js +1 -1
- package/package.json +1 -1
package/dist/async/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var $j=(U={})=>{let{chunkSize:G=100,maxCachedItems:Y=5000,evictionBuffer:N=200,onEvict:M}=U,Q=new Map,j=0,D=0,f=(q)=>{let X=Q.get(q);if(!X)X={items:Array(G),count:0,lastAccess:Date.now()},Q.set(q,X);else X.lastAccess=Date.now();return X},z=(q)=>{return Math.floor(q/G)},W=(q)=>{return q%G},y=()=>j,L=(q)=>{j=q},b=(q)=>{if(q<0||q>=j)return;let X=z(q),B=Q.get(X);if(!B)return;return B.items[W(q)]},C=(q)=>{if(q<0||q>=j)return!1;let X=z(q),B=Q.get(X);if(!B)return!1;return B.items[W(q)]!==void 0},u=(q,X)=>{let B=z(q),K=f(B),_=W(q),l=K.items[_]===void 0;if(K.items[_]=X,l)K.count++,D++;if(q>=j)j=q+1},H=(q,X)=>{for(let B=0;B<X.length;B++){let K=X[B];if(K!==void 0)u(q+B,K)}},Z=(q)=>{if(q<0||q>=j)return!1;let X=z(q),B=Q.get(X);if(!B)return!1;let K=W(q);if(B.items[K]===void 0)return!1;if(B.items[K]=void 0,B.count--,D--,B.count===0)Q.delete(X);return!0},F=(q,X)=>{let B=[];for(let K=q;K<=X&&K<j;K++)B.push(b(K));return B},V=(q,X)=>{for(let B=q;B<=X&&B<j;B++)if(!C(B))return!1;return!0},O=()=>{let q=[],X=null,B=Array.from(Q.keys()).sort((K,_)=>K-_);for(let K of B){let _=Q.get(K);if(!_)continue;let l=K*G;for(let R=0;R<G;R++){let p=l+R;if(p>=j)break;if(_.items[R]!==void 0)if(X===null)X={start:p,end:p};else if(p===X.end+1)X.end=p;else q.push(X),X={start:p,end:p};else if(X!==null)q.push(X),X=null}}if(X!==null)q.push(X);return q},h=(q,X)=>{let B=[],K=null;for(let _=q;_<=X&&_<j;_++)if(!C(_))if(K===null)K={start:_,end:_};else K.end=_;else if(K!==null)B.push(K),K=null;if(K!==null)B.push(K);return B},w=(q)=>{return Q.has(q)},k=(q)=>{let X=Q.get(q);if(X)X.lastAccess=Date.now()},A=(q,X)=>{if(q>X||Q.size===0)return;let B=Date.now(),K=z(Math.max(0,q)),_=z(Math.min(j-1,X));for(let l=K;l<=_;l++){let R=Q.get(l);if(R)R.lastAccess=B}},T=(q,X)=>{if(D<=Y)return 0;let B=Math.max(0,q-N),K=Math.min(j-1,X+N),_=z(B),l=z(K),R=0,p=[];for(let[i,qj]of Q)if(i<_||i>l)R+=qj.count,p.push(i),D-=qj.count,Q.delete(i);if(R>0&&M)M(R,p);return R},I=()=>{if(D<=Y)return 0;let q=Array.from(Q.entries()).sort(([,K],[,_])=>K.lastAccess-_.lastAccess),X=0,B=[];for(let[K,_]of q){if(D<=Y)break;X+=_.count,D-=_.count,B.push(K),Q.delete(K)}if(X>0&&M)M(X,B);return X},r=()=>{return{totalItems:j,cachedItems:D,cachedChunks:Q.size,chunkSize:G,maxCachedItems:Y,memoryEfficiency:j>0?1-D/j:1}},t=()=>D,e=()=>{Q.clear(),D=0};return{chunkSize:G,maxCachedItems:Y,getTotal:y,setTotal:L,get:b,has:C,set:u,setRange:H,delete:Z,getRange:F,isRangeLoaded:V,getLoadedRanges:O,findUnloadedRanges:h,getChunkIndex:z,isChunkLoaded:w,touchChunk:k,touchChunksForRange:A,evictDistant:T,evictToLimit:I,getStats:r,getCachedCount:t,clear:e,reset:()=>{e(),j=0}}},Uj=(U)=>{if(U.length===0)return[];let G=[...U].sort((N,M)=>N.start-M.start),Y=[{...G[0]}];for(let N=1;N<G.length;N++){let M=G[N],Q=Y[Y.length-1];if(M.start<=Q.end+1)Q.end=Math.max(Q.end,M.end);else Y.push({...M})}return Y},Xj=(U,G,Y)=>{let N=Math.floor(U.start/Y)*Y,M=Math.ceil((U.end+1)/Y)*Y-1,Q={start:N,end:M};if(G.length===0)return[Q];let j=[],D=Uj(G),f=Q.start;for(let z of D){if(z.end<f)continue;if(z.start>Q.end)break;if(z.start>f)j.push({start:f,end:Math.min(z.start-1,Q.end)});if(f=z.end+1,f>Q.end)break}if(f<=Q.end)j.push({start:f,end:Q.end});return j};var Yj=(U={})=>{let{enabled:G=!0,maskCharacter:Y="█",randomVariance:N=!0,maxSampleSize:M=20,customGenerator:Q}=U,j=null,D=!1,f=0,z=(Z)=>{if(!G||D||Z.length===0)return;let F=new Map,V=new Map,O=Math.min(Z.length,M);for(let h=0;h<O;h++){let w=Z[h];if(!w||typeof w!=="object")continue;for(let[k,A]of Object.entries(w)){if(k.startsWith("_")||k==="id")continue;if(!V.has(k))V.set(k,{lengths:[],types:new Set});let T=V.get(k),I=Array.isArray(A)?"array":typeof A;if(T.types.add(I),typeof A==="string")T.lengths.push(A.length);else if(A!==null&&A!==void 0)T.lengths.push(String(A).length)}}for(let[h,w]of V){if(w.lengths.length===0)continue;let k=Math.min(...w.lengths),A=Math.max(...w.lengths),T=Math.round(w.lengths.reduce((r,t)=>r+t,0)/w.lengths.length),I="string";if(w.types.has("number")&&w.types.size===1)I="number";else if(w.types.has("boolean")&&w.types.size===1)I="boolean";else if(w.types.has("array"))I="array";else if(w.types.has("object")&&!w.types.has("string"))I="object";F.set(h,{minLength:k,maxLength:A,avgLength:T,type:I})}j=F,D=!0},W=()=>D,y=(Z)=>{let F=Z.avgLength;if(N&&Z.minLength!==Z.maxLength){if(F=Math.floor(Math.random()*(Z.maxLength-Z.minLength+1)+Z.minLength),Math.random()<0.3)F=Math.max(1,F+Math.floor(Math.random()*3)-1)}return Y.repeat(Math.max(1,F))},L=(Z)=>{if(Q)return{...Q(Z),["_isPlaceholder"]:!0};let F={id:`__placeholder_${f++}`,["_isPlaceholder"]:!0,_index:Z};if(!j||j.size===0)return F.label=Y.repeat(12),F;for(let[V,O]of j)switch(O.type){case"string":F[V]=y(O);break;case"number":F[V]=0;break;case"boolean":F[V]=!1;break;case"array":F[V]=[];break;case"object":F[V]={};break;default:F[V]=y(O)}return F};return{analyzeStructure:z,hasAnalyzedStructure:W,generate:L,generateRange:(Z,F)=>{let V=[];for(let O=Z;O<=F;O++)V.push(L(O));return V},isPlaceholder:(Z)=>{if(!Z||typeof Z!=="object")return!1;return Z._isPlaceholder===!0},getPlaceholderKey:()=>"_isPlaceholder",clear:()=>{j=null,D=!1,f=0}}},d=(U)=>{if(!U||typeof U!=="object")return!1;return U._isPlaceholder===!0},Nj=(U)=>{return U.filter((G)=>!d(G))},Fj=(U)=>{let G=0;for(let Y of U)if(Y!==void 0&&!d(Y))G++;return G},Ej=(U,G,Y)=>{let N=0;for(let M=0;M<G.length;M++){let Q=Y+M,j=U[Q];if(j===void 0||d(j)){if(U[Q]=G[M],d(j))N++}}return N};var Lj=50,Bj=(U={})=>{let{adapter:G,initialItems:Y,initialTotal:N,storage:M,placeholder:Q,pageSize:j=Lj,onStateChange:D,onItemsLoaded:f,onItemsEvicted:z}=U,W=$j({...M,onEvict:(J,$)=>{z?.(J),O()}}),y=null,L=()=>{if(!y)y=Yj(Q);return y},b=new Map,C=!1,u,H=!0,Z,F=[],V=new Map,O=()=>{D?.(e())},h=()=>{b.clear();let J=W.getLoadedRanges();for(let $ of J)for(let P=$.start;P<=$.end;P++){let E=W.get(P);if(E&&!d(E))b.set(E.id,P)}},w=(J,$)=>{if(!d($))b.set($.id,J)},k=(J)=>{b.delete(J)},A=(J,$)=>{return`${J}-${$}`},T=()=>W.getTotal(),I=()=>W.getCachedCount(),r=()=>C,t=()=>H,e=()=>({total:W.getTotal(),cached:W.getCachedCount(),isLoading:C,pendingRanges:F,error:u,hasMore:H,cursor:Z}),Zj=()=>W,q=()=>L(),X=(J)=>{let $=W.get(J);if($!==void 0)return $;if(J>=0&&J<W.getTotal())return L().generate(J);return},B=(J)=>{let $=b.get(J);if($===void 0)return;return W.get($)},K=(J)=>{return b.get(J)??-1},_=(J)=>{let $=W.get(J);return $!==void 0&&!d($)},l=(J,$)=>{let P=[],E=W.getTotal(),g=0,x=0;W.touchChunksForRange(J,Math.min($,E-1));for(let c=J;c<=$&&c<E;c++){let s=W.get(c);if(s!==void 0)P.push(s),g++;else P.push(L().generate(c)),x++}return P},R=(J)=>{W.setTotal(J),H=W.getCachedCount()<J,O()},p=(J,$=0,P)=>{if(y&&!y.hasAnalyzedStructure()&&J.length>0)y.analyzeStructure(J);for(let E=0;E<J.length;E++){let g=J[E];if(g!==void 0){let x=$+E;W.set(x,g),w(x,g)}}if(P!==void 0)W.setTotal(P);else if($+J.length>W.getTotal())W.setTotal($+J.length);H=W.getCachedCount()<W.getTotal(),f?.(J,$,W.getTotal()),O()},i=(J,$)=>{let P=b.get(J);if(P===void 0)return!1;let E=W.get(P);if(!E)return!1;let g={...E,...$};if(W.set(P,g),$.id!==void 0&&$.id!==J)k(J),w(P,g);return O(),!0},qj=(J)=>{let $=b.get(J);if($===void 0)return!1;W.delete($),k(J);let P=W.getTotal();if(P>0)W.setTotal(P-1);return O(),!0},Jj=async(J,$)=>{if(!G)return;let P=A(J,$);if(V.has(P))return;let E=W.getLoadedRanges(),g=Xj({start:J,end:$},E,W.chunkSize);if(g.length===0)return;let x=W.chunkSize,c=[];for(let v of g){let a=Math.floor(v.start/x),n=Math.floor(v.end/x);for(let S=a;S<=n;S++){let o=S*x,m=o+x-1,Qj=A(o,m);if(!c.some((Wj)=>Wj.start===o)&&!V.has(Qj))c.push({start:o,end:m})}}let s=[];for(let v of g){let a=Math.floor(v.start/x),n=Math.floor(v.end/x);for(let S=a;S<=n;S++){let o=S*x,m=o+x-1,Qj=A(o,m);if(V.has(Qj)){let Wj=V.get(Qj);if(!s.includes(Wj))s.push(Wj)}}}for(let v of c){let a=A(v.start,v.end),n=(async()=>{F.push(v),C=!0,u=void 0,O();try{let S=v.end-v.start+1,o={offset:v.start,limit:S,cursor:void 0},m=await G.read(o);if(p(m.items,v.start,m.total),m.cursor)Z=m.cursor;if(m.hasMore!==void 0)H=m.hasMore;else if(m.total!==void 0)H=W.getCachedCount()<m.total}catch(S){u=S instanceof Error?S:Error(String(S))}finally{V.delete(a),F=F.filter((S)=>S.start!==v.start||S.end!==v.end),C=V.size>0,O()}})();V.set(a,n),s.push(n)}await Promise.all(s)},Aj=async(J,$)=>{if(W.isRangeLoaded(J,$))return;await Jj(J,$)},Dj=async()=>{if(!G)return;await Jj(0,j-1)},Oj=async()=>{if(!G||C||!H)return!1;let J=W.getCachedCount(),$=W.getTotal(),P=J,E=Math.min(P+j-1,$>0?$-1:P+j-1);if(P>=$&&$>0)return H=!1,!1;return await Jj(P,E),W.getCachedCount()>J},zj=async()=>{if(W.clear(),b.clear(),y)y.clear();Z=void 0,H=!0,u=void 0,O(),await Dj()},Hj=(J,$)=>{if(W.evictDistant(J,$)>0)h()},yj=()=>{W.clear(),b.clear(),Z=void 0,u=void 0,F=[],C=!1,O()},bj=()=>{if(W.reset(),b.clear(),y)y.clear();Z=void 0,H=!0,u=void 0,F=[],C=!1,O()};if(Y&&Y.length>0)p(Y,0,N??Y.length);else if(N!==void 0)W.setTotal(N);return{getState:e,getTotal:T,getCached:I,getIsLoading:r,getHasMore:t,getStorage:Zj,getPlaceholders:q,getItem:X,getItemById:B,getIndexById:K,isItemLoaded:_,getItemsInRange:l,setTotal:R,setItems:p,updateItem:i,removeItem:qj,loadRange:Jj,ensureRange:Aj,loadInitial:Dj,loadMore:Oj,reload:zj,evictDistant:Hj,clear:yj,reset:bj}};var Vj=(U,G,Y,N,M,Q)=>{if(N===0||G===0)return Q.start=0,Q.end=-1,Q;let j=Y.indexAtOffset(U),D=Y.indexAtOffset(U+G);if(D<N-1)D++;return Q.start=Math.max(0,j),Q.end=Math.min(N-1,Math.max(0,D)),Q},wj=(U,G,Y,N)=>{if(Y===0)return N.start=0,N.end=-1,N;return N.start=Math.max(0,U.start-G),N.end=Math.min(Y-1,U.end+G),N};var Gj=(U,G,Y,N,M,Q=Vj)=>{return Q(U.scrollTop,U.containerHeight,G,Y,M,U.visibleRange),wj(U.visibleRange,N,Y,U.renderRange),U.totalHeight=M.virtualHeight,U.actualHeight=M.actualHeight,U.isCompressed=M.isCompressed,U.compressionRatio=M.ratio,U};var Kj=200,jj=50;var Mj=15,Pj=2,_j=50;var fj=(U)=>{let{adapter:G,loading:Y}=U,N=Y?.cancelThreshold??Mj,M=Y?.preloadThreshold??Pj,Q=Y?.preloadAhead??_j;return{name:"withAsync",priority:20,methods:["reload"],setup(j){let{emitter:D}=j,f=j.config.reverse,z=j.config.overscan,W=Bj({adapter:G,pageSize:jj,onStateChange:()=>{if(j.state.isInitialized)j.heightCache.rebuild(j.getVirtualTotal()),j.updateCompressionMode(),j.state.viewportState=Gj(j.state.viewportState,j.heightCache,j.getVirtualTotal(),z,j.getCachedCompression()),j.updateContentSize(j.state.viewportState.totalHeight),j.renderIfNeeded()},onItemsLoaded:(Z,F,V)=>{if(j.state.isInitialized)j.heightCache.rebuild(j.getVirtualTotal()),j.forceRender(),D.emit("load:end",{items:Z,total:V})}});j.replaceDataManager(W);let y=null,L=null,b=0,C=()=>{if(L){let Z=L;L=null,j.dataManager.ensureRange(Z.start,Z.end).catch((F)=>{D.emit("error",{error:F,context:"ensureRange"})})}};j.afterScroll.push((Z,F)=>{if(j.state.isDestroyed)return;let V=j.scrollController.getVelocity(),h=j.scrollController.isTracking()&&V<=N;if(L&&b>N&&V<=N){let A=L;L=null,j.dataManager.ensureRange(A.start,A.end).catch((T)=>{D.emit("error",{error:T,context:"ensureRange"})})}if(b=V,h&&!j.dataManager.getIsLoading()&&j.dataManager.getHasMore()){if(f){if(Z<Kj)D.emit("load:start",{offset:j.dataManager.getCached(),limit:jj}),j.dataManager.loadMore().catch((A)=>{D.emit("error",{error:A,context:"loadMore"})})}else if(j.state.viewportState.totalHeight-Z-j.state.viewportState.containerHeight<Kj)D.emit("load:start",{offset:j.dataManager.getCached(),limit:jj}),j.dataManager.loadMore().catch((T)=>{D.emit("error",{error:T,context:"loadMore"})})}let{renderRange:w}=j.state.viewportState;if(!y||w.start!==y.start||w.end!==y.end)if(y={start:w.start,end:w.end},h){L=null;let{start:A,end:T}=w,I=j.getVirtualTotal();if(V>M)if(F==="down")T=Math.min(w.end+Q,I-1);else A=Math.max(w.start-Q,0);j.dataManager.ensureRange(A,T).catch((r)=>{D.emit("error",{error:r,context:"ensureRange"})})}else L={start:w.start,end:w.end}});let u=200,H=null;j.afterScroll.push((Z,F)=>{if(H!==null)clearTimeout(H);H=setTimeout(()=>{H=null,C()},u)}),j.destroyHandlers.push(()=>{if(H!==null)clearTimeout(H),H=null}),D.on("load:start",()=>{j.dom.root.setAttribute("aria-busy","true")}),D.on("load:end",()=>{j.dom.root.removeAttribute("aria-busy")}),j.methods.set("reload",async()=>{await j.dataManager.reload()}),D.emit("load:start",{offset:0,limit:jj}),j.dataManager.loadInitial().catch((Z)=>{D.emit("error",{error:Z,context:"loadInitial"})})}}};export{fj as withAsync,Ej as replacePlaceholders,Uj as mergeRanges,d as isPlaceholderItem,Nj as filterPlaceholders,$j as createSparseStorage,Yj as createPlaceholderManager,Bj as createDataManager,Fj as countRealItems,Xj as calculateMissingRanges};
|
|
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};
|
package/dist/builder/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
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,t=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)),e=new Set(d.map((j)=>j.name));for(let j of d)if(j.conflicts){for(let J of j.conflicts)if(e.has(J))throw Error(`[vlist/builder] ${j.name} and ${J} cannot be combined`)}if($){if(e.has("withGrid"))throw Error("[vlist/builder] withGrid cannot be used with direction: 'horizontal'");if(e.has("withGroups"))throw Error("[vlist/builder] withGroups cannot be used with direction: 'horizontal'")}if(c){if(e.has("withGrid"))throw Error("[vlist/builder] withGrid cannot be used with reverse: true")}let xj=WJ(X.container),_=DJ(xj,W,C,$),k=GJ(),B=Q?[...Q]:[],N=Tj(fj,B.length),jj=VJ(),F=_.viewport.clientHeight,Jj=_.viewport.clientWidth,s=!1,p=!1,O=0,x=null,l=null,I=YJ(0),Xj={start:0,end:0},E={start:0,end:0},h={start:-1,end:-1},w={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},v=new Map,Bj={selected:!1,focused:!1},hj=`${W}-item`,a="",z=new Map,Gj=()=>{z.clear();for(let j=0;j<B.length;j++){let J=B[j];if(J)z.set(J.id,j)}};Gj();let R=null,H=()=>R?R.getTotal():B.length,Wj=[],Dj=[],Vj=[],_j=[],r=[],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=jj.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}`,a=String(H()),Z.setAttribute("aria-setsize",a),Z.setAttribute("aria-posinset",String(j+1)),String(J.id).startsWith("__placeholder_"))Z.classList.add(`${W}-item--placeholder`);return Nj(Z,t(J,j,Bj)),Qj(Z,j),Z},o=()=>{let j=`${N.getTotalHeight()}px`;if($)_.content.style.width=j;else _.content.style.height=j},Mj=new Set,Aj=-1,mj=()=>{if(s)return;let j=H();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 v)Qj(A,G);return}let J=String(j),Z=J!==a;a=J;for(let[G,A]of v)if(G<E.start||G>E.end)A.remove(),jj.release(A),v.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=v.get(G);if(M){let P=M.dataset.id,i=String(A.id);if(P!==i){let qJ=P?.startsWith("__placeholder_"),Ij=i.startsWith("__placeholder_");if(Nj(M,t(A,G,Bj)),M.dataset.id=i,$)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",a)}else{let P=gj(G,A),i=Mj.has(A.id),Uj=G===Aj;if(i)P.classList.add(`${W}-item--selected`),P.ariaSelected="true";if(Uj)P.classList.add(`${W}-item--focused`);q.appendChild(P),D.push({index:G,element:P})}}if(D.length>0){_.items.appendChild(q);for(let{index:G,element:A}of D)v.set(G,A)}h.start=E.start,h.end=E.end,w.lastRenderRange.start=E.start,w.lastRenderRange.end=E.end,w.viewportState.scrollTop=O,w.viewportState.visibleRange.start=Xj.start,w.viewportState.visibleRange.end=Xj.end,w.viewportState.renderRange.start=E.start,w.viewportState.renderRange.end=E.end,k.emit("range:change",{range:{start:E.start,end:E.end}})},cj=()=>{h.start=-1,h.end=-1,y()};y=mj,T=cj;let n=()=>{if(s)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(),k.emit("scroll",{scrollTop:j,direction:J}),k.emit("velocity:change",{velocity:I.velocity,reliable:I.sampleCount>=Rj});for(let Z=0;Z<Wj.length;Z++)Wj[Z](j,J);if(l)clearTimeout(l);l=setTimeout(()=>{_.root.classList.remove(`${W}--scrolling`),I.velocity=0,I.sampleCount=0,k.emit("velocity:change",{velocity:0,reliable:!1})},Yj?.idleTimeout??150)},qj=null,g=_.viewport;if(g.addEventListener("scroll",n,{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;k.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;k.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(s)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,w.viewportState.containerHeight=D,p)o(),y(),k.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 k},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=v.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)=>v.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:w,getContainerWidth(){return Jj},afterScroll:Wj,clickHandlers:Dj,keydownHandlers:Vj,resizeHandlers:_j,contentSizeHandlers:r,destroyHandlers:Lj,methods:L,replaceTemplate(j){t=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 H()},getCachedCompression(){return{isCompressed:!1,actualHeight:N.getTotalHeight(),virtualHeight:N.getTotalHeight(),ratio:1}},getCompressionContext(){return{scrollTop:O,totalItems:H(),containerHeight:F,rangeStart:E.start}},renderIfNeeded(){y()},forceRender(){T()},getRenderFns(){return{renderIfNeeded:y,forceRender:T}},setRenderFns(j,J){y=j,T=J},setVirtualTotalFn(j){H=j},rebuildHeightCache(j){N.rebuild(j??H())},setHeightConfig(j){N=Tj(j,H())},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),n()}},setScrollTarget(j){g.removeEventListener("scroll",n),g=j,g.addEventListener("scroll",n,{passive:!0})},getScrollTarget(){return g},setContainerDimensions(j){sj=j.width,lj=j.height,Jj=j.width(),F=j.height(),w.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=z.get(j);return J!==void 0?B[J]:void 0},getIndexById:(j)=>z.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(H()),o(),b.updateCompressionMode();for(let q=0;q<r.length;q++)r[q]();T()}},updateItem:(j,J)=>{let Z=z.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)z.delete(j),z.set(J.id,Z);let D=v.get(Z);if(D)Nj(D,t(B[Z],Z,Bj)),D.dataset.id=String(B[Z].id);return!0},removeItem:(j)=>{let J=z.get(j);if(J===void 0)return!1;if(B.splice(J,1),Gj(),p){N.rebuild(H()),o(),b.updateCompressionMode();for(let Z=0;Z<r.length;Z++)r[Z]();T()}return!0},loadRange:async()=>{},ensureRange:async()=>{},loadInitial:async()=>{},loadMore:async()=>!1,reload:async()=>{},evictDistant:()=>{},clear:()=>{B=[],z.clear()},reset:()=>{if(B=[],z.clear(),p)N.rebuild(0),o(),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,o(),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),P=j+(J-j)*MJ(M);if(S(P),O=P,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=H(),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=z.get(j)??b.dataManager.getIndexById(j);if(Z>=0)vj(Z,J)},JJ=()=>u(),XJ=(j,J)=>{return k.on(j,J)},ZJ=(j,J)=>{k.off(j,J)},$J=()=>{if(s)return;if(s=!0,b.state.isDestroyed=!0,_.items.removeEventListener("click",Hj),_.root.removeEventListener("keydown",Pj),g.removeEventListener("scroll",n),Ej.disconnect(),qj)_.viewport.removeEventListener("wheel",qj);if(l)clearTimeout(l);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 v)j.remove(),jj.release(j);v.clear(),jj.clear(),k.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 H()},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
|
+
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};
|
package/dist/builder/types.d.ts
CHANGED
|
@@ -109,6 +109,12 @@ export interface BuilderContext<T extends VListItem = VListItem> {
|
|
|
109
109
|
getCompressionContext(): CompressionContext;
|
|
110
110
|
renderIfNeeded(): void;
|
|
111
111
|
forceRender(): void;
|
|
112
|
+
/**
|
|
113
|
+
* Remove all rendered DOM elements and return them to the pool.
|
|
114
|
+
* Used by reload to force a full re-render from scratch, bypassing
|
|
115
|
+
* the ID-based optimization that skips template updates for same-ID items.
|
|
116
|
+
*/
|
|
117
|
+
invalidateRendered(): void;
|
|
112
118
|
/**
|
|
113
119
|
* Get current render functions (for wrapping by selection/other plugins).
|
|
114
120
|
* Call this BEFORE setRenderFns to capture the current functions.
|
package/dist/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var{defineProperty:Gj,getOwnPropertyNames:mJ,getOwnPropertyDescriptor:dJ}=Object,cJ=Object.prototype.hasOwnProperty;var xj=new WeakMap,lJ=(j)=>{var X=xj.get(j),$;if(X)return X;if(X=Gj({},"__esModule",{value:!0}),j&&typeof j==="object"||typeof j==="function")mJ(j).map((J)=>!cJ.call(X,J)&&Gj(X,J,{get:()=>j[J],enumerable:!($=dJ(j,J))||$.enumerable}));return xj.set(j,X),X};var sJ=(j,X)=>{for(var $ in X)Gj(j,$,{get:X[$],enumerable:!0,configurable:!0,set:(J)=>X[$]=()=>J})};var hj=(j,X)=>()=>(j&&(X=j(j=0)),X);var Ej=200,u2=50,dj=15,cj=2,lj=50,O2=16000000;var Y4=(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}},Z4=(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,G=$-1;while(Z<G){let B=Z+G+1>>>1;if(J[B]<=q)Z=B;else G=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)=>Q(q),getTotalHeight:()=>J[$]??0,getTotal:()=>$,rebuild:(q)=>K(q),isVariable:()=>!0}},sj=(j,X)=>{if(typeof j==="number")return Y4(j,X);return Z4(j,X)},Aj=(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)},r2=(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)},Fj=(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 M2=(j,X)=>{let $=X.getTotalHeight(),J=$>O2,K=J?O2:$,Q=$>0?K/$:1;return{isCompressed:J,actualHeight:$,virtualHeight:K,ratio:Q}},n2=(j,X,$,J,K,Q)=>{if(J===0||X===0)return Q.start=0,Q.end=-1,Q;if(!K.isCompressed){let W=$.indexAtOffset(j),U=$.indexAtOffset(j+X);if(U<J-1)U++;return Q.start=Math.max(0,W),Q.end=Math.min(J-1,Math.max(0,U)),Q}let{virtualHeight:q}=K,G=j/q*J,B=Math.floor(G),D=Aj($,Math.max(0,B),X,J),L=Math.ceil(G)+D,y=q-X-j;if(y<=X&&y>=-1){let W=r2($,X,J),U=Math.max(0,J-W),M=Math.max(0,Math.min(1,1-y/X));B=Math.floor(B+(U-B)*M),L=y<=1?J-1:Math.min(J-1,B+D)}return Q.start=Math.max(0,B),Q.end=Math.min(J-1,Math.max(0,L)),Q},aj=(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},R2=(j,X,$,J,K,Q,q)=>{if(!Q.isCompressed||J===0)return $.getOffset(j);let{virtualHeight:Z}=Q,G=Z-K,B=G-X;if(B<=K&&B>=-1){if(X>=G-1){let V=$.getTotalHeight()-$.getOffset(j);return K-V}let y=r2($,K,J),W=Math.max(0,J-y),M=X/Z*J,E=Math.max(0,Math.min(1,1-B/K)),F=$.getOffset(j)-$.getOffset(W),z=$.getOffset(j)-Fj($,M,J);return z+(F-z)*E}let D=X/Z,L=$.getTotalHeight(),O=D*L;return $.getOffset(j)-O},o2=(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 G=K.virtualHeight-$;return Math.max(0,Math.min(q,G))},rj=(j,X,$,J)=>{if($===0)return 0;if(J.isCompressed){let K=j/J.virtualHeight;return Math.floor(K*$)}return X.indexAtOffset(j)},nj=(j,X)=>{if(typeof X==="number")return j*X>O2;return X.getTotalHeight()>O2},oj=(j)=>{if(j<=0)return 0;return Math.floor(O2/j)},ij=(j,X)=>{let $=M2(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 i2=()=>{};var P2=(j)=>{return j!==null&&typeof j==="object"&&j.__groupHeader===!0};var _J={};sJ(_J,{createGridRenderer:()=>m2});var V4=(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}}},m2=(j,X,$,J,K,Q,q,Z)=>{let G=V4(),B=new Map,D=Q,L=!1,O=null,y=0,W="",U=(b)=>{if(O&&y===b)return O;return O=M2(b,$),y=b,O},M={selected:!1,focused:!1},E=(b,C)=>{return M.selected=b,M.focused=C,M},F=`${K}-item ${K}-grid-item`,z=`${K}-item--selected`,V=`${K}-item--focused`,H=(b,C)=>{if(typeof C==="string")b.innerHTML=C;else b.replaceChildren(C)},N=(b,C,h)=>{b.classList.toggle(z,C),b.classList.toggle(V,h)},w=(b,C)=>{let h=J.getRow(b);if(C){let m=C.totalItems,s=U(m);if(s.isCompressed)return R2(h,C.scrollTop,$,m,C.containerHeight,s,C.rangeStart)}return $.getOffset(h)},_=(b,C,h)=>{let m=b.dataset.id?.startsWith("__group_header"),s=m?0:J.getCol(C),r=m?0:J.getColumnOffset(s,D),q2;if(L){let B2=J.getRow(C),T=0,d=new Set;for(let x=0;x<C;x++){let J2=J.getRow(x);if(J2<B2&&!d.has(J2)){let i=$.getHeight(x);T+=i,d.add(J2)}}q2=T}else q2=w(C,h);b.style.transform=`translate(${Math.round(r)}px, ${Math.round(q2)}px)`},R=(b,C)=>{let h=b.dataset.id?.startsWith("__group_header"),m=h?D:J.getColumnWidth(D),s;if(L||h)s=$.getHeight(C)-J.gap;else{let r=J.getRow(C);s=$.getHeight(r)-J.gap}b.style.width=`${m}px`,b.style.height=`${s}px`},g=(b,C,h,m,s)=>{let r=G.acquire(),q2=E(h,m);if(r.className=F,r.dataset.index=String(b),r.dataset.id=String(C.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)W=String(q()),r.setAttribute("aria-setsize",W),r.setAttribute("aria-posinset",String(b+1));R(r,b);let B2=X(C,b,q2);return H(r,B2),N(r,h,m),_(r,b,s),r},o=(b,C,h,m,s)=>{if(C.start===0&&b.length>0)L=P2(b[0]);for(let[T,d]of B)if(T<C.start||T>C.end)d.element.remove(),G.release(d.element),B.delete(T);let r=!1;if(q){let T=String(q());r=T!==W,W=T}let q2=document.createDocumentFragment(),B2=[];for(let T=C.start;T<=C.end;T++){let d=T-C.start,x=b[d];if(!x){console.warn(`⚠️ RENDER: Missing item at index ${T} (range: ${C.start}-${C.end}, items.length: ${b.length})`);continue}let J2=h.has(x.id),i=T===m,Q2=B.get(T);if(Q2){let v=Q2.element.dataset.id,f=String(x.id);if(v!==f){let $2=E(J2,i),l=X(x,T,$2);H(Q2.element,l),Q2.element.dataset.id=f,Q2.element.dataset.row=String(J.getRow(T)),Q2.element.dataset.col=String(J.getCol(T)),R(Q2.element,T)}if(N(Q2.element,J2,i),Q2.element.ariaSelected=String(J2),_(Q2.element,T,s),r)Q2.element.setAttribute("aria-setsize",W)}else{let v=g(T,x,J2,i,s);q2.appendChild(v),B2.push({index:T,element:v})}}if(B2.length>0){j.appendChild(q2);for(let{index:T,element:d}of B2)B.set(T,{index:T,element:d})}},c=(b)=>{for(let[C,h]of B)_(h.element,C,b)},e=(b,C,h,m)=>{let s=B.get(b);if(s){let r=E(h,m),q2=X(C,b,r);H(s.element,q2),N(s.element,h,m),s.element.dataset.id=String(C.id),s.element.ariaSelected=String(h),R(s.element,b)}},j2=(b,C,h)=>{let m=B.get(b);if(m)N(m.element,C,h)},k=(b)=>{return B.get(b)?.element},S=(b)=>{if(Math.abs(b-D)<1)return;D=b;for(let[C,h]of B)R(h.element,C),_(h.element,C)},p=()=>{for(let[,b]of B)b.element.remove(),G.release(b.element);B.clear()};return{render:o,updatePositions:c,updateItem:e,updateItemClasses:j2,getElement:k,updateContainerWidth:S,clear:p,destroy:()=>{p(),G.clear()}}};var Kj=hj(()=>{i2()});var aJ=0,H2=5,rJ=100,Mj=2,nJ=(j=0)=>{let X=Array(H2);for(let $=0;$<H2;$++)X[$]={position:0,time:0};return{velocity:0,lastPosition:j,lastTime:performance.now(),samples:X,sampleIndex:0,sampleCount:0}},oJ=(j,X)=>{let $=performance.now(),J=$-j.lastTime;if(J===0)return j;if(J>rJ){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)%H2,j.sampleCount=Math.min(j.sampleCount+1,H2),j.sampleCount>=Mj){let Q=(j.sampleIndex-j.sampleCount+H2)%H2,q=j.samples[Q],Z=X-q.position,G=$-q.time;j.velocity=G>0?Math.abs(Z)/G:0}return j.lastPosition=X,j.lastTime=$,j},gj=(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 G=q+Z+1>>>1;if(J[G]<=Q)q=G;else Z=G-1}return q},getTotalHeight:()=>J[$]??0,getTotal:()=>$,rebuild:(Q)=>K(Q),isVariable:()=>!0}},iJ=()=>{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(G){console.error(`[vlist] Error in "${Q}" handler:`,G)}})},clear:()=>{for(let Q in j)delete j[Q]}}},tJ=(j)=>{if(typeof j==="string"){let X=document.querySelector(j);if(!X)throw Error(`[vlist/builder] Container not found: ${j}`);return X}return j},eJ=(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}},j4=(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))},$4=(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)},Q4=(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),G=Math.max(0,X.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,G))},X4=(j)=>j<0.5?2*j*j:-1+(4-2*j)*j,q4=(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}},mj=(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,K4(j,K,X,J)}};return q};function K4(j,X,$,J){let{item:K,items:Q,overscan:q=3,classPrefix:Z="vlist",ariaLabel:G,reverse:B=!1,scroll:D}=j,L=D?.wheel??!0,O=D?.wrap??!1,y=B,W=`${Z}-${aJ++}`,U=J,M=$?typeof K.height==="number"?K.height:void 0:typeof K.width==="number"?K.width:void 0,E=K.template,F={overscan:q,classPrefix:Z,reverse:y,wrap:O,horizontal:$,ariaIdPrefix:W},z=Array.from(X.values()).sort((Y,A)=>(Y.priority??50)-(A.priority??50)),V=new Set(z.map((Y)=>Y.name));for(let Y of z)if(Y.conflicts){for(let A of Y.conflicts)if(V.has(A))throw Error(`[vlist/builder] ${Y.name} and ${A} 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 H=tJ(j.container),N=eJ(H,Z,G,$),w=iJ(),_=Q?[...Q]:[],R=gj(U,_.length),g=j4(),o=N.viewport.clientHeight,c=N.viewport.clientWidth,e=!1,j2=!1,k=0,S=null,p=null,u=nJ(0),b={start:0,end:0},C={start:0,end:0},h={start:-1,end:-1},m={viewportState:{scrollTop:0,containerHeight:o,totalHeight:R.getTotalHeight(),actualHeight:R.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},s=new Map,r={selected:!1,focused:!1},q2=`${Z}-item`,B2="",T=new Map,d=()=>{T.clear();for(let Y=0;Y<_.length;Y++){let A=_[Y];if(A)T.set(A.id,Y)}};d();let x=null,J2=()=>x?x.getTotal():_.length,i=[],Q2=[],v=[],f=[],n=[],$2=[],l=new Map,X2=()=>{return $?N.viewport.scrollLeft:N.viewport.scrollTop},K2=(Y)=>{if($)N.viewport.scrollLeft=Y;else N.viewport.scrollTop=Y},A2=(Y=2)=>{let A=R.getTotalHeight();return k+o>=A-Y},U2=!1,Y2,_2,D2=(Y,A,P,I,t)=>{J4(Y,A,P,I,t)},G2=(Y,A,P,I,t)=>{return Q4(Y,A,P,I,t)},N2=(Y,A)=>{if(typeof A==="string")Y.innerHTML=A;else Y.replaceChildren(A)},F2=(Y,A)=>{let P=Math.round(R.getOffset(A));if($)Y.style.transform=`translateX(${P}px)`;else Y.style.transform=`translateY(${P}px)`},OJ=(Y,A)=>{let P=g.acquire();if(P.className=q2,$){if(P.style.width=`${R.getHeight(Y)}px`,M!=null)P.style.height=`${M}px`}else P.style.height=`${R.getHeight(Y)}px`;if(P.dataset.index=String(Y),P.dataset.id=String(A.id),P.ariaSelected="false",P.id=`${W}-item-${Y}`,B2=String(J2()),P.setAttribute("aria-setsize",B2),P.setAttribute("aria-posinset",String(Y+1)),String(A.id).startsWith("__placeholder_"))P.classList.add(`${Z}-item--placeholder`);return N2(P,E(A,Y,r)),F2(P,Y),P},v2=()=>{let Y=`${R.getTotalHeight()}px`;if($)N.content.style.width=Y;else N.content.style.height=Y},Dj=new Set,Wj=-1,zJ=()=>{if(e)return;let Y=J2();if(D2(k,o,R,Y,b),$4(b,q,Y,C),C.start===h.start&&C.end===h.end){if(U2)for(let[a,W2]of s)F2(W2,a);return}let A=String(Y),P=A!==B2;B2=A;for(let[a,W2]of s)if(a<C.start||a>C.end)W2.remove(),g.release(W2),s.delete(a);let I=document.createDocumentFragment(),t=[];for(let a=C.start;a<=C.end;a++){let W2=x?x.getItem(a):_[a];if(!W2)continue;let Z2=s.get(a);if(Z2){let E2=Z2.dataset.id,I2=String(W2.id);if(E2!==I2){let gJ=E2?.startsWith("__placeholder_"),uj=I2.startsWith("__placeholder_");if(N2(Z2,E(W2,a,r)),Z2.dataset.id=I2,$)Z2.style.width=`${R.getHeight(a)}px`;else Z2.style.height=`${R.getHeight(a)}px`;if(uj)Z2.classList.add(`${Z}-item--placeholder`);else Z2.classList.remove(`${Z}-item--placeholder`);if(gJ&&!uj)Z2.classList.add(`${Z}-item--replaced`),setTimeout(()=>{Z2.classList.remove(`${Z}-item--replaced`)},300)}F2(Z2,a);let a2=Dj.has(W2.id),hJ=a===Wj;if(Z2.classList.toggle(`${Z}-item--selected`,a2),Z2.classList.toggle(`${Z}-item--focused`,hJ),Z2.ariaSelected=a2?"true":"false",P)Z2.setAttribute("aria-setsize",B2)}else{let E2=OJ(a,W2),I2=Dj.has(W2.id),a2=a===Wj;if(I2)E2.classList.add(`${Z}-item--selected`),E2.ariaSelected="true";if(a2)E2.classList.add(`${Z}-item--focused`);I.appendChild(E2),t.push({index:a,element:E2})}}if(t.length>0){N.items.appendChild(I);for(let{index:a,element:W2}of t)s.set(a,W2)}h.start=C.start,h.end=C.end,m.lastRenderRange.start=C.start,m.lastRenderRange.end=C.end,m.viewportState.scrollTop=k,m.viewportState.visibleRange.start=b.start,m.viewportState.visibleRange.end=b.end,m.viewportState.renderRange.start=C.start,m.viewportState.renderRange.end=C.end,w.emit("range:change",{range:{start:C.start,end:C.end}})},bJ=()=>{h.start=-1,h.end=-1,Y2()};Y2=zJ,_2=bJ;let f2=()=>{if(e)return;let Y=X2(),A=Y>=k?"down":"up";if(u=oJ(u,Y),!N.root.classList.contains(`${Z}--scrolling`))N.root.classList.add(`${Z}--scrolling`);k=Y,Y2(),w.emit("scroll",{scrollTop:Y,direction:A}),w.emit("velocity:change",{velocity:u.velocity,reliable:u.sampleCount>=Mj});for(let P=0;P<i.length;P++)i[P](Y,A);if(p)clearTimeout(p);p=setTimeout(()=>{N.root.classList.remove(`${Z}--scrolling`),u.velocity=0,u.sampleCount=0,w.emit("velocity:change",{velocity:0,reliable:!1})},D?.idleTimeout??150)},l2=null,y2=N.viewport;if(y2.addEventListener("scroll",f2,{passive:!0}),$&&L)l2=(Y)=>{if(Y.deltaX)return;Y.preventDefault(),N.viewport.scrollLeft+=Y.deltaY},N.viewport.addEventListener("wheel",l2);let Sj=(Y)=>{let P=Y.target.closest("[data-index]");if(P){let I=parseInt(P.dataset.index??"-1",10);if(I>=0){let t=x?.getItem(I)??_[I];if(t){if(t.__groupHeader)return;w.emit("item:click",{item:t,index:I,event:Y})}}}for(let I=0;I<Q2.length;I++)Q2[I](Y)},PJ=(Y)=>{let P=Y.target.closest("[data-index]");if(P){let I=parseInt(P.dataset.index??"-1",10);if(I>=0){let t=x?.getItem(I)??_[I];if(t){if(t.__groupHeader)return;w.emit("item:dblclick",{item:t,index:I,event:Y})}}}},vj=(Y)=>{for(let A=0;A<v.length;A++)v[A](Y)};N.items.addEventListener("click",Sj),N.items.addEventListener("dblclick",PJ),N.root.addEventListener("keydown",vj);let Nj=!0,yJ=()=>c,HJ=()=>o,Vj=new ResizeObserver((Y)=>{if(e)return;for(let A of Y){let P=A.contentRect.height,I=A.contentRect.width,t=$?I:P;if(c=I,Math.abs(t-o)>1){if(o=t,m.viewportState.containerHeight=t,j2)v2(),Y2(),w.emit("resize",{height:P,width:I})}if(j2)for(let a=0;a<f.length;a++)f[a](I,P)}});if(Nj)Vj.observe(N.viewport);let V2={get dom(){return N},get heightCache(){return R},get emitter(){return w},get config(){return F},get rawConfig(){return j},get renderer(){return{render:(Y,A,P,I,t)=>{Dj=P,Wj=I,_2()},updateItemClasses:(Y,A,P)=>{let I=s.get(Y);if(!I)return;I.classList.toggle(`${Z}-item--selected`,A),I.classList.toggle(`${Z}-item--focused`,P),I.ariaSelected=A?"true":"false"},updatePositions:()=>{},updateItem:()=>{},getElement:(Y)=>s.get(Y)??null,clear:()=>{},destroy:()=>{}}},set renderer(Y){},get dataManager(){return x},set dataManager(Y){x=Y},get scrollController(){return _j},set scrollController(Y){_j=Y},state:m,getContainerWidth(){return c},afterScroll:i,clickHandlers:Q2,keydownHandlers:v,resizeHandlers:f,contentSizeHandlers:n,destroyHandlers:$2,methods:l,replaceTemplate(Y){E=Y},replaceRenderer(Y){},replaceDataManager(Y){x=Y},replaceScrollController(Y){_j=Y},getItemsForRange(Y){let A=[];for(let P=Y.start;P<=Y.end;P++){let I=x?x.getItem(P):_[P];if(I)A.push(I)}return A},getAllLoadedItems(){if(x){let Y=x.getTotal(),A=[];for(let P=0;P<Y;P++){let I=x.getItem(P);if(I)A.push(I)}return A}return[..._]},getVirtualTotal(){return J2()},getCachedCompression(){return{isCompressed:!1,actualHeight:R.getTotalHeight(),virtualHeight:R.getTotalHeight(),ratio:1}},getCompressionContext(){return{scrollTop:k,totalItems:J2(),containerHeight:o,rangeStart:C.start}},renderIfNeeded(){Y2()},forceRender(){_2()},getRenderFns(){return{renderIfNeeded:Y2,forceRender:_2}},setRenderFns(Y,A){Y2=Y,_2=A},setVirtualTotalFn(Y){J2=Y},rebuildHeightCache(Y){R.rebuild(Y??J2())},setHeightConfig(Y){R=gj(Y,J2())},updateContentSize(Y){let A=`${Y}px`;if($)N.content.style.width=A;else N.content.style.height=A},updateCompressionMode(){},setVisibleRangeFn(Y){D2=Y},setScrollToPosFn(Y){G2=Y},setPositionElementFn(Y){F2=Y},setScrollFns(Y,A){X2=Y,K2=(P)=>{A(P),f2()}},setScrollTarget(Y){y2.removeEventListener("scroll",f2),y2=Y,y2.addEventListener("scroll",f2,{passive:!0})},getScrollTarget(){return y2},setContainerDimensions(Y){yJ=Y.width,HJ=Y.height,c=Y.width(),o=Y.height(),m.viewportState.containerHeight=o},disableViewportResize(){if(Nj)Nj=!1,Vj.unobserve(N.viewport)}};x={getState:()=>({total:_.length,cached:_.length,isLoading:!1,pendingRanges:[],error:void 0,hasMore:!1,cursor:void 0}),getTotal:()=>_.length,getCached:()=>_.length,getIsLoading:()=>!1,getHasMore:()=>!1,getStorage:()=>null,getPlaceholders:()=>null,getItem:(Y)=>_[Y],getItemById:(Y)=>{let A=T.get(Y);return A!==void 0?_[A]:void 0},getIndexById:(Y)=>T.get(Y)??-1,isItemLoaded:(Y)=>Y>=0&&Y<_.length&&_[Y]!==void 0,getItemsInRange:(Y,A)=>{let P=[],I=Math.max(0,Y),t=Math.min(A,_.length-1);for(let a=I;a<=t;a++)P.push(_[a]);return P},setTotal:(Y)=>{},setItems:(Y,A=0,P)=>{if(A===0&&(P!==void 0||_.length===0))_=[...Y];else{let I=A+Y.length;if(_.length<I)_.length=I;for(let t=0;t<Y.length;t++)_[A+t]=Y[t]}if(d(),j2){R.rebuild(J2()),v2(),V2.updateCompressionMode();for(let I=0;I<n.length;I++)n[I]();_2()}},updateItem:(Y,A)=>{let P=T.get(Y);if(P===void 0)return!1;let I=_[P];if(!I)return!1;if(_[P]={...I,...A},A.id!==void 0&&A.id!==Y)T.delete(Y),T.set(A.id,P);let t=s.get(P);if(t)N2(t,E(_[P],P,r)),t.dataset.id=String(_[P].id);return!0},removeItem:(Y)=>{let A=T.get(Y);if(A===void 0)return!1;if(_.splice(A,1),d(),j2){R.rebuild(J2()),v2(),V2.updateCompressionMode();for(let P=0;P<n.length;P++)n[P]();_2()}return!0},loadRange:async()=>{},ensureRange:async()=>{},loadInitial:async()=>{},loadMore:async()=>!1,reload:async()=>{},evictDistant:()=>{},clear:()=>{_=[],T.clear()},reset:()=>{if(_=[],T.clear(),j2)R.rebuild(0),v2(),_2()}};let _j={getScrollTop:()=>X2(),scrollTo:(Y)=>{K2(Y),k=Y,Y2()},scrollBy:(Y)=>{let A=X2()+Y;K2(A),k=A,Y2()},isAtTop:()=>k<=2,isAtBottom:(Y=2)=>A2(Y),getScrollPercentage:()=>{let Y=R.getTotalHeight(),A=Math.max(0,Y-o);return A>0?k/A:0},getVelocity:()=>u.velocity,isTracking:()=>u.sampleCount>=Mj,isScrolling:()=>N.root.classList.contains(`${Z}--scrolling`),updateConfig:()=>{},enableCompression:()=>{U2=!0},disableCompression:()=>{U2=!1},isCompressed:()=>U2,isWindowMode:()=>!1,updateContainerHeight:(Y)=>{o=Y},destroy:()=>{}},fj=new Map;for(let Y of z)if(Y.methods)for(let A of Y.methods){let P=fj.get(A);if(P)throw Error(`[vlist/builder] Method "${A}" is registered by both "${P}" and "${Y.name}"`);fj.set(A,Y.name)}for(let Y of z)Y.setup(V2);if(j2=!0,V2.state.isInitialized=!0,v2(),Y2(),y&&_.length>0){let Y=G2(_.length-1,R,o,_.length,"end");K2(Y),k=Y,Y2()}let RJ=(Y)=>{V2.dataManager.setItems(Y,0,Y.length)},kJ=y?(Y)=>{let A=A2(2),P=_.length;if(V2.dataManager.setItems(Y,P),A&&_.length>0){let I=G2(_.length-1,R,o,_.length,"end");K2(I),k=I,Y2()}}:(Y)=>{let A=_.length;V2.dataManager.setItems(Y,A)},TJ=y?(Y)=>{let A=X2(),P=R.getTotalHeight(),I=[..._];V2.dataManager.clear(),V2.dataManager.setItems([...Y,...I],0);let a=R.getTotalHeight()-P;if(a>0)K2(A+a),k=A+a}:(Y)=>{let A=[..._];V2.dataManager.clear(),V2.dataManager.setItems([...Y,...A],0)},CJ=(Y,A)=>{V2.dataManager.updateItem(Y,A)},wJ=(Y)=>{V2.dataManager.removeItem(Y)},SJ=async()=>{if(V2.dataManager.reload)await V2.dataManager.reload()},s2=()=>{if(S!==null)cancelAnimationFrame(S),S=null},vJ=(Y,A,P)=>{if(s2(),Math.abs(A-Y)<1){K2(A),k=A,Y2();return}let I=performance.now(),t=(a)=>{let W2=a-I,Z2=Math.min(W2/P,1),E2=Y+(A-Y)*X4(Z2);if(K2(E2),k=E2,Y2(),Z2<1)S=requestAnimationFrame(t);else S=null};S=requestAnimationFrame(t)},Ij=(Y,A)=>{let{align:P,behavior:I,duration:t}=q4(A),a=J2(),W2=Y;if(O&&a>0)W2=(W2%a+a)%a;let Z2=G2(W2,R,o,a,P);if(I==="smooth")vJ(X2(),Z2,t);else s2(),K2(Z2)},fJ=(Y,A)=>{let P=T.get(Y)??V2.dataManager.getIndexById(Y);if(P>=0)Ij(P,A)},IJ=()=>X2(),pJ=(Y,A)=>{return w.on(Y,A)},uJ=(Y,A)=>{w.off(Y,A)},xJ=()=>{if(e)return;if(e=!0,V2.state.isDestroyed=!0,N.items.removeEventListener("click",Sj),N.root.removeEventListener("keydown",vj),y2.removeEventListener("scroll",f2),Vj.disconnect(),l2)N.viewport.removeEventListener("wheel",l2);if(p)clearTimeout(p);for(let Y=0;Y<$2.length;Y++)$2[Y]();for(let Y of z)if(Y.destroy)Y.destroy();s2();for(let[,Y]of s)Y.remove(),g.release(Y);s.clear(),g.clear(),w.clear(),N.root.remove()},pj={get element(){return N.root},get items(){if(l.has("_getItems"))return l.get("_getItems")();return _},get total(){if(l.has("_getTotal"))return l.get("_getTotal")();return J2()},setItems:l.has("setItems")?l.get("setItems"):RJ,appendItems:l.has("appendItems")?l.get("appendItems"):kJ,prependItems:l.has("prependItems")?l.get("prependItems"):TJ,updateItem:l.has("updateItem")?l.get("updateItem"):CJ,removeItem:l.has("removeItem")?l.get("removeItem"):wJ,reload:l.has("reload")?l.get("reload"):SJ,scrollToIndex:l.has("scrollToIndex")?l.get("scrollToIndex"):Ij,scrollToItem:l.has("scrollToItem")?l.get("scrollToItem"):fJ,cancelScroll:l.has("cancelScroll")?l.get("cancelScroll"):s2,getScrollPosition:l.has("getScrollPosition")?l.get("getScrollPosition"):IJ,on:pJ,off:uJ,destroy:xJ};for(let[Y,A]of l){if(Y==="setItems"||Y==="appendItems"||Y==="prependItems"||Y==="updateItem"||Y==="removeItem"||Y==="reload"||Y==="scrollToIndex"||Y==="scrollToItem"||Y==="cancelScroll"||Y==="getScrollPosition")continue;pj[Y]=A}return pj}i2();var k2=(j,X,$={},J="vlist",K=!1)=>{let{autoHide:Q=!0,autoHideDelay:q=1000,minThumbSize:Z=30,showOnHover:G=!0,hoverZoneWidth:B=16,showOnViewportEnter:D=!0}=$,L=0,O=0,y=0,W=0,U=!1,M=!1,E=0,F=0,z=0,V=null,H=!1,N=null,w=null,_=K?"width":"height",R=K?"translateX":"translateY",g=K?(i)=>i.clientX:(i)=>i.clientY,o=K?"left":"top",c=document.createElement("div"),e=document.createElement("div"),j2=G?document.createElement("div"):null,k=()=>{if(c.className=`${J}-scrollbar`,e.className=`${J}-scrollbar-thumb`,K)c.classList.add(`${J}-scrollbar--horizontal`);if(c.appendChild(e),j.appendChild(c),j2){if(j2.className=`${J}-scrollbar-hover`,K)j2.classList.add(`${J}-scrollbar-hover--horizontal`),j2.style.height=`${B}px`;else j2.style.width=`${B}px`;j.appendChild(j2)}},S=()=>{if(V)clearTimeout(V),V=null},p=()=>{if(!Q)return;S(),V=setTimeout(b,q)},u=()=>{if(L<=O)return;if(S(),!H)c.classList.add(`${J}-scrollbar--visible`),H=!0;if(Q&&!U&&!M)p()},b=()=>{if(U||M)return;c.classList.remove(`${J}-scrollbar--visible`),H=!1},C=(i,Q2)=>{L=i,O=Q2;let v=L>O;if(c.style.display=v?"":"none",!v){b();return}let f=O/L;y=Math.max(Z,f*O),e.style[_]=`${y}px`,W=O-y,h(z)},h=(i)=>{if(z=i,L<=O||W<=0)return;let Q2=L-O,f=Math.min(1,Math.max(0,i/Q2))*W;e.style.transform=`${R}(${f}px)`},m=(i)=>{if(i.target===e)return;let Q2=c.getBoundingClientRect(),n=g(i)-Q2[o]-y/2,l=Math.max(0,Math.min(n,W))/W,X2=L-O,K2=l*X2;X(K2),u()},s=(i)=>{i.preventDefault(),i.stopPropagation(),U=!0,E=g(i),F=z,S(),c.classList.add(`${J}-scrollbar--dragging`),document.addEventListener("mousemove",r),document.addEventListener("mouseup",q2)},r=(i)=>{if(!U)return;let Q2=g(i)-E,v=W>0?Q2/W:0,f=L-O,n=v*f,$2=Math.max(0,Math.min(F+n,f)),X2=$2/f*W;if(e.style.transform=`${R}(${X2}px)`,w=$2,N===null)N=requestAnimationFrame(()=>{if(w!==null)X(w);N=null})},q2=()=>{if(U=!1,N!==null)cancelAnimationFrame(N),N=null;if(w!==null)X(w),w=null;if(c.classList.remove(`${J}-scrollbar--dragging`),Q&&!M)p();document.removeEventListener("mousemove",r),document.removeEventListener("mouseup",q2)},B2=()=>{if(D)u()},T=()=>{if(!U){if(M=!1,Q)p()}},d=()=>{M=!0,S(),u()},x=()=>{if(M=!1,!U&&Q)p()},J2=()=>{if(S(),N!==null)cancelAnimationFrame(N),N=null;if(c.removeEventListener("click",m),c.removeEventListener("mouseenter",d),c.removeEventListener("mouseleave",x),e.removeEventListener("mousedown",s),j.removeEventListener("mouseenter",B2),j.removeEventListener("mouseleave",T),document.removeEventListener("mousemove",r),document.removeEventListener("mouseup",q2),j2){if(j2.removeEventListener("mouseenter",d),j2.removeEventListener("mouseleave",x),j2.parentNode)j2.parentNode.removeChild(j2)}if(c.parentNode)c.parentNode.removeChild(c)};if(k(),c.addEventListener("click",m),c.addEventListener("mouseenter",d),c.addEventListener("mouseleave",x),e.addEventListener("mousedown",s),j.addEventListener("mouseenter",B2),j.addEventListener("mouseleave",T),j2)j2.addEventListener("mouseenter",d),j2.addEventListener("mouseleave",x);return{show:u,hide:b,updateBounds:C,updatePosition:h,isVisible:()=>H,destroy:J2}};var tj=(j)=>{let X=null;return{name:"withScrollbar",priority:30,setup($){let{dom:J,config:K}=$,{classPrefix:Q,horizontal:q}=K;if(X=k2(J.viewport,(B)=>$.scrollController.scrollTo(B),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 G=X;$.afterScroll.push((B,D)=>{G.updatePosition(B),G.show()}),$.resizeHandlers.push((B,D)=>{if(G){let L=$.getCachedCompression();G.updateBounds(L.virtualHeight,$.state.viewportState.containerHeight)}}),$.contentSizeHandlers.push(()=>{if(G){let B=$.getCachedCompression();G.updateBounds(B.virtualHeight,$.state.viewportState.containerHeight)}}),$.destroyHandlers.push(()=>{if(G)G.destroy()})},destroy(){if(X)X.destroy(),X=null}}};var ej=(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}},t2=(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,G=$-q.time;j.velocity=G>0?Z/G:0}return j.lastPosition=X,j.lastTime=$,j},B4=(j)=>j.sampleCount>=3,jJ=(j,X={})=>{let{wheel:$=!0,sensitivity:J=1,smoothing:K=!1,idleTimeout:Q=150,onScroll:q,onIdle:Z,scrollElement:G,horizontal:B=!1}=X,D=!!G,L=0,O=0,y=D?B?window.innerWidth:window.innerHeight:B?j.clientWidth:j.clientHeight,W=X.compressed??!1,U=X.compression,M=ej(),E=!1,F=null,V=e2(()=>{let T=B?j.scrollLeft:j.scrollTop,d=T>=L?"down":"up";if(M=t2(M,T),L=T,q)q({scrollTop:L,direction:d,velocity:M.velocity});g()}),N=e2(()=>{let T=j.getBoundingClientRect(),d=B?Math.max(0,-T.left):Math.max(0,-T.top),x=d>=L?"down":"up";if(M=t2(M,d),L=d,!E)E=!0;if(q)q({scrollTop:L,direction:x,velocity:M.velocity});g()}),w=(T)=>{T.preventDefault()},_=(T)=>{if(T.deltaX)return;T.preventDefault(),j.scrollLeft+=T.deltaY},R=(T)=>{if(!W)return;T.preventDefault();let d=(B?T.deltaX||T.deltaY:T.deltaY)*J,x=L+d;if(K)x=L+d*0.3;if(x=Math.max(0,Math.min(x,O)),x!==L){let i=x>=L?"down":"up";if(M=t2(M,x),L=x,!E)E=!0;if(q)q({scrollTop:L,direction:i,velocity:M.velocity});g()}},g=()=>{if(F)clearTimeout(F);F=setTimeout(()=>{if(E=!1,M=ej(L),Z)Z()},Q)},o=(T)=>{if(W)return;if(W=!0,U=T,O=T.virtualHeight-y,D)return;if(V.cancel(),j.removeEventListener("scroll",V),!$)j.removeEventListener("wheel",w);else if(B)j.removeEventListener("wheel",_);if(B)j.style.overflowX="hidden";else j.style.overflow="hidden";if($)j.addEventListener("wheel",R,{passive:!1});let d=B?j.scrollLeft:j.scrollTop;if(d>0){let x=B?U?.actualHeight??j.scrollWidth:U?.actualHeight??j.scrollHeight;L=d/x*O}if(B)j.scrollLeft=0;else j.scrollTop=0},c=()=>{if(!W)return;if(W=!1,D){U=void 0;return}if(j.removeEventListener("wheel",R),B)j.style.overflowX="auto";else j.style.overflow="auto";if(j.addEventListener("scroll",V,{passive:!0}),!$)j.addEventListener("wheel",w,{passive:!1});else if(B)j.addEventListener("wheel",_,{passive:!1});if(U&&L>0){let d=L/O*(U.actualHeight-y);if(B)j.scrollLeft=d;else j.scrollTop=d}U=void 0},e=()=>{if(D||W)return L;return B?j.scrollLeft:j.scrollTop},j2=(T,d=!1)=>{let x=Math.max(0,Math.min(T,O||1/0));if(D){let J2=j.getBoundingClientRect();if(B){let i=J2.left+window.scrollX;window.scrollTo({left:i+x,behavior:d?"smooth":"auto"})}else{let i=J2.top+window.scrollY;window.scrollTo({top:i+x,behavior:d?"smooth":"auto"})}}else if(W){if(x===L)return;let i=x>=L?"down":"up";if(M=t2(M,x),L=x,!E)E=!0;if(q)q({scrollTop:L,direction:i,velocity:M.velocity});g()}else if(B)j.scrollTo({left:x,behavior:d?"smooth":"auto"});else j.scrollTo({top:x,behavior:d?"smooth":"auto"})},k=(T)=>{j2(e()+T)},S=()=>{return e()<=0},p=(T=0)=>{let d=e(),x=D||W?O:B?j.scrollWidth-j.clientWidth:j.scrollHeight-j.clientHeight;return d>=x-T},u=()=>{let T=e(),d=D||W?O:B?j.scrollWidth-j.clientWidth:j.scrollHeight-j.clientHeight;if(d<=0)return 0;return Math.min(1,Math.max(0,T/d))},b=(T)=>{if(T.compression)U=T.compression,O=U.virtualHeight-y},C=()=>W,h=()=>Math.abs(M.velocity),m=()=>B4(M),s=()=>E,r=()=>D,q2=(T)=>{if(y=T,U)O=U.virtualHeight-y},B2=()=>{if(F)clearTimeout(F);if(D)N.cancel(),window.removeEventListener("scroll",N);else V.cancel(),j.removeEventListener("scroll",V),j.removeEventListener("wheel",R),j.removeEventListener("wheel",w),j.removeEventListener("wheel",_)};if(D){if(W&&U)O=U.virtualHeight-y;window.addEventListener("scroll",N,{passive:!0})}else if(W&&U){if(O=U.virtualHeight-y,B)j.style.overflowX="hidden";else j.style.overflow="hidden";if($)j.addEventListener("wheel",R,{passive:!1})}else{if(B)j.style.overflowX="auto",j.style.overflowY="hidden";else j.style.overflow="auto";if(j.addEventListener("scroll",V,{passive:!0}),!$)j.addEventListener("wheel",w,{passive:!1});else if(B)j.addEventListener("wheel",_,{passive:!1})}return{getScrollTop:e,scrollTo:j2,scrollBy:k,isAtTop:S,isAtBottom:p,getScrollPercentage:u,getVelocity:h,isTracking:m,isScrolling:s,updateConfig:b,enableCompression:o,disableCompression:c,isCompressed:C,isWindowMode:r,updateContainerHeight:q2,destroy:B2}},e2=(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 U4=0.65,D4=0.5,JJ=()=>{let j=null,X=0,$=!1,J=0,K=null;return{name:"withScale",priority:20,setup(Q){let{dom:q,config:Z}=Q,{classPrefix:G,horizontal:B}=Z,D=()=>{let W=Q.getVirtualTotal(),U=M2(W,Q.heightCache);if(U.isCompressed&&!$){$=!0,Q.scrollController.enableCompression(U),Q.updateContentSize(U.virtualHeight),Q.setScrollFns(()=>X,(V)=>{if(X=V,J=V,K!==null)cancelAnimationFrame(K),K=null});let M=()=>{let V=J-X;if(Math.abs(V)<D4)X=J,K=null;else X+=V*U4,K=requestAnimationFrame(M);Q.scrollController.scrollTo(X)},E=q.viewport,F=(V)=>{V.preventDefault();let N=Q.getCachedCompression().virtualHeight-Q.state.viewportState.containerHeight;if(J=Math.max(0,Math.min(J+V.deltaY,N)),K===null)K=requestAnimationFrame(M)};if(E.addEventListener("wheel",F,{passive:!1}),Q.destroyHandlers.push(()=>{if(E.removeEventListener("wheel",F),K!==null)cancelAnimationFrame(K),K=null}),!q.viewport.querySelector(`.${G}-scrollbar-track`)){if(j=k2(q.viewport,(H)=>Q.scrollController.scrollTo(H),{},G,B),!q.viewport.classList.contains(`${G}-viewport--custom-scrollbar`))q.viewport.classList.add(`${G}-viewport--custom-scrollbar`);j.updateBounds(U.virtualHeight,Q.state.viewportState.containerHeight);let V=j;Q.afterScroll.push((H,N)=>{if(V)V.updatePosition(H),V.show()}),Q.resizeHandlers.push((H,N)=>{if(V){let w=Q.getCachedCompression();V.updateBounds(w.virtualHeight,Q.state.viewportState.containerHeight)}})}}else if(!U.isCompressed&&$)$=!1,Q.scrollController.disableCompression(),Q.updateContentSize(U.actualHeight);else if(U.isCompressed)Q.scrollController.updateConfig({compression:U}),Q.updateContentSize(U.virtualHeight);if(j)j.updateBounds(U.virtualHeight,Q.state.viewportState.containerHeight);Q.state.cachedCompression={state:U,totalItems:W}};Q.updateCompressionMode=D;let L=Q.getCachedCompression.bind(Q);Q.getCachedCompression=()=>{if(Q.state.cachedCompression)return Q.state.cachedCompression.state;return L()},Q.setVisibleRangeFn((W,U,M,E,F)=>{O=null,y=null;let z=M2(E,M);n2(W,U,M,E,z,F)}),Q.setScrollToPosFn((W,U,M,E,F)=>{let z=M2(E,U);return o2(W,U,M,E,z,F)});let O=null,y=null;Q.setPositionElementFn((W,U)=>{let M=Q.getVirtualTotal(),E=M2(M,Q.heightCache);if(E.isCompressed){let F=Q.scrollController.getScrollTop();if(O===null||U<y)y=U,O=Math.round(R2(U,F,Q.heightCache,M,Q.state.viewportState.containerHeight,E));let z=O+Q.heightCache.getOffset(U)-Q.heightCache.getOffset(y),V=Q.config.horizontal;W.style.transform=V?`translateX(${z}px)`:`translateY(${z}px)`}else{let F=Math.round(Q.heightCache.getOffset(U)),z=Q.config.horizontal;W.style.transform=z?`translateX(${F}px)`:`translateY(${F}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,G=(k)=>{let S=Q.get(k);if(!S)S={items:Array(X),count:0,lastAccess:Date.now()},Q.set(k,S);else S.lastAccess=Date.now();return S},B=(k)=>{return Math.floor(k/X)},D=(k)=>{return k%X},L=()=>q,O=(k)=>{q=k},y=(k)=>{if(k<0||k>=q)return;let S=B(k),p=Q.get(S);if(!p)return;return p.items[D(k)]},W=(k)=>{if(k<0||k>=q)return!1;let S=B(k),p=Q.get(S);if(!p)return!1;return p.items[D(k)]!==void 0},U=(k,S)=>{let p=B(k),u=G(p),b=D(k),C=u.items[b]===void 0;if(u.items[b]=S,C)u.count++,Z++;if(k>=q)q=k+1},M=(k,S)=>{for(let p=0;p<S.length;p++){let u=S[p];if(u!==void 0)U(k+p,u)}},E=(k)=>{if(k<0||k>=q)return!1;let S=B(k),p=Q.get(S);if(!p)return!1;let u=D(k);if(p.items[u]===void 0)return!1;if(p.items[u]=void 0,p.count--,Z--,p.count===0)Q.delete(S);return!0},F=(k,S)=>{let p=[];for(let u=k;u<=S&&u<q;u++)p.push(y(u));return p},z=(k,S)=>{for(let p=k;p<=S&&p<q;p++)if(!W(p))return!1;return!0},V=()=>{let k=[],S=null,p=Array.from(Q.keys()).sort((u,b)=>u-b);for(let u of p){let b=Q.get(u);if(!b)continue;let C=u*X;for(let h=0;h<X;h++){let m=C+h;if(m>=q)break;if(b.items[h]!==void 0)if(S===null)S={start:m,end:m};else if(m===S.end+1)S.end=m;else k.push(S),S={start:m,end:m};else if(S!==null)k.push(S),S=null}}if(S!==null)k.push(S);return k},H=(k,S)=>{let p=[],u=null;for(let b=k;b<=S&&b<q;b++)if(!W(b))if(u===null)u={start:b,end:b};else u.end=b;else if(u!==null)p.push(u),u=null;if(u!==null)p.push(u);return p},N=(k)=>{return Q.has(k)},w=(k)=>{let S=Q.get(k);if(S)S.lastAccess=Date.now()},_=(k,S)=>{if(k>S||Q.size===0)return;let p=Date.now(),u=B(Math.max(0,k)),b=B(Math.min(q-1,S));for(let C=u;C<=b;C++){let h=Q.get(C);if(h)h.lastAccess=p}},R=(k,S)=>{if(Z<=$)return 0;let p=Math.max(0,k-J),u=Math.min(q-1,S+J),b=B(p),C=B(u),h=0,m=[];for(let[s,r]of Q)if(s<b||s>C)h+=r.count,m.push(s),Z-=r.count,Q.delete(s);if(h>0&&K)K(h,m);return h},g=()=>{if(Z<=$)return 0;let k=Array.from(Q.entries()).sort(([,u],[,b])=>u.lastAccess-b.lastAccess),S=0,p=[];for(let[u,b]of k){if(Z<=$)break;S+=b.count,Z-=b.count,p.push(u),Q.delete(u)}if(S>0&&K)K(S,p);return S},o=()=>{return{totalItems:q,cachedItems:Z,cachedChunks:Q.size,chunkSize:X,maxCachedItems:$,memoryEfficiency:q>0?1-Z/q:1}},c=()=>Z,e=()=>{Q.clear(),Z=0};return{chunkSize:X,maxCachedItems:$,getTotal:L,setTotal:O,get:y,has:W,set:U,setRange:M,delete:E,getRange:F,isRangeLoaded:z,getLoadedRanges:V,findUnloadedRanges:H,getChunkIndex:B,isChunkLoaded:N,touchChunk:w,touchChunksForRange:_,evictDistant:R,evictToLimit:g,getStats:o,getCachedCount:c,clear:e,reset:()=>{e(),q=0}}},Jj=(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 $},x2=(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=Jj(X),G=Q.start;for(let B of Z){if(B.end<G)continue;if(B.start>Q.end)break;if(B.start>G)q.push({start:G,end:Math.min(B.start-1,Q.end)});if(G=B.end+1,G>Q.end)break}if(G<=Q.end)q.push({start:G,end:Q.end});return q};var $j=(j={})=>{let{enabled:X=!0,maskCharacter:$="█",randomVariance:J=!0,maxSampleSize:K=20,customGenerator:Q}=j,q=null,Z=!1,G=0,B=(E)=>{if(!X||Z||E.length===0)return;let F=new Map,z=new Map,V=Math.min(E.length,K);for(let H=0;H<V;H++){let N=E[H];if(!N||typeof N!=="object")continue;for(let[w,_]of Object.entries(N)){if(w.startsWith("_")||w==="id")continue;if(!z.has(w))z.set(w,{lengths:[],types:new Set});let R=z.get(w),g=Array.isArray(_)?"array":typeof _;if(R.types.add(g),typeof _==="string")R.lengths.push(_.length);else if(_!==null&&_!==void 0)R.lengths.push(String(_).length)}}for(let[H,N]of z){if(N.lengths.length===0)continue;let w=Math.min(...N.lengths),_=Math.max(...N.lengths),R=Math.round(N.lengths.reduce((o,c)=>o+c,0)/N.lengths.length),g="string";if(N.types.has("number")&&N.types.size===1)g="number";else if(N.types.has("boolean")&&N.types.size===1)g="boolean";else if(N.types.has("array"))g="array";else if(N.types.has("object")&&!N.types.has("string"))g="object";F.set(H,{minLength:w,maxLength:_,avgLength:R,type:g})}q=F,Z=!0},D=()=>Z,L=(E)=>{let F=E.avgLength;if(J&&E.minLength!==E.maxLength){if(F=Math.floor(Math.random()*(E.maxLength-E.minLength+1)+E.minLength),Math.random()<0.3)F=Math.max(1,F+Math.floor(Math.random()*3)-1)}return $.repeat(Math.max(1,F))},O=(E)=>{if(Q)return{...Q(E),["_isPlaceholder"]:!0};let F={id:`__placeholder_${G++}`,["_isPlaceholder"]:!0,_index:E};if(!q||q.size===0)return F.label=$.repeat(12),F;for(let[z,V]of q)switch(V.type){case"string":F[z]=L(V);break;case"number":F[z]=0;break;case"boolean":F[z]=!1;break;case"array":F[z]=[];break;case"object":F[z]={};break;default:F[z]=L(V)}return F};return{analyzeStructure:B,hasAnalyzedStructure:D,generate:O,generateRange:(E,F)=>{let z=[];for(let V=E;V<=F;V++)z.push(O(V));return z},isPlaceholder:(E)=>{if(!E||typeof E!=="object")return!1;return E._isPlaceholder===!0},getPlaceholderKey:()=>"_isPlaceholder",clear:()=>{q=null,Z=!1,G=0}}},z2=(j)=>{if(!j||typeof j!=="object")return!1;return j._isPlaceholder===!0},Lj=(j)=>{return j.filter((X)=>!z2(X))};var N4=50,Qj=(j={})=>{let{adapter:X,initialItems:$,initialTotal:J,storage:K,placeholder:Q,pageSize:q=N4,onStateChange:Z,onItemsLoaded:G,onItemsEvicted:B}=j,D=jj({...K,onEvict:(v,f)=>{B?.(v),V()}}),L=null,O=()=>{if(!L)L=$j(Q);return L},y=new Map,W=!1,U,M=!0,E,F=[],z=new Map,V=()=>{Z?.(e())},H=()=>{y.clear();let v=D.getLoadedRanges();for(let f of v)for(let n=f.start;n<=f.end;n++){let $2=D.get(n);if($2&&!z2($2))y.set($2.id,n)}},N=(v,f)=>{if(!z2(f))y.set(f.id,v)},w=(v)=>{y.delete(v)},_=(v,f)=>{return`${v}-${f}`},R=()=>D.getTotal(),g=()=>D.getCachedCount(),o=()=>W,c=()=>M,e=()=>({total:D.getTotal(),cached:D.getCachedCount(),isLoading:W,pendingRanges:F,error:U,hasMore:M,cursor:E}),j2=()=>D,k=()=>O(),S=(v)=>{let f=D.get(v);if(f!==void 0)return f;if(v>=0&&v<D.getTotal())return O().generate(v);return},p=(v)=>{let f=y.get(v);if(f===void 0)return;return D.get(f)},u=(v)=>{return y.get(v)??-1},b=(v)=>{let f=D.get(v);return f!==void 0&&!z2(f)},C=(v,f)=>{let n=[],$2=D.getTotal(),l=0,X2=0;D.touchChunksForRange(v,Math.min(f,$2-1));for(let K2=v;K2<=f&&K2<$2;K2++){let A2=D.get(K2);if(A2!==void 0)n.push(A2),l++;else n.push(O().generate(K2)),X2++}return n},h=(v)=>{D.setTotal(v),M=D.getCachedCount()<v,V()},m=(v,f=0,n)=>{if(L&&!L.hasAnalyzedStructure()&&v.length>0)L.analyzeStructure(v);for(let $2=0;$2<v.length;$2++){let l=v[$2];if(l!==void 0){let X2=f+$2;D.set(X2,l),N(X2,l)}}if(n!==void 0)D.setTotal(n);else if(f+v.length>D.getTotal())D.setTotal(f+v.length);M=D.getCachedCount()<D.getTotal(),G?.(v,f,D.getTotal()),V()},s=(v,f)=>{let n=y.get(v);if(n===void 0)return!1;let $2=D.get(n);if(!$2)return!1;let l={...$2,...f};if(D.set(n,l),f.id!==void 0&&f.id!==v)w(v),N(n,l);return V(),!0},r=(v)=>{let f=y.get(v);if(f===void 0)return!1;D.delete(f),w(v);let n=D.getTotal();if(n>0)D.setTotal(n-1);return V(),!0},q2=async(v,f)=>{if(!X)return;let n=_(v,f);if(z.has(n))return;let $2=D.getLoadedRanges(),l=x2({start:v,end:f},$2,D.chunkSize);if(l.length===0)return;let X2=D.chunkSize,K2=[];for(let U2 of l){let Y2=Math.floor(U2.start/X2),_2=Math.floor(U2.end/X2);for(let D2=Y2;D2<=_2;D2++){let G2=D2*X2,N2=G2+X2-1,S2=_(G2,N2);if(!K2.some((F2)=>F2.start===G2)&&!z.has(S2))K2.push({start:G2,end:N2})}}let A2=[];for(let U2 of l){let Y2=Math.floor(U2.start/X2),_2=Math.floor(U2.end/X2);for(let D2=Y2;D2<=_2;D2++){let G2=D2*X2,N2=G2+X2-1,S2=_(G2,N2);if(z.has(S2)){let F2=z.get(S2);if(!A2.includes(F2))A2.push(F2)}}}for(let U2 of K2){let Y2=_(U2.start,U2.end),_2=(async()=>{F.push(U2),W=!0,U=void 0,V();try{let D2=U2.end-U2.start+1,G2={offset:U2.start,limit:D2,cursor:void 0},N2=await X.read(G2);if(m(N2.items,U2.start,N2.total),N2.cursor)E=N2.cursor;if(N2.hasMore!==void 0)M=N2.hasMore;else if(N2.total!==void 0)M=D.getCachedCount()<N2.total}catch(D2){U=D2 instanceof Error?D2:Error(String(D2))}finally{z.delete(Y2),F=F.filter((D2)=>D2.start!==U2.start||D2.end!==U2.end),W=z.size>0,V()}})();z.set(Y2,_2),A2.push(_2)}await Promise.all(A2)},B2=async(v,f)=>{if(D.isRangeLoaded(v,f))return;await q2(v,f)},T=async()=>{if(!X)return;await q2(0,q-1)},d=async()=>{if(!X||W||!M)return!1;let v=D.getCachedCount(),f=D.getTotal(),n=v,$2=Math.min(n+q-1,f>0?f-1:n+q-1);if(n>=f&&f>0)return M=!1,!1;return await q2(n,$2),D.getCachedCount()>v},x=async()=>{if(D.clear(),y.clear(),L)L.clear();E=void 0,M=!0,U=void 0,V(),await T()},J2=(v,f)=>{if(D.evictDistant(v,f)>0)H()},i=()=>{D.clear(),y.clear(),E=void 0,U=void 0,F=[],W=!1,V()},Q2=()=>{if(D.reset(),y.clear(),L)L.clear();E=void 0,M=!0,U=void 0,F=[],W=!1,V()};if($&&$.length>0)m($,0,J??$.length);else if(J!==void 0)D.setTotal(J);return{getState:e,getTotal:R,getCached:g,getIsLoading:o,getHasMore:c,getStorage:j2,getPlaceholders:k,getItem:S,getItemById:p,getIndexById:u,isItemLoaded:b,getItemsInRange:C,setTotal:h,setItems:m,updateItem:s,removeItem:r,loadRange:q2,ensureRange:B2,loadInitial:T,loadMore:d,reload:x,evictDistant:J2,clear:i,reset:Q2}};var Oj=(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},zj=(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},$J=(j,X,$,J,K,Q)=>{if(J===0)return 0;let q=Math.max(0,Math.min(j,J-1)),Z=X.getOffset(q),G=X.getHeight(q),B=X.getTotalHeight(),D=Math.max(0,B-$),L;switch(Q){case"center":L=Z-$/2+G/2;break;case"end":L=Z-$+G;break;case"start":default:L=Z;break}return Math.max(0,Math.min(L,D))},QJ=(j,X,$)=>{if($&&$.isCompressed)return $.virtualHeight;return X.getTotalHeight()},XJ=(j,X)=>{return X.getTotalHeight()},qJ=(j,X)=>{return X.getOffset(j)},KJ=(j,X,$)=>{let J=Math.max(0,X-$);return Math.max(0,Math.min(j,J))};var bj=(j,X,$,J,K,Q=Oj)=>{return Q(j.scrollTop,j.containerHeight,X,$,K,j.visibleRange),zj(j.visibleRange,J,$,j.renderRange),j.totalHeight=K.virtualHeight,j.actualHeight=K.actualHeight,j.isCompressed=K.isCompressed,j.compressionRatio=K.ratio,j},b2=(j,X,$,J,K="start",Q,q=$J)=>{return q(j,X,$,J,Q,K)},YJ=(j,X)=>{return j.start===X.start&&j.end===X.end},ZJ=(j,X)=>{return j>=X.start&&j<=X.end},BJ=(j)=>{if(j.end<j.start)return 0;return j.end-j.start+1};var UJ=(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}};i2();var DJ=(j)=>{let{adapter:X,loading:$}=j,J=$?.cancelThreshold??dj,K=$?.preloadThreshold??cj,Q=$?.preloadAhead??lj;return{name:"withAsync",priority:20,methods:["reload"],setup(q){let{emitter:Z}=q,G=q.config.reverse,B=q.config.overscan,D=Qj({adapter:X,pageSize:u2,onStateChange:()=>{if(q.state.isInitialized)q.heightCache.rebuild(q.getVirtualTotal()),q.updateCompressionMode(),q.state.viewportState=bj(q.state.viewportState,q.heightCache,q.getVirtualTotal(),B,q.getCachedCompression()),q.updateContentSize(q.state.viewportState.totalHeight),q.renderIfNeeded()},onItemsLoaded:(E,F,z)=>{if(q.state.isInitialized)q.heightCache.rebuild(q.getVirtualTotal()),q.forceRender(),Z.emit("load:end",{items:E,total:z})}});q.replaceDataManager(D);let L=null,O=null,y=0,W=()=>{if(O){let E=O;O=null,q.dataManager.ensureRange(E.start,E.end).catch((F)=>{Z.emit("error",{error:F,context:"ensureRange"})})}};q.afterScroll.push((E,F)=>{if(q.state.isDestroyed)return;let z=q.scrollController.getVelocity(),H=q.scrollController.isTracking()&&z<=J;if(O&&y>J&&z<=J){let _=O;O=null,q.dataManager.ensureRange(_.start,_.end).catch((R)=>{Z.emit("error",{error:R,context:"ensureRange"})})}if(y=z,H&&!q.dataManager.getIsLoading()&&q.dataManager.getHasMore()){if(G){if(E<Ej)Z.emit("load:start",{offset:q.dataManager.getCached(),limit:u2}),q.dataManager.loadMore().catch((_)=>{Z.emit("error",{error:_,context:"loadMore"})})}else if(q.state.viewportState.totalHeight-E-q.state.viewportState.containerHeight<Ej)Z.emit("load:start",{offset:q.dataManager.getCached(),limit:u2}),q.dataManager.loadMore().catch((R)=>{Z.emit("error",{error:R,context:"loadMore"})})}let{renderRange:N}=q.state.viewportState;if(!L||N.start!==L.start||N.end!==L.end)if(L={start:N.start,end:N.end},H){O=null;let{start:_,end:R}=N,g=q.getVirtualTotal();if(z>K)if(F==="down")R=Math.min(N.end+Q,g-1);else _=Math.max(N.start-Q,0);q.dataManager.ensureRange(_,R).catch((o)=>{Z.emit("error",{error:o,context:"ensureRange"})})}else O={start:N.start,end:N.end}});let U=200,M=null;q.afterScroll.push((E,F)=>{if(M!==null)clearTimeout(M);M=setTimeout(()=>{M=null,W()},U)}),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()=>{await q.dataManager.reload()}),Z.emit("load:start",{offset:0,limit:u2}),q.dataManager.loadInitial().catch((E)=>{Z.emit("error",{error:E,context:"loadInitial"})})}}};var WJ=()=>{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 B=$.viewport.getBoundingClientRect();if(K.horizontal)return Math.max(0,-B.left);else return Math.max(0,-B.top)},(B)=>{let D=$.viewport.getBoundingClientRect();if(K.horizontal){let L=D.left+window.scrollX;window.scrollTo(L+B,window.scrollY)}else{let L=D.top+window.scrollY;window.scrollTo(window.scrollX,L+B)}}),X.setContainerDimensions({width:()=>window.innerWidth,height:()=>window.innerHeight}),J.viewportState.containerHeight=window.innerHeight;let{innerHeight:q,innerWidth:Z}=window,G=()=>{let{innerWidth:B,innerHeight:D}=window,L=K.horizontal?B:D,O=K.horizontal?Z:q;if(Math.abs(L-O)<=1)return;q=D,Z=B,J.viewportState.containerHeight=D,Q.emit("resize",{width:B,height:D});for(let y=0;y<X.resizeHandlers.length;y++)X.resizeHandlers[y](B,D);X.renderIfNeeded()};window.addEventListener("resize",G,{passive:!0}),j=()=>{window.removeEventListener("resize",G)},X.destroyHandlers.push(j)},destroy(){if(j)j(),j=null}}};var Pj=(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 $},NJ=(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 $},VJ=(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 G=q-K;$.push({key:J,groupIndex:$.length,headerLayoutIndex:Q,firstDataIndex:K,count:G}),Q=Q+1+G,J=Z,K=q}}return $.push({key:J,groupIndex:$.length,headerLayoutIndex:Q,firstDataIndex:K,count:j-K}),$},h2=(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},g2=(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)}},Xj=(j,X)=>{let $=VJ(j,X.getGroupForIndex),J=j+$.length,K=X.headerHeight;return{get totalEntries(){return J},get groupCount(){return $.length},get groups(){return $},getEntry:(O)=>{if($.length===0)return{type:"item",dataIndex:O,group:{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0}};let y=Pj($,O),W=$[y];if(O===W.headerLayoutIndex)return{type:"header",group:W};let U=O-W.headerLayoutIndex-1;return{type:"item",dataIndex:W.firstDataIndex+U,group:W}},layoutToDataIndex:(O)=>{if($.length===0)return O;let y=Pj($,O),W=$[y];if(O===W.headerLayoutIndex)return-1;let U=O-W.headerLayoutIndex-1;return W.firstDataIndex+U},dataToLayoutIndex:(O)=>{if($.length===0)return O;let y=NJ($,O),W=$[y],U=O-W.firstDataIndex;return W.headerLayoutIndex+1+U},getGroupAtLayoutIndex:(O)=>{if($.length===0)return{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0};let y=Pj($,O);return $[y]},getGroupAtDataIndex:(O)=>{if($.length===0)return{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0};let y=NJ($,O);return $[y]},getHeaderHeight:typeof K==="number"?(O)=>K:(O)=>{let y=$[O];if(!y)return 0;return K(y.key,O)},rebuild:(O)=>{$=VJ(O,X.getGroupForIndex),J=O+$.length}}};var qj=(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,G=0,B=(U)=>{if(U===q)return;q=U;let M=X.groups;if(U<0||U>=M.length){Q.textContent="";return}let E=M[U],F=J.headerTemplate(E.key,E.groupIndex),z=X.getHeaderHeight(U);if(Q.style.height=`${z}px`,typeof F==="string")Q.innerHTML=F;else Q.replaceChildren(F)},D=(U)=>{let M=X.groups;if(M.length===0){O();return}let E=0;for(let N=M.length-1;N>=0;N--)if($.getOffset(M[N].headerLayoutIndex)<=U){E=N;break}let F=$.getOffset(M[0].headerLayoutIndex);if(U<F){O();return}if(!Z)L();B(E);let z=X.getHeaderHeight(E),V=0,H=E+1;if(H<M.length){let w=$.getOffset(M[H].headerLayoutIndex)-U;if(w<z)V=w-z}if(V!==G)G=V,Q.style.transform=V===0?"":`translateY(${Math.round(V)}px)`},L=()=>{if(Z)return;Z=!0,Q.style.display=""},O=()=>{if(!Z)return;Z=!1,Q.style.display="none",q=-1,G=0,Q.style.transform=""},y=()=>{let U=q;if(q=-1,U>=0)B(U)},W=()=>{Q.remove(),q=-1,Z=!1};return Q.style.display="none",{update:D,refresh:y,show:L,hide:O,destroy:W}};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:G}=Q,{classPrefix:B}=Z;if(Z.horizontal)throw Error("[vlist/builder] withGroups cannot be used with direction: 'horizontal'");let L=G.item.height;J=G.items?[...G.items]:[];let O=J.length,y={getGroupForIndex:j.getGroupForIndex,headerHeight:j.headerHeight,headerTemplate:j.headerTemplate,sticky:j.sticky??!1};X=Xj(O,y),K=h2(J,X.groups);let W=g2(X,L);Q.setHeightConfig(W),Q.rebuildHeightCache(K.length),Q.dataManager.setItems(K,0,K.length);let U=G.item.template,{headerTemplate:M}=j,E=(_,R,g)=>{if(P2(_))return M(_.groupKey,_.groupIndex);return U(_,R,g)},F=Q.methods.get("_getGridLayout"),z=Q.methods.get("_replaceGridRenderer"),V=Q.methods.get("_updateGridLayoutForGroups");if(F&&z){if(V)V((o)=>{let c=K[o];return!!(c&&P2(c))});let{createGridRenderer:_}=(Kj(),lJ(_J)),R=F(),g=_(q.items,E,Q.heightCache,R,B,Q.getContainerWidth(),()=>Q.dataManager.getTotal(),Z.ariaIdPrefix);z(g)}else Q.replaceTemplate(E);if(q.root.classList.add(`${B}--grouped`),j.sticky!==!1){$=qj(q.root,X,Q.heightCache,{...y,sticky:y.sticky??!1},B);let _=$;Q.afterScroll.push((R,g)=>{_.update(R)}),$.update(Q.scrollController.getScrollTop())}let H=()=>{if(!X)return;X.rebuild(J.length),K=h2(J,X.groups);let _=g2(X,L);if(Q.setHeightConfig(_),Q.rebuildHeightCache(K.length),Q.dataManager.setItems(K,0,K.length),$)$.refresh()};Q.methods.set("setItems",(_)=>{J=[..._],H()}),Q.methods.set("appendItems",(_)=>{J=[...J,..._],H()}),Q.methods.set("prependItems",(_)=>{J=[..._,...J],H()}),Q.methods.set("removeItem",(_)=>{J=J.filter((R)=>R.id!==_),H()});let{animateScroll:N,cancelScroll:w}=G4(Q.scrollController,Q.renderIfNeeded);Q.methods.set("scrollToIndex",(_,R)=>{let g=X.dataToLayoutIndex(_),{align:o,behavior:c,duration:e}=M4(R),j2=Q.dataManager.getTotal(),k=b2(g,Q.heightCache,Q.state.viewportState.containerHeight,j2,o,Q.getCachedCompression());if(c==="smooth")N(Q.scrollController.getScrollTop(),k,e);else w(),Q.scrollController.scrollTo(k)}),Q.methods.set("_getItems",()=>J),Q.methods.set("_getTotal",()=>J.length),Q.destroyHandlers.push(()=>{if(L2!==null)cancelAnimationFrame(L2),L2=null;if($)$.destroy(),$=null;q.root.classList.remove(`${B}--grouped`)})},destroy(){if($)$.destroy(),$=null}}},yj=300,_4=(j)=>j<0.5?2*j*j:-1+(4-2*j)*j,L2=null,G4=(j,X)=>{let $=()=>{if(L2!==null)cancelAnimationFrame(L2),L2=null};return{animateScroll:(K,Q,q)=>{if($(),Math.abs(Q-K)<1){j.scrollTo(Q);return}let Z=performance.now(),G=(B)=>{let D=B-Z,L=Math.min(D/q,1),O=K+(Q-K)*_4(L);if(j.scrollTo(O),X(),L<1)L2=requestAnimationFrame(G);else L2=null};L2=requestAnimationFrame(G)},cancelScroll:$}},M4=(j)=>{if(typeof j==="string")return{align:j,behavior:"auto",duration:yj};if(j&&typeof j==="object")return{align:j.align??"start",behavior:j.behavior??"auto",duration:j.duration??yj};return{align:"start",behavior:"auto",duration:yj}};var Yj=(j)=>{let X=Math.max(1,Math.floor(j.columns)),$=j.gap??0,J=j.isHeaderFn,K={row:0,col:0},Q=(W)=>{if(W<=0)return 0;if(!J)return Math.ceil(W/X);let U=0,M=0,E=0;for(let F=0;F<W;F++)if(J(F)){if(E++,M>0)U++,M=0;U++,M=0}else if(M++,M>=X)U++,M=0;if(M>0)U++;return U},q=(W)=>{return K.row=Z(W),K.col=G(W),K},Z=(W)=>{if(!J)return Math.floor(W/X);let U=0,M=0;for(let E=0;E<=W;E++)if(J(E)){if(M>0)U++,M=0;if(E===W)return U;U++,M=0}else{if(E===W)return U;if(M++,M>=X)U++,M=0}return console.warn(`⚠️ getRow(${W}) fell through - returning ${U}`),U},G=(W)=>{if(!J)return W%X;if(J(W))return 0;let U=0;for(let M=0;M<=W;M++)if(J(M))U=0;else{if(M===W)return U;if(U++,U>=X)U=0}return U},B=(W,U,M)=>{if(M<=0)return{start:0,end:-1};if(!J){let H=Math.max(0,W*X),N=Math.min(M-1,(U+1)*X-1);return{start:H,end:N}}let E=-1,F=-1,z=0,V=0;for(let H=0;H<M;H++){if(J(H)){if(V>0)z++,V=0;if(z>=W&&z<=U){if(E===-1)E=H;F=H}z++,V=0}else{if(z>=W&&z<=U){if(E===-1)E=H;F=H}if(V++,V>=X)z++,V=0}if(z>U&&V===0)break}if(E===-1)return{start:0,end:-1};return{start:E,end:F}},D=(W,U,M)=>{if(U<0||U>=X)return-1;let E=W*X+U;if(E<0||E>=M)return-1;return E},L=(W)=>{let U=(X-1)*$;return Math.max(0,(W-U)/X)};return{get columns(){return X},get gap(){return $},update:(W)=>{if(W.columns!==void 0)X=Math.max(1,Math.floor(W.columns));if(W.gap!==void 0)$=W.gap;if(W.isHeaderFn!==void 0)J=W.isHeaderFn},getTotalRows:Q,getPosition:q,getRow:Z,getCol:G,getItemRange:B,getItemIndex:D,getColumnWidth:L,getColumnOffset:(W,U)=>{let M=L(U);return W*(M+$)}}};Kj();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:G}=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((V)=>V.__groupHeader===!0),D={columns:j.columns,gap:j.gap??0};if(B)D.isHeaderFn=(V)=>{let H=J.dataManager.getItem(V);return!!(H&&H.__groupHeader===!0)};X=Yj(D);let L=X.gap;J.setVirtualTotalFn(()=>{let V=J.dataManager.getTotal();return X.getTotalRows(V)});let O=Z.item,y=q.horizontal?O.width:O.height,W={containerWidth:J.getContainerWidth(),columns:X.columns,gap:X.gap};if(typeof y==="function")J.setHeightConfig((V)=>{let H=W.containerWidth-2,N=(W.columns-1)*W.gap,w=(H-N)/W.columns,_={containerWidth:W.containerWidth,columns:W.columns,gap:W.gap,columnWidth:w,row:X.getRow(V),column:X.getCol(V),totalRows:X.getTotalRows(J.dataManager.getTotal()),totalColumns:W.columns};return y(V,_)+W.gap});else if(L>0)J.setHeightConfig(y+L);J.rebuildHeightCache(),K.root.classList.add(`${G}--grid`);let U=J.getContainerWidth(),M=Z.item.template,E=()=>{$=m2(K.items,M,J.heightCache,X,G,U,()=>J.dataManager.getTotal(),q.ariaIdPrefix),J.replaceRenderer($)};E(),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 H=J.dataManager.getTotal(),N=0;for(let w=0;w<H;w++)if(X.getCol(w)===0){let _=J.heightCache.getHeight(w);N+=_}J.heightCache.getTotalHeight=()=>N,J.dom.content.style.height=`${N}px`,E()}),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 H=J.getContainerWidth();if(W.containerWidth=H,W.columns=D.columns,W.gap=D.gap??0,$)$.updateContainerWidth(H);J.rebuildHeightCache(),J.updateContentSize(J.heightCache.getTotalHeight()),J.updateCompressionMode();for(let N=0;N<J.contentSizeHandlers.length;N++)J.contentSizeHandlers[N]();if($)$.clear();J.forceRender()});let F=()=>{if(J.state.isDestroyed)return;let V=J.scrollController.getScrollTop(),H=J.state.viewportState.containerHeight,N=J.getVirtualTotal(),w={start:0,end:0};if(N===0||H===0)w.start=0,w.end=0;else{w.start=Math.max(0,J.heightCache.indexAtOffset(V));let S=J.heightCache.indexAtOffset(V+H);if(S<N-1)S++;w.end=Math.min(N-1,Math.max(0,S))}let _=q.overscan??3,R={start:Math.max(0,w.start-_),end:Math.min(N-1,w.end+_)};J.state.viewportState.scrollTop=V,J.state.viewportState.visibleRange=w,J.state.viewportState.renderRange=R;let g=J.state.lastRenderRange,o=J.state.viewportState.isCompressed;if(R.start===g.start&&R.end===g.end){if(o)$.updatePositions(J.getCompressionContext());return}let c=J.dataManager.getTotal(),e=X.getItemRange(R.start,R.end,c),j2=J.dataManager.getItemsInRange(e.start,e.end),k=o?J.getCompressionContext():void 0;$.render(j2,e,new Set,-1,k),J.state.lastRenderRange={...R},Q.emit("range:change",{range:R})},z=()=>{if(J.state.isDestroyed)return;J.state.lastRenderRange={start:-1,end:-1},F()};if(J.setRenderFns(F,z),J.resizeHandlers.push((V,H)=>{if($)$.updateContainerWidth(V)}),J.methods.set("scrollToIndex",(V,H)=>{let N=Math.floor(V/j.columns),{align:w,behavior:_}=E4(H),R=J.dataManager.getState(),g=X.getTotalRows(R.total),o=Math.max(0,Math.min(N,g-1)),c=b2(o,J.heightCache,J.state.viewportState.containerHeight,g,w,J.getCachedCompression());if(_==="smooth")J.scrollController.scrollTo(c);else J.scrollController.scrollTo(c)}),!J.methods.has("_getTotal"))J.methods.set("_getTotal",()=>J.dataManager.getTotal());J.destroyHandlers.push(()=>{if($)$.destroy(),$=null;K.root.classList.remove(`${G}--grid`)})},destroy(){if($)$.destroy(),$=null}}},Hj=300,E4=(j)=>{if(typeof j==="string")return{align:j,behavior:"auto",duration:Hj};if(j&&typeof j==="object")return{align:j.align??"start",behavior:j.behavior??"auto",duration:j.duration??Hj};return{align:"start",behavior:"auto",duration:Hj}};Kj();var Zj=(j)=>({selected:new Set(j??[]),focusedIndex:-1}),d2=(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}},c2=(j,X)=>{let $=new Set(j.selected);for(let J of X)$.delete(J);return{...j,selected:$}},T2=(j,X,$)=>{if($==="none")return j;if(j.selected.has(X))return c2(j,[X]);else return d2(j,[X],$)},Bj=(j,X,$)=>{if($!=="multiple")return j;return{...j,selected:new Set(X.map((J)=>J.id))}},Uj=(j)=>({...j,selected:new Set}),Rj=(j,X)=>{return j.focusedIndex=X,j},kj=(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},Tj=(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},Cj=(j,X)=>{if(X===0)return j;return j.focusedIndex=0,j},wj=(j,X)=>{if(X===0)return j;return j.focusedIndex=X-1,j};var EJ=(j,X)=>{return j.selected.has(X)},C2=(j)=>{return Array.from(j.selected)},w2=(j,X)=>{let $=[];for(let J of j.selected){let K=X(J);if(K)$.push(K)}return $};var AJ=(j)=>{let X=j?.mode??"single",$=j?.initial,J=Zj($),K=null;return{name:"withSelection",priority:50,methods:["select","deselect","toggleSelect","selectAll","clearSelection","getSelected","getSelectedItems"],setup(Q){let{dom:q,emitter:Z,config:G}=Q,{classPrefix:B,ariaIdPrefix:D}=G;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:O}=Q.getRenderFns(),y=()=>{Q.dom.items.querySelectorAll("[data-index]").forEach((z)=>{let V=z,H=V.dataset.id;if(H!==void 0){let N=/^\d+$/.test(H)?parseInt(H,10):H,w=J.selected.has(N),R=parseInt(V.dataset.index??"-1",10)===J.focusedIndex;V.classList.toggle(`${B}-item--selected`,w),V.classList.toggle(`${B}-item--focused`,R),V.ariaSelected=w?"true":"false"}})},W=()=>{if(Q.state.isDestroyed)return;L(),y()},U=()=>{if(Q.state.isDestroyed)return;O(),y()};Q.setRenderFns(W,U);let M=()=>{y(),Z.emit("selection:change",{selected:C2(J),items:w2(J,(F)=>Q.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 E=K;Z.on("selection:change",({selected:F})=>{let z=F.length;if(z===0)E.textContent="";else if(z===1)E.textContent="1 item selected";else E.textContent=`${z} items selected`}),Q.clickHandlers.push((F)=>{if(Q.state.isDestroyed)return;let V=F.target.closest("[data-index]");if(!V)return;let H=parseInt(V.dataset.index??"-1",10);if(H<0)return;let N=Q.dataManager.getItem(H);if(!N)return;Z.emit("item:click",{item:N,index:H,event:F}),J=Rj(J,H),q.root.setAttribute("aria-activedescendant",`${D}-item-${H}`),J=T2(J,N.id,X),M()}),Q.keydownHandlers.push((F)=>{if(Q.state.isDestroyed)return;let z=Q.dataManager.getTotal(),V=J.focusedIndex,H=!1,N=!1,w=J;switch(F.key){case"ArrowUp":w=kj(J,z),H=!0,N=!0;break;case"ArrowDown":w=Tj(J,z),H=!0,N=!0;break;case"Home":w=Cj(J,z),H=!0,N=!0;break;case"End":w=wj(J,z),H=!0,N=!0;break;case" ":case"Enter":if(J.focusedIndex>=0){let _=Q.dataManager.getItem(J.focusedIndex);if(_)w=T2(J,_.id,X);H=!0}break}if(H){F.preventDefault(),J=w;let _=J.focusedIndex;if(_>=0){let R=Q.dataManager.getState(),g=b2(_,Q.heightCache,Q.state.viewportState.containerHeight,R.total,"center",Q.getCachedCompression());Q.scrollController.scrollTo(g),q.root.setAttribute("aria-activedescendant",`${D}-item-${_}`)}else q.root.removeAttribute("aria-activedescendant");if(N){let{selected:R}=J;if(V>=0&&V!==_){let g=Q.dataManager.getItem(V);if(g)Q.renderer.updateItemClasses(V,R.has(g.id),!1)}if(_>=0){let g=Q.dataManager.getItem(_);if(g)Q.renderer.updateItemClasses(_,R.has(g.id),!0)}}else U(),Z.emit("selection:change",{selected:C2(J),items:w2(J,(R)=>Q.dataManager.getItemById(R))})}}),Q.methods.set("select",(...F)=>{J=d2(J,F,X),M()}),Q.methods.set("deselect",(...F)=>{J=c2(J,F),M()}),Q.methods.set("toggleSelect",(F)=>{J=T2(J,F,X),M()}),Q.methods.set("selectAll",()=>{if(X!=="multiple")return;let F=Q.getAllLoadedItems();J=Bj(J,F,X),M()}),Q.methods.set("clearSelection",()=>{J=Uj(J);let{renderRange:F,isCompressed:z}=Q.state.viewportState,V=Q.getItemsForRange(F),H=z?Q.getCompressionContext():void 0;Q.renderer.render(V,F,J.selected,J.focusedIndex,H),Z.emit("selection:change",{selected:[],items:[]})}),Q.methods.set("getSelected",()=>{return C2(J)}),Q.methods.set("getSelectedItems",()=>{return w2(J,(F)=>Q.dataManager.getItemById(F))}),Q.destroyHandlers.push(()=>{if(E&&E.parentNode)E.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 B={index:0,offsetInItem:0};if(Q)B.selectedIds=Q;return B}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 G={index:q,offsetInItem:Z};if(Q)G.selectedIds=Q;return G}),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)),G;if(Q.isCompressed){let D=j.heightCache.getHeight(Z),L=D>0?J/D:0;G=(Z+L)/q*Q.virtualHeight}else G=j.heightCache.getOffset(Z)+J;let B=Math.max(0,Q.virtualHeight-j.state.viewportState.containerHeight);if(G=Math.max(0,Math.min(G,B)),j.scrollController.scrollTo(G),K&&K.length>0){let D=j.methods.get("select");if(D)D(...K)}})}}};var LJ=()=>{let j={},X=(Z,G)=>{if(!j[Z])j[Z]=new Set;return j[Z].add(G),()=>$(Z,G)},$=(Z,G)=>{j[Z]?.delete(G)};return{on:X,off:$,emit:(Z,G)=>{j[Z]?.forEach((B)=>{try{B(G)}catch(D){console.error(`[vlist] Error in event handler for "${String(Z)}":`,D)}})},once:(Z,G)=>{let B=(D)=>{$(Z,B),G(D)};return X(Z,B)},clear:(Z)=>{if(Z)delete j[Z];else for(let G in j)delete j[G]},listenerCount:(Z)=>{return j[Z]?.size??0}}};export{FJ as withSnapshots,AJ as withSelection,GJ as withSections,tj as withScrollbar,JJ as withScale,WJ as withPage,MJ as withGrid,DJ as withAsync,mj as vlist,T2 as toggleSelection,Oj as simpleVisibleRange,d2 as selectItems,Bj as selectAll,YJ as rangesEqual,e2 as rafThrottle,nj as needsScaling,Jj as mergeRanges,EJ as isSelected,P2 as isSectionHeader,z2 as isPlaceholderItem,ZJ as isInRange,w2 as getSelectedItems,C2 as getSelectedIds,M2 as getScaleState,ij as getScaleInfo,M2 as getScale,BJ as getRangeCount,oj as getMaxItemsWithoutScaling,Lj as filterPlaceholders,UJ as diffRanges,c2 as deselectItems,qj as createStickyHeader,jj as createSparseStorage,Zj as createSelectionState,g2 as createSectionedHeightFn,Xj as createSectionLayout,k2 as createScrollbar,jJ as createScrollController,$j as createPlaceholderManager,sj as createHeightCache,m2 as createGridRenderer,Yj as createGridLayout,LJ as createEmitter,Qj as createAsyncManager,Uj as clearSelection,KJ as clampScrollPosition,QJ as calculateTotalHeight,b2 as calculateScrollToIndex,n2 as calculateScaledVisibleRange,o2 as calculateScaledScrollToIndex,aj as calculateScaledRenderRange,R2 as calculateScaledItemPosition,zj as calculateRenderRange,x2 as calculateMissingRanges,qJ as calculateItemOffset,rj as calculateIndexFromScrollPosition,XJ as calculateActualHeight,h2 as buildLayoutItems,O2 as MAX_VIRTUAL_HEIGHT};
|
|
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};
|