@floor/vlist 0.6.2 → 0.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (148) hide show
  1. package/README.md +70 -75
  2. package/dist/index.d.ts +1 -0
  3. package/dist/index.js +1 -1
  4. package/dist/vlist.d.ts +7 -5
  5. package/dist/vlist.js +1 -0
  6. package/package.json +12 -28
  7. package/dist/adapters/index.d.ts +0 -20
  8. package/dist/adapters/index.d.ts.map +0 -1
  9. package/dist/adapters/react.d.ts +0 -119
  10. package/dist/adapters/react.d.ts.map +0 -1
  11. package/dist/adapters/svelte.d.ts +0 -198
  12. package/dist/adapters/svelte.d.ts.map +0 -1
  13. package/dist/adapters/vue.d.ts +0 -151
  14. package/dist/adapters/vue.d.ts.map +0 -1
  15. package/dist/builder/context.d.ts.map +0 -1
  16. package/dist/builder/core.d.ts.map +0 -1
  17. package/dist/builder/data.d.ts.map +0 -1
  18. package/dist/builder/index.d.ts.map +0 -1
  19. package/dist/builder/types.d.ts.map +0 -1
  20. package/dist/compression/index.js +0 -1
  21. package/dist/constants.d.ts.map +0 -1
  22. package/dist/core/core.js +0 -1
  23. package/dist/core/full.d.ts +0 -22
  24. package/dist/core/full.d.ts.map +0 -1
  25. package/dist/core/index.js +0 -1
  26. package/dist/core/lite.d.ts +0 -129
  27. package/dist/core/lite.d.ts.map +0 -1
  28. package/dist/core/minimal.d.ts +0 -104
  29. package/dist/core/minimal.d.ts.map +0 -1
  30. package/dist/core-light.d.ts +0 -104
  31. package/dist/core-light.d.ts.map +0 -1
  32. package/dist/core-light.js +0 -1
  33. package/dist/core.d.ts +0 -129
  34. package/dist/core.d.ts.map +0 -1
  35. package/dist/data/index.js +0 -1
  36. package/dist/events/emitter.d.ts.map +0 -1
  37. package/dist/events/index.d.ts.map +0 -1
  38. package/dist/features/async/index.d.ts.map +0 -1
  39. package/dist/features/async/manager.d.ts.map +0 -1
  40. package/dist/features/async/placeholder.d.ts.map +0 -1
  41. package/dist/features/async/plugin.d.ts.map +0 -1
  42. package/dist/features/async/sparse.d.ts.map +0 -1
  43. package/dist/features/grid/index.d.ts.map +0 -1
  44. package/dist/features/grid/layout.d.ts.map +0 -1
  45. package/dist/features/grid/plugin.d.ts.map +0 -1
  46. package/dist/features/grid/renderer.d.ts.map +0 -1
  47. package/dist/features/grid/types.d.ts.map +0 -1
  48. package/dist/features/page/index.d.ts.map +0 -1
  49. package/dist/features/page/plugin.d.ts.map +0 -1
  50. package/dist/features/scale/index.d.ts.map +0 -1
  51. package/dist/features/scale/plugin.d.ts.map +0 -1
  52. package/dist/features/scrollbar/controller.d.ts.map +0 -1
  53. package/dist/features/scrollbar/index.d.ts.map +0 -1
  54. package/dist/features/scrollbar/plugin.d.ts.map +0 -1
  55. package/dist/features/scrollbar/scrollbar.d.ts.map +0 -1
  56. package/dist/features/sections/index.d.ts.map +0 -1
  57. package/dist/features/sections/layout.d.ts.map +0 -1
  58. package/dist/features/sections/plugin.d.ts.map +0 -1
  59. package/dist/features/sections/sticky.d.ts.map +0 -1
  60. package/dist/features/sections/types.d.ts.map +0 -1
  61. package/dist/features/selection/index.d.ts.map +0 -1
  62. package/dist/features/selection/plugin.d.ts.map +0 -1
  63. package/dist/features/selection/state.d.ts.map +0 -1
  64. package/dist/features/snapshots/index.d.ts.map +0 -1
  65. package/dist/features/snapshots/plugin.d.ts.map +0 -1
  66. package/dist/groups/index.js +0 -1
  67. package/dist/index.d.ts.map +0 -1
  68. package/dist/plugins/compression/index.d.ts +0 -10
  69. package/dist/plugins/compression/index.d.ts.map +0 -1
  70. package/dist/plugins/compression/plugin.d.ts +0 -42
  71. package/dist/plugins/compression/plugin.d.ts.map +0 -1
  72. package/dist/plugins/data/index.d.ts +0 -9
  73. package/dist/plugins/data/index.d.ts.map +0 -1
  74. package/dist/plugins/data/manager.d.ts +0 -103
  75. package/dist/plugins/data/manager.d.ts.map +0 -1
  76. package/dist/plugins/data/placeholder.d.ts +0 -62
  77. package/dist/plugins/data/placeholder.d.ts.map +0 -1
  78. package/dist/plugins/data/plugin.d.ts +0 -60
  79. package/dist/plugins/data/plugin.d.ts.map +0 -1
  80. package/dist/plugins/data/sparse.d.ts +0 -91
  81. package/dist/plugins/data/sparse.d.ts.map +0 -1
  82. package/dist/plugins/grid/index.d.ts +0 -9
  83. package/dist/plugins/grid/index.d.ts.map +0 -1
  84. package/dist/plugins/grid/layout.d.ts +0 -29
  85. package/dist/plugins/grid/layout.d.ts.map +0 -1
  86. package/dist/plugins/grid/plugin.d.ts +0 -48
  87. package/dist/plugins/grid/plugin.d.ts.map +0 -1
  88. package/dist/plugins/grid/renderer.d.ts +0 -55
  89. package/dist/plugins/grid/renderer.d.ts.map +0 -1
  90. package/dist/plugins/grid/types.d.ts +0 -71
  91. package/dist/plugins/grid/types.d.ts.map +0 -1
  92. package/dist/plugins/groups/index.d.ts +0 -10
  93. package/dist/plugins/groups/index.d.ts.map +0 -1
  94. package/dist/plugins/groups/layout.d.ts +0 -46
  95. package/dist/plugins/groups/layout.d.ts.map +0 -1
  96. package/dist/plugins/groups/plugin.d.ts +0 -64
  97. package/dist/plugins/groups/plugin.d.ts.map +0 -1
  98. package/dist/plugins/groups/sticky.d.ts +0 -33
  99. package/dist/plugins/groups/sticky.d.ts.map +0 -1
  100. package/dist/plugins/groups/types.d.ts +0 -86
  101. package/dist/plugins/groups/types.d.ts.map +0 -1
  102. package/dist/plugins/scroll/controller.d.ts +0 -121
  103. package/dist/plugins/scroll/controller.d.ts.map +0 -1
  104. package/dist/plugins/scroll/index.d.ts +0 -8
  105. package/dist/plugins/scroll/index.d.ts.map +0 -1
  106. package/dist/plugins/scroll/plugin.d.ts +0 -60
  107. package/dist/plugins/scroll/plugin.d.ts.map +0 -1
  108. package/dist/plugins/scroll/scrollbar.d.ts +0 -73
  109. package/dist/plugins/scroll/scrollbar.d.ts.map +0 -1
  110. package/dist/plugins/selection/index.d.ts +0 -7
  111. package/dist/plugins/selection/index.d.ts.map +0 -1
  112. package/dist/plugins/selection/plugin.d.ts +0 -44
  113. package/dist/plugins/selection/plugin.d.ts.map +0 -1
  114. package/dist/plugins/selection/state.d.ts +0 -102
  115. package/dist/plugins/selection/state.d.ts.map +0 -1
  116. package/dist/plugins/snapshots/index.d.ts +0 -8
  117. package/dist/plugins/snapshots/index.d.ts.map +0 -1
  118. package/dist/plugins/snapshots/plugin.d.ts +0 -44
  119. package/dist/plugins/snapshots/plugin.d.ts.map +0 -1
  120. package/dist/plugins/window/index.d.ts +0 -8
  121. package/dist/plugins/window/index.d.ts.map +0 -1
  122. package/dist/plugins/window/plugin.d.ts +0 -53
  123. package/dist/plugins/window/plugin.d.ts.map +0 -1
  124. package/dist/react/index.js +0 -1
  125. package/dist/react/react.js +0 -1
  126. package/dist/render/compression.d.ts +0 -116
  127. package/dist/render/compression.d.ts.map +0 -1
  128. package/dist/render/heights.d.ts +0 -63
  129. package/dist/render/heights.d.ts.map +0 -1
  130. package/dist/render/index.d.ts +0 -9
  131. package/dist/render/index.d.ts.map +0 -1
  132. package/dist/render/renderer.d.ts +0 -103
  133. package/dist/render/renderer.d.ts.map +0 -1
  134. package/dist/render/virtual.d.ts +0 -139
  135. package/dist/render/virtual.d.ts.map +0 -1
  136. package/dist/rendering/heights.d.ts.map +0 -1
  137. package/dist/rendering/index.d.ts.map +0 -1
  138. package/dist/rendering/renderer.d.ts.map +0 -1
  139. package/dist/rendering/scale.d.ts.map +0 -1
  140. package/dist/rendering/viewport.d.ts.map +0 -1
  141. package/dist/scroll/index.js +0 -1
  142. package/dist/svelte/index.js +0 -1
  143. package/dist/svelte/svelte.js +0 -1
  144. package/dist/types.d.ts.map +0 -1
  145. package/dist/vlist.d.ts.map +0 -1
  146. package/dist/vue/index.js +0 -1
  147. package/dist/vue/vue.js +0 -1
  148. package/dist/window/index.js +0 -1
