virtua
Version:
A zero-config, fast and small (~3kB) virtual list (and grid) component for React, Vue, Solid and Svelte.
3 lines (2 loc) • 13.1 kB
JavaScript
var e=require("vue");const t=null,{min:r,max:o,abs:n,floor:s}=Math,i=(e,t,n)=>r(n,o(t,e)),l=e=>[...e].sort(((e,t)=>e-t)),c="function"==typeof queueMicrotask?queueMicrotask:e=>{Promise.resolve().then(e)},a=e=>{let t,r;return()=>(t||(t=!0,r=e()),r)},u=-1,f=(e,t,r)=>{const o=r?"unshift":"push";for(let r=0;r<t;r++)e[o](u);return e},d=(e,t)=>{const r=e.t[t];return r===u?e.o:r},p=(e,t,o)=>{const n=e.t[t]===u;return e.t[t]=o,e.i=r(t,e.i),n},h=(e,t)=>{if(!e.l)return 0;if(e.i>=t)return e.u[t];e.i<0&&(e.u[0]=0,e.i=0);let r=e.i,o=e.u[r];for(;r<t;)o+=d(e,r),e.u[++r]=o;return e.i=t,o},m=(e,t,r=0,o=e.l-1)=>{for(;r<=o;){const n=s((r+o)/2),i=h(e,n);if(i<=t){if(i+d(e,n)>t)return n;r=n+1}else o=n-1}return i(r,0,e.l-1)},_=(e,t,o)=>{const n=t-e.l;return e.i=o?-1:r(t-1,e.i),e.l=t,n>0?(f(e.u,n),f(e.t,n,o),e.o*n):(e.u.splice(n),(o?e.t.splice(0,-n):e.t.splice(n)).reduce(((t,r)=>t-(r===u?e.o:r)),0))},v="undefined"!=typeof window,b=()=>document.documentElement,y=e=>e.ownerDocument,S=e=>e.defaultView,g=/*#__PURE__*/a((()=>!!v&&"rtl"===getComputedStyle(b()).direction)),x=/*#__PURE__*/a((()=>/iP(hone|od|ad)/.test(navigator.userAgent))),z=/*#__PURE__*/a((()=>"scrollBehavior"in b().style)),$=e=>!!e.p(),w=(e,s=40,i=4,c=0,a,v=!1)=>{let b=!!c,y=1,S=0,g=0,z=0,$=0,w=0,I=0,k=0,O=0,j=b?[0,o(c-1,0)]:t,E=[0,0],T=0;const q=((e,t)=>({o:t,t:f([],e),l:e,i:-1,u:f([],e)}))(e,s),B=new Set,P=()=>z-g,R=()=>P()+w+$,M=e=>((e,t,o,n)=>{if(n=r(n,e.l-1),h(e,n)<=t){const r=m(e,t+o,n);return[m(e,t,n,r),r]}{const r=m(e,t,void 0,n);return[r,m(e,t+o,r)]}})(q,e,S,E[0]),N=()=>(e=>e.l?h(e,e.l-1)+d(e,e.l-1):0)(q),A=e=>h(q,e)-w,H=e=>d(q,e),V=e=>{e&&(x()&&0!==k?w+=e:$+=e)};return{h:()=>y,m:()=>(e=>[e.t.slice(),e.o])(q),v:()=>{let e,t;return I?[e,t]=E:([e,t]=E=M(o(0,R())),j&&(e=r(e,j[0]),t=o(t,j[1]))),1!==k&&(e-=o(0,i)),2!==k&&(t+=o(0,i)),[o(e,0),r(t,q.l-1)]},S:()=>m(q,R()),I:()=>m(q,R()+S),k:e=>q.t[e]===u,O:()=>!!j&&q.t.slice(o(0,j[0]-1),r(q.l-1,j[1]+1)+1).includes(u),j:A,T:H,q:()=>q.l,B:()=>z,P:()=>0!==k,p:()=>S,R:()=>g,M:N,N:()=>(I=$,$=0,[I,2===O||P()+S>=N()]),A:(e,t)=>{const r=[e,t];return B.add(r),()=>{B.delete(r)}},H:(e,r)=>{let s,i,c=0;switch(e){case 1:{const e=I;I=0;const o=r-z,s=n(o);e&&s<n(e)+1||0!==O||(k=o<0?2:1),b&&(j=t,b=!1),z=r,c=4;const l=P();l>=-S&&l<=N()&&(c+=1,i=s>S);break}case 2:c=8,0!==k&&(s=!0,c+=1),k=0,O=0,j=t;break;case 3:{const e=r.filter((([e,t])=>q.t[e]!==t));if(!e.length)break;V(e.reduce(((e,[t,r])=>((2===O||(j?!b&&t<j[0]:A(t)+(0===k&&0===O?H(t):0)<P()))&&(e+=r-H(t)),e)),0));for(const[t,r]of e){const e=H(t),o=p(q,t,r);v&&(T+=o?r:r-e)}v&&S&&T>S&&(V(((e,t)=>{let r=0;const n=[];e.t.forEach(((e,o)=>{e!==u&&(n.push(e),o<t&&r++)})),e.i=-1;const s=l(n),i=s.length,c=i/2|0,a=i%2==0?(s[c-1]+s[c])/2:s[c],f=e.o;return((e.o=a)-f)*o(t-r,0)})(q,m(q,R()))),v=!1),c=3,i=!0;break}case 4:S!==r&&(S=r,c=3);break;case 5:r[1]?(V(_(q,r[0],!0)),O=2,c=1):(_(q,r[0]),c=1);break;case 6:g=r;break;case 7:O=1;break;case 8:j=M(r),c=1}c&&(y=1+(2147483647&y),s&&w&&($+=w,w=0),B.forEach((([e,t])=>{c&e&&t(i)})))}}},I=setTimeout,k=(e,t)=>t&&g()?-e:e,O=(e,r,o,n,s,i)=>{const l=Date.now;let c=0,a=!1,u=!1,f=!1,d=!1;const p=(()=>{let r;const o=()=>{r!=t&&clearTimeout(r)},n=()=>{o(),r=I((()=>{r=t,(()=>{if(a||u)return a=!1,void p();f=!1,e.H(2)})()}),150)};return n.V=o,n})(),h=()=>{c=l(),f&&(d=!0),i&&e.H(6,i()),e.H(1,n()),p()},m=t=>{if(a||!e.P()||t.ctrlKey)return;const r=l()-c;150>r&&50<r&&(o?t.deltaX:t.deltaY)&&(a=!0)},_=()=>{u=!0,f=d=!1},v=()=>{u=!1,x()&&(f=!0)};return r.addEventListener("scroll",h),r.addEventListener("wheel",m,{passive:!0}),r.addEventListener("touchstart",_,{passive:!0}),r.addEventListener("touchend",v,{passive:!0}),{C:()=>{r.removeEventListener("scroll",h),r.removeEventListener("wheel",m),r.removeEventListener("touchstart",_),r.removeEventListener("touchend",v),p.V()},F:()=>{const[t,r]=e.N();t&&(s(k(t,o),r,d),d=!1,r&&e.p()>e.M()&&e.H(1,n()))}}},j=e=>{let t;return{J(r){(t||(t=new(S(y(r)).ResizeObserver)(e))).observe(r)},L(e){t.unobserve(e)},C(){t&&t.disconnect()}}},E=/*#__PURE__*/e.defineComponent({props:{W:{type:Object,required:!0},X:{type:Object,required:!0},Y:{type:Object,required:!0},U:{type:Function,required:!0},D:{type:Number,required:!0},G:{type:Boolean},K:{type:Boolean},Z:{type:String,required:!0},ee:Object},setup(t){const r=e.ref(),o=e.computed((()=>t.W.value&&t.X.j(t.D))),n=e.computed((()=>t.W.value&&t.X.k(t.D)));return e.watch((()=>r.value&&t.D),((e,o,n)=>{n(t.U(r.value,t.D))}),{flush:"post"}),()=>{var s;const{Y:i,G:l,K:c,Z:a}=t,u=n.value,{style:f,...d}=null!==(s=t.ee)&&void 0!==s?s:{},p={position:u&&c?void 0:"absolute",[l?"height":"width"]:"100%",[l?"top":"left"]:"0px",[l?g()?"right":"left":"top"]:o.value+"px",visibility:!u||c?"visible":"hidden",...f};return l&&(p.display="flex"),e.createVNode(a,e.mergeProps({ref:r,style:p},d),"function"==typeof(h=i)||"[object Object]"===Object.prototype.toString.call(h)&&!e.isVNode(h)?i:{default:()=>[i],_:2},16,["style"]);var h}}}),T=(e,t)=>{const r=e.key;return null!=r?r:"_"+t},q=(e,t)=>e[0]===t[0]&&e[1]===t[1],B={data:{type:Array,required:!0},overscan:Number,itemSize:Number,shift:Boolean,horizontal:Boolean,startMargin:{type:Number,default:0},ssrCount:Number,scrollRef:Object,as:{type:String,default:"div"},item:{type:String,default:"div"},itemProps:Function,keepMounted:Array},P=/*#__PURE__*/e.defineComponent({props:B,emits:["scroll","scrollEnd"],setup(r,{emit:n,expose:s,slots:a}){let u=!!r.ssrCount;const f=r.horizontal,d=e.ref(),p=w(r.data.length,r.itemSize,r.overscan,r.ssrCount,0,!r.itemSize),h=((e,r)=>{let o;const n=r?"width":"height",s=new WeakMap,i=j((r=>{const i=[];for(const{target:l,contentRect:c}of r)if(l.offsetParent)if(l===o)e.H(4,c[n]);else{const e=s.get(l);e!=t&&i.push([e,c[n]])}i.length&&e.H(3,i)}));return{te(e){i.J(o=e)},re:(e,t)=>(s.set(e,t),i.J(e),()=>{s.delete(e),i.L(e)}),oe:i.C}})(p,f),m=((e,t)=>{let r,o,n;const s=t?"scrollLeft":"scrollTop",l=t?"overflowX":"overflowY",a=async(o,i)=>{if(!r)return void c((()=>a(o,i)));n&&n();const l=()=>{let t;return[new Promise(((r,o)=>{t=r,n=o,$(e)&&I(o,150)})),e.A(2,(()=>{t&&t()}))]};if(i&&z()){for(;e.H(8,o()),e.O();){const[e,t]=l();try{await e}catch(e){return}finally{t()}}r.scrollTo({[t?"left":"top"]:k(o(),t),behavior:"smooth"})}else for(;;){const[n,i]=l();try{r[s]=k(o(),t),e.H(7),await n}catch(e){return}finally{i()}}};return{ne(i){r=i,o=O(e,i,t,(()=>k(i[s],t)),((t,r,o)=>{if(o){const e=i.style,t=e[l];e[l]="hidden",I((()=>{e[l]=t}))}r?(i[s]=e.B()+t,n&&n()):i[s]+=t}))},oe(){o&&o.C()},se(e){a((()=>e))},ie(t){t+=e.B(),a((()=>t))},le(t,{align:r,smooth:o,offset:n=0}={}){if(t=i(t,0,e.q()-1),"nearest"===r){const o=e.j(t),n=e.B();if(o<n)r="start";else{if(!(o+e.T(t)>n+e.p()))return;r="end"}}a((()=>n+e.R()+e.j(t)+("end"===r?e.T(t)-e.p():"center"===r?(e.T(t)-e.p())/2:0)),o)},ce:()=>{o&&o.F()}}})(p,f),_=e.ref(p.h()),v=p.A(1,(()=>{_.value=p.h()})),b=p.A(4,(()=>{n("scroll",p.B())})),y=p.A(8,(()=>{n("scrollEnd")})),S=e.computed((e=>{_.value;const t=p.v();return e&&q(e,t)?e:t})),g=e.computed((()=>_.value&&p.P())),x=e.computed((()=>_.value&&p.M()));return e.onMounted((()=>{u=!1,c((()=>{const e=e=>{h.te(e),m.ne(e)};r.scrollRef?e(r.scrollRef):e(d.value.parentElement)}))})),e.onUnmounted((()=>{v(),b(),y(),h.oe(),m.oe()})),e.watch((()=>r.data.length),(e=>{p.H(5,[e,r.shift])})),e.watch((()=>r.startMargin),(e=>{p.H(6,e)}),{immediate:!0}),e.watch([_],(()=>{m.ce()}),{flush:"post"}),s({get scrollOffset(){return p.B()},get scrollSize(){return(e=>o(e.M(),e.p()))(p)},get viewportSize(){return p.p()},findStartIndex:p.S,findEndIndex:p.I,getItemOffset:p.j,getItemSize:p.T,scrollToIndex:m.le,scrollTo:m.se,scrollBy:m.ie}),()=>{const t=r.as,o=r.item,[n,s]=S.value,i=x.value,c=[];function m(t){var n;const s=a.default({item:r.data[t],index:t})[0];return e.createVNode(E,{key:T(s,t),W:_,X:p,U:h.re,D:t,Y:s,G:f,K:u,Z:o,ee:null===(n=r.itemProps)||void 0===n?void 0:n.call(r,{item:r.data[t],index:t})},null,8,["_stateVersion","_store","_resizer","_index","_children","_isHorizontal","_isSSR","_as","_itemProps"])}for(let e=n,t=s;e<=t;e++)c.push(m(e));if(r.keepMounted){const e=[],t=[];l(r.keepMounted).forEach((r=>{r<n&&e.push(m(r)),r>s&&t.push(m(r))})),c.unshift(...e),c.push(...t)}return e.createVNode(t,{ref:d,style:{overflowAnchor:"none",flex:"none",position:"relative",visibility:"hidden",width:f?i+"px":"100%",height:f?"100%":i+"px",pointerEvents:g.value?"none":void 0}},"function"==typeof(v=c)||"[object Object]"===Object.prototype.toString.call(v)&&!e.isVNode(v)?c:{default:()=>[c],_:2},8,["style"]);var v}}}),R={data:{type:Array,required:!0},overscan:Number,itemSize:Number,shift:Boolean,horizontal:Boolean,ssrCount:Number,itemProps:Function,keepMounted:Array},M=/*#__PURE__*/e.defineComponent({props:R,emits:["scroll","scrollEnd"],setup(t,{emit:r,expose:o,slots:n}){const s=t.horizontal,i=e=>{r("scroll",e)},l=()=>{r("scrollEnd")},c=e.ref();return o({get scrollOffset(){return c.value.scrollOffset},get scrollSize(){return c.value.scrollSize},get viewportSize(){return c.value.viewportSize},findStartIndex:(...e)=>c.value.findStartIndex(...e),findEndIndex:(...e)=>c.value.findEndIndex(...e),getItemOffset:(...e)=>c.value.getItemOffset(...e),getItemSize:(...e)=>c.value.getItemSize(...e),scrollToIndex:(...e)=>c.value.scrollToIndex(...e),scrollTo:(...e)=>c.value.scrollTo(...e),scrollBy:(...e)=>c.value.scrollBy(...e)}),()=>{return e.createVNode("div",{style:{display:s?"inline-block":"block",[s?"overflowX":"overflowY"]:"auto",contain:"strict",width:"100%",height:"100%"}},[e.createVNode(P,{ref:c,data:t.data,overscan:t.overscan,itemSize:t.itemSize,itemProps:t.itemProps,shift:t.shift,ssrCount:t.ssrCount,horizontal:s,keepMounted:t.keepMounted,onScroll:i,onScrollEnd:l},(r=n,"function"==typeof r||"[object Object]"===Object.prototype.toString.call(r)&&!e.isVNode(r)?n:{default:()=>[n],_:2}),8,["data","overscan","itemSize","itemProps","shift","ssrCount","horizontal","keepMounted","onScroll","onScrollEnd"])],4);var r}}}),N={data:{type:Array,required:!0},overscan:Number,itemSize:Number,shift:Boolean,horizontal:Boolean,as:{type:String,default:"div"},item:{type:String,default:"div"}},A=/*#__PURE__*/e.defineComponent({props:N,emits:["scroll","scrollEnd"],setup(r,{emit:o,slots:n,expose:s}){const l=r.horizontal,a=e.ref(),u=w(r.data.length,r.itemSize,r.overscan,void 0,0,!r.itemSize),f=((e,r)=>{const o=r?"width":"height",n=r?"innerWidth":"innerHeight",s=new WeakMap,i=j((r=>{const n=[];for(const{target:e,contentRect:i}of r){if(!e.offsetParent)continue;const r=s.get(e);r!=t&&n.push([r,i[o]])}n.length&&e.H(3,n)}));let l;return{te(t){const r=S(y(t)),o=()=>{e.H(4,r[n])};r.addEventListener("resize",o),o(),l=()=>{r.removeEventListener("resize",o)}},re:(e,t)=>(s.set(e,t),i.J(e),()=>{s.delete(e),i.L(e)}),oe(){l&&l(),i.C()}}})(u,l),d=((e,t)=>{let r,o,n;const s=(e,t,r,o,n=0)=>{const i=o?"offsetLeft":"offsetTop",l=n+(o&&g()?r.innerWidth-e[i]-e.offsetWidth:e[i]),c=e.offsetParent;return e!==t&&c?s(c,t,r,o,l):l},l=async(o,s)=>{if(!r)return void c((()=>l(o,s)));n&&n();const i=()=>{let t;return[new Promise(((r,o)=>{t=r,n=o,$(e)&&I(o,150)})),e.A(2,(()=>{t&&t()}))]},a=S(y(r));if(s&&z()){for(;e.H(8,o()),e.O();){const[e,t]=i();try{await e}catch(e){return}finally{t()}}a.scroll({[t?"left":"top"]:k(o(),t),behavior:"smooth"})}else for(;;){const[r,n]=i();try{a.scroll({[t?"left":"top"]:k(o(),t)}),e.H(7),await r}catch(e){return}finally{n()}}};return{ne(n){r=n;const i=t?"scrollX":"scrollY",l=y(n),c=S(l),a=l.body;o=O(e,c,t,(()=>k(c[i],t)),((r,o)=>{o?c.scroll({[t?"left":"top"]:e.B()+r}):c.scrollBy(t?r:0,t?0:r)}),(()=>s(n,a,c,t)))},oe(){o&&o.C(),r=void 0},ce:()=>{o&&o.F()},le(o,{align:n,smooth:c,offset:a=0}={}){if(!r)return;if(o=i(o,0,e.q()-1),"nearest"===n){const t=e.j(o),r=e.B();if(t<r)n="start";else{if(!(t+e.T(o)>r+e.p()))return;n="end"}}const u=y(r),f=S(u),d=u.documentElement,p=()=>e.p()-(t?d.clientWidth:d.clientHeight);l((()=>a+s(r,u.body,f,t)+e.j(o)+("end"===n?e.T(o)-(e.p()-p()):"center"===n?(e.T(o)-(e.p()-p()))/2:0)),c)}}})(u,l),p=e.ref(u.h()),h=u.A(1,(()=>{p.value=u.h()})),m=u.A(4,(()=>{o("scroll")})),_=u.A(8,(()=>{o("scrollEnd")})),v=e.computed((e=>{p.value;const t=u.v();return e&&q(e,t)?e:t})),b=e.computed((()=>p.value&&u.P())),x=e.computed((()=>p.value&&u.M()));return e.onMounted((()=>{const e=a.value;e&&(f.te(e),d.ne(e))})),e.onUnmounted((()=>{h(),m(),_(),f.oe(),d.oe()})),e.watch((()=>r.data.length),(e=>{u.H(5,[e,r.shift])})),e.watch([p],(()=>{d.ce()}),{flush:"post"}),s({findStartIndex:u.S,findEndIndex:u.I,scrollToIndex:d.le}),()=>{const t=r.as,o=r.item,[s,i]=v.value,c=x.value,d=[];for(let t=s,c=i;t<=c;t++){const s=n.default({item:r.data[t],index:t})[0];d.push(e.createVNode(E,{key:T(s,t),W:p,X:u,U:f.re,D:t,Y:s,G:l,Z:o},null,8,["_stateVersion","_store","_resizer","_index","_children","_isHorizontal","_as"]))}return e.createVNode(t,{ref:a,style:{overflowAnchor:"none",flex:"none",position:"relative",visibility:"hidden",width:l?c+"px":"100%",height:l?"100%":c+"px",pointerEvents:b.value?"none":void 0}},"function"==typeof(h=d)||"[object Object]"===Object.prototype.toString.call(h)&&!e.isVNode(h)?d:{default:()=>[d],_:2},8,["style"]);var h}}});exports.VList=M,exports.Virtualizer=P,exports.WindowVirtualizer=A;
//# sourceMappingURL=index.js.map