@@ -1,53 +0,0 @@
1
- /**
2
- * vlist/window - Window Scroll Mode Plugin
3
- *
4
- * Enables the list to scroll with the page instead of in its own container.
5
- * Useful for infinite feeds, full-page lists, and chat UIs that integrate
6
- * with page scroll.
7
- *
8
- * Priority: 5 (runs early, before other plugins that depend on scroll)
9
- *
10
- * What it does:
11
- * - Uses window as scroll target instead of viewport element
12
- * - Calculates scroll position relative to document
13
- * - Uses window.innerWidth/innerHeight for container dimensions
14
- * - Listens to window resize events instead of ResizeObserver
15
- * - Adjusts DOM styles (overflow: visible, height: auto)
16
- *
17
- * Bundle impact: ~0.3 KB gzipped when used
18
- */
19
- import type { VListItem } from "../../types";
20
- import type { VListPlugin } from "../../builder/types";
21
- /**
22
- * Create a window scroll mode plugin.
23
- *
24
- * Use this when you want your list to scroll with the page instead of
25
- * in a fixed-height container.
26
- *
27
- * @example
28
- * ```ts
29
- * import { vlist } from 'vlist/builder'
30
- * import { withWindow } from 'vlist/window'
31
- *
32
- * const feed = vlist({
33
- * container: '#infinite-feed',
34
- * item: { height: 200, template: renderPost },
35
- * items: posts
36
- * })
37
- * .use(withWindow())
38
- * .build()
39
- * ```
40
- *
41
- * @example Horizontal window scrolling
42
- * ```ts
43
- * const timeline = vlist({
44
- * container: '#timeline',
45
- * item: { height: 100, template: renderEvent },
46
- * direction: 'horizontal'
47
- * })
48
- * .use(withWindow())
49
- * .build()
50
- * ```
51
- */
52
- export declare const withWindow: <T extends VListItem = VListItem>() => VListPlugin<T>;
53
- //# sourceMappingURL=plugin.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"plugin.d.ts","sourceRoot":"","sources":["../../../src/plugins/window/plugin.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,KAAK,EAAE,WAAW,EAAkB,MAAM,qBAAqB,CAAC;AAEvE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AACH,eAAO,MAAM,UAAU,GACrB,CAAC,SAAS,SAAS,GAAG,SAAS,OAC5B,WAAW,CAAC,CAAC,CA6HjB,CAAC"}
@@ -1 +0,0 @@
1
- var{defineProperty:rj,getOwnPropertyNames:L2,getOwnPropertyDescriptor:O2}=Object,z2=Object.prototype.hasOwnProperty;var AJ=new WeakMap,P2=(J)=>{var X=AJ.get(J),Q;if(X)return X;if(X=rj({},"__esModule",{value:!0}),J&&typeof J==="object"||typeof J==="function")L2(J).map((j)=>!z2.call(X,j)&&rj(X,j,{get:()=>J[j],enumerable:!(Q=O2(J,j))||Q.enumerable}));return AJ.set(J,X),X};var b2=(J,X)=>{for(var Q in X)rj(J,Q,{get:X[Q],enumerable:!0,configurable:!0,set:(j)=>X[Q]=()=>j})};var EJ=(J,X)=>()=>(J&&(X=J(J=0)),X);var nj=200,wj=50,OJ=15,zJ=2,PJ=50,ij=16000000;var bJ=(J,X,Q,j)=>{if(j===0)return 0;if(!J.isVariable())return Math.ceil(Q/J.getHeight(0));let Y=0,$=0,q=X;while(q<j&&$<Q)$+=J.getHeight(q),Y++,q++;return Math.max(1,Y)},tj=(J,X,Q)=>{if(Q===0)return 0;if(!J.isVariable())return Math.floor(X/J.getHeight(0));let j=0,Y=0;for(let $=Q-1;$>=0;$--){let q=J.getHeight($);if(Y+q>X)break;Y+=q,j++}return Math.max(j,1)},ej=(J,X,Q)=>{if(Q===0)return 0;let j=Math.floor(X),Y=X-j,$=Math.max(0,Math.min(j,Q-1));return J.getOffset($)+Y*J.getHeight($)};var Lj=(J,X)=>{let Q=X.getTotalHeight(),j=Q>ij,Y=j?ij:Q,$=Q>0?Y/Q:1;return{isCompressed:j,actualHeight:Q,virtualHeight:Y,ratio:$}},kJ=(J,X,Q,j,Y,$)=>{if(j===0||X===0)return $.start=0,$.end=-1,$;if(!Y.isCompressed){let N=Q.indexAtOffset(J),D=Q.indexAtOffset(J+X);if(D<j-1)D++;return $.start=Math.max(0,N),$.end=Math.min(j-1,Math.max(0,D)),$}let{virtualHeight:q}=Y,M=J/q*j,_=Math.floor(M),B=bJ(Q,Math.max(0,_),X,j),A=Math.ceil(M)+B,b=q-X-J;if(b<=X&&b>=-1){let N=tj(Q,X,j),D=Math.max(0,j-N),E=Math.max(0,Math.min(1,1-b/X));_=Math.floor(_+(D-_)*E),A=b<=1?j-1:Math.min(j-1,_+B)}return $.start=Math.max(0,_),$.end=Math.min(j-1,Math.max(0,A)),$},pj=(J,X,Q,j,Y,$,q)=>{if(!$.isCompressed||j===0)return Q.getOffset(J);let{virtualHeight:Z}=$,M=Z-Y,_=M-X;if(_<=Y&&_>=-1){if(X>=M-1){let k=Q.getTotalHeight()-Q.getOffset(J);return Y-k}let L=tj(Q,Y,j),b=Math.max(0,j-L),D=X/Z*j,E=Math.max(0,Math.min(1,1-_/Y)),F=Q.getOffset(J)-Q.getOffset(b),O=Q.getOffset(J)-ej(Q,D,j);return O+(F-O)*E}let A=X/Z*j;return Q.getOffset(J)-ej(Q,A,j)},yJ=(J,X,Q,j,Y,$="start")=>{if(j===0)return 0;let q;if(Y.isCompressed){if($==="end"&&J===j-1)return Math.max(0,Y.virtualHeight-Q);q=J/j*Y.virtualHeight}else q=X.getOffset(J);let Z=X.getHeight(J);switch($){case"center":q-=(Q-Z)/2;break;case"end":q-=Q-Z;break}let M=Y.virtualHeight-Q;return Math.max(0,Math.min(q,M))};var jJ=()=>{};var Tj=(J)=>{return J!==null&&typeof J==="object"&&J.__groupHeader===!0};var HJ={};b2(HJ,{createGridRenderer:()=>JJ});var x2=(J=200)=>{let X=[];return{acquire:()=>{let $=X.pop();if($)return $;let q=document.createElement("div");return q.setAttribute("role","option"),q},release:($)=>{if(X.length<J)$.className="",$.textContent="",$.removeAttribute("style"),$.removeAttribute("data-index"),$.removeAttribute("data-id"),$.removeAttribute("data-row"),$.removeAttribute("data-col"),X.push($)},clear:()=>{X.length=0}}},JJ=(J,X,Q,j,Y,$,q,Z)=>{let M=x2(),_=new Map,B=$,A=!1,L=null,b=0,N="",D=(z)=>{if(L&&b===z)return L;return L=Lj(z,Q),b=z,L},E={selected:!1,focused:!1},F=(z,T)=>{return E.selected=z,E.focused=T,E},O=`${Y}-item ${Y}-grid-item`,k=`${Y}-item--selected`,G=`${Y}-item--focused`,w=(z,T)=>{if(typeof T==="string")z.innerHTML=T;else z.replaceChildren(T)},U=(z,T,u)=>{z.classList.toggle(k,T),z.classList.toggle(G,u)},C=(z,T)=>{let u=j.getRow(z);if(T){let h=T.totalItems,l=D(h);if(l.isCompressed)return pj(u,T.scrollTop,Q,h,T.containerHeight,l,T.rangeStart)}return Q.getOffset(u)},W=(z,T,u)=>{let h=z.dataset.id?.startsWith("__group_header"),l=h?0:j.getCol(T),a=h?0:j.getColumnOffset(l,B),Xj;if(A){let Bj=j.getRow(T),m=0,Yj=new Set;for(let n=0;n<T;n++){let Qj=j.getRow(n);if(Qj<Bj&&!Yj.has(Qj)){let t=Q.getHeight(n);m+=t,Yj.add(Qj)}}Xj=m}else Xj=C(T,u);z.style.transform=`translate(${Math.round(a)}px, ${Math.round(Xj)}px)`},y=(z,T)=>{let u=z.dataset.id?.startsWith("__group_header"),h=u?B:j.getColumnWidth(B),l;if(A||u)l=Q.getHeight(T)-j.gap;else{let a=j.getRow(T);l=Q.getHeight(a)-j.gap}z.style.width=`${h}px`,z.style.height=`${l}px`},x=(z,T,u,h,l)=>{let a=M.acquire(),Xj=F(u,h);if(a.className=O,a.dataset.index=String(z),a.dataset.id=String(T.id),a.dataset.row=String(j.getRow(z)),a.dataset.col=String(j.getCol(z)),a.ariaSelected=String(u),Z)a.id=`${Z}-item-${z}`;if(q)N=String(q()),a.setAttribute("aria-setsize",N),a.setAttribute("aria-posinset",String(z+1));y(a,z);let Bj=X(T,z,Xj);return w(a,Bj),U(a,u,h),W(a,z,l),a},o=(z,T,u,h,l)=>{if(T.start===0&&z.length>0)A=Tj(z[0]);for(let[m,Yj]of _)if(m<T.start||m>T.end)Yj.element.remove(),M.release(Yj.element),_.delete(m);let a=!1;if(q){let m=String(q());a=m!==N,N=m}let Xj=document.createDocumentFragment(),Bj=[];for(let m=T.start;m<=T.end;m++){let Yj=m-T.start,n=z[Yj];if(!n){console.warn(`⚠️ RENDER: Missing item at index ${m} (range: ${T.start}-${T.end}, items.length: ${z.length})`);continue}let Qj=u.has(n.id),t=m===h,Jj=_.get(m);if(Jj){let R=Jj.element.dataset.id,S=String(n.id);if(R!==S){let jj=F(Qj,t),g=X(n,m,jj);w(Jj.element,g),Jj.element.dataset.id=S,Jj.element.dataset.row=String(j.getRow(m)),Jj.element.dataset.col=String(j.getCol(m)),y(Jj.element,m)}if(U(Jj.element,Qj,t),Jj.element.ariaSelected=String(Qj),W(Jj.element,m,l),a)Jj.element.setAttribute("aria-setsize",N)}else{let R=x(m,n,Qj,t,l);Xj.appendChild(R),Bj.push({index:m,element:R})}}if(Bj.length>0){J.appendChild(Xj);for(let{index:m,element:Yj}of Bj)_.set(m,{index:m,element:Yj})}},d=(z)=>{for(let[T,u]of _)W(u.element,T,z)},e=(z,T,u,h)=>{let l=_.get(z);if(l){let a=F(u,h),Xj=X(T,z,a);w(l.element,Xj),U(l.element,u,h),l.element.dataset.id=String(T.id),l.element.ariaSelected=String(u),y(l.element,z)}},i=(z,T,u)=>{let h=_.get(z);if(h)U(h.element,T,u)},H=(z)=>{return _.get(z)?.element},v=(z)=>{if(Math.abs(z-B)<1)return;B=z;for(let[T,u]of _)y(u.element,T),W(u.element,T)},I=()=>{for(let[,z]of _)z.element.remove(),M.release(z.element);_.clear()};return{render:o,updatePositions:d,updateItem:e,updateItemClasses:i,getElement:H,updateContainerWidth:v,clear:I,destroy:()=>{I(),M.clear()}}};var $J=EJ(()=>{jJ()});import{useRef as Rj,useEffect as NJ,useCallback as r2}from"react";var k2=0,Pj=5,y2=100,aj=2,H2=(J=0)=>{let X=Array(Pj);for(let Q=0;Q<Pj;Q++)X[Q]={position:0,time:0};return{velocity:0,lastPosition:J,lastTime:performance.now(),samples:X,sampleIndex:0,sampleCount:0}},w2=(J,X)=>{let Q=performance.now(),j=Q-J.lastTime;if(j===0)return J;if(j>y2){J.sampleCount=0,J.sampleIndex=0,J.velocity=0;let $=J.samples[0];return $.position=X,$.time=Q,J.sampleIndex=1,J.sampleCount=1,J.lastPosition=X,J.lastTime=Q,J}let Y=J.samples[J.sampleIndex];if(Y.position=X,Y.time=Q,J.sampleIndex=(J.sampleIndex+1)%Pj,J.sampleCount=Math.min(J.sampleCount+1,Pj),J.sampleCount>=aj){let $=(J.sampleIndex-J.sampleCount+Pj)%Pj,q=J.samples[$],Z=X-q.position,M=Q-q.time;J.velocity=M>0?Math.abs(Z)/M:0}return J.lastPosition=X,J.lastTime=Q,J},FJ=(J,X)=>{if(typeof J==="number"){let $=X;return{getOffset:(q)=>q*J,getHeight:()=>J,indexAtOffset:(q)=>{if($===0||J===0)return 0;return Math.max(0,Math.min(Math.floor(q/J),$-1))},getTotalHeight:()=>$*J,getTotal:()=>$,rebuild:(q)=>{$=q},isVariable:()=>!1}}let Q=X,j=new Float64Array(0),Y=($)=>{Q=$,j=new Float64Array($+1),j[0]=0;for(let q=0;q<$;q++)j[q+1]=j[q]+J(q)};return Y(X),{getOffset:($)=>{if($<=0)return 0;if($>=Q)return j[Q];return j[$]},getHeight:($)=>J($),indexAtOffset:($)=>{if(Q===0)return 0;if($<=0)return 0;if($>=j[Q])return Q-1;let q=0,Z=Q-1;while(q<Z){let M=q+Z+1>>>1;if(j[M]<=$)q=M;else Z=M-1}return q},getTotalHeight:()=>j[Q]??0,getTotal:()=>Q,rebuild:($)=>Y($),isVariable:()=>!0}},T2=()=>{let J={},X=($,q)=>{if(!J[$])J[$]=new Set;return J[$].add(q),()=>Q($,q)},Q=($,q)=>{J[$]?.delete(q)};return{on:X,off:Q,emit:($,q)=>{J[$]?.forEach((Z)=>{try{Z(q)}catch(M){console.error(`[vlist] Error in "${$}" handler:`,M)}})},clear:()=>{for(let $ in J)delete J[$]}}},v2=(J)=>{if(typeof J==="string"){let X=document.querySelector(J);if(!X)throw Error(`[vlist/builder] Container not found: ${J}`);return X}return J},R2=(J,X,Q,j)=>{let Y=document.createElement("div");if(Y.className=X,j)Y.classList.add(`${X}--horizontal`);if(Y.setAttribute("role","listbox"),Y.setAttribute("tabindex","0"),Q)Y.setAttribute("aria-label",Q);if(j)Y.setAttribute("aria-orientation","horizontal");let $=document.createElement("div");if($.className=`${X}-viewport`,j)$.style.overflowX="auto",$.style.overflowY="hidden";else $.style.overflow="auto";$.style.height="100%",$.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),$.appendChild(q),Y.appendChild($),J.appendChild(Y),{root:Y,viewport:$,content:q,items:Z}},C2=(J=100)=>{let X=[];return{acquire:()=>{let Q=X.pop();if(Q)return Q;let j=document.createElement("div");return j.setAttribute("role","option"),j},release:(Q)=>{if(X.length<J)Q.className="",Q.textContent="",Q.removeAttribute("style"),Q.removeAttribute("data-index"),Q.removeAttribute("data-id"),X.push(Q)},clear:()=>{X.length=0}}},S2=(J,X,Q,j,Y)=>{if(j===0||X===0){Y.start=0,Y.end=0;return}let $=Q.indexAtOffset(J),q=Q.indexAtOffset(J+X);if(q<j-1)q++;Y.start=Math.max(0,$),Y.end=Math.min(j-1,Math.max(0,q))},f2=(J,X,Q,j)=>{if(Q===0){j.start=0,j.end=0;return}j.start=Math.max(0,J.start-X),j.end=Math.min(Q-1,J.end+X)},I2=(J,X,Q,j,Y)=>{if(j===0)return 0;let $=Math.max(0,Math.min(J,j-1)),q=X.getOffset($),Z=X.getHeight($),M=Math.max(0,X.getTotalHeight()-Q),_;switch(Y){case"center":_=q-(Q-Z)/2;break;case"end":_=q-Q+Z;break;default:_=q}return Math.max(0,Math.min(_,M))},p2=(J)=>J<0.5?2*J*J:-1+(4-2*J)*J,u2=(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}},oj=(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",Q=X?"width":"height",j=X?J.item.width:J.item.height;if(j==null)throw Error(`[vlist/builder] item.${Q} is required${X?" when direction is 'horizontal'":""}`);if(typeof j==="number"&&j<=0)throw Error(`[vlist/builder] item.${Q} must be a positive number`);if(typeof j!=="number"&&typeof j!=="function")throw Error(`[vlist/builder] item.${Q} 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 Y=new Map,$=!1,q={use(Z){if($)throw Error("[vlist/builder] Cannot call .use() after .build()");return Y.set(Z.name,Z),q},build(){if($)throw Error("[vlist/builder] .build() can only be called once");return $=!0,h2(J,Y,X,j)}};return q};function h2(J,X,Q,j){let{item:Y,items:$,overscan:q=3,classPrefix:Z="vlist",ariaLabel:M,reverse:_=!1,scroll:B}=J,A=B?.wheel??!0,L=B?.wrap??!1,b=_,N=`${Z}-${k2++}`,D=j,E=Q?typeof Y.height==="number"?Y.height:void 0:typeof Y.width==="number"?Y.width:void 0,F=Y.template,O={overscan:q,classPrefix:Z,reverse:b,wrap:L,horizontal:Q,ariaIdPrefix:N},k=Array.from(X.values()).sort((K,V)=>(K.priority??50)-(V.priority??50)),G=new Set(k.map((K)=>K.name));for(let K of k)if(K.conflicts){for(let V of K.conflicts)if(G.has(V))throw Error(`[vlist/builder] ${K.name} and ${V} cannot be combined`)}if(Q){if(G.has("withGrid"))throw Error("[vlist/builder] withGrid cannot be used with direction: 'horizontal'");if(G.has("withGroups"))throw Error("[vlist/builder] withGroups cannot be used with direction: 'horizontal'")}if(b){if(G.has("withGrid"))throw Error("[vlist/builder] withGrid cannot be used with reverse: true")}let w=v2(J.container),U=R2(w,Z,M,Q),C=T2(),W=$?[...$]:[],y=FJ(D,W.length),x=C2(),o=U.viewport.clientHeight,d=U.viewport.clientWidth,e=!1,i=!1,H=0,v=null,I=null,p=H2(0),z={start:0,end:0},T={start:0,end:0},u={start:-1,end:-1},h={viewportState:{scrollTop:0,containerHeight:o,totalHeight:y.getTotalHeight(),actualHeight:y.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},l=new Map,a={selected:!1,focused:!1},Xj=`${Z}-item`,Bj="",m=new Map,Yj=()=>{m.clear();for(let K=0;K<W.length;K++){let V=W[K];if(V)m.set(V.id,K)}};Yj();let n=null,Qj=()=>n?n.getTotal():W.length,t=[],Jj=[],R=[],S=[],s=[],jj=[],g=new Map,$j=()=>{return Q?U.viewport.scrollLeft:U.viewport.scrollTop},qj=(K)=>{if(Q)U.viewport.scrollLeft=K;else U.viewport.scrollTop=K},Mj=(K=2)=>{let V=y.getTotalHeight();return H+o>=V-K},Uj=!1,Kj,_j,Zj=(K,V,P,f,r)=>{S2(K,V,P,f,r)},Gj=(K,V,P,f,r)=>{return I2(K,V,P,f,r)},Wj=(K,V)=>{if(typeof V==="string")K.innerHTML=V;else K.replaceChildren(V)},Fj=(K,V)=>{let P=Math.round(y.getOffset(V));if(Q)K.style.transform=`translateX(${P}px)`;else K.style.transform=`translateY(${P}px)`},$2=(K,V)=>{let P=x.acquire();if(P.className=Xj,Q){if(P.style.width=`${y.getHeight(K)}px`,E!=null)P.style.height=`${E}px`}else P.style.height=`${y.getHeight(K)}px`;return P.dataset.index=String(K),P.dataset.id=String(V.id),P.ariaSelected="false",P.id=`${N}-item-${K}`,Bj=String(Qj()),P.setAttribute("aria-setsize",Bj),P.setAttribute("aria-posinset",String(K+1)),Wj(P,F(V,K,a)),Fj(P,K),P},kj=()=>{let K=`${y.getTotalHeight()}px`;if(Q)U.content.style.width=K;else U.content.style.height=K},gj=new Set,dj=-1,Q2=()=>{if(e)return;let K=Qj();if(Zj(H,o,y,K,z),f2(z,q,K,T),T.start===u.start&&T.end===u.end)return;let V=String(K),P=V!==Bj;Bj=V;for(let[c,Dj]of l)if(c<T.start||c>T.end)Dj.remove(),x.release(Dj),l.delete(c);let f=document.createDocumentFragment(),r=[];for(let c=T.start;c<=T.end;c++){let Dj=n?n.getItem(c):W[c];if(!Dj)continue;let Vj=l.get(c);if(Vj){let Aj=Vj.dataset.id,fj=String(Dj.id);if(Aj!==fj)if(Wj(Vj,F(Dj,c,a)),Vj.dataset.id=fj,Q)Vj.style.width=`${y.getHeight(c)}px`;else Vj.style.height=`${y.getHeight(c)}px`;Fj(Vj,c);let Ij=gj.has(Dj.id),F2=c===dj;if(Vj.classList.toggle(`${Z}-item--selected`,Ij),Vj.classList.toggle(`${Z}-item--focused`,F2),Vj.ariaSelected=Ij?"true":"false",P)Vj.setAttribute("aria-setsize",Bj)}else{let Aj=$2(c,Dj),fj=gj.has(Dj.id),Ij=c===dj;if(fj)Aj.classList.add(`${Z}-item--selected`),Aj.ariaSelected="true";if(Ij)Aj.classList.add(`${Z}-item--focused`);f.appendChild(Aj),r.push({index:c,element:Aj})}}if(r.length>0){U.items.appendChild(f);for(let{index:c,element:Dj}of r)l.set(c,Dj)}u.start=T.start,u.end=T.end,h.lastRenderRange.start=T.start,h.lastRenderRange.end=T.end,h.viewportState.scrollTop=H,h.viewportState.visibleRange.start=z.start,h.viewportState.visibleRange.end=z.end,h.viewportState.renderRange.start=T.start,h.viewportState.renderRange.end=T.end,C.emit("range:change",{range:{start:T.start,end:T.end}})},X2=()=>{u.start=-1,u.end=-1,Kj()};Kj=Q2,_j=X2;let yj=()=>{if(e)return;let K=$j(),V=K>=H?"down":"up";if(p=w2(p,K),!U.root.classList.contains(`${Z}--scrolling`))U.root.classList.add(`${Z}--scrolling`);H=K,Kj(),C.emit("scroll",{scrollTop:K,direction:V}),C.emit("velocity:change",{velocity:p.velocity,reliable:p.sampleCount>=aj});for(let P=0;P<t.length;P++)t[P](K,V);if(I)clearTimeout(I);I=setTimeout(()=>{U.root.classList.remove(`${Z}--scrolling`),p.velocity=0,p.sampleCount=0,C.emit("velocity:change",{velocity:0,reliable:!1})},B?.idleTimeout??150)},Cj=null,zj=U.viewport;if(zj.addEventListener("scroll",yj,{passive:!0}),Q&&A)Cj=(K)=>{if(K.deltaX)return;K.preventDefault(),U.viewport.scrollLeft+=K.deltaY},U.viewport.addEventListener("wheel",Cj);let DJ=(K)=>{let P=K.target.closest("[data-index]");if(P){let f=parseInt(P.dataset.index??"-1",10);if(f>=0){let r=n?.getItem(f)??W[f];if(r){if(r.__groupHeader)return;C.emit("item:click",{item:r,index:f,event:K})}}}for(let f=0;f<Jj.length;f++)Jj[f](K)},q2=(K)=>{let P=K.target.closest("[data-index]");if(P){let f=parseInt(P.dataset.index??"-1",10);if(f>=0){let r=n?.getItem(f)??W[f];if(r){if(r.__groupHeader)return;C.emit("item:dblclick",{item:r,index:f,event:K})}}}},VJ=(K)=>{for(let V=0;V<R.length;V++)R[V](K)};U.items.addEventListener("click",DJ),U.items.addEventListener("dblclick",q2),U.root.addEventListener("keydown",VJ);let lj=!0,K2=()=>d,Y2=()=>o,cj=new ResizeObserver((K)=>{if(e)return;for(let V of K){let P=V.contentRect.height,f=V.contentRect.width,r=Q?f:P;if(d=f,Math.abs(r-o)>1){if(o=r,h.viewportState.containerHeight=r,i)kj(),Kj(),C.emit("resize",{height:P,width:f})}if(i)for(let c=0;c<S.length;c++)S[c](f,P)}});if(lj)cj.observe(U.viewport);let Nj={get dom(){return U},get heightCache(){return y},get emitter(){return C},get config(){return O},get rawConfig(){return J},get renderer(){return{render:(K,V,P,f,r)=>{gj=P,dj=f,_j()},updateItemClasses:(K,V,P)=>{let f=l.get(K);if(!f)return;f.classList.toggle(`${Z}-item--selected`,V),f.classList.toggle(`${Z}-item--focused`,P),f.ariaSelected=V?"true":"false"},updatePositions:()=>{},updateItem:()=>{},getElement:(K)=>l.get(K)??null,clear:()=>{},destroy:()=>{}}},set renderer(K){},get dataManager(){return n},set dataManager(K){n=K},get scrollController(){return sj},set scrollController(K){sj=K},state:h,getContainerWidth(){return d},afterScroll:t,clickHandlers:Jj,keydownHandlers:R,resizeHandlers:S,contentSizeHandlers:s,destroyHandlers:jj,methods:g,replaceTemplate(K){F=K},replaceRenderer(K){},replaceDataManager(K){n=K},replaceScrollController(K){sj=K},getItemsForRange(K){let V=[];for(let P=K.start;P<=K.end;P++){let f=n?n.getItem(P):W[P];if(f)V.push(f)}return V},getAllLoadedItems(){if(n){let K=n.getTotal(),V=[];for(let P=0;P<K;P++){let f=n.getItem(P);if(f)V.push(f)}return V}return[...W]},getVirtualTotal(){return Qj()},getCachedCompression(){return{isCompressed:!1,actualHeight:y.getTotalHeight(),virtualHeight:y.getTotalHeight(),ratio:1}},getCompressionContext(){return{scrollTop:H,totalItems:Qj(),containerHeight:o,rangeStart:T.start}},renderIfNeeded(){Kj()},forceRender(){_j()},getRenderFns(){return{renderIfNeeded:Kj,forceRender:_j}},setRenderFns(K,V){Kj=K,_j=V},setVirtualTotalFn(K){Qj=K},rebuildHeightCache(K){y.rebuild(K??Qj())},setHeightConfig(K){y=FJ(K,Qj())},updateContentSize(K){let V=`${K}px`;if(Q)U.content.style.width=V;else U.content.style.height=V},updateCompressionMode(){},setVisibleRangeFn(K){Zj=K},setScrollToPosFn(K){Gj=K},setPositionElementFn(K){Fj=K},setScrollFns(K,V){$j=K,qj=(P)=>{V(P),yj()}},setScrollTarget(K){zj.removeEventListener("scroll",yj),zj=K,zj.addEventListener("scroll",yj,{passive:!0})},getScrollTarget(){return zj},setContainerDimensions(K){K2=K.width,Y2=K.height,d=K.width(),o=K.height(),h.viewportState.containerHeight=o},disableViewportResize(){if(lj)lj=!1,cj.unobserve(U.viewport)}};n={getState:()=>({total:W.length,cached:W.length,isLoading:!1,pendingRanges:[],error:void 0,hasMore:!1,cursor:void 0}),getTotal:()=>W.length,getCached:()=>W.length,getIsLoading:()=>!1,getHasMore:()=>!1,getStorage:()=>null,getPlaceholders:()=>null,getItem:(K)=>W[K],getItemById:(K)=>{let V=m.get(K);return V!==void 0?W[V]:void 0},getIndexById:(K)=>m.get(K)??-1,isItemLoaded:(K)=>K>=0&&K<W.length&&W[K]!==void 0,getItemsInRange:(K,V)=>{let P=[],f=Math.max(0,K),r=Math.min(V,W.length-1);for(let c=f;c<=r;c++)P.push(W[c]);return P},setTotal:(K)=>{},setItems:(K,V=0,P)=>{if(V===0&&(P!==void 0||W.length===0))W=[...K];else{let f=V+K.length;if(W.length<f)W.length=f;for(let r=0;r<K.length;r++)W[V+r]=K[r]}if(Yj(),i){y.rebuild(Qj()),kj(),Nj.updateCompressionMode();for(let f=0;f<s.length;f++)s[f]();_j()}},updateItem:(K,V)=>{let P=m.get(K);if(P===void 0)return!1;let f=W[P];if(!f)return!1;if(W[P]={...f,...V},V.id!==void 0&&V.id!==K)m.delete(K),m.set(V.id,P);let r=l.get(P);if(r)Wj(r,F(W[P],P,a)),r.dataset.id=String(W[P].id);return!0},removeItem:(K)=>{let V=m.get(K);if(V===void 0)return!1;if(W.splice(V,1),Yj(),i){y.rebuild(Qj()),kj(),Nj.updateCompressionMode();for(let P=0;P<s.length;P++)s[P]();_j()}return!0},loadRange:async()=>{},ensureRange:async()=>{},loadInitial:async()=>{},loadMore:async()=>!1,reload:async()=>{},evictDistant:()=>{},clear:()=>{W=[],m.clear()},reset:()=>{if(W=[],m.clear(),i)y.rebuild(0),kj(),_j()}};let sj={getScrollTop:()=>$j(),scrollTo:(K)=>{qj(K),H=K,Kj()},scrollBy:(K)=>{let V=$j()+K;qj(V),H=V,Kj()},isAtTop:()=>H<=2,isAtBottom:(K=2)=>Mj(K),getScrollPercentage:()=>{let K=y.getTotalHeight(),V=Math.max(0,K-o);return V>0?H/V:0},getVelocity:()=>p.velocity,isTracking:()=>p.sampleCount>=aj,isScrolling:()=>U.root.classList.contains(`${Z}--scrolling`),updateConfig:()=>{},enableCompression:()=>{},disableCompression:()=>{},isCompressed:()=>Uj,isWindowMode:()=>!1,updateContainerHeight:(K)=>{o=K},destroy:()=>{}},_J=new Map;for(let K of k)if(K.methods)for(let V of K.methods){let P=_J.get(V);if(P)throw Error(`[vlist/builder] Method "${V}" is registered by both "${P}" and "${K.name}"`);_J.set(V,K.name)}for(let K of k)K.setup(Nj);if(i=!0,Nj.state.isInitialized=!0,kj(),Kj(),b&&W.length>0){let K=Gj(W.length-1,y,o,W.length,"end");qj(K),H=K,Kj()}let Z2=(K)=>{Nj.dataManager.setItems(K,0,K.length)},B2=b?(K)=>{let V=Mj(2),P=W.length;if(Nj.dataManager.setItems(K,P),V&&W.length>0){let f=Gj(W.length-1,y,o,W.length,"end");qj(f),H=f,Kj()}}:(K)=>{let V=W.length;Nj.dataManager.setItems(K,V)},U2=b?(K)=>{let V=$j(),P=y.getTotalHeight(),f=[...W];Nj.dataManager.clear(),Nj.dataManager.setItems([...K,...f],0);let c=y.getTotalHeight()-P;if(c>0)qj(V+c),H=V+c}:(K)=>{let V=[...W];Nj.dataManager.clear(),Nj.dataManager.setItems([...K,...V],0)},W2=(K,V)=>{Nj.dataManager.updateItem(K,V)},N2=(K)=>{Nj.dataManager.removeItem(K)},D2=async()=>{if(Nj.dataManager.reload)await Nj.dataManager.reload()},Sj=()=>{if(v!==null)cancelAnimationFrame(v),v=null},V2=(K,V,P)=>{if(Sj(),Math.abs(V-K)<1){qj(V),H=V,Kj();return}let f=performance.now(),r=(c)=>{let Dj=c-f,Vj=Math.min(Dj/P,1),Aj=K+(V-K)*p2(Vj);if(qj(Aj),H=Aj,Kj(),Vj<1)v=requestAnimationFrame(r);else v=null};v=requestAnimationFrame(r)},GJ=(K,V)=>{let{align:P,behavior:f,duration:r}=u2(V),c=Qj(),Dj=K;if(L&&c>0)Dj=(Dj%c+c)%c;let Vj=Gj(Dj,y,o,c,P);if(f==="smooth")V2($j(),Vj,r);else Sj(),qj(Vj)},_2=(K,V)=>{let P=m.get(K)??Nj.dataManager.getIndexById(K);if(P>=0)GJ(P,V)},G2=()=>$j(),M2=(K,V)=>{return C.on(K,V)},A2=(K,V)=>{C.off(K,V)},E2=()=>{if(e)return;if(e=!0,Nj.state.isDestroyed=!0,U.items.removeEventListener("click",DJ),U.root.removeEventListener("keydown",VJ),zj.removeEventListener("scroll",yj),cj.disconnect(),Cj)U.viewport.removeEventListener("wheel",Cj);if(I)clearTimeout(I);for(let K=0;K<jj.length;K++)jj[K]();for(let K of k)if(K.destroy)K.destroy();Sj();for(let[,K]of l)K.remove(),x.release(K);l.clear(),x.clear(),C.clear(),U.root.remove()},MJ={get element(){return U.root},get items(){if(g.has("_getItems"))return g.get("_getItems")();return W},get total(){if(g.has("_getTotal"))return g.get("_getTotal")();return Qj()},setItems:g.has("setItems")?g.get("setItems"):Z2,appendItems:g.has("appendItems")?g.get("appendItems"):B2,prependItems:g.has("prependItems")?g.get("prependItems"):U2,updateItem:g.has("updateItem")?g.get("updateItem"):W2,removeItem:g.has("removeItem")?g.get("removeItem"):N2,reload:g.has("reload")?g.get("reload"):D2,scrollToIndex:g.has("scrollToIndex")?g.get("scrollToIndex"):GJ,scrollToItem:g.has("scrollToItem")?g.get("scrollToItem"):_2,cancelScroll:g.has("cancelScroll")?g.get("cancelScroll"):Sj,getScrollPosition:g.has("getScrollPosition")?g.get("getScrollPosition"):G2,on:M2,off:A2,destroy:E2};for(let[K,V]of g){if(K==="setItems"||K==="appendItems"||K==="prependItems"||K==="updateItem"||K==="removeItem"||K==="reload"||K==="scrollToIndex"||K==="scrollToItem"||K==="cancelScroll"||K==="getScrollPosition")continue;MJ[K]=V}return MJ}var LJ=(J)=>{let X=Math.max(1,Math.floor(J.columns)),Q=J.gap??0,j=J.isHeaderFn,Y={row:0,col:0},$=(N)=>{if(N<=0)return 0;if(!j)return Math.ceil(N/X);let D=0,E=0,F=0;for(let O=0;O<N;O++)if(j(O)){if(F++,E>0)D++,E=0;D++,E=0}else if(E++,E>=X)D++,E=0;if(E>0)D++;return D},q=(N)=>{return Y.row=Z(N),Y.col=M(N),Y},Z=(N)=>{if(!j)return Math.floor(N/X);let D=0,E=0;for(let F=0;F<=N;F++)if(j(F)){if(E>0)D++,E=0;if(F===N)return D;D++,E=0}else{if(F===N)return D;if(E++,E>=X)D++,E=0}return console.warn(`⚠️ getRow(${N}) fell through - returning ${D}`),D},M=(N)=>{if(!j)return N%X;if(j(N))return 0;let D=0;for(let E=0;E<=N;E++)if(j(E))D=0;else{if(E===N)return D;if(D++,D>=X)D=0}return D},_=(N,D,E)=>{if(E<=0)return{start:0,end:-1};if(!j){let w=Math.max(0,N*X),U=Math.min(E-1,(D+1)*X-1);return{start:w,end:U}}let F=-1,O=-1,k=0,G=0;for(let w=0;w<E;w++){if(j(w)){if(G>0)k++,G=0;if(k>=N&&k<=D){if(F===-1)F=w;O=w}k++,G=0}else{if(k>=N&&k<=D){if(F===-1)F=w;O=w}if(G++,G>=X)k++,G=0}if(k>D&&G===0)break}if(F===-1)return{start:0,end:-1};return{start:F,end:O}},B=(N,D,E)=>{if(D<0||D>=X)return-1;let F=N*X+D;if(F<0||F>=E)return-1;return F},A=(N)=>{let D=(X-1)*Q;return Math.max(0,(N-D)/X)};return{get columns(){return X},get gap(){return Q},update:(N)=>{if(N.columns!==void 0)X=Math.max(1,Math.floor(N.columns));if(N.gap!==void 0)Q=N.gap;if(N.isHeaderFn!==void 0)j=N.isHeaderFn},getTotalRows:$,getPosition:q,getRow:Z,getCol:M,getItemRange:_,getItemIndex:B,getColumnWidth:A,getColumnOffset:(N,D)=>{let E=A(D);return N*(E+Q)}}};$J();var wJ=(J,X,Q,j,Y,$)=>{if(j===0||X===0)return $.start=0,$.end=-1,$;let q=Q.indexAtOffset(J),Z=Q.indexAtOffset(J+X);if(Z<j-1)Z++;return $.start=Math.max(0,q),$.end=Math.min(j-1,Math.max(0,Z)),$},TJ=(J,X,Q,j)=>{if(Q===0)return j.start=0,j.end=-1,j;return j.start=Math.max(0,J.start-X),j.end=Math.min(Q-1,J.end+X),j},vJ=(J,X,Q,j,Y,$)=>{if(j===0)return 0;let q=Math.max(0,Math.min(J,j-1)),Z=X.getOffset(q),M=X.getHeight(q),_=X.getTotalHeight(),B=Math.max(0,_-Q),A;switch($){case"center":A=Z-Q/2+M/2;break;case"end":A=Z-Q+M;break;case"start":default:A=Z;break}return Math.max(0,Math.min(A,B))};var QJ=(J,X,Q,j,Y,$=wJ)=>{return $(J.scrollTop,J.containerHeight,X,Q,Y,J.visibleRange),TJ(J.visibleRange,j,Q,J.renderRange),J.totalHeight=Y.virtualHeight,J.actualHeight=Y.actualHeight,J.isCompressed=Y.isCompressed,J.compressionRatio=Y.ratio,J},Oj=(J,X,Q,j,Y="start",$,q=vJ)=>{return q(J,X,Q,j,$,Y)};var RJ=(J)=>{if(!J.columns||J.columns<1)throw Error("[vlist/builder] withGrid: columns must be a positive integer >= 1");let X=null,Q=null;return{name:"withGrid",priority:10,setup(j){let{dom:Y,emitter:$,config:q,rawConfig:Z}=j,{classPrefix:M}=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 _=Z.items?.some((G)=>G.__groupHeader===!0),B={columns:J.columns,gap:J.gap??0};if(_)B.isHeaderFn=(G)=>{let w=j.dataManager.getItem(G);return!!(w&&w.__groupHeader===!0)};X=LJ(B);let A=X.gap;j.setVirtualTotalFn(()=>{let G=j.dataManager.getTotal();return X.getTotalRows(G)});let L=Z.item,b=q.horizontal?L.width:L.height,N={containerWidth:j.getContainerWidth(),columns:X.columns,gap:X.gap};if(typeof b==="function")j.setHeightConfig((G)=>{let w=N.containerWidth-2,U=(N.columns-1)*N.gap,C=(w-U)/N.columns,W={containerWidth:N.containerWidth,columns:N.columns,gap:N.gap,columnWidth:C,row:X.getRow(G),column:X.getCol(G),totalRows:X.getTotalRows(j.dataManager.getTotal()),totalColumns:N.columns};return b(G,W)+N.gap});else if(A>0)j.setHeightConfig(b+A);j.rebuildHeightCache(),Y.root.classList.add(`${M}--grid`);let D=j.getContainerWidth(),E=Z.item.template,F=()=>{Q=JJ(Y.items,E,j.heightCache,X,M,D,()=>j.dataManager.getTotal(),q.ariaIdPrefix),j.replaceRenderer(Q)};F(),j.methods.set("_getGridLayout",()=>X),j.methods.set("_getGridConfig",()=>B),j.methods.set("_replaceGridRenderer",(G)=>{Q=G}),j.methods.set("_updateGridLayoutForGroups",(G)=>{X.update({isHeaderFn:G});let w=j.dataManager.getTotal(),U=0;for(let C=0;C<w;C++)if(X.getCol(C)===0){let W=j.heightCache.getHeight(C);U+=W}j.heightCache.getTotalHeight=()=>U,j.dom.content.style.height=`${U}px`,F()}),j.methods.set("updateGrid",(G)=>{if(G.columns!==void 0){if(!Number.isInteger(G.columns)||G.columns<1)throw Error("[vlist/builder] updateGrid: columns must be a positive integer >= 1");B.columns=G.columns}if(G.gap!==void 0){if(G.gap<0)throw Error("[vlist/builder] updateGrid: gap must be non-negative");B.gap=G.gap}if(X)X.update(B);let w=j.getContainerWidth();if(N.containerWidth=w,N.columns=B.columns,N.gap=B.gap??0,Q)Q.updateContainerWidth(w);j.rebuildHeightCache(),j.updateContentSize(j.heightCache.getTotalHeight()),j.updateCompressionMode();for(let U=0;U<j.contentSizeHandlers.length;U++)j.contentSizeHandlers[U]();if(Q)Q.clear();j.forceRender()});let O=()=>{if(j.state.isDestroyed)return;let G=j.scrollController.getScrollTop(),w=j.state.viewportState.containerHeight,U=j.getVirtualTotal(),C={start:0,end:0};if(U===0||w===0)C.start=0,C.end=0;else{C.start=Math.max(0,j.heightCache.indexAtOffset(G));let v=j.heightCache.indexAtOffset(G+w);if(v<U-1)v++;C.end=Math.min(U-1,Math.max(0,v))}let W=q.overscan??3,y={start:Math.max(0,C.start-W),end:Math.min(U-1,C.end+W)};j.state.viewportState.scrollTop=G,j.state.viewportState.visibleRange=C,j.state.viewportState.renderRange=y;let x=j.state.lastRenderRange,o=j.state.viewportState.isCompressed;if(y.start===x.start&&y.end===x.end){if(o)Q.updatePositions(j.getCompressionContext());return}let d=j.dataManager.getTotal(),e=X.getItemRange(y.start,y.end,d),i=j.dataManager.getItemsInRange(e.start,e.end),H=o?j.getCompressionContext():void 0;Q.render(i,e,new Set,-1,H),j.state.lastRenderRange={...y},$.emit("range:change",{range:y})},k=()=>{if(j.state.isDestroyed)return;j.state.lastRenderRange={start:-1,end:-1},O()};if(j.setRenderFns(O,k),j.resizeHandlers.push((G,w)=>{if(Q)Q.updateContainerWidth(G)}),j.methods.set("scrollToIndex",(G,w)=>{let U=Math.floor(G/J.columns),{align:C,behavior:W}=m2(w),y=j.dataManager.getState(),x=X.getTotalRows(y.total),o=Math.max(0,Math.min(U,x-1)),d=Oj(o,j.heightCache,j.state.viewportState.containerHeight,x,C,j.getCachedCompression());if(W==="smooth")j.scrollController.scrollTo(d);else j.scrollController.scrollTo(d)}),!j.methods.has("_getTotal"))j.methods.set("_getTotal",()=>j.dataManager.getTotal());j.destroyHandlers.push(()=>{if(Q)Q.destroy(),Q=null;Y.root.classList.remove(`${M}--grid`)})},destroy(){if(Q)Q.destroy(),Q=null}}},XJ=300,m2=(J)=>{if(typeof J==="string")return{align:J,behavior:"auto",duration:XJ};if(J&&typeof J==="object")return{align:J.align??"start",behavior:J.behavior??"auto",duration:J.duration??XJ};return{align:"start",behavior:"auto",duration:XJ}};var qJ=(J,X)=>{let Q=0,j=J.length-1;while(Q<j){let Y=Q+j+1>>>1;if(J[Y].headerLayoutIndex<=X)Q=Y;else j=Y-1}return Q},CJ=(J,X)=>{let Q=0,j=J.length-1;while(Q<j){let Y=Q+j+1>>>1;if(J[Y].firstDataIndex<=X)Q=Y;else j=Y-1}return Q},SJ=(J,X)=>{if(J===0)return[];let Q=[],j=X(0),Y=0,$=0;for(let q=1;q<J;q++){let Z=X(q);if(Z!==j){let M=q-Y;Q.push({key:j,groupIndex:Q.length,headerLayoutIndex:$,firstDataIndex:Y,count:M}),$=$+1+M,j=Z,Y=q}}return Q.push({key:j,groupIndex:Q.length,headerLayoutIndex:$,firstDataIndex:Y,count:J-Y}),Q},KJ=(J,X)=>{if(J.length===0||X.length===0)return[];let Q=J.length+X.length,j=Array(Q),Y=0;for(let $ of X){j[Y]={id:`__group_header_${$.groupIndex}`,__groupHeader:!0,groupKey:$.key,groupIndex:$.groupIndex},Y++;for(let q=0;q<$.count;q++)j[Y]=J[$.firstDataIndex+q],Y++}return j},YJ=(J,X)=>{let Q=typeof X==="number"?(j)=>X:X;return(j)=>{let Y=J.getEntry(j);if(Y.type==="header")return J.getHeaderHeight(Y.group.groupIndex);return Q(Y.dataIndex)}},fJ=(J,X)=>{let Q=SJ(J,X.getGroupForIndex),j=J+Q.length,Y=X.headerHeight;return{get totalEntries(){return j},get groupCount(){return Q.length},get groups(){return Q},getEntry:(L)=>{if(Q.length===0)return{type:"item",dataIndex:L,group:{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0}};let b=qJ(Q,L),N=Q[b];if(L===N.headerLayoutIndex)return{type:"header",group:N};let D=L-N.headerLayoutIndex-1;return{type:"item",dataIndex:N.firstDataIndex+D,group:N}},layoutToDataIndex:(L)=>{if(Q.length===0)return L;let b=qJ(Q,L),N=Q[b];if(L===N.headerLayoutIndex)return-1;let D=L-N.headerLayoutIndex-1;return N.firstDataIndex+D},dataToLayoutIndex:(L)=>{if(Q.length===0)return L;let b=CJ(Q,L),N=Q[b],D=L-N.firstDataIndex;return N.headerLayoutIndex+1+D},getGroupAtLayoutIndex:(L)=>{if(Q.length===0)return{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0};let b=qJ(Q,L);return Q[b]},getGroupAtDataIndex:(L)=>{if(Q.length===0)return{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0};let b=CJ(Q,L);return Q[b]},getHeaderHeight:typeof Y==="number"?(L)=>Y:(L)=>{let b=Q[L];if(!b)return 0;return Y(b.key,L)},rebuild:(L)=>{Q=SJ(L,X.getGroupForIndex),j=L+Q.length}}};var IJ=(J,X,Q,j,Y)=>{let $=document.createElement("div");$.className=`${Y}-sticky-header`,$.setAttribute("role","presentation"),$.setAttribute("aria-hidden","true"),$.style.position="absolute",$.style.top="0",$.style.left="0",$.style.right="0",$.style.zIndex="5",$.style.pointerEvents="none",$.style.willChange="transform",$.style.overflow="hidden",J.insertBefore($,J.firstChild);let q=-1,Z=!1,M=0,_=(D)=>{if(D===q)return;q=D;let E=X.groups;if(D<0||D>=E.length){$.textContent="";return}let F=E[D],O=j.headerTemplate(F.key,F.groupIndex),k=X.getHeaderHeight(D);if($.style.height=`${k}px`,typeof O==="string")$.innerHTML=O;else $.replaceChildren(O)},B=(D)=>{let E=X.groups;if(E.length===0){L();return}let F=0;for(let U=E.length-1;U>=0;U--)if(Q.getOffset(E[U].headerLayoutIndex)<=D){F=U;break}let O=Q.getOffset(E[0].headerLayoutIndex);if(D<O){L();return}if(!Z)A();_(F);let k=X.getHeaderHeight(F),G=0,w=F+1;if(w<E.length){let C=Q.getOffset(E[w].headerLayoutIndex)-D;if(C<k)G=C-k}if(G!==M)M=G,$.style.transform=G===0?"":`translateY(${Math.round(G)}px)`},A=()=>{if(Z)return;Z=!0,$.style.display=""},L=()=>{if(!Z)return;Z=!1,$.style.display="none",q=-1,M=0,$.style.transform=""},b=()=>{let D=q;if(q=-1,D>=0)_(D)},N=()=>{$.remove(),q=-1,Z=!1};return $.style.display="none",{update:B,refresh:b,show:A,hide:L,destroy:N}};var pJ=(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,Q=null,j=[],Y=[];return{name:"withSections",priority:10,setup($){let{dom:q,config:Z,rawConfig:M}=$,{classPrefix:_}=Z;if(Z.horizontal)throw Error("[vlist/builder] withGroups cannot be used with direction: 'horizontal'");let A=M.item.height;j=M.items?[...M.items]:[];let L=j.length,b={getGroupForIndex:J.getGroupForIndex,headerHeight:J.headerHeight,headerTemplate:J.headerTemplate,sticky:J.sticky??!1};X=fJ(L,b),Y=KJ(j,X.groups);let N=YJ(X,A);$.setHeightConfig(N),$.rebuildHeightCache(Y.length),$.dataManager.setItems(Y,0,Y.length);let D=M.item.template,{headerTemplate:E}=J,F=(W,y,x)=>{if(Tj(W))return E(W.groupKey,W.groupIndex);return D(W,y,x)},O=$.methods.get("_getGridLayout"),k=$.methods.get("_replaceGridRenderer"),G=$.methods.get("_updateGridLayoutForGroups");if(O&&k){if(G)G((o)=>{let d=Y[o];return!!(d&&Tj(d))});let{createGridRenderer:W}=($J(),P2(HJ)),y=O(),x=W(q.items,F,$.heightCache,y,_,$.getContainerWidth(),()=>$.dataManager.getTotal(),Z.ariaIdPrefix);k(x)}else $.replaceTemplate(F);if(q.root.classList.add(`${_}--grouped`),J.sticky!==!1){Q=IJ(q.root,X,$.heightCache,{...b,sticky:b.sticky??!1},_);let W=Q;$.afterScroll.push((y,x)=>{W.update(y)}),Q.update($.scrollController.getScrollTop())}let w=()=>{if(!X)return;X.rebuild(j.length),Y=KJ(j,X.groups);let W=YJ(X,A);if($.setHeightConfig(W),$.rebuildHeightCache(Y.length),$.dataManager.setItems(Y,0,Y.length),Q)Q.refresh()};$.methods.set("setItems",(W)=>{j=[...W],w()}),$.methods.set("appendItems",(W)=>{j=[...j,...W],w()}),$.methods.set("prependItems",(W)=>{j=[...W,...j],w()}),$.methods.set("removeItem",(W)=>{j=j.filter((y)=>y.id!==W),w()});let{animateScroll:U,cancelScroll:C}=d2($.scrollController,$.renderIfNeeded);$.methods.set("scrollToIndex",(W,y)=>{let x=X.dataToLayoutIndex(W),{align:o,behavior:d,duration:e}=l2(y),i=$.dataManager.getTotal(),H=Oj(x,$.heightCache,$.state.viewportState.containerHeight,i,o,$.getCachedCompression());if(d==="smooth")U($.scrollController.getScrollTop(),H,e);else C(),$.scrollController.scrollTo(H)}),$.methods.set("_getItems",()=>j),$.methods.set("_getTotal",()=>j.length),$.destroyHandlers.push(()=>{if(Ej!==null)cancelAnimationFrame(Ej),Ej=null;if(Q)Q.destroy(),Q=null;q.root.classList.remove(`${_}--grouped`)})},destroy(){if(Q)Q.destroy(),Q=null}}},ZJ=300,g2=(J)=>J<0.5?2*J*J:-1+(4-2*J)*J,Ej=null,d2=(J,X)=>{let Q=()=>{if(Ej!==null)cancelAnimationFrame(Ej),Ej=null};return{animateScroll:(Y,$,q)=>{if(Q(),Math.abs($-Y)<1){J.scrollTo($);return}let Z=performance.now(),M=(_)=>{let B=_-Z,A=Math.min(B/q,1),L=Y+($-Y)*g2(A);if(J.scrollTo(L),X(),A<1)Ej=requestAnimationFrame(M);else Ej=null};Ej=requestAnimationFrame(M)},cancelScroll:Q}},l2=(J)=>{if(typeof J==="string")return{align:J,behavior:"auto",duration:ZJ};if(J&&typeof J==="object")return{align:J.align??"start",behavior:J.behavior??"auto",duration:J.duration??ZJ};return{align:"start",behavior:"auto",duration:ZJ}};var uJ=(J)=>({selected:new Set(J??[]),focusedIndex:-1}),BJ=(J,X,Q)=>{if(Q==="none")return J;let j=new Set(J.selected);if(Q==="single"){if(j.clear(),X.length>0)j.add(X[0])}else for(let Y of X)j.add(Y);return{...J,selected:j}},UJ=(J,X)=>{let Q=new Set(J.selected);for(let j of X)Q.delete(j);return{...J,selected:Q}},uj=(J,X,Q)=>{if(Q==="none")return J;if(J.selected.has(X))return UJ(J,[X]);else return BJ(J,[X],Q)},hJ=(J,X,Q)=>{if(Q!=="multiple")return J;return{...J,selected:new Set(X.map((j)=>j.id))}},xJ=(J)=>({...J,selected:new Set}),mJ=(J,X)=>{return J.focusedIndex=X,J},gJ=(J,X,Q=!0)=>{if(X===0)return J;let j=J.focusedIndex-1;if(j<0)j=Q?X-1:0;return J.focusedIndex=j,J},dJ=(J,X,Q=!0)=>{if(X===0)return J;let j=J.focusedIndex+1;if(j>=X)j=Q?0:X-1;return J.focusedIndex=j,J},lJ=(J,X)=>{if(X===0)return J;return J.focusedIndex=0,J},cJ=(J,X)=>{if(X===0)return J;return J.focusedIndex=X-1,J};var hj=(J)=>{return Array.from(J.selected)},xj=(J,X)=>{let Q=[];for(let j of J.selected){let Y=X(j);if(Y)Q.push(Y)}return Q};var WJ=(J)=>{let X=J?.mode??"single",Q=J?.initial,j=uJ(Q),Y=null;return{name:"withSelection",priority:50,methods:["select","deselect","toggleSelect","selectAll","clearSelection","getSelected","getSelectedItems"],setup($){let{dom:q,emitter:Z,config:M}=$,{classPrefix:_,ariaIdPrefix:B}=M;if(X==="none"){$.methods.set("select",()=>{}),$.methods.set("deselect",()=>{}),$.methods.set("toggleSelect",()=>{}),$.methods.set("selectAll",()=>{}),$.methods.set("clearSelection",()=>{}),$.methods.set("getSelected",()=>[]),$.methods.set("getSelectedItems",()=>[]),$.methods.set("setSelectionMode",()=>{});return}let{renderIfNeeded:A,forceRender:L}=$.getRenderFns(),b=()=>{$.dom.items.querySelectorAll("[data-index]").forEach((k)=>{let G=k,w=G.dataset.id;if(w!==void 0){let U=/^\d+$/.test(w)?parseInt(w,10):w,C=j.selected.has(U),y=parseInt(G.dataset.index??"-1",10)===j.focusedIndex;G.classList.toggle(`${_}-item--selected`,C),G.classList.toggle(`${_}-item--focused`,y),G.ariaSelected=C?"true":"false"}})},N=()=>{if($.state.isDestroyed)return;A(),b()},D=()=>{if($.state.isDestroyed)return;L(),b()};$.setRenderFns(N,D);let E=()=>{b(),Z.emit("selection:change",{selected:hj(j),items:xj(j,(O)=>$.dataManager.getItemById(O))})};Y=document.createElement("div"),Y.setAttribute("aria-live","polite"),Y.setAttribute("aria-atomic","true"),Y.className=`${_}-live-region`,Y.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(Y);let F=Y;Z.on("selection:change",({selected:O})=>{let k=O.length;if(k===0)F.textContent="";else if(k===1)F.textContent="1 item selected";else F.textContent=`${k} items selected`}),$.clickHandlers.push((O)=>{if($.state.isDestroyed)return;let G=O.target.closest("[data-index]");if(!G)return;let w=parseInt(G.dataset.index??"-1",10);if(w<0)return;let U=$.dataManager.getItem(w);if(!U)return;Z.emit("item:click",{item:U,index:w,event:O}),j=mJ(j,w),q.root.setAttribute("aria-activedescendant",`${B}-item-${w}`),j=uj(j,U.id,X),E()}),$.keydownHandlers.push((O)=>{if($.state.isDestroyed)return;let k=$.dataManager.getTotal(),G=j.focusedIndex,w=!1,U=!1,C=j;switch(O.key){case"ArrowUp":C=gJ(j,k),w=!0,U=!0;break;case"ArrowDown":C=dJ(j,k),w=!0,U=!0;break;case"Home":C=lJ(j,k),w=!0,U=!0;break;case"End":C=cJ(j,k),w=!0,U=!0;break;case" ":case"Enter":if(j.focusedIndex>=0){let W=$.dataManager.getItem(j.focusedIndex);if(W)C=uj(j,W.id,X);w=!0}break}if(w){O.preventDefault(),j=C;let W=j.focusedIndex;if(W>=0){let y=$.dataManager.getState(),x=Oj(W,$.heightCache,$.state.viewportState.containerHeight,y.total,"center",$.getCachedCompression());$.scrollController.scrollTo(x),q.root.setAttribute("aria-activedescendant",`${B}-item-${W}`)}else q.root.removeAttribute("aria-activedescendant");if(U){let{selected:y}=j;if(G>=0&&G!==W){let x=$.dataManager.getItem(G);if(x)$.renderer.updateItemClasses(G,y.has(x.id),!1)}if(W>=0){let x=$.dataManager.getItem(W);if(x)$.renderer.updateItemClasses(W,y.has(x.id),!0)}}else D(),Z.emit("selection:change",{selected:hj(j),items:xj(j,(y)=>$.dataManager.getItemById(y))})}}),$.methods.set("select",(...O)=>{j=BJ(j,O,X),E()}),$.methods.set("deselect",(...O)=>{j=UJ(j,O),E()}),$.methods.set("toggleSelect",(O)=>{j=uj(j,O,X),E()}),$.methods.set("selectAll",()=>{if(X!=="multiple")return;let O=$.getAllLoadedItems();j=hJ(j,O,X),E()}),$.methods.set("clearSelection",()=>{j=xJ(j);let{renderRange:O,isCompressed:k}=$.state.viewportState,G=$.getItemsForRange(O),w=k?$.getCompressionContext():void 0;$.renderer.render(G,O,j.selected,j.focusedIndex,w),Z.emit("selection:change",{selected:[],items:[]})}),$.methods.set("getSelected",()=>{return hj(j)}),$.methods.set("getSelectedItems",()=>{return xj(j,(O)=>$.dataManager.getItemById(O))}),$.destroyHandlers.push(()=>{if(F&&F.parentNode)F.remove()})},destroy(){if(Y&&Y.parentNode)Y.remove();Y=null}}};var vj=(J,X,Q={},j="vlist",Y=!1)=>{let{autoHide:$=!0,autoHideDelay:q=1000,minThumbSize:Z=30,showOnHover:M=!0,hoverZoneWidth:_=16,showOnViewportEnter:B=!0}=Q,A=0,L=0,b=0,N=0,D=!1,E=!1,F=0,O=0,k=0,G=null,w=!1,U=null,C=null,W=Y?"width":"height",y=Y?"translateX":"translateY",x=Y?(t)=>t.clientX:(t)=>t.clientY,o=Y?"left":"top",d=document.createElement("div"),e=document.createElement("div"),i=M?document.createElement("div"):null,H=()=>{if(d.className=`${j}-scrollbar`,e.className=`${j}-scrollbar-thumb`,Y)d.classList.add(`${j}-scrollbar--horizontal`);if(d.appendChild(e),J.appendChild(d),i){if(i.className=`${j}-scrollbar-hover`,Y)i.classList.add(`${j}-scrollbar-hover--horizontal`),i.style.height=`${_}px`;else i.style.width=`${_}px`;J.appendChild(i)}},v=()=>{if(G)clearTimeout(G),G=null},I=()=>{if(!$)return;v(),G=setTimeout(z,q)},p=()=>{if(A<=L)return;if(v(),!w)d.classList.add(`${j}-scrollbar--visible`),w=!0;if($&&!D&&!E)I()},z=()=>{if(D||E)return;d.classList.remove(`${j}-scrollbar--visible`),w=!1},T=(t,Jj)=>{A=t,L=Jj;let R=A>L;if(d.style.display=R?"":"none",!R){z();return}let S=L/A;b=Math.max(Z,S*L),e.style[W]=`${b}px`,N=L-b,u(k)},u=(t)=>{if(k=t,A<=L||N<=0)return;let Jj=A-L,S=Math.min(1,Math.max(0,t/Jj))*N;e.style.transform=`${y}(${S}px)`},h=(t)=>{if(t.target===e)return;let Jj=d.getBoundingClientRect(),s=x(t)-Jj[o]-b/2,g=Math.max(0,Math.min(s,N))/N,$j=A-L,qj=g*$j;X(qj),p()},l=(t)=>{t.preventDefault(),t.stopPropagation(),D=!0,F=x(t),O=k,v(),d.classList.add(`${j}-scrollbar--dragging`),document.addEventListener("mousemove",a),document.addEventListener("mouseup",Xj)},a=(t)=>{if(!D)return;let Jj=x(t)-F,R=N>0?Jj/N:0,S=A-L,s=R*S,jj=Math.max(0,Math.min(O+s,S)),$j=jj/S*N;if(e.style.transform=`${y}(${$j}px)`,C=jj,U===null)U=requestAnimationFrame(()=>{if(C!==null)X(C);U=null})},Xj=()=>{if(D=!1,U!==null)cancelAnimationFrame(U),U=null;if(C!==null)X(C),C=null;if(d.classList.remove(`${j}-scrollbar--dragging`),$&&!E)I();document.removeEventListener("mousemove",a),document.removeEventListener("mouseup",Xj)},Bj=()=>{if(B)p()},m=()=>{if(!D){if(E=!1,$)I()}},Yj=()=>{E=!0,v(),p()},n=()=>{if(E=!1,!D&&$)I()},Qj=()=>{if(v(),U!==null)cancelAnimationFrame(U),U=null;if(d.removeEventListener("click",h),d.removeEventListener("mouseenter",Yj),d.removeEventListener("mouseleave",n),e.removeEventListener("mousedown",l),J.removeEventListener("mouseenter",Bj),J.removeEventListener("mouseleave",m),document.removeEventListener("mousemove",a),document.removeEventListener("mouseup",Xj),i){if(i.removeEventListener("mouseenter",Yj),i.removeEventListener("mouseleave",n),i.parentNode)i.parentNode.removeChild(i)}if(d.parentNode)d.parentNode.removeChild(d)};if(H(),d.addEventListener("click",h),d.addEventListener("mouseenter",Yj),d.addEventListener("mouseleave",n),e.addEventListener("mousedown",l),J.addEventListener("mouseenter",Bj),J.addEventListener("mouseleave",m),i)i.addEventListener("mouseenter",Yj),i.addEventListener("mouseleave",n);return{show:p,hide:z,updateBounds:T,updatePosition:u,isVisible:()=>w,destroy:Qj}};var sJ=(J)=>{let X=null;return{name:"withScrollbar",priority:30,setup(Q){let{dom:j,config:Y}=Q,{classPrefix:$,horizontal:q}=Y;if(X=vj(j.viewport,(_)=>Q.scrollController.scrollTo(_),J??{},$,q),!j.viewport.classList.contains(`${$}-viewport--custom-scrollbar`))j.viewport.classList.add(`${$}-viewport--custom-scrollbar`);let Z=Q.getCachedCompression();X.updateBounds(Z.virtualHeight,Q.state.viewportState.containerHeight);let M=X;Q.afterScroll.push((_,B)=>{M.updatePosition(_),M.show()}),Q.resizeHandlers.push((_,B)=>{if(M){let A=Q.getCachedCompression();M.updateBounds(A.virtualHeight,Q.state.viewportState.containerHeight)}}),Q.contentSizeHandlers.push(()=>{if(M){let _=Q.getCachedCompression();M.updateBounds(_.virtualHeight,Q.state.viewportState.containerHeight)}}),Q.destroyHandlers.push(()=>{if(M)M.destroy()})},destroy(){if(X)X.destroy(),X=null}}};jJ();var rJ=()=>{let J=null,X=0,Q=!1;return{name:"withScale",priority:20,setup(j){let{dom:Y,config:$}=j,{classPrefix:q,horizontal:Z}=$,M=()=>{let B=j.getVirtualTotal(),A=Lj(B,j.heightCache);if(A.isCompressed&&!Q){Q=!0,j.scrollController.enableCompression(A),j.updateContentSize(A.virtualHeight),j.setScrollFns(()=>X,(D)=>{X=D});let L=Y.viewport,b=(D)=>{D.preventDefault();let E=A.virtualHeight-j.state.viewportState.containerHeight;X=Math.max(0,Math.min(X+D.deltaY,E)),j.scrollController.scrollTo(X)};if(L.addEventListener("wheel",b,{passive:!1}),j.destroyHandlers.push(()=>{L.removeEventListener("wheel",b)}),!Y.viewport.querySelector(`.${q}-scrollbar-track`)){if(J=vj(Y.viewport,(E)=>j.scrollController.scrollTo(E),{},q,Z),!Y.viewport.classList.contains(`${q}-viewport--custom-scrollbar`))Y.viewport.classList.add(`${q}-viewport--custom-scrollbar`);J.updateBounds(A.virtualHeight,j.state.viewportState.containerHeight);let D=J;j.afterScroll.push((E,F)=>{if(D)D.updatePosition(E),D.show()}),j.resizeHandlers.push((E,F)=>{if(D){let O=j.getCachedCompression();D.updateBounds(O.virtualHeight,j.state.viewportState.containerHeight)}})}}else if(!A.isCompressed&&Q)Q=!1,j.scrollController.disableCompression(),j.updateContentSize(A.actualHeight);else if(A.isCompressed)j.scrollController.updateConfig({compression:A}),j.updateContentSize(A.virtualHeight);if(J)J.updateBounds(A.virtualHeight,j.state.viewportState.containerHeight);j.state.cachedCompression={state:A,totalItems:B}};j.updateCompressionMode=M;let _=j.getCachedCompression.bind(j);j.getCachedCompression=()=>{if(j.state.cachedCompression)return j.state.cachedCompression.state;return _()},j.setVisibleRangeFn((B,A,L,b,N)=>{let D=Lj(b,L);kJ(B,A,L,b,D,N)}),j.setScrollToPosFn((B,A,L,b,N)=>{let D=Lj(b,A);return yJ(B,A,L,b,D,N)}),j.setPositionElementFn((B,A)=>{let L=j.getVirtualTotal(),b=Lj(L,j.heightCache);if(b.isCompressed){let N=Math.round(pj(A,j.scrollController.getScrollTop(),j.heightCache,L,j.state.viewportState.containerHeight,b)),D=j.config.horizontal;B.style.transform=D?`translateX(${N}px)`:`translateY(${N}px)`}else{let N=Math.round(j.heightCache.getOffset(A)),D=j.config.horizontal;B.style.transform=D?`translateX(${N}px)`:`translateY(${N}px)`}}),M(),j.destroyHandlers.push(()=>{if(J)J.destroy(),J=null})},destroy(){if(J)J.destroy(),J=null}}};var aJ=()=>{return{name:"withSnapshots",priority:50,methods:["getScrollSnapshot","restoreScroll"],setup(J){J.methods.set("getScrollSnapshot",()=>{let X=J.scrollController.getScrollTop(),Q=J.getCachedCompression(),j=J.getVirtualTotal(),Y=J.methods.get("getSelected"),$=Y&&Y().length>0?Y():void 0;if(j===0){let _={index:0,offsetInItem:0};if($)_.selectedIds=$;return _}let q,Z;if(Q.isCompressed){let B=X/Q.virtualHeight*j;q=Math.max(0,Math.min(Math.floor(B),j-1)),Z=(B-q)*J.heightCache.getHeight(q)}else q=J.heightCache.indexAtOffset(X),Z=X-J.heightCache.getOffset(q);Z=Math.max(0,Z);let M={index:q,offsetInItem:Z};if($)M.selectedIds=$;return M}),J.methods.set("restoreScroll",(X)=>{let{index:Q,offsetInItem:j,selectedIds:Y}=X,$=J.getCachedCompression(),q=J.getVirtualTotal();if(q===0)return;let Z=Math.max(0,Math.min(Q,q-1)),M;if($.isCompressed){let B=J.heightCache.getHeight(Z),A=B>0?j/B:0;M=(Z+A)/q*$.virtualHeight}else M=J.heightCache.getOffset(Z)+j;let _=Math.max(0,$.virtualHeight-J.state.viewportState.containerHeight);if(M=Math.max(0,Math.min(M,_)),J.scrollController.scrollTo(M),Y&&Y.length>0){let B=J.methods.get("select");if(B)B(...Y)}})}}};var oJ=(J={})=>{let{chunkSize:X=100,maxCachedItems:Q=5000,evictionBuffer:j=200,onEvict:Y}=J,$=new Map,q=0,Z=0,M=(H)=>{let v=$.get(H);if(!v)v={items:Array(X),count:0,lastAccess:Date.now()},$.set(H,v);else v.lastAccess=Date.now();return v},_=(H)=>{return Math.floor(H/X)},B=(H)=>{return H%X},A=()=>q,L=(H)=>{q=H},b=(H)=>{if(H<0||H>=q)return;let v=_(H),I=$.get(v);if(!I)return;return I.items[B(H)]},N=(H)=>{if(H<0||H>=q)return!1;let v=_(H),I=$.get(v);if(!I)return!1;return I.items[B(H)]!==void 0},D=(H,v)=>{let I=_(H),p=M(I),z=B(H),T=p.items[z]===void 0;if(p.items[z]=v,T)p.count++,Z++;if(H>=q)q=H+1},E=(H,v)=>{for(let I=0;I<v.length;I++){let p=v[I];if(p!==void 0)D(H+I,p)}},F=(H)=>{if(H<0||H>=q)return!1;let v=_(H),I=$.get(v);if(!I)return!1;let p=B(H);if(I.items[p]===void 0)return!1;if(I.items[p]=void 0,I.count--,Z--,I.count===0)$.delete(v);return!0},O=(H,v)=>{let I=[];for(let p=H;p<=v&&p<q;p++)I.push(b(p));return I},k=(H,v)=>{for(let I=H;I<=v&&I<q;I++)if(!N(I))return!1;return!0},G=()=>{let H=[],v=null,I=Array.from($.keys()).sort((p,z)=>p-z);for(let p of I){let z=$.get(p);if(!z)continue;let T=p*X;for(let u=0;u<X;u++){let h=T+u;if(h>=q)break;if(z.items[u]!==void 0)if(v===null)v={start:h,end:h};else if(h===v.end+1)v.end=h;else H.push(v),v={start:h,end:h};else if(v!==null)H.push(v),v=null}}if(v!==null)H.push(v);return H},w=(H,v)=>{let I=[],p=null;for(let z=H;z<=v&&z<q;z++)if(!N(z))if(p===null)p={start:z,end:z};else p.end=z;else if(p!==null)I.push(p),p=null;if(p!==null)I.push(p);return I},U=(H)=>{return $.has(H)},C=(H)=>{let v=$.get(H);if(v)v.lastAccess=Date.now()},W=(H,v)=>{if(H>v||$.size===0)return;let I=Date.now(),p=_(Math.max(0,H)),z=_(Math.min(q-1,v));for(let T=p;T<=z;T++){let u=$.get(T);if(u)u.lastAccess=I}},y=(H,v)=>{if(Z<=Q)return 0;let I=Math.max(0,H-j),p=Math.min(q-1,v+j),z=_(I),T=_(p),u=0,h=[];for(let[l,a]of $)if(l<z||l>T)u+=a.count,h.push(l),Z-=a.count,$.delete(l);if(u>0&&Y)Y(u,h);return u},x=()=>{if(Z<=Q)return 0;let H=Array.from($.entries()).sort(([,p],[,z])=>p.lastAccess-z.lastAccess),v=0,I=[];for(let[p,z]of H){if(Z<=Q)break;v+=z.count,Z-=z.count,I.push(p),$.delete(p)}if(v>0&&Y)Y(v,I);return v},o=()=>{return{totalItems:q,cachedItems:Z,cachedChunks:$.size,chunkSize:X,maxCachedItems:Q,memoryEfficiency:q>0?1-Z/q:1}},d=()=>Z,e=()=>{$.clear(),Z=0};return{chunkSize:X,maxCachedItems:Q,getTotal:A,setTotal:L,get:b,has:N,set:D,setRange:E,delete:F,getRange:O,isRangeLoaded:k,getLoadedRanges:G,findUnloadedRanges:w,getChunkIndex:_,isChunkLoaded:U,touchChunk:C,touchChunksForRange:W,evictDistant:y,evictToLimit:x,getStats:o,getCachedCount:d,clear:e,reset:()=>{e(),q=0}}},c2=(J)=>{if(J.length===0)return[];let X=[...J].sort((j,Y)=>j.start-Y.start),Q=[{...X[0]}];for(let j=1;j<X.length;j++){let Y=X[j],$=Q[Q.length-1];if(Y.start<=$.end+1)$.end=Math.max($.end,Y.end);else Q.push({...Y})}return Q},nJ=(J,X,Q)=>{let j=Math.floor(J.start/Q)*Q,Y=Math.ceil((J.end+1)/Q)*Q-1,$={start:j,end:Y};if(X.length===0)return[$];let q=[],Z=c2(X),M=$.start;for(let _ of Z){if(_.end<M)continue;if(_.start>$.end)break;if(_.start>M)q.push({start:M,end:Math.min(_.start-1,$.end)});if(M=_.end+1,M>$.end)break}if(M<=$.end)q.push({start:M,end:$.end});return q};var iJ=(J={})=>{let{enabled:X=!0,maskCharacter:Q="█",randomVariance:j=!0,maxSampleSize:Y=20,customGenerator:$}=J,q=null,Z=!1,M=0,_=(F)=>{if(!X||Z||F.length===0)return;let O=new Map,k=new Map,G=Math.min(F.length,Y);for(let w=0;w<G;w++){let U=F[w];if(!U||typeof U!=="object")continue;for(let[C,W]of Object.entries(U)){if(C.startsWith("_")||C==="id")continue;if(!k.has(C))k.set(C,{lengths:[],types:new Set});let y=k.get(C),x=Array.isArray(W)?"array":typeof W;if(y.types.add(x),typeof W==="string")y.lengths.push(W.length);else if(W!==null&&W!==void 0)y.lengths.push(String(W).length)}}for(let[w,U]of k){if(U.lengths.length===0)continue;let C=Math.min(...U.lengths),W=Math.max(...U.lengths),y=Math.round(U.lengths.reduce((o,d)=>o+d,0)/U.lengths.length),x="string";if(U.types.has("number")&&U.types.size===1)x="number";else if(U.types.has("boolean")&&U.types.size===1)x="boolean";else if(U.types.has("array"))x="array";else if(U.types.has("object")&&!U.types.has("string"))x="object";O.set(w,{minLength:C,maxLength:W,avgLength:y,type:x})}q=O,Z=!0},B=()=>Z,A=(F)=>{let O=F.avgLength;if(j&&F.minLength!==F.maxLength){if(O=Math.floor(Math.random()*(F.maxLength-F.minLength+1)+F.minLength),Math.random()<0.3)O=Math.max(1,O+Math.floor(Math.random()*3)-1)}return Q.repeat(Math.max(1,O))},L=(F)=>{if($)return{...$(F),["_isPlaceholder"]:!0};let O={id:`__placeholder_${M++}`,["_isPlaceholder"]:!0,_index:F};if(!q||q.size===0)return O.label=Q.repeat(12),O;for(let[k,G]of q)switch(G.type){case"string":O[k]=A(G);break;case"number":O[k]=0;break;case"boolean":O[k]=!1;break;case"array":O[k]=[];break;case"object":O[k]={};break;default:O[k]=A(G)}return O};return{analyzeStructure:_,hasAnalyzedStructure:B,generate:L,generateRange:(F,O)=>{let k=[];for(let G=F;G<=O;G++)k.push(L(G));return k},isPlaceholder:(F)=>{if(!F||typeof F!=="object")return!1;return F._isPlaceholder===!0},getPlaceholderKey:()=>"_isPlaceholder",clear:()=>{q=null,Z=!1,M=0}}},mj=(J)=>{if(!J||typeof J!=="object")return!1;return J._isPlaceholder===!0};var s2=50,tJ=(J={})=>{let{adapter:X,initialItems:Q,initialTotal:j,storage:Y,placeholder:$,pageSize:q=s2,onStateChange:Z,onItemsLoaded:M,onItemsEvicted:_}=J,B=oJ({...Y,onEvict:(R,S)=>{_?.(R),G()}}),A=null,L=()=>{if(!A)A=iJ($);return A},b=new Map,N=!1,D,E=!0,F,O=[],k=new Map,G=()=>{Z?.(e())},w=()=>{b.clear();let R=B.getLoadedRanges();for(let S of R)for(let s=S.start;s<=S.end;s++){let jj=B.get(s);if(jj&&!mj(jj))b.set(jj.id,s)}},U=(R,S)=>{if(!mj(S))b.set(S.id,R)},C=(R)=>{b.delete(R)},W=(R,S)=>{return`${R}-${S}`},y=()=>B.getTotal(),x=()=>B.getCachedCount(),o=()=>N,d=()=>E,e=()=>({total:B.getTotal(),cached:B.getCachedCount(),isLoading:N,pendingRanges:O,error:D,hasMore:E,cursor:F}),i=()=>B,H=()=>L(),v=(R)=>{let S=B.get(R);if(S!==void 0)return S;if(R>=0&&R<B.getTotal())return L().generate(R);return},I=(R)=>{let S=b.get(R);if(S===void 0)return;return B.get(S)},p=(R)=>{return b.get(R)??-1},z=(R)=>{let S=B.get(R);return S!==void 0&&!mj(S)},T=(R,S)=>{let s=[],jj=B.getTotal(),g=0,$j=0;B.touchChunksForRange(R,Math.min(S,jj-1));for(let qj=R;qj<=S&&qj<jj;qj++){let Mj=B.get(qj);if(Mj!==void 0)s.push(Mj),g++;else s.push(L().generate(qj)),$j++}return s},u=(R)=>{B.setTotal(R),E=B.getCachedCount()<R,G()},h=(R,S=0,s)=>{if(A&&!A.hasAnalyzedStructure()&&R.length>0)A.analyzeStructure(R);for(let jj=0;jj<R.length;jj++){let g=R[jj];if(g!==void 0){let $j=S+jj;B.set($j,g),U($j,g)}}if(s!==void 0)B.setTotal(s);else if(S+R.length>B.getTotal())B.setTotal(S+R.length);E=B.getCachedCount()<B.getTotal(),M?.(R,S,B.getTotal()),G()},l=(R,S)=>{let s=b.get(R);if(s===void 0)return!1;let jj=B.get(s);if(!jj)return!1;let g={...jj,...S};if(B.set(s,g),S.id!==void 0&&S.id!==R)C(R),U(s,g);return G(),!0},a=(R)=>{let S=b.get(R);if(S===void 0)return!1;B.delete(S),C(R);let s=B.getTotal();if(s>0)B.setTotal(s-1);return G(),!0},Xj=async(R,S)=>{if(!X)return;let s=W(R,S);if(k.has(s))return;let jj=B.getLoadedRanges(),g=nJ({start:R,end:S},jj,B.chunkSize);if(g.length===0)return;let $j=B.chunkSize,qj=[];for(let Uj of g){let Kj=Math.floor(Uj.start/$j),_j=Math.floor(Uj.end/$j);for(let Zj=Kj;Zj<=_j;Zj++){let Gj=Zj*$j,Wj=Gj+$j-1,bj=W(Gj,Wj);if(!qj.some((Fj)=>Fj.start===Gj)&&!k.has(bj))qj.push({start:Gj,end:Wj})}}let Mj=[];for(let Uj of g){let Kj=Math.floor(Uj.start/$j),_j=Math.floor(Uj.end/$j);for(let Zj=Kj;Zj<=_j;Zj++){let Gj=Zj*$j,Wj=Gj+$j-1,bj=W(Gj,Wj);if(k.has(bj)){let Fj=k.get(bj);if(!Mj.includes(Fj))Mj.push(Fj)}}}for(let Uj of qj){let Kj=W(Uj.start,Uj.end),_j=(async()=>{O.push(Uj),N=!0,D=void 0,G();try{let Zj=Uj.end-Uj.start+1,Gj={offset:Uj.start,limit:Zj,cursor:void 0},Wj=await X.read(Gj);if(h(Wj.items,Uj.start,Wj.total),Wj.cursor)F=Wj.cursor;if(Wj.hasMore!==void 0)E=Wj.hasMore;else if(Wj.total!==void 0)E=B.getCachedCount()<Wj.total}catch(Zj){D=Zj instanceof Error?Zj:Error(String(Zj))}finally{k.delete(Kj),O=O.filter((Zj)=>Zj.start!==Uj.start||Zj.end!==Uj.end),N=k.size>0,G()}})();k.set(Kj,_j),Mj.push(_j)}await Promise.all(Mj)},Bj=async(R,S)=>{if(B.isRangeLoaded(R,S))return;await Xj(R,S)},m=async()=>{if(!X)return;await Xj(0,q-1)},Yj=async()=>{if(!X||N||!E)return!1;let R=B.getCachedCount(),S=B.getTotal(),s=R,jj=Math.min(s+q-1,S>0?S-1:s+q-1);if(s>=S&&S>0)return E=!1,!1;return await Xj(s,jj),B.getCachedCount()>R},n=async()=>{if(B.clear(),b.clear(),A)A.clear();F=void 0,E=!0,D=void 0,G(),await m()},Qj=(R,S)=>{if(B.evictDistant(R,S)>0)w()},t=()=>{B.clear(),b.clear(),F=void 0,D=void 0,O=[],N=!1,G()},Jj=()=>{if(B.reset(),b.clear(),A)A.clear();F=void 0,E=!0,D=void 0,O=[],N=!1,G()};if(Q&&Q.length>0)h(Q,0,j??Q.length);else if(j!==void 0)B.setTotal(j);return{getState:e,getTotal:y,getCached:x,getIsLoading:o,getHasMore:d,getStorage:i,getPlaceholders:H,getItem:v,getItemById:I,getIndexById:p,isItemLoaded:z,getItemsInRange:T,setTotal:u,setItems:h,updateItem:l,removeItem:a,loadRange:Xj,ensureRange:Bj,loadInitial:m,loadMore:Yj,reload:n,evictDistant:Qj,clear:t,reset:Jj}};var eJ=(J)=>{let{adapter:X,loading:Q}=J,j=Q?.cancelThreshold??OJ,Y=Q?.preloadThreshold??zJ,$=Q?.preloadAhead??PJ;return{name:"withAsync",priority:20,methods:["reload"],setup(q){let{emitter:Z}=q,M=q.config.reverse,_=q.config.overscan,B=tJ({adapter:X,pageSize:wj,onStateChange:()=>{if(q.state.isInitialized)q.heightCache.rebuild(q.getVirtualTotal()),q.updateCompressionMode(),q.state.viewportState=QJ(q.state.viewportState,q.heightCache,q.getVirtualTotal(),_,q.getCachedCompression()),q.updateContentSize(q.state.viewportState.totalHeight),q.renderIfNeeded()},onItemsLoaded:(F,O,k)=>{if(q.state.isInitialized)q.heightCache.rebuild(q.getVirtualTotal()),q.forceRender(),Z.emit("load:end",{items:F,total:k})}});q.replaceDataManager(B);let A=null,L=null,b=0,N=()=>{if(L){let F=L;L=null,q.dataManager.ensureRange(F.start,F.end).catch((O)=>{Z.emit("error",{error:O,context:"ensureRange"})})}};q.afterScroll.push((F,O)=>{if(q.state.isDestroyed)return;let k=q.scrollController.getVelocity(),w=q.scrollController.isTracking()&&k<=j;if(L&&b>j&&k<=j){let W=L;L=null,q.dataManager.ensureRange(W.start,W.end).catch((y)=>{Z.emit("error",{error:y,context:"ensureRange"})})}if(b=k,w&&!q.dataManager.getIsLoading()&&q.dataManager.getHasMore()){if(M){if(F<nj)Z.emit("load:start",{offset:q.dataManager.getCached(),limit:wj}),q.dataManager.loadMore().catch((W)=>{Z.emit("error",{error:W,context:"loadMore"})})}else if(q.state.viewportState.totalHeight-F-q.state.viewportState.containerHeight<nj)Z.emit("load:start",{offset:q.dataManager.getCached(),limit:wj}),q.dataManager.loadMore().catch((y)=>{Z.emit("error",{error:y,context:"loadMore"})})}let{renderRange:U}=q.state.viewportState;if(!A||U.start!==A.start||U.end!==A.end)if(A={start:U.start,end:U.end},w){L=null;let{start:W,end:y}=U,x=q.getVirtualTotal();if(k>Y)if(O==="down")y=Math.min(U.end+$,x-1);else W=Math.max(U.start-$,0);q.dataManager.ensureRange(W,y).catch((o)=>{Z.emit("error",{error:o,context:"ensureRange"})})}else L={start:U.start,end:U.end}});let D=200,E=null;q.afterScroll.push((F,O)=>{if(E!==null)clearTimeout(E);E=setTimeout(()=>{E=null,N()},D)}),q.destroyHandlers.push(()=>{if(E!==null)clearTimeout(E),E=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:wj}),q.dataManager.loadInitial().catch((F)=>{Z.emit("error",{error:F,context:"loadInitial"})})}}};var j2=()=>{let J=null;return{name:"withPage",priority:5,setup(X){let{dom:Q,state:j,config:Y,emitter:$}=X;Q.root.style.overflow="visible",Q.root.style.height="auto",Q.viewport.classList.remove(`${Y.classPrefix}-viewport--custom-scrollbar`),X.disableViewportResize(),X.setScrollTarget(window),X.setScrollFns(()=>{let _=Q.viewport.getBoundingClientRect();if(Y.horizontal)return Math.max(0,-_.left);else return Math.max(0,-_.top)},(_)=>{let B=Q.viewport.getBoundingClientRect();if(Y.horizontal){let A=B.left+window.scrollX;window.scrollTo(A+_,window.scrollY)}else{let A=B.top+window.scrollY;window.scrollTo(window.scrollX,A+_)}}),X.setContainerDimensions({width:()=>window.innerWidth,height:()=>window.innerHeight}),j.viewportState.containerHeight=window.innerHeight;let{innerHeight:q,innerWidth:Z}=window,M=()=>{let{innerWidth:_,innerHeight:B}=window,A=Y.horizontal?_:B,L=Y.horizontal?Z:q;if(Math.abs(A-L)<=1)return;q=B,Z=_,j.viewportState.containerHeight=B,$.emit("resize",{width:_,height:B});for(let b=0;b<X.resizeHandlers.length;b++)X.resizeHandlers[b](_,B);X.renderIfNeeded()};window.addEventListener("resize",M,{passive:!0}),J=()=>{window.removeEventListener("resize",M)},X.destroyHandlers.push(J)},destroy(){if(J)J(),J=null}}};var J2=(J)=>{let X=oj(J);if(J.scroll?.element===window)X=X.use(j2());if(J.adapter)X=X.use(eJ({adapter:J.adapter,...J.loading&&{loading:J.loading}}));if(J.layout==="grid"){if(!J.grid)throw Error("[vlist/builder] grid configuration is required when layout is 'grid'");if(!J.grid.columns||J.grid.columns<1)throw Error("[vlist/builder] grid.columns must be a positive integer >= 1");let $={columns:J.grid.columns};if(J.grid.gap!==void 0)$.gap=J.grid.gap;X=X.use(RJ($))}if(J.groups){if(J.direction==="horizontal")throw Error("[vlist/builder] horizontal direction cannot be combined with groups");let $={getGroupForIndex:J.groups.getGroupForIndex,headerHeight:typeof J.groups.headerHeight==="function"?J.groups.headerHeight("",0):J.groups.headerHeight,headerTemplate:J.groups.headerTemplate};if(J.groups.sticky!==void 0)$.sticky=J.groups.sticky;X=X.use(pJ($))}let Q=J.selection?.mode||"none";if(Q!=="none"){let $={mode:Q};if(J.selection?.initial!==void 0)$.initial=J.selection.initial;X=X.use(WJ($))}else X=X.use(WJ({mode:"none"}));X=X.use(rJ());let j=J.scroll?.scrollbar||J.scrollbar;if(j!=="none"){let $=typeof j==="object"?j:{};X=X.use(sJ($))}X=X.use(aJ());let Y=X.build();return Y.update=($)=>{if($.grid&&Y.updateGrid)Y.updateGrid($.grid);if($.selectionMode!==void 0&&Y.setSelectionMode)Y.setSelectionMode($.selectionMode);if($.itemHeight!==void 0)console.warn("[vlist] Updating itemHeight via update() is not yet supported with the builder pattern. Please recreate the instance or use the full API from 'vlist/full'.");if($.overscan!==void 0)console.warn("[vlist] Updating overscan via update() is not yet supported with the builder pattern.")},Y};function G6(J){let X=Rj(null),Q=Rj(null),j=Rj(J);j.current=J;let Y=Rj(!1);NJ(()=>{let q=X.current;if(!q)return;let Z=J2({...j.current,container:q});return Q.current=Z,Y.current=!0,()=>{Y.current=!1,Z.destroy(),Q.current=null}},[]),NJ(()=>{if(!Y.current||!Q.current)return;if(J.items)Q.current.setItems(J.items)},[J.items]);let $=r2(()=>{return Q.current},[]);return{containerRef:X,instanceRef:Q,getInstance:$}}function M6(J,X,Q){let j=Rj(Q);j.current=Q,NJ(()=>{let Y=J.current;if(!Y)return;let $=(Z)=>{j.current(Z)};return Y.on(X,$)},[J.current,X])}export{M6 as useVListEvent,G6 as useVList};
@@ -1 +0,0 @@
1
- var Ke=Object.defineProperty;var bn=Object.getOwnPropertyDescriptor;var vn=Object.getOwnPropertyNames;var yn=Object.prototype.hasOwnProperty;var Fe=(t,o)=>()=>(t&&(o=t(t=0)),o);var Tn=(t,o)=>{for(var r in o)Ke(t,r,{get:o[r],enumerable:!0})},Sn=(t,o,r,e)=>{if(o&&typeof o=="object"||typeof o=="function")for(let a of vn(o))!yn.call(t,a)&&a!==r&&Ke(t,a,{get:()=>o[a],enumerable:!(e=bn(o,a))||e.enumerable});return t};var In=t=>Sn(Ke({},"__esModule",{value:!0}),t);var yt,Xe,je,Tt=Fe(()=>{"use strict";yt=(t,o,r,e)=>{if(e===0)return 0;if(!t.isVariable())return Math.ceil(r/t.getHeight(0));let a=0,n=0,s=o;for(;s<e&&n<r;)n+=t.getHeight(s),a++,s++;return Math.max(1,a)},Xe=(t,o,r)=>{if(r===0)return 0;if(!t.isVariable())return Math.floor(o/t.getHeight(0));let e=0,a=0;for(let n=r-1;n>=0;n--){let s=t.getHeight(n);if(a+s>o)break;a+=s,e++}return Math.max(e,1)},je=(t,o,r)=>{if(r===0)return 0;let e=Math.floor(o),a=o-e,n=Math.max(0,Math.min(e,r-1));return t.getOffset(n)+a*t.getHeight(n)}});var Te,St,Ge,It,Ze=Fe(()=>{"use strict";Tt();Te=(t,o)=>{let r=o.getTotalHeight(),e=r>16e6,a=e?16e6:r,n=r>0?a/r:1;return{isCompressed:e,actualHeight:r,virtualHeight:a,ratio:n}},St=(t,o,r,e,a,n)=>{if(e===0||o===0)return n.start=0,n.end=-1,n;if(!a.isCompressed){let c=r.indexAtOffset(t),m=r.indexAtOffset(t+o);return m<e-1&&m++,n.start=Math.max(0,c),n.end=Math.min(e-1,Math.max(0,m)),n}let{virtualHeight:s}=a,y=t/s*e,f=Math.floor(y),u=yt(r,Math.max(0,f),o,e),T=Math.ceil(y)+u,L=s-o-t;if(L<=o&&L>=-1){let c=Xe(r,o,e),m=Math.max(0,e-c),b=Math.max(0,Math.min(1,1-L/o));f=Math.floor(f+(m-f)*b),T=L<=1?e-1:Math.min(e-1,f+u)}return n.start=Math.max(0,f),n.end=Math.min(e-1,Math.max(0,T)),n},Ge=(t,o,r,e,a,n,s)=>{if(!n.isCompressed||e===0)return r.getOffset(t);let{virtualHeight:l}=n,y=l-a,f=y-o;if(f<=a&&f>=-1){if(o>=y-1){let H=r.getTotalHeight()-r.getOffset(t);return a-H}let I=Xe(r,a,e),L=Math.max(0,e-I),m=o/l*e,b=Math.max(0,Math.min(1,1-f/a)),v=r.getOffset(t)-r.getOffset(L),S=r.getOffset(t)-je(r,m,e);return S+(v-S)*b}let T=o/l*e;return r.getOffset(t)-je(r,T,e)},It=(t,o,r,e,a,n="start")=>{if(e===0)return 0;let s;if(a.isCompressed){if(n==="end"&&t===e-1)return Math.max(0,a.virtualHeight-r);s=t/e*a.virtualHeight}else s=o.getOffset(t);let l=o.getHeight(t);switch(n){case"center":s-=(r-l)/2;break;case"end":s-=r-l;break}let y=a.virtualHeight-r;return Math.max(0,Math.min(s,y))}});var Me,Qe=Fe(()=>{"use strict";Me=t=>t!==null&&typeof t=="object"&&t.__groupHeader===!0});var Ct={};Tn(Ct,{createGridRenderer:()=>Je});var On,Je,et=Fe(()=>{"use strict";Ze();Qe();On=(t=200)=>{let o=[];return{acquire:()=>{let n=o.pop();if(n)return n;let s=document.createElement("div");return s.setAttribute("role","option"),s},release:n=>{o.length<t&&(n.className="",n.textContent="",n.removeAttribute("style"),n.removeAttribute("data-index"),n.removeAttribute("data-id"),n.removeAttribute("data-row"),n.removeAttribute("data-col"),o.push(n))},clear:()=>{o.length=0}}},Je=(t,o,r,e,a,n,s,l)=>{let y=On(),f=new Map,u=n,T=!1,I=null,L=0,c="",m=C=>(I&&L===C||(I=Te(C,r),L=C),I),b={selected:!1,focused:!1},v=(C,x)=>(b.selected=C,b.focused=x,b),S=`${a}-item ${a}-grid-item`,H=`${a}-item--selected`,h=`${a}-item--focused`,M=(C,x)=>{typeof x=="string"?C.innerHTML=x:C.replaceChildren(x)},d=(C,x,D)=>{C.classList.toggle(H,x),C.classList.toggle(h,D)},E=(C,x)=>{let D=e.getRow(C);if(x){let O=x.totalItems,N=m(O);if(N.isCompressed)return Ge(D,x.scrollTop,r,O,x.containerHeight,N,x.rangeStart)}return r.getOffset(D)},p=(C,x,D)=>{let O=C.dataset.id?.startsWith("__group_header"),N=O?0:e.getCol(x),Y=O?0:e.getColumnOffset(N,u),oe;if(T){let de=e.getRow(x),$=0,ae=new Set;for(let j=0;j<x;j++){let re=e.getRow(j);if(re<de&&!ae.has(re)){let Q=r.getHeight(j);$+=Q,ae.add(re)}}oe=$}else oe=E(x,D);C.style.transform=`translate(${Math.round(Y)}px, ${Math.round(oe)}px)`},V=(C,x)=>{let D=C.dataset.id?.startsWith("__group_header"),O=D?u:e.getColumnWidth(u),N;if(T||D)N=r.getHeight(x)-e.gap;else{let Y=e.getRow(x);N=r.getHeight(Y)-e.gap}C.style.width=`${O}px`,C.style.height=`${N}px`},z=(C,x,D,O,N)=>{let Y=y.acquire(),oe=v(D,O);Y.className=S,Y.dataset.index=String(C),Y.dataset.id=String(x.id),Y.dataset.row=String(e.getRow(C)),Y.dataset.col=String(e.getCol(C)),Y.ariaSelected=String(D),l&&(Y.id=`${l}-item-${C}`),s&&(c=String(s()),Y.setAttribute("aria-setsize",c),Y.setAttribute("aria-posinset",String(C+1))),V(Y,C);let de=o(x,C,oe);return M(Y,de),d(Y,D,O),p(Y,C,N),Y},X=(C,x,D,O,N)=>{x.start===0&&C.length>0&&(T=Me(C[0]));for(let[$,ae]of f)($<x.start||$>x.end)&&(ae.element.remove(),y.release(ae.element),f.delete($));let Y=!1;if(s){let $=String(s());Y=$!==c,c=$}let oe=document.createDocumentFragment(),de=[];for(let $=x.start;$<=x.end;$++){let ae=$-x.start,j=C[ae];if(!j){console.warn(`\u26A0\uFE0F RENDER: Missing item at index ${$} (range: ${x.start}-${x.end}, items.length: ${C.length})`);continue}let re=D.has(j.id),Q=$===O,te=f.get($);if(te){let _=te.element.dataset.id,P=String(j.id);if(_!==P){let J=v(re,Q),B=o(j,$,J);M(te.element,B),te.element.dataset.id=P,te.element.dataset.row=String(e.getRow($)),te.element.dataset.col=String(e.getCol($)),V(te.element,$)}d(te.element,re,Q),te.element.ariaSelected=String(re),p(te.element,$,N),Y&&te.element.setAttribute("aria-setsize",c)}else{let _=z($,j,re,Q,N);oe.appendChild(_),de.push({index:$,element:_})}}if(de.length>0){t.appendChild(oe);for(let{index:$,element:ae}of de)f.set($,{index:$,element:ae})}},U=C=>{for(let[x,D]of f)p(D.element,x,C)},ee=(C,x,D,O)=>{let N=f.get(C);if(N){let Y=v(D,O),oe=o(x,C,Y);M(N.element,oe),d(N.element,D,O),N.element.dataset.id=String(x.id),N.element.ariaSelected=String(D),V(N.element,C)}},Z=(C,x,D)=>{let O=f.get(C);O&&d(O.element,x,D)},R=C=>f.get(C)?.element,A=C=>{if(!(Math.abs(C-u)<1)){u=C;for(let[x,D]of f)V(D.element,x),p(D.element,x)}},G=()=>{for(let[,C]of f)C.element.remove(),y.release(C.element);f.clear()};return{render:X,updatePositions:U,updateItem:ee,updateItemClasses:Z,getElement:R,updateContainerWidth:A,clear:G,destroy:()=>{G(),y.clear()}}}});import{useRef as xe,useEffect as ct,useCallback as Kn}from"react";var Cn="vlist";var wn=0,Ce=5,Ln=100,qe=2,Hn=(t=0)=>{let o=new Array(Ce);for(let r=0;r<Ce;r++)o[r]={position:0,time:0};return{velocity:0,lastPosition:t,lastTime:performance.now(),samples:o,sampleIndex:0,sampleCount:0}},Mn=(t,o)=>{let r=performance.now(),e=r-t.lastTime;if(e===0)return t;if(e>Ln){t.sampleCount=0,t.sampleIndex=0,t.velocity=0;let n=t.samples[0];return n.position=o,n.time=r,t.sampleIndex=1,t.sampleCount=1,t.lastPosition=o,t.lastTime=r,t}let a=t.samples[t.sampleIndex];if(a.position=o,a.time=r,t.sampleIndex=(t.sampleIndex+1)%Ce,t.sampleCount=Math.min(t.sampleCount+1,Ce),t.sampleCount>=qe){let n=(t.sampleIndex-t.sampleCount+Ce)%Ce,s=t.samples[n],l=o-s.position,y=r-s.time;t.velocity=y>0?Math.abs(l)/y:0}return t.lastPosition=o,t.lastTime=r,t},bt=(t,o)=>{if(typeof t=="number"){let n=o;return{getOffset:s=>s*t,getHeight:()=>t,indexAtOffset:s=>n===0||t===0?0:Math.max(0,Math.min(Math.floor(s/t),n-1)),getTotalHeight:()=>n*t,getTotal:()=>n,rebuild:s=>{n=s},isVariable:()=>!1}}let r=o,e=new Float64Array(0),a=n=>{r=n,e=new Float64Array(n+1),e[0]=0;for(let s=0;s<n;s++)e[s+1]=e[s]+t(s)};return a(o),{getOffset:n=>n<=0?0:n>=r?e[r]:e[n],getHeight:n=>t(n),indexAtOffset:n=>{if(r===0||n<=0)return 0;if(n>=e[r])return r-1;let s=0,l=r-1;for(;s<l;){let y=s+l+1>>>1;e[y]<=n?s=y:l=y-1}return s},getTotalHeight:()=>e[r]??0,getTotal:()=>r,rebuild:n=>a(n),isVariable:()=>!0}},Rn=()=>{let t={},o=(n,s)=>(t[n]||(t[n]=new Set),t[n].add(s),()=>r(n,s)),r=(n,s)=>{t[n]?.delete(s)};return{on:o,off:r,emit:(n,s)=>{t[n]?.forEach(l=>{try{l(s)}catch(y){console.error(`[vlist] Error in "${n}" handler:`,y)}})},clear:()=>{for(let n in t)delete t[n]}}},En=t=>{if(typeof t=="string"){let o=document.querySelector(t);if(!o)throw new Error(`[vlist/builder] Container not found: ${t}`);return o}return t},xn=(t,o,r,e)=>{let a=document.createElement("div");a.className=o,e&&a.classList.add(`${o}--horizontal`),a.setAttribute("role","listbox"),a.setAttribute("tabindex","0"),r&&a.setAttribute("aria-label",r),e&&a.setAttribute("aria-orientation","horizontal");let n=document.createElement("div");n.className=`${o}-viewport`,e?(n.style.overflowX="auto",n.style.overflowY="hidden"):n.style.overflow="auto",n.style.height="100%",n.style.width="100%";let s=document.createElement("div");s.className=`${o}-content`,s.style.position="relative",e?s.style.height="100%":s.style.width="100%";let l=document.createElement("div");return l.className=`${o}-items`,l.style.position="relative",e?l.style.height="100%":l.style.width="100%",s.appendChild(l),n.appendChild(s),a.appendChild(n),t.appendChild(a),{root:a,viewport:n,content:s,items:l}},Vn=(t=100)=>{let o=[];return{acquire:()=>{let r=o.pop();if(r)return r;let e=document.createElement("div");return e.setAttribute("role","option"),e},release:r=>{o.length<t&&(r.className="",r.textContent="",r.removeAttribute("style"),r.removeAttribute("data-index"),r.removeAttribute("data-id"),o.push(r))},clear:()=>{o.length=0}}},An=(t,o,r,e,a)=>{if(e===0||o===0){a.start=0,a.end=0;return}let n=r.indexAtOffset(t),s=r.indexAtOffset(t+o);s<e-1&&s++,a.start=Math.max(0,n),a.end=Math.min(e-1,Math.max(0,s))},_n=(t,o,r,e)=>{if(r===0){e.start=0,e.end=0;return}e.start=Math.max(0,t.start-o),e.end=Math.min(r-1,t.end+o)},Pn=(t,o,r,e,a)=>{if(e===0)return 0;let n=Math.max(0,Math.min(t,e-1)),s=o.getOffset(n),l=o.getHeight(n),y=Math.max(0,o.getTotalHeight()-r),f;switch(a){case"center":f=s-(r-l)/2;break;case"end":f=s-r+l;break;default:f=s}return Math.max(0,Math.min(f,y))},Fn=t=>t<.5?2*t*t:-1+(4-2*t)*t,Gn=t=>typeof t=="string"?{align:t,behavior:"auto",duration:300}:t&&typeof t=="object"?{align:t.align??"start",behavior:t.behavior??"auto",duration:t.duration??300}:{align:"start",behavior:"auto",duration:300},Ye=t=>{if(!t.container)throw new Error("[vlist/builder] Container is required");if(!t.item)throw new Error("[vlist/builder] item configuration is required");let o=t.direction==="horizontal",r=o?"width":"height",e=o?t.item.width:t.item.height;if(e==null)throw new Error(`[vlist/builder] item.${r} is required${o?" when direction is 'horizontal'":""}`);if(typeof e=="number"&&e<=0)throw new Error(`[vlist/builder] item.${r} must be a positive number`);if(typeof e!="number"&&typeof e!="function")throw new Error(`[vlist/builder] item.${r} must be a number or a function (index) => number`);if(!t.item.template)throw new Error("[vlist/builder] item.template is required");if(o&&t.reverse)throw new Error("[vlist/builder] horizontal direction cannot be combined with reverse mode");let a=new Map,n=!1,s={use(l){if(n)throw new Error("[vlist/builder] Cannot call .use() after .build()");return a.set(l.name,l),s},build(){if(n)throw new Error("[vlist/builder] .build() can only be called once");return n=!0,kn(t,a,o,e)}};return s};function kn(t,o,r,e){let{item:a,items:n,overscan:s=3,classPrefix:l=Cn,ariaLabel:y,reverse:f=!1,scroll:u}=t,T=u?.wheel??!0,I=u?.wrap??!1,L=f,c=`${l}-${wn++}`,m=e,b=r?typeof a.height=="number"?a.height:void 0:typeof a.width=="number"?a.width:void 0,v=a.template,S={overscan:s,classPrefix:l,reverse:L,wrap:I,horizontal:r,ariaIdPrefix:c},H=Array.from(o.values()).sort((i,g)=>(i.priority??50)-(g.priority??50)),h=new Set(H.map(i=>i.name));for(let i of H)if(i.conflicts){for(let g of i.conflicts)if(h.has(g))throw new Error(`[vlist/builder] ${i.name} and ${g} cannot be combined`)}if(r){if(h.has("withGrid"))throw new Error("[vlist/builder] withGrid cannot be used with direction: 'horizontal'");if(h.has("withGroups"))throw new Error("[vlist/builder] withGroups cannot be used with direction: 'horizontal'")}if(L){if(h.has("withGrid"))throw new Error("[vlist/builder] withGrid cannot be used with reverse: true");if(h.has("withGroups"))throw new Error("[vlist/builder] withGroups cannot be used with reverse: true")}let M=En(t.container),d=xn(M,l,y,r),E=Rn(),p=n?[...n]:[],V=bt(m,p.length),z=Vn(),X=d.viewport.clientHeight,U=d.viewport.clientWidth,ee=!1,Z=!1,R=0,A=null,G=null,k=Hn(0),C={start:0,end:0},x={start:0,end:0},D={start:-1,end:-1},O={viewportState:{scrollTop:0,containerHeight:X,totalHeight:V.getTotalHeight(),actualHeight:V.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},N=new Map,Y={selected:!1,focused:!1},oe=`${l}-item`,de="",$=new Map,ae=()=>{$.clear();for(let i=0;i<p.length;i++){let g=p[i];g&&$.set(g.id,i)}};ae();let j=null,re=()=>j?j.getTotal():p.length,Q=[],te=[],_=[],P=[],K=[],J=[],B=new Map,ne=()=>r?d.viewport.scrollLeft:d.viewport.scrollTop,se=i=>{r?d.viewport.scrollLeft=i:d.viewport.scrollTop=i},be=(i=2)=>{let g=V.getTotalHeight();return R+X>=g-i},ue=!1,ie,fe,le=(i,g,w,F,q)=>{An(i,g,w,F,q)},he=(i,g,w,F,q)=>Pn(i,g,w,F,q),ce=(i,g)=>{typeof g=="string"?i.innerHTML=g:i.replaceChildren(g)},ye=(i,g)=>{let w=Math.round(V.getOffset(g));r?i.style.transform=`translateX(${w}px)`:i.style.transform=`translateY(${w}px)`},Zt=(i,g)=>{let w=z.acquire();return w.className=oe,r?(w.style.width=`${V.getHeight(i)}px`,b!=null&&(w.style.height=`${b}px`)):w.style.height=`${V.getHeight(i)}px`,w.dataset.index=String(i),w.dataset.id=String(g.id),w.ariaSelected="false",w.id=`${c}-item-${i}`,de=String(re()),w.setAttribute("aria-setsize",de),w.setAttribute("aria-posinset",String(i+1)),ce(w,v(g,i,Y)),ye(w,i),w},Le=()=>{let i=`${V.getTotalHeight()}px`;r?d.content.style.width=i:d.content.style.height=i},Be=new Set,ze=-1,Qt=()=>{if(ee)return;let i=re();if(le(R,X,V,i,C),_n(C,s,i,x),x.start===D.start&&x.end===D.end)return;let g=String(i),w=g!==de;de=g;for(let[W,ge]of N)(W<x.start||W>x.end)&&(ge.remove(),z.release(ge),N.delete(W));let F=document.createDocumentFragment(),q=[];for(let W=x.start;W<=x.end;W++){let ge=j?j.getItem(W):p[W];if(!ge)continue;let pe=N.get(W);if(pe){let ve=pe.dataset.id,_e=String(ge.id);ve!==_e&&(ce(pe,v(ge,W,Y)),pe.dataset.id=_e,r?pe.style.width=`${V.getHeight(W)}px`:pe.style.height=`${V.getHeight(W)}px`),ye(pe,W);let Pe=Be.has(ge.id),hn=W===ze;pe.classList.toggle(`${l}-item--selected`,Pe),pe.classList.toggle(`${l}-item--focused`,hn),pe.ariaSelected=Pe?"true":"false",w&&pe.setAttribute("aria-setsize",de)}else{let ve=Zt(W,ge),_e=Be.has(ge.id),Pe=W===ze;_e&&(ve.classList.add(`${l}-item--selected`),ve.ariaSelected="true"),Pe&&ve.classList.add(`${l}-item--focused`),F.appendChild(ve),q.push({index:W,element:ve})}}if(q.length>0){d.items.appendChild(F);for(let{index:W,element:ge}of q)N.set(W,ge)}D.start=x.start,D.end=x.end,O.lastRenderRange.start=x.start,O.lastRenderRange.end=x.end,O.viewportState.scrollTop=R,O.viewportState.visibleRange.start=C.start,O.viewportState.visibleRange.end=C.end,O.viewportState.renderRange.start=x.start,O.viewportState.renderRange.end=x.end,E.emit("range:change",{range:{start:x.start,end:x.end}})},Jt=()=>{D.start=-1,D.end=-1,ie()};ie=Qt,fe=Jt;let He=()=>{if(ee)return;let i=ne(),g=i>=R?"down":"up";k=Mn(k,i),d.root.classList.contains(`${l}--scrolling`)||d.root.classList.add(`${l}--scrolling`),R=i,ie(),E.emit("scroll",{scrollTop:i,direction:g}),E.emit("velocity:change",{velocity:k.velocity,reliable:k.sampleCount>=qe});for(let w=0;w<Q.length;w++)Q[w](i,g);G&&clearTimeout(G),G=setTimeout(()=>{d.root.classList.remove(`${l}--scrolling`),k.velocity=0,k.sampleCount=0,E.emit("velocity:change",{velocity:0,reliable:!1})},u?.idleTimeout??150)},Ve=null,Ie=d.viewport;Ie.addEventListener("scroll",He,{passive:!0}),r&&T&&(Ve=i=>{i.deltaX||(i.preventDefault(),d.viewport.scrollLeft+=i.deltaY)},d.viewport.addEventListener("wheel",Ve)),d.viewport.classList.add(`${l}-viewport--custom-scrollbar`);let mt=i=>{let w=i.target.closest("[data-index]");if(w){let F=parseInt(w.dataset.index??"-1",10);if(F>=0){let q=j?.getItem(F)??p[F];if(q){if(q.__groupHeader)return;E.emit("item:click",{item:q,index:F,event:i})}}}for(let F=0;F<te.length;F++)te[F](i)},en=i=>{let w=i.target.closest("[data-index]");if(w){let F=parseInt(w.dataset.index??"-1",10);if(F>=0){let q=j?.getItem(F)??p[F];if(q){if(q.__groupHeader)return;E.emit("item:dblclick",{item:q,index:F,event:i})}}}},gt=i=>{for(let g=0;g<_.length;g++)_[g](i)};d.items.addEventListener("click",mt),d.items.addEventListener("dblclick",en),d.root.addEventListener("keydown",gt);let Ue=!0,tn=()=>U,nn=()=>X,Ne=new ResizeObserver(i=>{if(!ee)for(let g of i){let w=g.contentRect.height,F=g.contentRect.width,q=r?F:w;if(U=F,Math.abs(q-X)>1&&(X=q,O.viewportState.containerHeight=q,Z&&(Le(),ie(),E.emit("resize",{height:w,width:F}))),Z)for(let W=0;W<P.length;W++)P[W](F,w)}});Ue&&Ne.observe(d.viewport);let me={get dom(){return d},get heightCache(){return V},get emitter(){return E},get config(){return S},get rawConfig(){return t},get renderer(){return{render:(i,g,w,F,q)=>{Be=w,ze=F,fe()},updateItemClasses:(i,g,w)=>{let F=N.get(i);F&&(F.classList.toggle(`${l}-item--selected`,g),F.classList.toggle(`${l}-item--focused`,w),F.ariaSelected=g?"true":"false")},updatePositions:()=>{},updateItem:()=>{},getElement:i=>N.get(i)??null,clear:()=>{},destroy:()=>{}}},set renderer(i){},get dataManager(){return j},set dataManager(i){j=i},get scrollController(){return We},set scrollController(i){We=i},state:O,getContainerWidth(){return U},afterScroll:Q,clickHandlers:te,keydownHandlers:_,resizeHandlers:P,contentSizeHandlers:K,destroyHandlers:J,methods:B,replaceTemplate(i){v=i},replaceRenderer(i){},replaceDataManager(i){j=i},replaceScrollController(i){We=i},getItemsForRange(i){let g=[];for(let w=i.start;w<=i.end;w++){let F=j?j.getItem(w):p[w];F&&g.push(F)}return g},getAllLoadedItems(){if(j){let i=j.getTotal(),g=[];for(let w=0;w<i;w++){let F=j.getItem(w);F&&g.push(F)}return g}return[...p]},getVirtualTotal(){return re()},getCachedCompression(){return{isCompressed:!1,actualHeight:V.getTotalHeight(),virtualHeight:V.getTotalHeight(),ratio:1}},getCompressionContext(){return{scrollTop:R,totalItems:re(),containerHeight:X,rangeStart:x.start}},renderIfNeeded(){ie()},forceRender(){fe()},getRenderFns(){return{renderIfNeeded:ie,forceRender:fe}},setRenderFns(i,g){ie=i,fe=g},setVirtualTotalFn(i){re=i},rebuildHeightCache(i){V.rebuild(i??re())},setHeightConfig(i){V=bt(i,re())},updateContentSize(i){let g=`${i}px`;r?d.content.style.width=g:d.content.style.height=g},updateCompressionMode(){},setVisibleRangeFn(i){le=i},setScrollToPosFn(i){he=i},setPositionElementFn(i){ye=i},setScrollFns(i,g){ne=i,se=w=>{g(w),He()}},setScrollTarget(i){Ie.removeEventListener("scroll",He),Ie=i,Ie.addEventListener("scroll",He,{passive:!0})},getScrollTarget(){return Ie},setContainerDimensions(i){tn=i.width,nn=i.height,U=i.width(),X=i.height(),O.viewportState.containerHeight=X},disableViewportResize(){Ue&&(Ue=!1,Ne.unobserve(d.viewport))}};j={getState:()=>({total:p.length,cached:p.length,isLoading:!1,pendingRanges:[],error:void 0,hasMore:!1,cursor:void 0}),getTotal:()=>p.length,getCached:()=>p.length,getIsLoading:()=>!1,getHasMore:()=>!1,getStorage:()=>null,getPlaceholders:()=>null,getItem:i=>p[i],getItemById:i=>{let g=$.get(i);return g!==void 0?p[g]:void 0},getIndexById:i=>$.get(i)??-1,isItemLoaded:i=>i>=0&&i<p.length&&p[i]!==void 0,getItemsInRange:(i,g)=>{let w=[],F=Math.max(0,i),q=Math.min(g,p.length-1);for(let W=F;W<=q;W++)w.push(p[W]);return w},setTotal:i=>{},setItems:(i,g=0,w)=>{if(g===0&&(w!==void 0||p.length===0))p=[...i];else{let F=g+i.length;p.length<F&&(p.length=F);for(let q=0;q<i.length;q++)p[g+q]=i[q]}if(ae(),Z){V.rebuild(re()),Le(),me.updateCompressionMode();for(let F=0;F<K.length;F++)K[F]();fe()}},updateItem:(i,g)=>{let w=$.get(i);if(w===void 0)return!1;let F=p[w];if(!F)return!1;p[w]={...F,...g},g.id!==void 0&&g.id!==i&&($.delete(i),$.set(g.id,w));let q=N.get(w);return q&&(ce(q,v(p[w],w,Y)),q.dataset.id=String(p[w].id)),!0},removeItem:i=>{let g=$.get(i);if(g===void 0)return!1;if(p.splice(g,1),ae(),Z){V.rebuild(re()),Le(),me.updateCompressionMode();for(let w=0;w<K.length;w++)K[w]();fe()}return!0},loadRange:async()=>{},ensureRange:async()=>{},loadInitial:async()=>{},loadMore:async()=>!1,reload:async()=>{},evictDistant:()=>{},clear:()=>{p=[],$.clear()},reset:()=>{p=[],$.clear(),Z&&(V.rebuild(0),Le(),fe())}};let We={getScrollTop:()=>ne(),scrollTo:i=>{se(i),R=i,ie()},scrollBy:i=>{let g=ne()+i;se(g),R=g,ie()},isAtTop:()=>R<=2,isAtBottom:(i=2)=>be(i),getScrollPercentage:()=>{let i=V.getTotalHeight(),g=Math.max(0,i-X);return g>0?R/g:0},getVelocity:()=>k.velocity,isTracking:()=>k.sampleCount>=qe,isScrolling:()=>d.root.classList.contains(`${l}--scrolling`),updateConfig:()=>{},enableCompression:()=>{},disableCompression:()=>{},isCompressed:()=>ue,isWindowMode:()=>!1,updateContainerHeight:i=>{X=i},destroy:()=>{}},pt=new Map;for(let i of H)if(i.methods)for(let g of i.methods){let w=pt.get(g);if(w)throw new Error(`[vlist/builder] Method "${g}" is registered by both "${w}" and "${i.name}"`);pt.set(g,i.name)}for(let i of H)i.setup(me);if(Z=!0,me.state.isInitialized=!0,Le(),ie(),L&&p.length>0){let i=he(p.length-1,V,X,p.length,"end");se(i),R=i,ie()}let rn=i=>{me.dataManager.setItems(i,0,i.length)},on=L?i=>{let g=be(2),w=p.length;if(me.dataManager.setItems(i,w),g&&p.length>0){let F=he(p.length-1,V,X,p.length,"end");se(F),R=F,ie()}}:i=>{let g=p.length;me.dataManager.setItems(i,g)},sn=L?i=>{let g=ne(),w=V.getTotalHeight(),F=[...p];me.dataManager.clear(),me.dataManager.setItems([...i,...F],0);let W=V.getTotalHeight()-w;W>0&&(se(g+W),R=g+W)}:i=>{let g=[...p];me.dataManager.clear(),me.dataManager.setItems([...i,...g],0)},an=(i,g)=>{me.dataManager.updateItem(i,g)},ln=i=>{me.dataManager.removeItem(i)},dn=async()=>{me.dataManager.reload&&await me.dataManager.reload()},Ae=()=>{A!==null&&(cancelAnimationFrame(A),A=null)},un=(i,g,w)=>{if(Ae(),Math.abs(g-i)<1){se(g),R=g,ie();return}let F=performance.now(),q=W=>{let ge=W-F,pe=Math.min(ge/w,1),ve=i+(g-i)*Fn(pe);se(ve),R=ve,ie(),pe<1?A=requestAnimationFrame(q):A=null};A=requestAnimationFrame(q)},ft=(i,g)=>{let{align:w,behavior:F,duration:q}=Gn(g),W=re(),ge=i;I&&W>0&&(ge=(ge%W+W)%W);let pe=he(ge,V,X,W,w);F==="smooth"?un(ne(),pe,q):(Ae(),se(pe))},cn=(i,g)=>{let w=$.get(i)??me.dataManager.getIndexById(i);w>=0&&ft(w,g)},mn=()=>ne(),gn=(i,g)=>E.on(i,g),pn=(i,g)=>{E.off(i,g)},fn=()=>{if(!ee){ee=!0,me.state.isDestroyed=!0,d.items.removeEventListener("click",mt),d.root.removeEventListener("keydown",gt),Ie.removeEventListener("scroll",He),Ne.disconnect(),Ve&&d.viewport.removeEventListener("wheel",Ve),G&&clearTimeout(G);for(let i=0;i<J.length;i++)J[i]();for(let i of H)i.destroy&&i.destroy();Ae();for(let[,i]of N)i.remove(),z.release(i);N.clear(),z.clear(),E.clear(),d.root.remove()}},ht={get element(){return d.root},get items(){return B.has("_getItems")?B.get("_getItems")():p},get total(){return B.has("_getTotal")?B.get("_getTotal")():re()},setItems:B.has("setItems")?B.get("setItems"):rn,appendItems:B.has("appendItems")?B.get("appendItems"):on,prependItems:B.has("prependItems")?B.get("prependItems"):sn,updateItem:B.has("updateItem")?B.get("updateItem"):an,removeItem:B.has("removeItem")?B.get("removeItem"):ln,reload:B.has("reload")?B.get("reload"):dn,scrollToIndex:B.has("scrollToIndex")?B.get("scrollToIndex"):ft,scrollToItem:B.has("scrollToItem")?B.get("scrollToItem"):cn,cancelScroll:B.has("cancelScroll")?B.get("cancelScroll"):Ae,getScrollPosition:B.has("getScrollPosition")?B.get("getScrollPosition"):mn,on:gn,off:pn,destroy:fn};for(let[i,g]of B)i==="setItems"||i==="appendItems"||i==="prependItems"||i==="updateItem"||i==="removeItem"||i==="reload"||i==="scrollToIndex"||i==="scrollToItem"||i==="cancelScroll"||i==="getScrollPosition"||(ht[i]=g);return ht}var vt=t=>{let o=Math.max(1,Math.floor(t.columns)),r=t.gap??0,e=t.isHeaderFn,a={row:0,col:0},n=c=>{if(c<=0)return 0;if(!e)return Math.ceil(c/o);let m=0,b=0,v=0;for(let S=0;S<c;S++)e(S)?(v++,b>0&&(m++,b=0),m++,b=0):(b++,b>=o&&(m++,b=0));return b>0&&m++,m},s=c=>(a.row=l(c),a.col=y(c),a),l=c=>{if(!e)return Math.floor(c/o);let m=0,b=0;for(let v=0;v<=c;v++)if(e(v)){if(b>0&&(m++,b=0),v===c)return m;m++,b=0}else{if(v===c)return m;b++,b>=o&&(m++,b=0)}return console.warn(`\u26A0\uFE0F getRow(${c}) fell through - returning ${m}`),m},y=c=>{if(!e)return c%o;if(e(c))return 0;let m=0;for(let b=0;b<=c;b++)if(e(b))m=0;else{if(b===c)return m;m++,m>=o&&(m=0)}return m},f=(c,m,b)=>{if(b<=0)return{start:0,end:-1};if(!e){let M=Math.max(0,c*o),d=Math.min(b-1,(m+1)*o-1);return{start:M,end:d}}let v=-1,S=-1,H=0,h=0;for(let M=0;M<b&&(e(M)?(h>0&&(H++,h=0),H>=c&&H<=m&&(v===-1&&(v=M),S=M),H++,h=0):(H>=c&&H<=m&&(v===-1&&(v=M),S=M),h++,h>=o&&(H++,h=0)),!(H>m&&h===0));M++);return v===-1?{start:0,end:-1}:{start:v,end:S}},u=(c,m,b)=>{if(m<0||m>=o)return-1;let v=c*o+m;return v<0||v>=b?-1:v},T=c=>{let m=(o-1)*r;return Math.max(0,(c-m)/o)};return{get columns(){return o},get gap(){return r},update:c=>{c.columns!==void 0&&(o=Math.max(1,Math.floor(c.columns))),c.gap!==void 0&&(r=c.gap),c.isHeaderFn!==void 0&&(e=c.isHeaderFn)},getTotalRows:n,getPosition:s,getRow:l,getCol:y,getItemRange:f,getItemIndex:u,getColumnWidth:T,getColumnOffset:(c,m)=>{let b=T(m);return c*(b+r)}}};et();var wt=(t,o,r,e,a,n)=>{if(e===0||o===0)return n.start=0,n.end=-1,n;let s=r.indexAtOffset(t),l=r.indexAtOffset(t+o);return l<e-1&&l++,n.start=Math.max(0,s),n.end=Math.min(e-1,Math.max(0,l)),n},Lt=(t,o,r,e)=>r===0?(e.start=0,e.end=-1,e):(e.start=Math.max(0,t.start-o),e.end=Math.min(r-1,t.end+o),e),Ht=(t,o,r,e,a,n)=>{if(e===0)return 0;let s=Math.max(0,Math.min(t,e-1)),l=o.getOffset(s),y=o.getHeight(s),f=o.getTotalHeight(),u=Math.max(0,f-r),T;switch(n){case"center":T=l-r/2+y/2;break;case"end":T=l-r+y;break;default:T=l;break}return Math.max(0,Math.min(T,u))};var tt=(t,o,r,e,a,n=wt)=>(n(t.scrollTop,t.containerHeight,o,r,a,t.visibleRange),Lt(t.visibleRange,e,r,t.renderRange),t.totalHeight=a.virtualHeight,t.actualHeight=a.actualHeight,t.isCompressed=a.isCompressed,t.compressionRatio=a.ratio,t),Se=(t,o,r,e,a="start",n,s=Ht)=>s(t,o,r,e,n,a);var Mt=t=>{if(!t.columns||t.columns<1)throw new Error("[vlist/builder] withGrid: columns must be a positive integer >= 1");let o=null,r=null;return{name:"withGrid",priority:10,setup(e){let{dom:a,emitter:n,config:s,rawConfig:l}=e,{classPrefix:y}=s;if(s.horizontal)throw new Error("[vlist/builder] withGrid cannot be used with direction: 'horizontal'");if(s.reverse)throw new Error("[vlist/builder] withGrid cannot be used with reverse: true");let f=l.items?.some(h=>h.__groupHeader===!0),u={columns:t.columns,gap:t.gap??0};f&&(u.isHeaderFn=h=>{let M=e.dataManager.getItem(h);return!!(M&&M.__groupHeader===!0)}),o=vt(u);let T=o.gap;e.setVirtualTotalFn(()=>{let h=e.dataManager.getTotal();return o.getTotalRows(h)});let I=l.item,L=s.horizontal?I.width:I.height,c={containerWidth:e.getContainerWidth(),columns:o.columns,gap:o.gap};typeof L=="function"?e.setHeightConfig(h=>{let M=c.containerWidth-2,d=(c.columns-1)*c.gap,E=(M-d)/c.columns,p={containerWidth:c.containerWidth,columns:c.columns,gap:c.gap,columnWidth:E,row:o.getRow(h),column:o.getCol(h),totalRows:o.getTotalRows(e.dataManager.getTotal()),totalColumns:c.columns};return L(h,p)+c.gap}):T>0&&e.setHeightConfig(L+T),e.rebuildHeightCache(),a.root.classList.add(`${y}--grid`);let m=e.getContainerWidth(),b=l.item.template,v=()=>{r=Je(a.items,b,e.heightCache,o,y,m,()=>e.dataManager.getTotal(),s.ariaIdPrefix),e.replaceRenderer(r)};v(),e.methods.set("_getGridLayout",()=>o),e.methods.set("_getGridConfig",()=>u),e.methods.set("_replaceGridRenderer",h=>{r=h}),e.methods.set("_updateGridLayoutForGroups",h=>{o.update({isHeaderFn:h});let M=e.dataManager.getTotal(),d=0;for(let E=0;E<M;E++)if(o.getCol(E)===0){let p=e.heightCache.getHeight(E);d+=p}e.heightCache.getTotalHeight=()=>d,e.dom.content.style.height=`${d}px`,v()}),e.methods.set("updateGrid",h=>{if(h.columns!==void 0){if(!Number.isInteger(h.columns)||h.columns<1)throw new Error("[vlist/builder] updateGrid: columns must be a positive integer >= 1");u.columns=h.columns}if(h.gap!==void 0){if(h.gap<0)throw new Error("[vlist/builder] updateGrid: gap must be non-negative");u.gap=h.gap}o&&o.update(u);let M=e.getContainerWidth();c.containerWidth=M,c.columns=u.columns,c.gap=u.gap??0,r&&r.updateContainerWidth(M),e.rebuildHeightCache(),e.updateContentSize(e.heightCache.getTotalHeight()),e.updateCompressionMode();for(let d=0;d<e.contentSizeHandlers.length;d++)e.contentSizeHandlers[d]();r&&r.clear(),e.forceRender()});let S=()=>{if(e.state.isDestroyed)return;let h=e.scrollController.getScrollTop(),M=e.state.viewportState.containerHeight,d=e.getVirtualTotal(),E={start:0,end:0};if(d===0||M===0)E.start=0,E.end=0;else{E.start=Math.max(0,e.heightCache.indexAtOffset(h));let A=e.heightCache.indexAtOffset(h+M);A<d-1&&A++,E.end=Math.min(d-1,Math.max(0,A))}let p=s.overscan??3,V={start:Math.max(0,E.start-p),end:Math.min(d-1,E.end+p)};e.state.viewportState.scrollTop=h,e.state.viewportState.visibleRange=E,e.state.viewportState.renderRange=V;let z=e.state.lastRenderRange,X=e.state.viewportState.isCompressed;if(V.start===z.start&&V.end===z.end){X&&r.updatePositions(e.getCompressionContext());return}let U=e.dataManager.getTotal(),ee=o.getItemRange(V.start,V.end,U),Z=e.dataManager.getItemsInRange(ee.start,ee.end),R=X?e.getCompressionContext():void 0;r.render(Z,ee,new Set,-1,R),e.state.lastRenderRange={...V},n.emit("range:change",{range:V})},H=()=>{e.state.isDestroyed||(e.state.lastRenderRange={start:-1,end:-1},S())};e.setRenderFns(S,H),e.resizeHandlers.push((h,M)=>{r&&r.updateContainerWidth(h)}),e.methods.set("scrollToIndex",(h,M)=>{let d=Math.floor(h/t.columns),{align:E,behavior:p}=$n(M),V=e.dataManager.getState(),z=o.getTotalRows(V.total),X=Math.max(0,Math.min(d,z-1)),U=Se(X,e.heightCache,e.state.viewportState.containerHeight,z,E,e.getCachedCompression());e.scrollController.scrollTo(U)}),e.methods.has("_getTotal")||e.methods.set("_getTotal",()=>e.dataManager.getTotal()),e.destroyHandlers.push(()=>{r&&(r.destroy(),r=null),a.root.classList.remove(`${y}--grid`)})},destroy(){r&&(r.destroy(),r=null)}}},nt=300,$n=t=>typeof t=="string"?{align:t,behavior:"auto",duration:nt}:t&&typeof t=="object"?{align:t.align??"start",behavior:t.behavior??"auto",duration:t.duration??nt}:{align:"start",behavior:"auto",duration:nt};var rt=(t,o)=>{let r=0,e=t.length-1;for(;r<e;){let a=r+e+1>>>1;t[a].headerLayoutIndex<=o?r=a:e=a-1}return r},Rt=(t,o)=>{let r=0,e=t.length-1;for(;r<e;){let a=r+e+1>>>1;t[a].firstDataIndex<=o?r=a:e=a-1}return r},Et=(t,o)=>{if(t===0)return[];let r=[],e=o(0),a=0,n=0;for(let s=1;s<t;s++){let l=o(s);if(l!==e){let y=s-a;r.push({key:e,groupIndex:r.length,headerLayoutIndex:n,firstDataIndex:a,count:y}),n=n+1+y,e=l,a=s}}return r.push({key:e,groupIndex:r.length,headerLayoutIndex:n,firstDataIndex:a,count:t-a}),r},ot=(t,o)=>{if(t.length===0||o.length===0)return[];let r=t.length+o.length,e=new Array(r),a=0;for(let n of o){e[a]={id:`__group_header_${n.groupIndex}`,__groupHeader:!0,groupKey:n.key,groupIndex:n.groupIndex},a++;for(let s=0;s<n.count;s++)e[a]=t[n.firstDataIndex+s],a++}return e},st=(t,o)=>{let r=typeof o=="number"?e=>o:o;return e=>{let a=t.getEntry(e);return a.type==="header"?t.getHeaderHeight(a.group.groupIndex):r(a.dataIndex)}},xt=(t,o)=>{let r=Et(t,o.getGroupForIndex),e=t+r.length,a=o.headerHeight;return{get totalEntries(){return e},get groupCount(){return r.length},get groups(){return r},getEntry:I=>{if(r.length===0)return{type:"item",dataIndex:I,group:{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0}};let L=rt(r,I),c=r[L];if(I===c.headerLayoutIndex)return{type:"header",group:c};let m=I-c.headerLayoutIndex-1;return{type:"item",dataIndex:c.firstDataIndex+m,group:c}},layoutToDataIndex:I=>{if(r.length===0)return I;let L=rt(r,I),c=r[L];if(I===c.headerLayoutIndex)return-1;let m=I-c.headerLayoutIndex-1;return c.firstDataIndex+m},dataToLayoutIndex:I=>{if(r.length===0)return I;let L=Rt(r,I),c=r[L],m=I-c.firstDataIndex;return c.headerLayoutIndex+1+m},getGroupAtLayoutIndex:I=>{if(r.length===0)return{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0};let L=rt(r,I);return r[L]},getGroupAtDataIndex:I=>{if(r.length===0)return{key:"",groupIndex:0,headerLayoutIndex:0,firstDataIndex:0,count:0};let L=Rt(r,I);return r[L]},getHeaderHeight:typeof a=="number"?I=>a:I=>{let L=r[I];return L?a(L.key,I):0},rebuild:I=>{r=Et(I,o.getGroupForIndex),e=I+r.length}}};var Vt=(t,o,r,e,a)=>{let n=document.createElement("div");n.className=`${a}-sticky-header`,n.setAttribute("role","presentation"),n.setAttribute("aria-hidden","true"),n.style.position="absolute",n.style.top="0",n.style.left="0",n.style.right="0",n.style.zIndex="5",n.style.pointerEvents="none",n.style.willChange="transform",n.style.overflow="hidden",t.insertBefore(n,t.firstChild);let s=-1,l=!1,y=0,f=m=>{if(m===s)return;s=m;let b=o.groups;if(m<0||m>=b.length){n.textContent="";return}let v=b[m],S=e.headerTemplate(v.key,v.groupIndex),H=o.getHeaderHeight(m);n.style.height=`${H}px`,typeof S=="string"?n.innerHTML=S:n.replaceChildren(S)},u=m=>{let b=o.groups;if(b.length===0){I();return}let v=0;for(let d=b.length-1;d>=0;d--)if(r.getOffset(b[d].headerLayoutIndex)<=m){v=d;break}let S=r.getOffset(b[0].headerLayoutIndex);if(m<S){I();return}l||T(),f(v);let H=o.getHeaderHeight(v),h=0,M=v+1;if(M<b.length){let E=r.getOffset(b[M].headerLayoutIndex)-m;E<H&&(h=E-H)}h!==y&&(y=h,n.style.transform=h===0?"":`translateY(${Math.round(h)}px)`)},T=()=>{l||(l=!0,n.style.display="")},I=()=>{l&&(l=!1,n.style.display="none",s=-1,y=0,n.style.transform="")},L=()=>{let m=s;s=-1,m>=0&&f(m)},c=()=>{n.remove(),s=-1,l=!1};return n.style.display="none",{update:u,refresh:L,show:T,hide:I,destroy:c}};Qe();var At=t=>{if(!t.getGroupForIndex)throw new Error("[vlist/builder] withGroups: getGroupForIndex is required");if(t.headerHeight==null||t.headerHeight<=0)throw new Error("[vlist/builder] withGroups: headerHeight must be a positive number");if(!t.headerTemplate)throw new Error("[vlist/builder] withGroups: headerTemplate is required");let o=null,r=null,e=[],a=[];return{name:"withGroups",priority:10,setup(n){let{dom:s,config:l,rawConfig:y}=n,{classPrefix:f}=l;if(l.horizontal)throw new Error("[vlist/builder] withGroups cannot be used with direction: 'horizontal'");if(l.reverse)throw new Error("[vlist/builder] withGroups cannot be used with reverse: true");let T=y.item.height;e=y.items?[...y.items]:[];let I=e.length,L={getGroupForIndex:t.getGroupForIndex,headerHeight:t.headerHeight,headerTemplate:t.headerTemplate,sticky:t.sticky??!1};o=xt(I,L),a=ot(e,o.groups);let c=st(o,T);n.setHeightConfig(c),n.rebuildHeightCache(a.length),n.dataManager.setItems(a,0,a.length);let m=y.item.template,{headerTemplate:b}=t,v=((d,E,p)=>Me(d)?b(d.groupKey,d.groupIndex):m(d,E,p)),S=n.methods.get("_getGridLayout"),H=n.methods.get("_replaceGridRenderer"),h=n.methods.get("_updateGridLayoutForGroups");if(S&&H){h&&h(V=>{let z=a[V];return!!(z&&Me(z))});let{createGridRenderer:d}=(et(),In(Ct)),E=S(),p=d(s.items,v,n.heightCache,E,f,n.getContainerWidth(),()=>n.dataManager.getTotal(),l.ariaIdPrefix);H(p)}else n.replaceTemplate(v);if(s.root.classList.add(`${f}--grouped`),t.sticky!==!1){r=Vt(s.root,o,n.heightCache,{...L,sticky:L.sticky??!1},f);let d=r;n.afterScroll.push((E,p)=>{d.update(E)}),r.update(n.scrollController.getScrollTop())}let M=()=>{if(!o)return;o.rebuild(e.length),a=ot(e,o.groups);let d=st(o,T);n.setHeightConfig(d),n.rebuildHeightCache(a.length),n.dataManager.setItems(a,0,a.length),r&&r.refresh()};n.methods.set("setItems",d=>{e=[...d],M()}),n.methods.set("appendItems",d=>{e=[...e,...d],M()}),n.methods.set("prependItems",d=>{e=[...d,...e],M()}),n.methods.set("removeItem",d=>{e=e.filter(E=>E.id!==d),M()}),n.methods.set("scrollToIndex",(d,E)=>{let p=o.dataToLayoutIndex(d),{align:V,behavior:z}=Bn(E),X=n.dataManager.getTotal(),U=Se(p,n.heightCache,n.state.viewportState.containerHeight,X,V,n.getCachedCompression());n.scrollController.scrollTo(U)}),n.methods.set("_getItems",()=>e),n.methods.set("_getTotal",()=>e.length),n.destroyHandlers.push(()=>{r&&(r.destroy(),r=null),s.root.classList.remove(`${f}--grouped`)})},destroy(){r&&(r.destroy(),r=null)}}},it=300,Bn=t=>typeof t=="string"?{align:t,behavior:"auto",duration:it}:t&&typeof t=="object"?{align:t.align??"start",behavior:t.behavior??"auto",duration:t.duration??it}:{align:"start",behavior:"auto",duration:it};var _t=t=>({selected:new Set(t??[]),focusedIndex:-1}),at=(t,o,r)=>{if(r==="none")return t;let e=new Set(t.selected);if(r==="single")e.clear(),o.length>0&&e.add(o[0]);else for(let a of o)e.add(a);return{...t,selected:e}},lt=(t,o)=>{let r=new Set(t.selected);for(let e of o)r.delete(e);return{...t,selected:r}},ke=(t,o,r)=>r==="none"?t:t.selected.has(o)?lt(t,[o]):at(t,[o],r),Pt=(t,o,r)=>r!=="multiple"?t:{...t,selected:new Set(o.map(e=>e.id))},Ft=t=>({...t,selected:new Set}),Gt=(t,o)=>(t.focusedIndex=o,t),kt=(t,o,r=!0)=>{if(o===0)return t;let e=t.focusedIndex-1;return e<0&&(e=r?o-1:0),t.focusedIndex=e,t},Dt=(t,o,r=!0)=>{if(o===0)return t;let e=t.focusedIndex+1;return e>=o&&(e=r?0:o-1),t.focusedIndex=e,t},Ot=(t,o)=>(o===0||(t.focusedIndex=0),t),$t=(t,o)=>(o===0||(t.focusedIndex=o-1),t);var De=t=>Array.from(t.selected),Oe=(t,o)=>{let r=[];for(let e of t.selected){let a=o(e);a&&r.push(a)}return r};var dt=t=>{let o=t?.mode??"single",r=t?.initial,e=_t(r),a=null;return{name:"withSelection",priority:50,methods:["select","deselect","toggleSelect","selectAll","clearSelection","getSelected","getSelectedItems"],setup(n){let{dom:s,emitter:l,config:y}=n,{classPrefix:f,ariaIdPrefix:u}=y;if(o==="none"){n.methods.set("select",()=>{}),n.methods.set("deselect",()=>{}),n.methods.set("toggleSelect",()=>{}),n.methods.set("selectAll",()=>{}),n.methods.set("clearSelection",()=>{}),n.methods.set("getSelected",()=>[]),n.methods.set("getSelectedItems",()=>[]),n.methods.set("setSelectionMode",()=>{});return}let{renderIfNeeded:T,forceRender:I}=n.getRenderFns(),L=()=>{n.dom.items.querySelectorAll("[data-index]").forEach(H=>{let h=H,M=h.dataset.id;if(M!==void 0){let d=/^\d+$/.test(M)?parseInt(M,10):M,E=e.selected.has(d),V=parseInt(h.dataset.index??"-1",10)===e.focusedIndex;h.classList.toggle(`${f}-item--selected`,E),h.classList.toggle(`${f}-item--focused`,V),h.ariaSelected=E?"true":"false"}})},c=()=>{n.state.isDestroyed||(T(),L())},m=()=>{n.state.isDestroyed||(I(),L())};n.setRenderFns(c,m);let b=()=>{L(),l.emit("selection:change",{selected:De(e),items:Oe(e,S=>n.dataManager.getItemById(S))})};a=document.createElement("div"),a.setAttribute("aria-live","polite"),a.setAttribute("aria-atomic","true"),a.className=`${f}-live-region`,a.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",s.root.appendChild(a);let v=a;l.on("selection:change",({selected:S})=>{let H=S.length;H===0?v.textContent="":H===1?v.textContent="1 item selected":v.textContent=`${H} items selected`}),n.clickHandlers.push(S=>{if(n.state.isDestroyed)return;let h=S.target.closest("[data-index]");if(!h)return;let M=parseInt(h.dataset.index??"-1",10);if(M<0)return;let d=n.dataManager.getItem(M);d&&(l.emit("item:click",{item:d,index:M,event:S}),e=Gt(e,M),s.root.setAttribute("aria-activedescendant",`${u}-item-${M}`),e=ke(e,d.id,o),b())}),n.keydownHandlers.push(S=>{if(n.state.isDestroyed)return;let H=n.dataManager.getTotal(),h=e.focusedIndex,M=!1,d=!1,E=e;switch(S.key){case"ArrowUp":E=kt(e,H),M=!0,d=!0;break;case"ArrowDown":E=Dt(e,H),M=!0,d=!0;break;case"Home":E=Ot(e,H),M=!0,d=!0;break;case"End":E=$t(e,H),M=!0,d=!0;break;case" ":case"Enter":if(e.focusedIndex>=0){let p=n.dataManager.getItem(e.focusedIndex);p&&(E=ke(e,p.id,o)),M=!0}break}if(M){S.preventDefault(),e=E;let p=e.focusedIndex;if(p>=0){let V=n.dataManager.getState(),z=Se(p,n.heightCache,n.state.viewportState.containerHeight,V.total,"center",n.getCachedCompression());n.scrollController.scrollTo(z),s.root.setAttribute("aria-activedescendant",`${u}-item-${p}`)}else s.root.removeAttribute("aria-activedescendant");if(d){let{selected:V}=e;if(h>=0&&h!==p){let z=n.dataManager.getItem(h);z&&n.renderer.updateItemClasses(h,V.has(z.id),!1)}if(p>=0){let z=n.dataManager.getItem(p);z&&n.renderer.updateItemClasses(p,V.has(z.id),!0)}}else m(),l.emit("selection:change",{selected:De(e),items:Oe(e,V=>n.dataManager.getItemById(V))})}}),n.methods.set("select",(...S)=>{e=at(e,S,o),b()}),n.methods.set("deselect",(...S)=>{e=lt(e,S),b()}),n.methods.set("toggleSelect",S=>{e=ke(e,S,o),b()}),n.methods.set("selectAll",()=>{if(o!=="multiple")return;let S=n.getAllLoadedItems();e=Pt(e,S,o),b()}),n.methods.set("clearSelection",()=>{e=Ft(e);let{renderRange:S,isCompressed:H}=n.state.viewportState,h=n.getItemsForRange(S),M=H?n.getCompressionContext():void 0;n.renderer.render(h,S,e.selected,e.focusedIndex,M),l.emit("selection:change",{selected:[],items:[]})}),n.methods.set("getSelected",()=>De(e)),n.methods.set("getSelectedItems",()=>Oe(e,S=>n.dataManager.getItemById(S))),n.destroyHandlers.push(()=>{v&&v.parentNode&&v.remove()})},destroy(){a&&a.parentNode&&a.remove(),a=null}}};var Re=(t,o,r={},e="vlist",a=!1)=>{let{autoHide:n=!0,autoHideDelay:s=1e3,minThumbSize:l=30,showOnHover:y=!0,hoverZoneWidth:f=16,showOnViewportEnter:u=!0}=r,T=0,I=0,L=0,c=0,m=!1,b=!1,v=0,S=0,H=0,h=null,M=!1,d=null,E=null,p=a?"width":"height",V=a?"translateX":"translateY",z=a?Q=>Q.clientX:Q=>Q.clientY,X=a?"left":"top",U=document.createElement("div"),ee=document.createElement("div"),Z=y?document.createElement("div"):null,R=()=>{U.className=`${e}-scrollbar`,ee.className=`${e}-scrollbar-thumb`,a&&U.classList.add(`${e}-scrollbar--horizontal`),U.appendChild(ee),t.appendChild(U),Z&&(Z.className=`${e}-scrollbar-hover`,a?(Z.classList.add(`${e}-scrollbar-hover--horizontal`),Z.style.height=`${f}px`):Z.style.width=`${f}px`,t.appendChild(Z))},A=()=>{h&&(clearTimeout(h),h=null)},G=()=>{n&&(A(),h=setTimeout(C,s))},k=()=>{T<=I||(A(),M||(U.classList.add(`${e}-scrollbar--visible`),M=!0),n&&!m&&!b&&G())},C=()=>{m||b||(U.classList.remove(`${e}-scrollbar--visible`),M=!1)},x=(Q,te)=>{T=Q,I=te;let _=T>I;if(U.style.display=_?"":"none",!_){C();return}let P=I/T;L=Math.max(l,P*I),ee.style[p]=`${L}px`,c=I-L,D(H)},D=Q=>{if(H=Q,T<=I||c<=0)return;let te=T-I,P=Math.min(1,Math.max(0,Q/te))*c;ee.style.transform=`${V}(${P}px)`},O=Q=>{if(Q.target===ee)return;let te=U.getBoundingClientRect(),K=z(Q)-te[X]-L/2,B=Math.max(0,Math.min(K,c))/c,ne=T-I,se=B*ne;o(se),k()},N=Q=>{Q.preventDefault(),Q.stopPropagation(),m=!0,v=z(Q),S=H,A(),U.classList.add(`${e}-scrollbar--dragging`),document.addEventListener("mousemove",Y),document.addEventListener("mouseup",oe)},Y=Q=>{if(!m)return;let te=z(Q)-v,_=c>0?te/c:0,P=T-I,K=_*P,J=Math.max(0,Math.min(S+K,P)),ne=J/P*c;ee.style.transform=`${V}(${ne}px)`,E=J,d===null&&(d=requestAnimationFrame(()=>{E!==null&&o(E),d=null}))},oe=()=>{m=!1,d!==null&&(cancelAnimationFrame(d),d=null),E!==null&&(o(E),E=null),U.classList.remove(`${e}-scrollbar--dragging`),n&&!b&&G(),document.removeEventListener("mousemove",Y),document.removeEventListener("mouseup",oe)},de=()=>{u&&k()},$=()=>{m||(b=!1,n&&G())},ae=()=>{b=!0,A(),k()},j=()=>{b=!1,!m&&n&&G()},re=()=>{A(),d!==null&&(cancelAnimationFrame(d),d=null),U.removeEventListener("click",O),U.removeEventListener("mouseenter",ae),U.removeEventListener("mouseleave",j),ee.removeEventListener("mousedown",N),t.removeEventListener("mouseenter",de),t.removeEventListener("mouseleave",$),document.removeEventListener("mousemove",Y),document.removeEventListener("mouseup",oe),Z&&(Z.removeEventListener("mouseenter",ae),Z.removeEventListener("mouseleave",j),Z.parentNode&&Z.parentNode.removeChild(Z)),U.parentNode&&U.parentNode.removeChild(U)};return R(),U.addEventListener("click",O),U.addEventListener("mouseenter",ae),U.addEventListener("mouseleave",j),ee.addEventListener("mousedown",N),t.addEventListener("mouseenter",de),t.addEventListener("mouseleave",$),Z&&(Z.addEventListener("mouseenter",ae),Z.addEventListener("mouseleave",j)),{show:k,hide:C,updateBounds:x,updatePosition:D,isVisible:()=>M,destroy:re}};var Bt=t=>{let o=null;return{name:"withScrollbar",priority:30,setup(r){let{dom:e,config:a}=r,{classPrefix:n,horizontal:s}=a;o=Re(e.viewport,f=>r.scrollController.scrollTo(f),t??{},n,s),e.viewport.classList.contains(`${n}-viewport--custom-scrollbar`)||e.viewport.classList.add(`${n}-viewport--custom-scrollbar`);let l=r.getCachedCompression();o.updateBounds(l.virtualHeight,r.state.viewportState.containerHeight);let y=o;r.afterScroll.push((f,u)=>{y.updatePosition(f),y.show()}),r.resizeHandlers.push((f,u)=>{if(y){let T=r.getCachedCompression();y.updateBounds(T.virtualHeight,r.state.viewportState.containerHeight)}}),r.contentSizeHandlers.push(()=>{if(y){let f=r.getCachedCompression();y.updateBounds(f.virtualHeight,r.state.viewportState.containerHeight)}}),r.destroyHandlers.push(()=>{y&&y.destroy()})},destroy(){o&&(o.destroy(),o=null)}}};Ze();var zt=()=>{let t=null,o=0,r=!1;return{name:"withCompression",priority:20,setup(e){let{dom:a,config:n}=e,{classPrefix:s,horizontal:l}=n,y=()=>{let u=e.getVirtualTotal(),T=Te(u,e.heightCache);if(T.isCompressed&&!r){r=!0,e.scrollController.enableCompression(T),e.updateContentSize(T.virtualHeight),e.setScrollFns(()=>o,m=>{o=m});let I=a.viewport,L=m=>{m.preventDefault();let b=T.virtualHeight-e.state.viewportState.containerHeight;o=Math.max(0,Math.min(o+m.deltaY,b)),e.scrollController.scrollTo(o)};if(I.addEventListener("wheel",L,{passive:!1}),e.destroyHandlers.push(()=>{I.removeEventListener("wheel",L)}),!a.viewport.querySelector(`.${s}-scrollbar-track`)){t=Re(a.viewport,b=>e.scrollController.scrollTo(b),{},s,l),a.viewport.classList.contains(`${s}-viewport--custom-scrollbar`)||a.viewport.classList.add(`${s}-viewport--custom-scrollbar`),t.updateBounds(T.virtualHeight,e.state.viewportState.containerHeight);let m=t;e.afterScroll.push((b,v)=>{m&&(m.updatePosition(b),m.show())}),e.resizeHandlers.push((b,v)=>{if(m){let S=e.getCachedCompression();m.updateBounds(S.virtualHeight,e.state.viewportState.containerHeight)}})}}else!T.isCompressed&&r?(r=!1,e.scrollController.disableCompression(),e.updateContentSize(T.actualHeight)):T.isCompressed&&(e.scrollController.updateConfig({compression:T}),e.updateContentSize(T.virtualHeight));t&&t.updateBounds(T.virtualHeight,e.state.viewportState.containerHeight),e.state.cachedCompression={state:T,totalItems:u}};e.updateCompressionMode=y;let f=e.getCachedCompression.bind(e);e.getCachedCompression=()=>e.state.cachedCompression?e.state.cachedCompression.state:f(),e.setVisibleRangeFn((u,T,I,L,c)=>{let m=Te(L,I);St(u,T,I,L,m,c)}),e.setScrollToPosFn((u,T,I,L,c)=>{let m=Te(L,T);return It(u,T,I,L,m,c)}),e.setPositionElementFn((u,T)=>{let I=e.getVirtualTotal(),L=Te(I,e.heightCache);if(L.isCompressed){let c=Math.round(Ge(T,e.scrollController.getScrollTop(),e.heightCache,I,e.state.viewportState.containerHeight,L)),m=e.config.horizontal;u.style.transform=m?`translateX(${c}px)`:`translateY(${c}px)`}else{let c=Math.round(e.heightCache.getOffset(T)),m=e.config.horizontal;u.style.transform=m?`translateX(${c}px)`:`translateY(${c}px)`}}),y(),e.destroyHandlers.push(()=>{t&&(t.destroy(),t=null)})},destroy(){t&&(t.destroy(),t=null)}}};var Ut=()=>({name:"withSnapshots",priority:50,methods:["getScrollSnapshot","restoreScroll"],setup(t){t.methods.set("getScrollSnapshot",()=>{let o=t.scrollController.getScrollTop(),r=t.getCachedCompression(),e=t.getVirtualTotal(),a=t.methods.get("getSelected"),n=a&&a().length>0?a():void 0;if(e===0){let f={index:0,offsetInItem:0};return n&&(f.selectedIds=n),f}let s,l;if(r.isCompressed){let u=o/r.virtualHeight*e;s=Math.max(0,Math.min(Math.floor(u),e-1)),l=(u-s)*t.heightCache.getHeight(s)}else s=t.heightCache.indexAtOffset(o),l=o-t.heightCache.getOffset(s);l=Math.max(0,l);let y={index:s,offsetInItem:l};return n&&(y.selectedIds=n),y}),t.methods.set("restoreScroll",o=>{let{index:r,offsetInItem:e,selectedIds:a}=o,n=t.getCachedCompression(),s=t.getVirtualTotal();if(s===0)return;let l=Math.max(0,Math.min(r,s-1)),y;if(n.isCompressed){let u=t.heightCache.getHeight(l),T=u>0?e/u:0;y=(l+T)/s*n.virtualHeight}else y=t.heightCache.getOffset(l)+e;let f=Math.max(0,n.virtualHeight-t.state.viewportState.containerHeight);if(y=Math.max(0,Math.min(y,f)),t.scrollController.scrollTo(y),a&&a.length>0){let u=t.methods.get("select");u&&u(...a)}})}});var Nt=(t={})=>{let{chunkSize:o=100,maxCachedItems:r=5e3,evictionBuffer:e=200,onEvict:a}=t,n=new Map,s=0,l=0,y=R=>{let A=n.get(R);return A?A.lastAccess=Date.now():(A={items:new Array(o),count:0,lastAccess:Date.now()},n.set(R,A)),A},f=R=>Math.floor(R/o),u=R=>R%o,T=()=>s,I=R=>{s=R},L=R=>{if(R<0||R>=s)return;let A=f(R),G=n.get(A);if(G)return G.items[u(R)]},c=R=>{if(R<0||R>=s)return!1;let A=f(R),G=n.get(A);return G?G.items[u(R)]!==void 0:!1},m=(R,A)=>{let G=f(R),k=y(G),C=u(R),x=k.items[C]===void 0;k.items[C]=A,x&&(k.count++,l++),R>=s&&(s=R+1)},b=(R,A)=>{for(let G=0;G<A.length;G++){let k=A[G];k!==void 0&&m(R+G,k)}},v=R=>{if(R<0||R>=s)return!1;let A=f(R),G=n.get(A);if(!G)return!1;let k=u(R);return G.items[k]===void 0?!1:(G.items[k]=void 0,G.count--,l--,G.count===0&&n.delete(A),!0)},S=(R,A)=>{let G=[];for(let k=R;k<=A&&k<s;k++)G.push(L(k));return G},H=(R,A)=>{for(let G=R;G<=A&&G<s;G++)if(!c(G))return!1;return!0},h=()=>{let R=[],A=null,G=Array.from(n.keys()).sort((k,C)=>k-C);for(let k of G){let C=n.get(k);if(!C)continue;let x=k*o;for(let D=0;D<o;D++){let O=x+D;if(O>=s)break;C.items[D]!==void 0?A===null?A={start:O,end:O}:O===A.end+1?A.end=O:(R.push(A),A={start:O,end:O}):A!==null&&(R.push(A),A=null)}}return A!==null&&R.push(A),R},M=(R,A)=>{let G=[],k=null;for(let C=R;C<=A&&C<s;C++)c(C)?k!==null&&(G.push(k),k=null):k===null?k={start:C,end:C}:k.end=C;return k!==null&&G.push(k),G},d=R=>n.has(R),E=R=>{let A=n.get(R);A&&(A.lastAccess=Date.now())},p=(R,A)=>{if(R>A||n.size===0)return;let G=Date.now(),k=f(Math.max(0,R)),C=f(Math.min(s-1,A));for(let x=k;x<=C;x++){let D=n.get(x);D&&(D.lastAccess=G)}},V=(R,A)=>{if(l<=r)return 0;let G=Math.max(0,R-e),k=Math.min(s-1,A+e),C=f(G),x=f(k),D=0,O=[];for(let[N,Y]of n)(N<C||N>x)&&(D+=Y.count,O.push(N),l-=Y.count,n.delete(N));return D>0&&a&&a(D,O),D},z=()=>{if(l<=r)return 0;let R=Array.from(n.entries()).sort(([,k],[,C])=>k.lastAccess-C.lastAccess),A=0,G=[];for(let[k,C]of R){if(l<=r)break;A+=C.count,l-=C.count,G.push(k),n.delete(k)}return A>0&&a&&a(A,G),A},X=()=>({totalItems:s,cachedItems:l,cachedChunks:n.size,chunkSize:o,maxCachedItems:r,memoryEfficiency:s>0?1-l/s:1}),U=()=>l,ee=()=>{n.clear(),l=0};return{chunkSize:o,maxCachedItems:r,getTotal:T,setTotal:I,get:L,has:c,set:m,setRange:b,delete:v,getRange:S,isRangeLoaded:H,getLoadedRanges:h,findUnloadedRanges:M,getChunkIndex:f,isChunkLoaded:d,touchChunk:E,touchChunksForRange:p,evictDistant:V,evictToLimit:z,getStats:X,getCachedCount:U,clear:ee,reset:()=>{ee(),s=0}}},zn=t=>{if(t.length===0)return[];let o=[...t].sort((e,a)=>e.start-a.start),r=[{...o[0]}];for(let e=1;e<o.length;e++){let a=o[e],n=r[r.length-1];a.start<=n.end+1?n.end=Math.max(n.end,a.end):r.push({...a})}return r},Wt=(t,o,r)=>{let e=Math.floor(t.start/r)*r,a=Math.ceil((t.end+1)/r)*r-1,n={start:e,end:a};if(o.length===0)return[n];let s=[],l=zn(o),y=n.start;for(let f of l)if(!(f.end<y)&&(f.start>n.end||(f.start>y&&s.push({start:y,end:Math.min(f.start-1,n.end)}),y=f.end+1,y>n.end)))break;return y<=n.end&&s.push({start:y,end:n.end}),s};var Ee="_isPlaceholder",Un="__placeholder_",Kt=(t={})=>{let{enabled:o=!0,maskCharacter:r="\u2588",randomVariance:e=!0,maxSampleSize:a=20,customGenerator:n}=t,s=null,l=!1,y=0,f=v=>{if(!o||l||v.length===0)return;let S=new Map,H=new Map,h=Math.min(v.length,a);for(let M=0;M<h;M++){let d=v[M];if(!(!d||typeof d!="object"))for(let[E,p]of Object.entries(d)){if(E.startsWith("_")||E==="id")continue;H.has(E)||H.set(E,{lengths:[],types:new Set});let V=H.get(E),z=Array.isArray(p)?"array":typeof p;V.types.add(z),typeof p=="string"?V.lengths.push(p.length):p!=null&&V.lengths.push(String(p).length)}}for(let[M,d]of H){if(d.lengths.length===0)continue;let E=Math.min(...d.lengths),p=Math.max(...d.lengths),V=Math.round(d.lengths.reduce((X,U)=>X+U,0)/d.lengths.length),z="string";d.types.has("number")&&d.types.size===1?z="number":d.types.has("boolean")&&d.types.size===1?z="boolean":d.types.has("array")?z="array":d.types.has("object")&&!d.types.has("string")&&(z="object"),S.set(M,{minLength:E,maxLength:p,avgLength:V,type:z})}s=S,l=!0},u=()=>l,T=v=>{let S=v.avgLength;return e&&v.minLength!==v.maxLength&&(S=Math.floor(Math.random()*(v.maxLength-v.minLength+1)+v.minLength),Math.random()<.3&&(S=Math.max(1,S+Math.floor(Math.random()*3)-1))),r.repeat(Math.max(1,S))},I=v=>{if(n)return{...n(v),[Ee]:!0};let S={id:`${Un}${y++}`,[Ee]:!0,_index:v};if(!s||s.size===0)return S.label=r.repeat(12),S;for(let[H,h]of s)switch(h.type){case"string":S[H]=T(h);break;case"number":S[H]=0;break;case"boolean":S[H]=!1;break;case"array":S[H]=[];break;case"object":S[H]={};break;default:S[H]=T(h)}return S};return{analyzeStructure:f,hasAnalyzedStructure:u,generate:I,generateRange:(v,S)=>{let H=[];for(let h=v;h<=S;h++)H.push(I(h));return H},isPlaceholder:v=>!v||typeof v!="object"?!1:v[Ee]===!0,getPlaceholderKey:()=>Ee,clear:()=>{s=null,l=!1,y=0}}},$e=t=>!t||typeof t!="object"?!1:t[Ee]===!0;var Nn=50,qt=(t={})=>{let{adapter:o,initialItems:r,initialTotal:e,storage:a,placeholder:n,pageSize:s=Nn,onStateChange:l,onItemsLoaded:y,onItemsEvicted:f}=t,u=Nt({...a,onEvict:(_,P)=>{f?.(_),h()}}),T=null,I=()=>(T||(T=Kt(n)),T),L=new Map,c=!1,m,b=!0,v,S=[],H=new Map,h=()=>{l?.(ee())},M=()=>{L.clear();let _=u.getLoadedRanges();for(let P of _)for(let K=P.start;K<=P.end;K++){let J=u.get(K);J&&!$e(J)&&L.set(J.id,K)}},d=(_,P)=>{$e(P)||L.set(P.id,_)},E=_=>{L.delete(_)},p=(_,P)=>`${_}-${P}`,V=()=>u.getTotal(),z=()=>u.getCachedCount(),X=()=>c,U=()=>b,ee=()=>({total:u.getTotal(),cached:u.getCachedCount(),isLoading:c,pendingRanges:S,error:m,hasMore:b,cursor:v}),Z=()=>u,R=()=>I(),A=_=>{let P=u.get(_);if(P!==void 0)return P;if(_>=0&&_<u.getTotal())return I().generate(_)},G=_=>{let P=L.get(_);if(P!==void 0)return u.get(P)},k=_=>L.get(_)??-1,C=_=>{let P=u.get(_);return P!==void 0&&!$e(P)},x=(_,P)=>{let K=[],J=u.getTotal(),B=0,ne=0;u.touchChunksForRange(_,Math.min(P,J-1));for(let se=_;se<=P&&se<J;se++){let be=u.get(se);be!==void 0?(K.push(be),B++):(K.push(I().generate(se)),ne++)}return K},D=_=>{u.setTotal(_),b=u.getCachedCount()<_,h()},O=(_,P=0,K)=>{T&&!T.hasAnalyzedStructure()&&_.length>0&&T.analyzeStructure(_);for(let J=0;J<_.length;J++){let B=_[J];if(B!==void 0){let ne=P+J;u.set(ne,B),d(ne,B)}}K!==void 0?u.setTotal(K):P+_.length>u.getTotal()&&u.setTotal(P+_.length),b=u.getCachedCount()<u.getTotal(),y?.(_,P,u.getTotal()),h()},N=(_,P)=>{let K=L.get(_);if(K===void 0)return!1;let J=u.get(K);if(!J)return!1;let B={...J,...P};return u.set(K,B),P.id!==void 0&&P.id!==_&&(E(_),d(K,B)),h(),!0},Y=_=>{let P=L.get(_);if(P===void 0)return!1;u.delete(P),E(_);let K=u.getTotal();return K>0&&u.setTotal(K-1),h(),!0},oe=async(_,P)=>{if(!o)return;let K=p(_,P);if(H.has(K))return;let J=u.getLoadedRanges(),B=Wt({start:_,end:P},J,u.chunkSize);if(B.length===0)return;let ne=u.chunkSize,se=[];for(let ue of B){let ie=Math.floor(ue.start/ne),fe=Math.floor(ue.end/ne);for(let le=ie;le<=fe;le++){let he=le*ne,ce=he+ne-1,we=p(he,ce);!se.some(ye=>ye.start===he)&&!H.has(we)&&se.push({start:he,end:ce})}}let be=[];for(let ue of B){let ie=Math.floor(ue.start/ne),fe=Math.floor(ue.end/ne);for(let le=ie;le<=fe;le++){let he=le*ne,ce=he+ne-1,we=p(he,ce);if(H.has(we)){let ye=H.get(we);be.includes(ye)||be.push(ye)}}}for(let ue of se){let ie=p(ue.start,ue.end),fe=(async()=>{S.push(ue),c=!0,m=void 0,h();try{let le=ue.end-ue.start+1,he={offset:ue.start,limit:le,cursor:void 0},ce=await o.read(he);O(ce.items,ue.start,ce.total),ce.cursor&&(v=ce.cursor),ce.hasMore!==void 0?b=ce.hasMore:ce.total!==void 0&&(b=u.getCachedCount()<ce.total)}catch(le){m=le instanceof Error?le:new Error(String(le))}finally{H.delete(ie),S=S.filter(le=>le.start!==ue.start||le.end!==ue.end),c=H.size>0,h()}})();H.set(ie,fe),be.push(fe)}await Promise.all(be)},de=async(_,P)=>{u.isRangeLoaded(_,P)||await oe(_,P)},$=async()=>{o&&await oe(0,s-1)},ae=async()=>{if(!o||c||!b)return!1;let _=u.getCachedCount(),P=u.getTotal(),K=_,J=Math.min(K+s-1,P>0?P-1:K+s-1);return K>=P&&P>0?(b=!1,!1):(await oe(K,J),u.getCachedCount()>_)},j=async()=>{u.clear(),L.clear(),T&&T.clear(),v=void 0,b=!0,m=void 0,h(),await $()},re=(_,P)=>{u.evictDistant(_,P)>0&&M()},Q=()=>{u.clear(),L.clear(),v=void 0,m=void 0,S=[],c=!1,h()},te=()=>{u.reset(),L.clear(),T&&T.clear(),v=void 0,b=!0,m=void 0,S=[],c=!1,h()};return r&&r.length>0?O(r,0,e??r.length):e!==void 0&&u.setTotal(e),{getState:ee,getTotal:V,getCached:z,getIsLoading:X,getHasMore:U,getStorage:Z,getPlaceholders:R,getItem:A,getItemById:G,getIndexById:k,isItemLoaded:C,getItemsInRange:x,setTotal:D,setItems:O,updateItem:N,removeItem:Y,loadRange:oe,ensureRange:de,loadInitial:$,loadMore:ae,reload:j,evictDistant:re,clear:Q,reset:te}};var Yt=t=>{let{adapter:o,loading:r}=t,e=r?.cancelThreshold??15,a=r?.preloadThreshold??2,n=r?.preloadAhead??50;return{name:"withData",priority:20,methods:["reload"],setup(s){let{emitter:l}=s,y=s.config.reverse,f=s.config.overscan,u=qt({adapter:o,pageSize:50,onStateChange:()=>{s.state.isInitialized&&(s.heightCache.rebuild(s.getVirtualTotal()),s.updateCompressionMode(),s.state.viewportState=tt(s.state.viewportState,s.heightCache,s.getVirtualTotal(),f,s.getCachedCompression()),s.updateContentSize(s.state.viewportState.totalHeight),s.renderIfNeeded())},onItemsLoaded:(v,S,H)=>{s.state.isInitialized&&(s.heightCache.rebuild(s.getVirtualTotal()),s.forceRender(),l.emit("load:end",{items:v,total:H}))}});s.replaceDataManager(u);let T=null,I=null,L=0,c=()=>{if(I){let v=I;I=null,s.dataManager.ensureRange(v.start,v.end).catch(S=>{l.emit("error",{error:S,context:"ensureRange"})})}};s.afterScroll.push((v,S)=>{if(s.state.isDestroyed)return;let H=s.scrollController.getVelocity(),M=s.scrollController.isTracking()&&H<=e;if(I&&L>e&&H<=e){let p=I;I=null,s.dataManager.ensureRange(p.start,p.end).catch(V=>{l.emit("error",{error:V,context:"ensureRange"})})}L=H,M&&!s.dataManager.getIsLoading()&&s.dataManager.getHasMore()&&(y?v<200&&(l.emit("load:start",{offset:s.dataManager.getCached(),limit:50}),s.dataManager.loadMore().catch(p=>{l.emit("error",{error:p,context:"loadMore"})})):s.state.viewportState.totalHeight-v-s.state.viewportState.containerHeight<200&&(l.emit("load:start",{offset:s.dataManager.getCached(),limit:50}),s.dataManager.loadMore().catch(V=>{l.emit("error",{error:V,context:"loadMore"})})));let{renderRange:d}=s.state.viewportState;if(!T||d.start!==T.start||d.end!==T.end)if(T={start:d.start,end:d.end},M){I=null;let p=d.start,V=d.end,z=s.getVirtualTotal();H>a&&(S==="down"?V=Math.min(d.end+n,z-1):p=Math.max(d.start-n,0)),s.dataManager.ensureRange(p,V).catch(X=>{l.emit("error",{error:X,context:"ensureRange"})})}else I={start:d.start,end:d.end}});let m=200,b=null;s.afterScroll.push((v,S)=>{b!==null&&clearTimeout(b),b=setTimeout(()=>{b=null,c()},m)}),s.destroyHandlers.push(()=>{b!==null&&(clearTimeout(b),b=null)}),l.on("load:start",()=>{s.dom.root.setAttribute("aria-busy","true")}),l.on("load:end",()=>{s.dom.root.removeAttribute("aria-busy")}),s.methods.set("reload",async()=>{await s.dataManager.reload()}),l.emit("load:start",{offset:0,limit:50}),s.dataManager.loadInitial().catch(v=>{l.emit("error",{error:v,context:"loadInitial"})})}}};var Xt=()=>{let t=null;return{name:"withWindow",priority:5,setup(o){let{dom:r,state:e,config:a,emitter:n}=o;r.root.style.overflow="visible",r.root.style.height="auto",r.viewport.classList.remove(`${a.classPrefix}-viewport--custom-scrollbar`),o.disableViewportResize(),o.setScrollTarget(window),o.setScrollFns(()=>{let f=r.viewport.getBoundingClientRect();return a.horizontal?Math.max(0,-f.left):Math.max(0,-f.top)},f=>{let u=r.viewport.getBoundingClientRect();if(a.horizontal){let T=u.left+window.scrollX;window.scrollTo(T+f,window.scrollY)}else{let T=u.top+window.scrollY;window.scrollTo(window.scrollX,T+f)}}),o.setContainerDimensions({width:()=>window.innerWidth,height:()=>window.innerHeight}),e.viewportState.containerHeight=window.innerHeight;let s=window.innerHeight,l=window.innerWidth,y=()=>{let f=window.innerWidth,u=window.innerHeight,T=a.horizontal?f:u,I=a.horizontal?l:s;if(!(Math.abs(T-I)<=1)){s=u,l=f,e.viewportState.containerHeight=u,n.emit("resize",{width:f,height:u});for(let L=0;L<o.resizeHandlers.length;L++)o.resizeHandlers[L](f,u);o.renderIfNeeded()}};window.addEventListener("resize",y,{passive:!0}),t=()=>{window.removeEventListener("resize",y)},o.destroyHandlers.push(t)},destroy(){t&&(t(),t=null)}}};var jt=t=>{let o=Ye(t);if(t.scroll?.element===window&&(o=o.use(Xt())),t.adapter&&(o=o.use(Yt({adapter:t.adapter,...t.loading&&{loading:t.loading}}))),t.layout==="grid"){if(!t.grid)throw new Error("[vlist/builder] grid configuration is required when layout is 'grid'");if(!t.grid.columns||t.grid.columns<1)throw new Error("[vlist/builder] grid.columns must be a positive integer >= 1");let n={columns:t.grid.columns};t.grid.gap!==void 0&&(n.gap=t.grid.gap),o=o.use(Mt(n))}if(t.groups){if(t.direction==="horizontal")throw new Error("[vlist/builder] horizontal direction cannot be combined with groups");let n={getGroupForIndex:t.groups.getGroupForIndex,headerHeight:typeof t.groups.headerHeight=="function"?t.groups.headerHeight("",0):t.groups.headerHeight,headerTemplate:t.groups.headerTemplate};t.groups.sticky!==void 0&&(n.sticky=t.groups.sticky),o=o.use(At(n))}let r=t.selection?.mode||"none";if(r!=="none"){let n={mode:r};t.selection?.initial!==void 0&&(n.initial=t.selection.initial),o=o.use(dt(n))}else o=o.use(dt({mode:"none"}));o=o.use(zt());let e=t.scroll?.scrollbar||t.scrollbar;if(e!=="none"){let n=typeof e=="object"?e:{};o=o.use(Bt(n))}o=o.use(Ut());let a=o.build();return a.update=n=>{n.grid&&a.updateGrid&&a.updateGrid(n.grid),n.selectionMode!==void 0&&a.setSelectionMode&&a.setSelectionMode(n.selectionMode),n.itemHeight!==void 0&&console.warn("[vlist] Updating itemHeight via update() is not yet supported with the builder pattern. Please recreate the instance or use the full API from 'vlist/full'."),n.overscan!==void 0&&console.warn("[vlist] Updating overscan via update() is not yet supported with the builder pattern.")},a};function ho(t){let o=xe(null),r=xe(null),e=xe(t);e.current=t;let a=xe(!1);ct(()=>{let s=o.current;if(!s)return;let l=jt({...e.current,container:s});return r.current=l,a.current=!0,()=>{a.current=!1,l.destroy(),r.current=null}},[]),ct(()=>{!a.current||!r.current||t.items&&r.current.setItems(t.items)},[t.items]);let n=Kn(()=>r.current,[]);return{containerRef:o,instanceRef:r,getInstance:n}}function bo(t,o,r){let e=xe(r);e.current=r,ct(()=>{let a=t.current;if(!a)return;let n=l=>{e.current(l)};return a.on(o,n)},[t.current,o])}export{ho as useVList,bo as useVListEvent};
@@ -1,116 +0,0 @@
1
- /**
2
- * vlist - Compression Module
3
- * Pure functions for handling large lists that exceed browser height limits
4
- *
5
- * When a list's total height (totalItems × itemHeight) exceeds the browser's
6
- * maximum element height (~16.7M pixels), we "compress" the virtual scroll space.
7
- *
8
- * Key concepts:
9
- * - actualHeight: The true height if all items were rendered
10
- * - virtualHeight: The capped height used for the scroll container (≤ MAX_VIRTUAL_HEIGHT)
11
- * - compressionRatio: virtualHeight / actualHeight (1 = no compression, <1 = compressed)
12
- *
13
- * When compressed:
14
- * - Scroll position maps to item index via ratio, not pixel math
15
- * - Item positions are calculated relative to a "virtual index" at current scroll
16
- * - Near-bottom interpolation ensures the last items are reachable
17
- */
18
- import type { Range } from "../types";
19
- import { MAX_VIRTUAL_HEIGHT } from "../constants";
20
- import type { HeightCache } from "./heights";
21
- export { MAX_VIRTUAL_HEIGHT };
22
- /** Compression calculation result */
23
- export interface CompressionState {
24
- /** Whether compression is active */
25
- isCompressed: boolean;
26
- /** The actual total height */
27
- actualHeight: number;
28
- /** The virtual height (capped at MAX_VIRTUAL_HEIGHT) */
29
- virtualHeight: number;
30
- /** Compression ratio (1 = no compression, <1 = compressed) */
31
- ratio: number;
32
- }
33
- /**
34
- * Calculate compression state for a list
35
- * Pure function - no side effects
36
- */
37
- export declare const getCompressionState: (_totalItems: number, heightCache: HeightCache) => CompressionState;
38
- /**
39
- * Calculate visible range with compression support
40
- * Pure function - no side effects
41
- *
42
- * @param scrollTop - Current scroll position
43
- * @param containerHeight - Viewport container height
44
- * @param heightCache - Height cache for item heights/offsets
45
- * @param totalItems - Total number of items
46
- * @param compression - Compression state
47
- * @param out - Output range to mutate (avoids allocation on hot path)
48
- */
49
- export declare const calculateCompressedVisibleRange: (scrollTop: number, containerHeight: number, heightCache: HeightCache, totalItems: number, compression: CompressionState, out: Range) => Range;
50
- /**
51
- * Calculate render range with compression support (adds overscan)
52
- * Pure function - no side effects
53
- *
54
- * @param out - Output range to mutate (avoids allocation on hot path)
55
- */
56
- export declare const calculateCompressedRenderRange: (visibleRange: Range, overscan: number, totalItems: number, out: Range) => Range;
57
- /**
58
- * Calculate item position (translateY) with compression support
59
- * Pure function - no side effects
60
- *
61
- * In compressed mode (manual wheel scrolling, overflow: hidden), items are
62
- * positioned RELATIVE TO THE VIEWPORT. The scroll container doesn't actually
63
- * scroll - we intercept wheel events and manually position items.
64
- *
65
- * Key insight:
66
- * - Calculate a "virtual scroll index" from the scroll ratio
67
- * - Items are positioned relative to this virtual index using actual heights
68
- * - Each item keeps its full height for proper rendering
69
- *
70
- * @param index - Item index
71
- * @param scrollTop - Current (virtual) scroll position
72
- * @param heightCache - Height cache for item heights/offsets
73
- * @param totalItems - Total number of items
74
- * @param containerHeight - Viewport container height
75
- * @param compression - Compression state
76
- * @param _rangeStart - (unused, kept for API compatibility)
77
- */
78
- export declare const calculateCompressedItemPosition: (index: number, scrollTop: number, heightCache: HeightCache, totalItems: number, containerHeight: number, compression: CompressionState, _rangeStart?: number) => number;
79
- /**
80
- * Calculate scroll position to bring an index into view (with compression)
81
- * Pure function - no side effects
82
- *
83
- * @param index - Target item index
84
- * @param heightCache - Height cache for item heights/offsets
85
- * @param containerHeight - Viewport container height
86
- * @param totalItems - Total number of items
87
- * @param compression - Compression state
88
- * @param align - Alignment within viewport
89
- */
90
- export declare const calculateCompressedScrollToIndex: (index: number, heightCache: HeightCache, containerHeight: number, totalItems: number, compression: CompressionState, align?: "start" | "center" | "end") => number;
91
- /**
92
- * Calculate the approximate item index at a given scroll position
93
- * Useful for debugging and scroll position restoration
94
- * Pure function - no side effects
95
- */
96
- export declare const calculateIndexFromScrollPosition: (scrollTop: number, heightCache: HeightCache, totalItems: number, compression: CompressionState) => number;
97
- /**
98
- * Check if compression is needed for a list configuration
99
- * Pure function - no side effects
100
- *
101
- * Note: This overload accepts a HeightCache for variable heights.
102
- * For simple fixed-height checks, use needsCompressionFixed().
103
- */
104
- export declare const needsCompression: (totalItems: number, heightOrCache: number | HeightCache) => boolean;
105
- /**
106
- * Calculate maximum items supported without compression
107
- * Only meaningful for fixed-height items
108
- * Pure function - no side effects
109
- */
110
- export declare const getMaxItemsWithoutCompression: (itemHeight: number) => number;
111
- /**
112
- * Get human-readable compression info for debugging
113
- * Pure function - no side effects
114
- */
115
- export declare const getCompressionInfo: (totalItems: number, heightCache: HeightCache) => string;
116
- //# sourceMappingURL=compression.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"compression.d.ts","sourceRoot":"","sources":["../../src/render/compression.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;AAEH,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAClD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAQ7C,OAAO,EAAE,kBAAkB,EAAE,CAAC;AAM9B,qCAAqC;AACrC,MAAM,WAAW,gBAAgB;IAC/B,oCAAoC;IACpC,YAAY,EAAE,OAAO,CAAC;IAEtB,8BAA8B;IAC9B,YAAY,EAAE,MAAM,CAAC;IAErB,wDAAwD;IACxD,aAAa,EAAE,MAAM,CAAC;IAEtB,8DAA8D;IAC9D,KAAK,EAAE,MAAM,CAAC;CACf;AAED;;;GAGG;AACH,eAAO,MAAM,mBAAmB,GAC9B,aAAa,MAAM,EACnB,aAAa,WAAW,KACvB,gBAYF,CAAC;AAMF;;;;;;;;;;GAUG;AACH,eAAO,MAAM,+BAA+B,GAC1C,WAAW,MAAM,EACjB,iBAAiB,MAAM,EACvB,aAAa,WAAW,EACxB,YAAY,MAAM,EAClB,aAAa,gBAAgB,EAC7B,KAAK,KAAK,KACT,KAmEF,CAAC;AAEF;;;;;GAKG;AACH,eAAO,MAAM,8BAA8B,GACzC,cAAc,KAAK,EACnB,UAAU,MAAM,EAChB,YAAY,MAAM,EAClB,KAAK,KAAK,KACT,KAUF,CAAC;AAMF;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,eAAO,MAAM,+BAA+B,GAC1C,OAAO,MAAM,EACb,WAAW,MAAM,EACjB,aAAa,WAAW,EACxB,YAAY,MAAM,EAClB,iBAAiB,MAAM,EACvB,aAAa,gBAAgB,EAC7B,cAAc,MAAM,KACnB,MAyDF,CAAC;AAMF;;;;;;;;;;GAUG;AACH,eAAO,MAAM,gCAAgC,GAC3C,OAAO,MAAM,EACb,aAAa,WAAW,EACxB,iBAAiB,MAAM,EACvB,YAAY,MAAM,EAClB,aAAa,gBAAgB,EAC7B,QAAO,OAAO,GAAG,QAAQ,GAAG,KAAe,KAC1C,MAmCF,CAAC;AAEF;;;;GAIG;AACH,eAAO,MAAM,gCAAgC,GAC3C,WAAW,MAAM,EACjB,aAAa,WAAW,EACxB,YAAY,MAAM,EAClB,aAAa,gBAAgB,KAC5B,MASF,CAAC;AAMF;;;;;;GAMG;AACH,eAAO,MAAM,gBAAgB,GAC3B,YAAY,MAAM,EAClB,eAAe,MAAM,GAAG,WAAW,KAClC,OAKF,CAAC;AAEF;;;;GAIG;AACH,eAAO,MAAM,6BAA6B,GAAI,YAAY,MAAM,KAAG,MAGlE,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,kBAAkB,GAC7B,YAAY,MAAM,EAClB,aAAa,WAAW,KACvB,MASF,CAAC"}
@@ -1,63 +0,0 @@
1
- /**
2
- * vlist - Height Cache
3
- * Efficient height management for fixed and variable item heights
4
- *
5
- * Provides two implementations:
6
- * - Fixed: O(1) operations using multiplication (zero overhead, matches existing behavior)
7
- * - Variable: O(1) offset lookup via prefix sums, O(log n) binary search for index-at-offset
8
- *
9
- * The HeightCache abstraction allows all virtual scrolling and compression code
10
- * to work identically with both fixed and variable heights.
11
- */
12
- /** Height cache for efficient offset/index lookups */
13
- export interface HeightCache {
14
- /** Get offset (Y position) for an item index — O(1) */
15
- getOffset(index: number): number;
16
- /** Get height of a specific item */
17
- getHeight(index: number): number;
18
- /** Find item index at a scroll offset — O(1) fixed, O(log n) variable */
19
- indexAtOffset(offset: number): number;
20
- /** Total content height */
21
- getTotalHeight(): number;
22
- /** Current total item count */
23
- getTotal(): number;
24
- /** Rebuild cache (call when items change) */
25
- rebuild(totalItems: number): void;
26
- /** Whether heights are variable (false = fixed fast path) */
27
- isVariable(): boolean;
28
- }
29
- /**
30
- * Create a height cache — returns fixed or variable implementation
31
- *
32
- * When height is a number, returns a zero-overhead fixed implementation.
33
- * When height is a function, builds a prefix-sum array for efficient lookups.
34
- */
35
- export declare const createHeightCache: (height: number | ((index: number) => number), initialTotal: number) => HeightCache;
36
- /**
37
- * Count how many items fit in a given container height starting from startIndex
38
- * Used for compressed mode visible range calculations
39
- *
40
- * For fixed heights: O(1) via division
41
- * For variable heights: O(k) where k = visible item count (typically 10-50)
42
- */
43
- export declare const countVisibleItems: (heightCache: HeightCache, startIndex: number, containerHeight: number, totalItems: number) => number;
44
- /**
45
- * Count how many items fit starting from the bottom of the list
46
- * Used for near-bottom interpolation in compressed mode
47
- *
48
- * For fixed heights: O(1) via division
49
- * For variable heights: O(k) where k = items fitting (typically 10-50)
50
- */
51
- export declare const countItemsFittingFromBottom: (heightCache: HeightCache, containerHeight: number, totalItems: number) => number;
52
- /**
53
- * Calculate the pixel offset for a fractional virtual scroll index
54
- *
55
- * In compressed mode, the scroll position maps to a fractional item index
56
- * (e.g., 5.3 means 30% into item 5). This function calculates the actual
57
- * pixel offset for such a fractional position using variable heights.
58
- *
59
- * For fixed heights this reduces to: virtualIndex * itemHeight
60
- * For variable heights: offset(floor) + frac * height(floor)
61
- */
62
- export declare const getOffsetForVirtualIndex: (heightCache: HeightCache, virtualIndex: number, totalItems: number) => number;
63
- //# sourceMappingURL=heights.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"heights.d.ts","sourceRoot":"","sources":["../../src/render/heights.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAMH,sDAAsD;AACtD,MAAM,WAAW,WAAW;IAC1B,uDAAuD;IACvD,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;IAEjC,oCAAoC;IACpC,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;IAEjC,yEAAyE;IACzE,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC;IAEtC,2BAA2B;IAC3B,cAAc,IAAI,MAAM,CAAC;IAEzB,+BAA+B;IAC/B,QAAQ,IAAI,MAAM,CAAC;IAEnB,6CAA6C;IAC7C,OAAO,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAElC,6DAA6D;IAC7D,UAAU,IAAI,OAAO,CAAC;CACvB;AAiID;;;;;GAKG;AACH,eAAO,MAAM,iBAAiB,GAC5B,QAAQ,MAAM,GAAG,CAAC,CAAC,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC,EAC5C,cAAc,MAAM,KACnB,WAKF,CAAC;AAMF;;;;;;GAMG;AACH,eAAO,MAAM,iBAAiB,GAC5B,aAAa,WAAW,EACxB,YAAY,MAAM,EAClB,iBAAiB,MAAM,EACvB,YAAY,MAAM,KACjB,MAkBF,CAAC;AAEF;;;;;;GAMG;AACH,eAAO,MAAM,2BAA2B,GACtC,aAAa,WAAW,EACxB,iBAAiB,MAAM,EACvB,YAAY,MAAM,KACjB,MAkBF,CAAC;AAEF;;;;;;;;;GASG;AACH,eAAO,MAAM,wBAAwB,GACnC,aAAa,WAAW,EACxB,cAAc,MAAM,EACpB,YAAY,MAAM,KACjB,MAUF,CAAC"}
@@ -1,9 +0,0 @@
1
- /**
2
- * vlist - Render Domain
3
- * Rendering, virtualization, and compression
4
- */
5
- export { createHeightCache, countVisibleItems, countItemsFittingFromBottom, getOffsetForVirtualIndex, type HeightCache, } from "./heights";
6
- export { createRenderer, createDOMStructure, updateContentHeight, updateContentWidth, resolveContainer, getContainerDimensions, type Renderer, type DOMStructure, type CompressionContext, type CompressedPositionFn, type CompressionStateFn, } from "./renderer";
7
- export { createViewportState, updateViewportState, updateViewportSize, updateViewportItems, calculateRenderRange, calculateTotalHeight, calculateActualHeight, calculateItemOffset, calculateScrollToIndex, clampScrollPosition, getScrollDirection, rangesEqual, isInRange, getRangeCount, diffRanges, getSimpleCompressionState, simpleVisibleRange, simpleScrollToIndex, NO_COMPRESSION, type CompressionState, type VisibleRangeFn, type ScrollToIndexFn, } from "./virtual";
8
- export { MAX_VIRTUAL_HEIGHT, getCompressionState, getCompressionState as getCompression, needsCompression, getMaxItemsWithoutCompression, getCompressionInfo, calculateCompressedVisibleRange, calculateCompressedRenderRange, calculateCompressedItemPosition, calculateCompressedScrollToIndex, calculateIndexFromScrollPosition, } from "./compression";
9
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/render/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EACL,iBAAiB,EACjB,iBAAiB,EACjB,2BAA2B,EAC3B,wBAAwB,EACxB,KAAK,WAAW,GACjB,MAAM,WAAW,CAAC;AAGnB,OAAO,EACL,cAAc,EACd,kBAAkB,EAClB,mBAAmB,EACnB,kBAAkB,EAClB,gBAAgB,EAChB,sBAAsB,EACtB,KAAK,QAAQ,EACb,KAAK,YAAY,EACjB,KAAK,kBAAkB,EACvB,KAAK,oBAAoB,EACzB,KAAK,kBAAkB,GACxB,MAAM,YAAY,CAAC;AAGpB,OAAO,EACL,mBAAmB,EACnB,mBAAmB,EACnB,kBAAkB,EAClB,mBAAmB,EACnB,oBAAoB,EACpB,oBAAoB,EACpB,qBAAqB,EACrB,mBAAmB,EACnB,sBAAsB,EACtB,mBAAmB,EACnB,kBAAkB,EAClB,WAAW,EACX,SAAS,EACT,aAAa,EACb,UAAU,EACV,yBAAyB,EACzB,kBAAkB,EAClB,mBAAmB,EACnB,cAAc,EACd,KAAK,gBAAgB,EACrB,KAAK,cAAc,EACnB,KAAK,eAAe,GACrB,MAAM,WAAW,CAAC;AAGnB,OAAO,EACL,kBAAkB,EAClB,mBAAmB,EACnB,mBAAmB,IAAI,cAAc,EACrC,gBAAgB,EAChB,6BAA6B,EAC7B,kBAAkB,EAClB,+BAA+B,EAC/B,8BAA8B,EAC9B,+BAA+B,EAC/B,gCAAgC,EAChC,gCAAgC,GACjC,MAAM,eAAe,CAAC"}