@ehfuse/mui-virtual-data-table 1.1.14 → 1.1.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.esm.js +2 -2
- package/dist/index.esm.js.map +3 -3
- package/dist/index.js +2 -2
- package/dist/index.js.map +3 -3
- package/package.json +3 -3
package/dist/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";var ze=Object.defineProperty;var tt=Object.getOwnPropertyDescriptor;var rt=Object.getOwnPropertyNames;var nt=Object.prototype.hasOwnProperty;var ot=(i,p)=>{for(var g in p)ze(i,g,{get:p[g],enumerable:!0})},it=(i,p,g,v)=>{if(p&&typeof p=="object"||typeof p=="function")for(let w of rt(p))!nt.call(i,w)&&w!==g&&ze(i,w,{get:()=>p[w],enumerable:!(v=tt(p,w))||v.enumerable});return i};var lt=i=>it(ze({},"__esModule",{value:!0}),i);var bt={};ot(bt,{VirtualDataTable:()=>Qe});module.exports=lt(bt);var d=require("react"),f=require("@mui/material"),Je=require("react-virtuoso");var Ne=require("react/jsx-runtime"),ve=require("react"),Pe=require("@mui/material"),De=function(){return De=Object.assign||function(p){for(var g,v=1,w=arguments.length;v<w;v++){g=arguments[v];for(var H in g)Object.prototype.hasOwnProperty.call(g,H)&&(p[H]=g[H])}return p},De.apply(this,arguments)};function Ue(i){var p=i.visible,g=i.onComplete,v=i.fadeoutDuration,w=v===void 0?200:v,H=i.exitDelay,k=H===void 0?0:H,R=i.size,I=R===void 0?40:R,q=i.className,U=i.style,j=i.sx,X=i.indicator,O=i.background,W=O===void 0?{show:!0,color:"255, 255, 255",opacity:.9}:O,ie=(0,ve.useRef)(void 0),u=(0,ve.useRef)(null),z=(0,ve.useState)(p),le=z[0],ae=z[1],P=W.show,Y=P===void 0?!0:P,L=W.color,N=L===void 0?"255, 255, 255":L,te=W.opacity,re=te===void 0?.9:te;if((0,ve.useEffect)(function(){var Se=ie.current;if(Se===!0&&p===!1&&u.current){var ne=u.current;ne.style.opacity="0",setTimeout(function(){ae(!1),g?.()},w+k)}else p===!0&&(ae(!0),u.current&&(u.current.style.opacity="1"));ie.current=p},[p,g,w,k]),!le)return null;var we=function(){return typeof X=="string"?(0,Ne.jsx)("img",{src:X,alt:"Loading",style:{width:I,height:I}}):X||(0,Ne.jsx)(Pe.CircularProgress,{size:I})},de=function(){return Y?N.startsWith("rgba")?{backgroundColor:N}:/^\d+,\s*\d+,\s*\d+$/.test(N)?{backgroundColor:"rgba(".concat(N,", ").concat(re,")")}:re!==1?{backgroundColor:N,"&::before":{content:'""',position:"absolute",top:0,left:0,right:0,bottom:0,backgroundColor:N,opacity:re,zIndex:-1}}:{backgroundColor:N}:{backgroundColor:"transparent"}};return(0,Ne.jsx)(Pe.Box,{ref:u,className:q,style:De({},U),sx:De(De({position:"absolute",top:0,left:0,right:0,bottom:0,display:"flex",alignItems:"center",justifyContent:"center",zIndex:1e3,opacity:p?1:0,transition:"opacity ".concat(w,"ms ease-out")},de()),j),children:we()})}var n=require("react"),ee=require("react/jsx-runtime"),at=["editor","textarea","input","select","textfield","form-control","contenteditable","MuiInputBase-input","MuiSelect-select","MuiOutlinedInput-input","MuiFilledInput-input","MuiInput-input","MuiFormControl-root","MuiTextField-root","MuiSelect-root","MuiOutlinedInput-root","MuiFilledInput-root","MuiInput-root","MuiAutocomplete-input","MuiDatePicker-input","MuiSlider-thumb","MuiSlider-rail","MuiSlider-track","MuiSlider-mark","MuiSlider-markLabel","MuiSlider-root","MuiSlider-colorPrimary","MuiSlider-sizeMedium","MuiIconButton-root","MuiButton-root","MuiButtonBase-root","MuiTouchRipple-root","MuiCheckbox-root","MuiRadio-root","MuiSwitch-root","PrivateSwitchBase-root","ant-input","ant-input-affix-wrapper","ant-input-group-addon","ant-input-number","ant-input-number-handler","ant-select","ant-select-selector","ant-select-selection-search","ant-select-dropdown","ant-cascader","ant-cascader-input","ant-picker","ant-picker-input","ant-time-picker","ant-calendar-picker","ant-slider","ant-slider-track","ant-slider-handle","ant-switch","ant-checkbox","ant-checkbox-wrapper","ant-radio","ant-radio-wrapper","ant-rate","ant-upload","ant-upload-drag","ant-form-item","ant-form-item-control","ant-btn","ant-dropdown","ant-dropdown-trigger","ant-menu","ant-menu-item","ant-tooltip","ant-popover","ant-modal","ant-drawer","ant-tree-select","ant-auto-complete","ant-mentions","ant-transfer","ui-input","ui-textarea","ui-select","ui-select-trigger","ui-select-content","ui-select-item","ui-button","ui-checkbox","ui-radio-group","ui-switch","ui-slider","ui-range-slider","ui-calendar","ui-date-picker","ui-combobox","ui-command","ui-command-input","ui-popover","ui-dialog","ui-sheet","ui-dropdown-menu","ui-context-menu","ui-menubar","ui-navigation-menu","ui-form","ui-form-control","ui-form-item","ui-form-field","ui-label","radix-ui","radix-select","radix-dropdown","radix-dialog","radix-popover","radix-accordion","radix-tabs","radix-slider","radix-switch","radix-checkbox","radix-radio","ql-editor","ql-container","ql-toolbar","ql-picker","ql-picker-label","ql-picker-options","ql-formats","ql-snow","ql-bubble","quill","quilleditor","monaco-editor","monaco-editor-background","view-lines","decorationsOverviewRuler","monaco-scrollable-element","CodeMirror","CodeMirror-code","CodeMirror-lines","CodeMirror-scroll","CodeMirror-sizer","cm-editor","cm-focused","cm-content","tox-editor-container","tox-editor-header","tox-edit-area","tox-tinymce","mce-content-body","ck-editor","ck-content","ck-toolbar","ck-editor__editable","ck-widget","slate-editor","slate-content","DraftEditor-root","DraftEditor-editorContainer","public-DraftEditor-content","ehfuse-editor","ehfuse-editor-wrapper","ehfuse-editor-content","ehfuse-toolbar","ehfuse-toolbar-group","ehfuse-cursor","text-editor","rich-text-editor","wysiwyg","ace_editor","ace_content"],Xe=(i,p)=>{let g=i.tagName.toLowerCase(),v=["text","password","email","number","search","tel","url","checkbox","radio"];if(g==="input"){let w=i.type;return v.includes(w)}if(["textarea","select","button"].includes(g)||["svg","path","circle","rect","line","polygon","polyline"].includes(g)||i.getAttribute("contenteditable")==="true")return!0;if(p?.excludeSelectors){for(let w of p.excludeSelectors)if(i.matches(w))return!0}return st(i,p)},st=(i,p)=>{let g=[...at,...p?.excludeClasses||[]],v=i,w=0,H=5;for(;v&&w<=H;){if(g.some(k=>v.classList.contains(k)))return!0;if(v.classList.contains("MuiDialogContent-root"))break;v=v.parentElement,w++}return!1},ct={},ut={},dt={},pt={},ft={},mt=(0,n.forwardRef)(({className:i="",style:p={},containerStyle:g={},contentStyle:v={},children:w,onScroll:H,thumb:k=ct,track:R=ut,arrows:I=dt,dragScroll:q=pt,autoHide:U=ft,showScrollbar:j=!0,detectInnerScroll:X=!1},O)=>{let W=(0,n.useRef)({});(0,n.useEffect)(()=>{W.current={children:w,onScroll:H,showScrollbar:j,thumb:k,track:R,arrows:I,dragScroll:q,autoHide:U}});let ie=(0,n.useRef)(null),u=(0,n.useRef)(null),z=(0,n.useRef)(null),le=(0,n.useRef)(null),ae=(0,n.useRef)(null),P=(0,n.useRef)(null),[Y,L]=(0,n.useState)(!1),[N,te]=(0,n.useState)(!1),[re,we]=(0,n.useState)(!1),[de,Se]=(0,n.useState)({y:0,scrollTop:0}),[ne,Fe]=(0,n.useState)(0),[Be,Ee]=(0,n.useState)(0),[Me,Ae]=(0,n.useState)(!1),[x,b]=(0,n.useState)(!1),[se,Re]=(0,n.useState)({x:0,y:0,scrollTop:0,scrollLeft:0}),[He,Ye]=(0,n.useState)(null),[pe,Ce]=(0,n.useState)(null),[_e,Ie]=(0,n.useState)(!1),fe=(0,n.useRef)(null),[Ve,Te]=(0,n.useState)(!1),oe=(0,n.useRef)(null),me=(0,n.useRef)(null),Z=(0,n.useRef)(null),F=(0,n.useMemo)(()=>{let t=k.color??"#606060";return{width:k.width??8,minHeight:k.minHeight??50,radius:k.radius??(k.width??8)/2,color:t,opacity:k.opacity??.6,hoverColor:k.hoverColor??t,hoverOpacity:k.hoverOpacity??1}},[k]),y=(0,n.useMemo)(()=>({width:R.width??16,color:R.color??"rgba(128, 128, 128, 0.1)",visible:R.visible??!0,alignment:R.alignment??"center",radius:R.radius??F.radius??4,margin:R.margin??4}),[R,F.radius]),_=(0,n.useMemo)(()=>{let t=I.color??"#808080";return{visible:I.visible??!1,step:I.step??50,color:t,opacity:I.opacity??.6,hoverColor:I.hoverColor??t,hoverOpacity:I.hoverOpacity??1}},[I]),he=(0,n.useMemo)(()=>({enabled:q.enabled??!0,excludeClasses:q.excludeClasses??[],excludeSelectors:q.excludeSelectors??[]}),[q]),T=(0,n.useMemo)(()=>({enabled:U.enabled??!0,delay:U.delay??1500,delayOnWheel:U.delayOnWheel??700}),[U]),$=F.width,Ge=y.width,ke=F.minHeight,G=_.visible,l=_.step,r=(0,n.useCallback)(()=>{if(!u.current)return;let t=document.activeElement;t&&u.current.contains(t)&&t!==u.current||u.current.focus()},[]);(0,n.useImperativeHandle)(O,()=>({getScrollContainer:()=>u.current,scrollTo:t=>{u.current&&u.current.scrollTo(t)},get scrollTop(){return u.current?.scrollTop||0},get scrollHeight(){return u.current?.scrollHeight||0},get clientHeight(){return u.current?.clientHeight||0}}),[]);let h=(0,n.useCallback)(()=>{if(P.current){let o=P.current;if(document.contains(o)&&o.scrollHeight>o.clientHeight+2)return o;P.current=null}if(!u.current)return null;if(z.current&&z.current.scrollHeight>u.current.clientHeight+2)return P.current=u.current,u.current;if(!X)return null;let t=u.current.querySelectorAll('[data-virtuoso-scroller], [style*="overflow"], .virtuoso-scroller, [style*="overflow: auto"], [style*="overflow:auto"]');for(let o of t){let s=o;if(s!==u.current&&s.classList.contains("overlay-scrollbar-container"))continue;let m=s.parentElement,S=!1;for(;m&&m!==u.current;){if(m.classList.contains("overlay-scrollbar-container")&&m!==u.current){S=!0;break}m=m.parentElement}if(!S&&s.scrollHeight>s.clientHeight+2)return P.current=s,s}return null},[]),D=(0,n.useCallback)(()=>h()!==null,[h]),a=(0,n.useCallback)(()=>{oe.current&&(clearTimeout(oe.current),oe.current=null)},[]),e=(0,n.useCallback)(()=>{me.current&&(clearTimeout(me.current),me.current=null)},[]),V=(0,n.useCallback)(()=>{Z.current&&(clearTimeout(Z.current),Z.current=null)},[]),M=(0,n.useCallback)(t=>{T.enabled&&(a(),oe.current=setTimeout(()=>{L(!1),oe.current=null},t))},[a,T.enabled]),C=(0,n.useCallback)(()=>{let t=h();if(!t){L(!1),Ae(!1),a();return}if(Ae(!0),!le.current)return;T.enabled||(L(!0),a());let o=t.clientHeight,s=t.scrollHeight,m=t.scrollTop,S=0;if(ie.current){let $e=window.getComputedStyle(ie.current),We=parseFloat($e.paddingTop)||0,et=parseFloat($e.paddingBottom)||0;S=We+et}let E=G?$*2+y.margin*4:y.margin*2,B=o-E+S,A=o/s,ye=Math.max(B*A,ke),Le=s-o,J=B-ye,qe=Le>0?m/Le*J:0;Fe(ye),Ee(qe)},[h,a,G,$,ke,T.enabled]),Q=(0,n.useCallback)(t=>{t.preventDefault(),t.stopPropagation();let o=h();o&&(te(!0),Se({y:t.clientY,scrollTop:o.scrollTop}),a(),L(!0),r())},[h,a,r]),ge=(0,n.useCallback)(t=>{if(!N)return;let o=h();if(!o)return;let s=o.clientHeight,m=o.scrollHeight-s,S=t.clientY-de.y,E=s-ne,B=S/E*m,A=Math.max(0,Math.min(m,de.scrollTop+B));o.scrollTop=A,C()},[N,de,ne,C,h]),ce=(0,n.useCallback)(()=>{te(!1),D()&&M(T.delay)},[D,M,T.delay]),K=(0,n.useCallback)(t=>{if(!le.current)return;let o=le.current.getBoundingClientRect(),s=t.clientY-o.top,m=h();if(!m)return;let S=m.clientHeight,E=m.scrollHeight,B=s/S*(E-S);m.scrollTop=Math.max(0,Math.min(E-S,B)),C(),L(!0),M(T.delay),r()},[C,M,T.delay,h,r]),je=(0,n.useCallback)(t=>{if(t.preventDefault(),t.stopPropagation(),!u.current)return;let o=Math.max(0,u.current.scrollTop-l);u.current.scrollTop=o,C(),L(!0),M(T.delay),r()},[C,M,l,T.delay,r]),Ke=(0,n.useCallback)(t=>{if(t.preventDefault(),t.stopPropagation(),!u.current||!z.current)return;let o=u.current,s=z.current.scrollHeight-o.clientHeight,m=Math.min(s,o.scrollTop+l);o.scrollTop=m,C(),L(!0),M(T.delay),r()},[C,M,l,T.delay,r]),Oe=(0,n.useCallback)(t=>{if(!he.enabled)return;let o=t.target;if(Xe(o,he)||t.button!==0)return;let s=h();s&&(s.scrollHeight<=s.clientHeight||(t.preventDefault(),b(!0),Re({x:t.clientX,y:t.clientY,scrollTop:s.scrollTop,scrollLeft:s.scrollLeft||0}),a()))},[he,Xe,h,a]),be=(0,n.useCallback)(t=>{if(!x)return;let o=h();if(!o)return;let s=se.x-t.clientX,m=se.y-t.clientY;if(Math.abs(m)<3&&Math.abs(s)<3)return;L(!0);let S=Math.max(0,Math.min(o.scrollHeight-o.clientHeight,se.scrollTop+m));o.scrollTop=S,C()},[x,se,h,C]),ue=(0,n.useCallback)(()=>{b(!1),D()&&M(T.delay)},[D,M,T.delay]);(0,n.useEffect)(()=>{let t=E=>{C(),a(),L(!0);let B=Ve?T.delayOnWheel:T.delay;M(B),H&&H(E)},o=()=>{Te(!0),fe.current&&clearTimeout(fe.current),fe.current=setTimeout(()=>{Te(!1)},300),a(),V(),Z.current=setTimeout(()=>{L(!0),Z.current=null},50)},s=[],m=h();m&&s.push(m);let S=u.current;return S&&!m&&(s.push(S),S.querySelectorAll('[data-virtuoso-scroller], [style*="overflow"], .virtuoso-scroller, [style*="overflow: auto"], [style*="overflow:auto"]').forEach(E=>{let B=E;if(B!==S&&B.classList.contains("overlay-scrollbar-container"))return;let A=B.parentElement;for(;A&&A!==S;){if(A.classList.contains("overlay-scrollbar-container")&&A!==S)return;A=A.parentElement}s.push(B)})),s.forEach(E=>{E.addEventListener("scroll",t,{passive:!0}),E.addEventListener("wheel",o,{passive:!0})}),()=>{s.forEach(E=>{E.removeEventListener("scroll",t),E.removeEventListener("wheel",o)}),fe.current&&clearTimeout(fe.current),Z.current&&clearTimeout(Z.current)}},[h,C,H,a,M,T,Ve]),(0,n.useEffect)(()=>{let t=s=>{let m=h();if(!m)return;let{key:S}=s,{scrollTop:E,scrollHeight:B,clientHeight:A}=m,ye=B-A,Le=50,J=null;switch(S){case"ArrowUp":s.preventDefault(),J=Math.max(0,E-Le);break;case"ArrowDown":s.preventDefault(),J=Math.min(ye,E+Le);break;case"PageUp":s.preventDefault(),J=Math.max(0,E-A);break;case"PageDown":s.preventDefault(),J=Math.min(ye,E+A);break;case"Home":s.preventDefault(),J=0;break;case"End":s.preventDefault(),J=ye;break;default:return}if(J!==null){let qe=J/ye,$e=G?$*2+y.margin*4:y.margin*2,We=(A-$e-ne)*qe;Ee(We),m.scrollTop=J,a(),L(!0),M(T.delay)}},o=u.current;if(o)return o.addEventListener("keydown",t),()=>{o.removeEventListener("keydown",t)}},[h,G,$,y.margin,ne,a,M,T.delay]),(0,n.useEffect)(()=>{if(x)return document.addEventListener("mousemove",be),document.addEventListener("mouseup",ue),()=>{document.removeEventListener("mousemove",be),document.removeEventListener("mouseup",ue)}},[x,be,ue]),(0,n.useEffect)(()=>{if(N)return document.addEventListener("mousemove",ge),document.addEventListener("mouseup",ce),()=>{document.removeEventListener("mousemove",ge),document.removeEventListener("mouseup",ce)}},[N,ge,ce]),(0,n.useEffect)(()=>{C();let t=setTimeout(()=>{C()},100);return()=>clearTimeout(t)},[C]),(0,n.useLayoutEffect)(()=>{Ie(!0),C(),!T.enabled&&D()&&L(!0)},[D,C,T.enabled]),(0,n.useEffect)(()=>{let t=new ResizeObserver(()=>{C()}),o=[];return u.current&&o.push(u.current),z.current&&o.push(z.current),P.current&&document.contains(P.current)&&o.push(P.current),o.forEach(s=>{t.observe(s)}),()=>t.disconnect()},[C]),(0,n.useEffect)(()=>{if(!u.current)return;let t=new MutationObserver(()=>{P.current=null,C()});return t.observe(u.current,{childList:!0,subtree:!0,attributes:!0,attributeFilter:["style"]}),()=>t.disconnect()},[C]);let xe=Math.max(Ge,$);return(0,n.useEffect)(()=>{let t="overlay-scrollbar-webkit-hide",o=document.getElementById(t);o&&o.remove();let s=document.createElement("style");return s.id=t,s.textContent=`
|
|
1
|
+
"use strict";var _e=Object.defineProperty;var rt=Object.getOwnPropertyDescriptor;var nt=Object.getOwnPropertyNames;var ot=Object.prototype.hasOwnProperty;var it=(l,d)=>{for(var b in d)_e(l,b,{get:d[b],enumerable:!0})},lt=(l,d,b,v)=>{if(d&&typeof d=="object"||typeof d=="function")for(let w of nt(d))!ot.call(l,w)&&w!==b&&_e(l,w,{get:()=>d[w],enumerable:!(v=rt(d,w))||v.enumerable});return l};var at=l=>lt(_e({},"__esModule",{value:!0}),l);var xt={};it(xt,{VirtualDataTable:()=>et});module.exports=at(xt);var u=require("react"),m=require("@mui/material"),Qe=require("react-virtuoso");var Fe=require("react/jsx-runtime"),ge=require("react"),Ae=require("@mui/material"),He=function(){return He=Object.assign||function(d){for(var b,v=1,w=arguments.length;v<w;v++){b=arguments[v];for(var I in b)Object.prototype.hasOwnProperty.call(b,I)&&(d[I]=b[I])}return d},He.apply(this,arguments)};function Ke(l){var d=l.visible,b=l.onComplete,v=l.fadeoutDuration,w=v===void 0?200:v,I=l.exitDelay,k=I===void 0?0:I,E=l.size,O=E===void 0?40:E,Y=l.className,K=l.style,W=l.sx,U=l.indicator,$=l.background,_=$===void 0?{show:!0,color:"255, 255, 255",opacity:.9}:$,ie=(0,ge.useRef)(void 0),c=(0,ge.useRef)(null),G=(0,ge.useState)(d),le=G[0],ae=G[1],A=_.show,X=A===void 0?!0:A,L=_.color,P=L===void 0?"255, 255, 255":L,te=_.opacity,re=te===void 0?.9:te;if((0,ge.useEffect)(function(){var Ce=ie.current;if(Ce===!0&&d===!1&&c.current){var ne=c.current;ne.style.opacity="0",setTimeout(function(){ae(!1),b?.()},w+k)}else d===!0&&(ae(!0),c.current&&(c.current.style.opacity="1"));ie.current=d},[d,b,w,k]),!le)return null;var be=function(){return typeof U=="string"?(0,Fe.jsx)("img",{src:U,alt:"Loading",style:{width:O,height:O}}):U||(0,Fe.jsx)(Ae.CircularProgress,{size:O})},de=function(){return X?P.startsWith("rgba")?{backgroundColor:P}:/^\d+,\s*\d+,\s*\d+$/.test(P)?{backgroundColor:"rgba(".concat(P,", ").concat(re,")")}:re!==1?{backgroundColor:P,"&::before":{content:'""',position:"absolute",top:0,left:0,right:0,bottom:0,backgroundColor:P,opacity:re,zIndex:-1}}:{backgroundColor:P}:{backgroundColor:"transparent"}};return(0,Fe.jsx)(Ae.Box,{ref:c,className:Y,style:He({},K),sx:He(He({position:"absolute",top:0,left:0,right:0,bottom:0,display:"flex",alignItems:"center",justifyContent:"center",zIndex:1e3,opacity:d?1:0,transition:"opacity ".concat(w,"ms ease-out")},de()),W),children:be()})}var r=require("react"),ee=require("react/jsx-runtime"),st=["editor","textarea","input","select","textfield","form-control","contenteditable","MuiInputBase-input","MuiSelect-select","MuiOutlinedInput-input","MuiFilledInput-input","MuiInput-input","MuiFormControl-root","MuiTextField-root","MuiSelect-root","MuiOutlinedInput-root","MuiFilledInput-root","MuiInput-root","MuiAutocomplete-input","MuiDatePicker-input","MuiSlider-thumb","MuiSlider-rail","MuiSlider-track","MuiSlider-mark","MuiSlider-markLabel","MuiSlider-root","MuiSlider-colorPrimary","MuiSlider-sizeMedium","MuiIconButton-root","MuiButton-root","MuiButtonBase-root","MuiTouchRipple-root","MuiCheckbox-root","MuiRadio-root","MuiSwitch-root","PrivateSwitchBase-root","ant-input","ant-input-affix-wrapper","ant-input-group-addon","ant-input-number","ant-input-number-handler","ant-select","ant-select-selector","ant-select-selection-search","ant-select-dropdown","ant-cascader","ant-cascader-input","ant-picker","ant-picker-input","ant-time-picker","ant-calendar-picker","ant-slider","ant-slider-track","ant-slider-handle","ant-switch","ant-checkbox","ant-checkbox-wrapper","ant-radio","ant-radio-wrapper","ant-rate","ant-upload","ant-upload-drag","ant-form-item","ant-form-item-control","ant-btn","ant-dropdown","ant-dropdown-trigger","ant-menu","ant-menu-item","ant-tooltip","ant-popover","ant-modal","ant-drawer","ant-tree-select","ant-auto-complete","ant-mentions","ant-transfer","ui-input","ui-textarea","ui-select","ui-select-trigger","ui-select-content","ui-select-item","ui-button","ui-checkbox","ui-radio-group","ui-switch","ui-slider","ui-range-slider","ui-calendar","ui-date-picker","ui-combobox","ui-command","ui-command-input","ui-popover","ui-dialog","ui-sheet","ui-dropdown-menu","ui-context-menu","ui-menubar","ui-navigation-menu","ui-form","ui-form-control","ui-form-item","ui-form-field","ui-label","radix-ui","radix-select","radix-dropdown","radix-dialog","radix-popover","radix-accordion","radix-tabs","radix-slider","radix-switch","radix-checkbox","radix-radio","ql-editor","ql-container","ql-toolbar","ql-picker","ql-picker-label","ql-picker-options","ql-formats","ql-snow","ql-bubble","quill","quilleditor","monaco-editor","monaco-editor-background","view-lines","decorationsOverviewRuler","monaco-scrollable-element","CodeMirror","CodeMirror-code","CodeMirror-lines","CodeMirror-scroll","CodeMirror-sizer","cm-editor","cm-focused","cm-content","tox-editor-container","tox-editor-header","tox-edit-area","tox-tinymce","mce-content-body","ck-editor","ck-content","ck-toolbar","ck-editor__editable","ck-widget","slate-editor","slate-content","DraftEditor-root","DraftEditor-editorContainer","public-DraftEditor-content","ehfuse-editor","ehfuse-editor-wrapper","ehfuse-editor-content","ehfuse-toolbar","ehfuse-toolbar-group","ehfuse-cursor","text-editor","rich-text-editor","wysiwyg","ace_editor","ace_content"],Ue=(l,d)=>{let b=l.tagName.toLowerCase(),v=["text","password","email","number","search","tel","url","checkbox","radio"];if(b==="input"){let w=l.type;return v.includes(w)}if(["textarea","select","button"].includes(b)||["svg","path","circle","rect","line","polygon","polyline"].includes(b)||l.getAttribute("contenteditable")==="true")return!0;if(d?.excludeSelectors){for(let w of d.excludeSelectors)if(l.matches(w))return!0}return ct(l,d)},ct=(l,d)=>{let b=[...st,...d?.excludeClasses||[]],v=l,w=0,I=5;for(;v&&w<=I;){if(b.some(k=>v.classList.contains(k)))return!0;if(v.classList.contains("MuiDialogContent-root"))break;v=v.parentElement,w++}return!1},ut={},dt={},pt={},ft={},mt={},ht=(0,r.forwardRef)(({className:l="",style:d={},containerStyle:b={},contentStyle:v={},children:w,onScroll:I,thumb:k=ut,track:E=dt,arrows:O=pt,dragScroll:Y=ft,autoHide:K=mt,showScrollbar:W=!0,detectInnerScroll:U=!1},$)=>{let _=(0,r.useRef)({});(0,r.useEffect)(()=>{_.current={children:w,onScroll:I,showScrollbar:W,thumb:k,track:E,arrows:O,dragScroll:Y,autoHide:K}});let ie=(0,r.useRef)(null),c=(0,r.useRef)(null),G=(0,r.useRef)(null),le=(0,r.useRef)(null),ae=(0,r.useRef)(null),A=(0,r.useRef)(null),[X,L]=(0,r.useState)(!1),[P,te]=(0,r.useState)(!1),[re,be]=(0,r.useState)(!1),[de,Ce]=(0,r.useState)({y:0,scrollTop:0}),[ne,Be]=(0,r.useState)(0),[Ve,Ie]=(0,r.useState)(0),[xe,qe]=(0,r.useState)(!1),[y,x]=(0,r.useState)(!1),[se,Oe]=(0,r.useState)({x:0,y:0,scrollTop:0,scrollLeft:0}),[$e,Ge]=(0,r.useState)(null),[pe,ye]=(0,r.useState)(null),[Xe,Ne]=(0,r.useState)(!1),fe=(0,r.useRef)(null),[je,ve]=(0,r.useState)(!1),oe=(0,r.useRef)(null),Z=(0,r.useRef)(null),z=(0,r.useRef)(null),N=(0,r.useMemo)(()=>{let t=k.color??"#606060";return{width:k.width??8,minHeight:k.minHeight??50,radius:k.radius??(k.width??8)/2,color:t,opacity:k.opacity??.6,hoverColor:k.hoverColor??t,hoverOpacity:k.hoverOpacity??1}},[k]),T=(0,r.useMemo)(()=>({width:E.width??16,color:E.color??"rgba(128, 128, 128, 0.1)",visible:E.visible??!0,alignment:E.alignment??"center",radius:E.radius??N.radius??4,margin:E.margin??4}),[E,N.radius]),q=(0,r.useMemo)(()=>{let t=O.color??"#808080";return{visible:O.visible??!1,step:O.step??50,color:t,opacity:O.opacity??.6,hoverColor:O.hoverColor??t,hoverOpacity:O.hoverOpacity??1}},[O]),Te=(0,r.useMemo)(()=>({enabled:Y.enabled??!0,excludeClasses:Y.excludeClasses??[],excludeSelectors:Y.excludeSelectors??[]}),[Y]),M=(0,r.useMemo)(()=>({enabled:K.enabled??!0,delay:K.delay??1500,delayOnWheel:K.delayOnWheel??700}),[K]),F=N.width,We=T.width,we=N.minHeight,o=q.visible,n=q.step,C=(0,r.useCallback)(()=>{if(!c.current)return;let t=document.activeElement;t&&c.current.contains(t)&&t!==c.current||c.current.focus()},[]);(0,r.useImperativeHandle)($,()=>({getScrollContainer:()=>c.current,scrollTo:t=>{c.current&&c.current.scrollTo(t)},get scrollTop(){return c.current?.scrollTop||0},get scrollHeight(){return c.current?.scrollHeight||0},get clientHeight(){return c.current?.clientHeight||0}}),[]);let p=(0,r.useCallback)(()=>{if(A.current){let i=A.current;if(document.contains(i)&&i.scrollHeight>i.clientHeight+2)return i;A.current=null}if(!c.current)return null;if(G.current&&G.current.scrollHeight>c.current.clientHeight+2)return A.current=c.current,c.current;if(!U)return null;let t=c.current.querySelectorAll('[data-virtuoso-scroller], [style*="overflow"], .virtuoso-scroller, [style*="overflow: auto"], [style*="overflow:auto"]');for(let i of t){let a=i;if(a!==c.current&&a.classList.contains("overlay-scrollbar-container"))continue;let h=a.parentElement,S=!1;for(;h&&h!==c.current;){if(h.classList.contains("overlay-scrollbar-container")&&h!==c.current){S=!0;break}h=h.parentElement}if(!S&&a.scrollHeight>a.clientHeight+2)return A.current=a,a}return null},[]),f=(0,r.useCallback)(()=>p()!==null,[p]),e=(0,r.useCallback)(()=>{oe.current&&(clearTimeout(oe.current),oe.current=null)},[]),j=(0,r.useCallback)(()=>{Z.current&&(clearTimeout(Z.current),Z.current=null)},[]),J=(0,r.useCallback)(()=>{z.current&&(clearTimeout(z.current),z.current=null)},[]),R=(0,r.useCallback)(t=>{M.enabled&&(e(),oe.current=setTimeout(()=>{L(!1),oe.current=null},t))},[e,M.enabled]),g=(0,r.useCallback)(()=>{let t=p();if(!t){L(!1),qe(!1),e();return}if(qe(!0),!le.current)return;M.enabled||(L(!0),e());let i=t.clientHeight,a=t.scrollHeight,h=t.scrollTop,S=0;if(ie.current){let Pe=window.getComputedStyle(ie.current),Ye=parseFloat(Pe.paddingTop)||0,tt=parseFloat(Pe.paddingBottom)||0;S=Ye+tt}let D=o?F*2+T.margin*4:T.margin*2,B=i-D+S,V=i/a,he=Math.max(B*V,we),Re=a-i,Q=B-he,ze=Re>0?h/Re*Q:0;Be(he),Ie(ze)},[p,e,o,F,we,M.enabled]),Se=(0,r.useCallback)(t=>{t.preventDefault(),t.stopPropagation();let i=p();i&&(te(!0),Ce({y:t.clientY,scrollTop:i.scrollTop}),e(),L(!0),C())},[p,e,C]),ce=(0,r.useCallback)(t=>{if(!P)return;let i=p();if(!i)return;let a=i.clientHeight,h=i.scrollHeight-a,S=t.clientY-de.y,D=a-ne,B=S/D*h,V=Math.max(0,Math.min(h,de.scrollTop+B));i.scrollTop=V,g()},[P,de,ne,g,p]),H=(0,r.useCallback)(()=>{te(!1),f()&&R(M.delay)},[f,R,M.delay]),Me=(0,r.useCallback)(t=>{if(!le.current)return;let i=le.current.getBoundingClientRect(),a=t.clientY-i.top,h=p();if(!h)return;let S=h.clientHeight,D=h.scrollHeight,B=a/S*(D-S);h.scrollTop=Math.max(0,Math.min(D-S,B)),g(),L(!0),R(M.delay),C()},[g,R,M.delay,p,C]),ke=(0,r.useCallback)(t=>{if(t.preventDefault(),t.stopPropagation(),!c.current)return;let i=Math.max(0,c.current.scrollTop-n);c.current.scrollTop=i,g(),L(!0),R(M.delay),C()},[g,R,n,M.delay,C]),Le=(0,r.useCallback)(t=>{if(t.preventDefault(),t.stopPropagation(),!c.current||!G.current)return;let i=c.current,a=G.current.scrollHeight-i.clientHeight,h=Math.min(a,i.scrollTop+n);i.scrollTop=h,g(),L(!0),R(M.delay),C()},[g,R,n,M.delay,C]),De=(0,r.useCallback)(t=>{if(!Te.enabled)return;let i=t.target;if(Ue(i,Te)||t.button!==0)return;let a=p();a&&(a.scrollHeight<=a.clientHeight||(t.preventDefault(),x(!0),Oe({x:t.clientX,y:t.clientY,scrollTop:a.scrollTop,scrollLeft:a.scrollLeft||0}),e()))},[Te,Ue,p,e]),ue=(0,r.useCallback)(t=>{if(!y)return;let i=p();if(!i)return;let a=se.x-t.clientX,h=se.y-t.clientY;if(Math.abs(h)<3&&Math.abs(a)<3)return;L(!0);let S=Math.max(0,Math.min(i.scrollHeight-i.clientHeight,se.scrollTop+h));i.scrollTop=S,g()},[y,se,p,g]),Ee=(0,r.useCallback)(()=>{x(!1),f()&&R(M.delay)},[f,R,M.delay]);(0,r.useEffect)(()=>{let t=D=>{g(),e(),L(!0);let B=je?M.delayOnWheel:M.delay;R(B),I&&I(D)},i=()=>{ve(!0),fe.current&&clearTimeout(fe.current),fe.current=setTimeout(()=>{ve(!1)},300),e(),J(),z.current=setTimeout(()=>{L(!0),z.current=null},50)},a=[],h=p();h&&a.push(h);let S=c.current;return S&&!h&&(a.push(S),S.querySelectorAll('[data-virtuoso-scroller], [style*="overflow"], .virtuoso-scroller, [style*="overflow: auto"], [style*="overflow:auto"]').forEach(D=>{let B=D;if(B!==S&&B.classList.contains("overlay-scrollbar-container"))return;let V=B.parentElement;for(;V&&V!==S;){if(V.classList.contains("overlay-scrollbar-container")&&V!==S)return;V=V.parentElement}a.push(B)})),a.forEach(D=>{D.addEventListener("scroll",t,{passive:!0}),D.addEventListener("wheel",i,{passive:!0})}),()=>{a.forEach(D=>{D.removeEventListener("scroll",t),D.removeEventListener("wheel",i)}),fe.current&&clearTimeout(fe.current),z.current&&clearTimeout(z.current)}},[p,g,I,e,R,M,je]),(0,r.useEffect)(()=>{let t=a=>{let h=p();if(!h)return;let{key:S}=a,{scrollTop:D,scrollHeight:B,clientHeight:V}=h,he=B-V,Re=50,Q=null;switch(S){case"ArrowUp":a.preventDefault(),Q=Math.max(0,D-Re);break;case"ArrowDown":a.preventDefault(),Q=Math.min(he,D+Re);break;case"PageUp":a.preventDefault(),Q=Math.max(0,D-V);break;case"PageDown":a.preventDefault(),Q=Math.min(he,D+V);break;case"Home":a.preventDefault(),Q=0;break;case"End":a.preventDefault(),Q=he;break;default:return}if(Q!==null){let ze=Q/he,Pe=o?F*2+T.margin*4:T.margin*2,Ye=(V-Pe-ne)*ze;Ie(Ye),h.scrollTop=Q,e(),L(!0),R(M.delay)}},i=c.current;if(i)return i.addEventListener("keydown",t),()=>{i.removeEventListener("keydown",t)}},[p,o,F,T.margin,ne,e,R,M.delay]),(0,r.useEffect)(()=>{if(y)return document.addEventListener("mousemove",ue),document.addEventListener("mouseup",Ee),()=>{document.removeEventListener("mousemove",ue),document.removeEventListener("mouseup",Ee)}},[y,ue,Ee]),(0,r.useEffect)(()=>{if(P)return document.addEventListener("mousemove",ce),document.addEventListener("mouseup",H),()=>{document.removeEventListener("mousemove",ce),document.removeEventListener("mouseup",H)}},[P,ce,H]),(0,r.useEffect)(()=>{g();let t=setTimeout(()=>{g()},100);return()=>clearTimeout(t)},[g]),(0,r.useLayoutEffect)(()=>{Ne(!0),g(),!M.enabled&&f()&&L(!0)},[f,g,M.enabled]),(0,r.useEffect)(()=>{let t=new ResizeObserver(()=>{g()}),i=[];return c.current&&i.push(c.current),G.current&&i.push(G.current),A.current&&document.contains(A.current)&&i.push(A.current),i.forEach(a=>{t.observe(a)}),()=>t.disconnect()},[g]),(0,r.useEffect)(()=>{if(!c.current)return;let t=new MutationObserver(()=>{A.current=null,g()});return t.observe(c.current,{childList:!0,subtree:!0,attributes:!0,attributeFilter:["style"]}),()=>t.disconnect()},[g]);let me=Math.max(We,F);return(0,r.useEffect)(()=>{let t="overlay-scrollbar-webkit-hide",i=document.getElementById(t);i&&i.remove();let a=document.createElement("style");return a.id=t,a.textContent=`
|
|
2
2
|
.overlay-scrollbar-container::-webkit-scrollbar {
|
|
3
3
|
display: none !important;
|
|
4
4
|
width: 0 !important;
|
|
@@ -18,7 +18,7 @@
|
|
|
18
18
|
outline: 2px solid rgba(0, 123, 255, 0.5);
|
|
19
19
|
outline-offset: -2px;
|
|
20
20
|
}
|
|
21
|
-
`,document.head.appendChild(s),()=>{let m=document.getElementById(t);m&&m.remove()}},[]),(0,ee.jsxs)("div",{ref:ie,className:`overlay-scrollbar-wrapper ${i}`,style:{display:"flex",flexDirection:"column",position:"relative",minHeight:0,height:"100%",flex:"1 1 0%",...p},children:[(0,ee.jsx)("div",{ref:u,className:"overlay-scrollbar-container",tabIndex:-1,onMouseDown:Oe,style:{display:"flex",width:"100%",flex:"1 1 auto",minHeight:0,overflow:"auto",scrollbarWidth:"none",msOverflowStyle:"none",outline:"none",userSelect:x?"none":"auto",...g},children:(0,ee.jsx)("div",{ref:z,className:"overlay-scrollbar-content",style:{flex:"1 1 0%",minHeight:0,display:"flex",flexDirection:"column",...v},children:w})}),j&&Me&&(0,ee.jsxs)("div",{ref:le,className:"overlay-scrollbar-track",onMouseEnter:()=>{a(),me.current=setTimeout(()=>{L(!0),me.current=null},100)},onMouseLeave:()=>{e(),N||M(T.delay)},style:{position:"absolute",top:0,right:0,width:`${xe}px`,height:"100%",opacity:Y?1:0,transition:"opacity 0.2s ease-in-out",cursor:"pointer",zIndex:1e3,pointerEvents:"auto"},children:[y.visible&&(0,ee.jsx)("div",{className:"overlay-scrollbar-track-background",onClick:t=>{t.preventDefault(),t.stopPropagation(),K(t)},style:{position:"absolute",top:G?`${F.width+y.margin*2}px`:`${y.margin}px`,right:y.alignment==="right"?"0px":`${(xe-F.width)/2}px`,width:`${F.width}px`,height:G?`calc(100% - ${F.width*2+y.margin*4}px)`:`calc(100% - ${y.margin*2}px)`,backgroundColor:y.color,borderRadius:`${y.radius}px`,cursor:"pointer"}}),(0,ee.jsx)("div",{ref:ae,className:"overlay-scrollbar-thumb",onMouseDown:Q,onMouseEnter:()=>we(!0),onMouseLeave:()=>we(!1),style:{position:"absolute",top:`${(G?$+y.margin*2:y.margin)+Be}px`,right:y.alignment==="right"?"0px":`${(xe-$)/2}px`,width:`${$}px`,height:`${Math.max(ne,ke)}px`,backgroundColor:re||N?F.hoverColor:F.color,opacity:re||N?F.hoverOpacity:F.opacity,borderRadius:`${F.radius}px`,cursor:"pointer",transition:"background-color 0.2s ease-in-out, opacity 0.2s ease-in-out"}})]}),j&&Me&&G&&(0,ee.jsx)("div",{className:"overlay-scrollbar-up-arrow",onClick:je,onMouseEnter:()=>Ce("up"),onMouseLeave:()=>Ce(null),style:{position:"absolute",top:`${y.margin}px`,right:y.alignment==="right"?"0px":`${(xe-$)/2}px`,width:`${$}px`,height:`${$}px`,cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",fontSize:`${Math.max($*.75,8)}px`,color:pe==="up"?_.hoverColor:_.color,userSelect:"none",zIndex:1001,opacity:Y?pe==="up"?_.hoverOpacity:_.opacity:0,transition:"opacity 0.2s ease-in-out, color 0.15s ease-in-out"},children:"\u25B2"}),j&&Me&&G&&(0,ee.jsx)("div",{className:"overlay-scrollbar-down-arrow",onClick:Ke,onMouseEnter:()=>Ce("down"),onMouseLeave:()=>Ce(null),style:{position:"absolute",bottom:`${y.margin}px`,right:y.alignment==="right"?"0px":`${(xe-$)/2}px`,width:`${$}px`,height:`${$}px`,cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",fontSize:`${Math.max($*.75,8)}px`,color:pe==="down"?_.hoverColor:_.color,userSelect:"none",zIndex:1001,opacity:Y?pe==="down"?_.hoverOpacity:_.opacity:0,transition:"opacity 0.2s ease-in-out, color 0.15s ease-in-out"},children:"\u25BC"})]})}),Ze=mt;var c=require("react/jsx-runtime"),ht={alignment:"right",margin:0,radius:0};function gt({data:i,loading:p=!1,columns:g,onRowClick:v,getRowId:w,selectedRowId:H,selectedRowSx:k,rowHeight:R=50,columnHeight:I=56,striped:q,rowDivider:U=!0,onSort:j,onLoadMore:X,sortBy:O,sortDirection:W,showPaper:ie=!0,paddingX:u="1rem",paddingTop:z=0,paddingBottom:le=0,rowHoverColor:ae,rowHoverOpacity:P,viewportBuffer:Y,overscan:L,scrollbars:N,emptyMessage:te="NO DATA",LoadingComponent:re}){let we=Math.max(R*12,480),de=Math.max(R*12,480),Se=typeof Y=="number"?Y:Y?.top??we,ne=typeof Y=="number"?Y:Y?.bottom??de,Fe=Math.max(R*8,420),Be=Math.max(R*10,520),Ee=typeof L=="number"?L:{main:L?.main??Fe,reverse:L?.reverse??Be},Me=R+(U?1:0),Ae=typeof window<"u"&&(window.location.hostname==="localhost"||window.location.hostname==="127.0.0.1"),[x]=(0,d.useState)(()=>typeof window>"u"?!1:window.localStorage.getItem("vdt-perf-debug")==="1"),b=(0,d.useRef)({wheelEvents:0,wheelInputPx:0,wheelHandlerMs:0,wheelRafFlushes:0,wheelRafMs:0,rangeChangedCalls:0,rangeChangedMs:0,rowContentCalls:0,rowContentMs:0,rowContentMaxMs:0,cellRenderCalls:0,cellRenderMs:0,cellRenderMaxMs:0}),se=(0,d.useCallback)(l=>{if(!x)return;let r=b.current;if(!(r.wheelEvents>0||r.rangeChangedCalls>0||r.rowContentCalls>0||r.cellRenderCalls>0))return;let D=r.rowContentCalls>0?r.rowContentMs/r.rowContentCalls:0,a=r.cellRenderCalls>0?r.cellRenderMs/r.cellRenderCalls:0;console.log("[VDT perf]",{reason:l,wheel:{events:r.wheelEvents,inputPx:Math.round(r.wheelInputPx),handlerMs:Number(r.wheelHandlerMs.toFixed(2)),rafFlushes:r.wheelRafFlushes,rafMs:Number(r.wheelRafMs.toFixed(2))},rangeChanged:{calls:r.rangeChangedCalls,totalMs:Number(r.rangeChangedMs.toFixed(2))},rowContent:{calls:r.rowContentCalls,totalMs:Number(r.rowContentMs.toFixed(2)),avgMs:Number(D.toFixed(3)),maxMs:Number(r.rowContentMaxMs.toFixed(3))},cellRender:{calls:r.cellRenderCalls,totalMs:Number(r.cellRenderMs.toFixed(2)),avgMs:Number(a.toFixed(3)),maxMs:Number(r.cellRenderMaxMs.toFixed(3))}}),b.current={wheelEvents:0,wheelInputPx:0,wheelHandlerMs:0,wheelRafFlushes:0,wheelRafMs:0,rangeChangedCalls:0,rangeChangedMs:0,rowContentCalls:0,rowContentMs:0,rowContentMaxMs:0,cellRenderCalls:0,cellRenderMs:0,cellRenderMaxMs:0}},[x]);(0,d.useEffect)(()=>{if(!x||typeof window>"u")return;console.log("[VDT perf] enabled (localStorage vdt-perf-debug=1)");let l=window.setInterval(()=>{se("interval")},1500);return()=>{window.clearInterval(l),se("cleanup")}},[se,x]);let Re=(0,d.useMemo)(()=>(0,d.forwardRef)((l,r)=>{let h=(0,d.useRef)(null),D=(0,d.useRef)(0),a=(0,d.useRef)(null);return(0,d.useEffect)(()=>{let e=h.current;if(!e)return;let V=M=>{let C=x?performance.now():0;M.preventDefault();let Q=M.deltaY;M.deltaMode===1?Q*=40:M.deltaMode===2&&(Q*=e.clientHeight),x&&(b.current.wheelEvents+=1,b.current.wheelInputPx+=Q),D.current+=Q,a.current===null&&(a.current=requestAnimationFrame(()=>{let ge=x?performance.now():0,ce=Math.max(e.clientHeight*.4,160),K=Math.max(-ce,Math.min(ce,D.current));D.current=0,a.current=null,K!==0&&(e.scrollTop+=K),x&&(b.current.wheelRafFlushes+=1,b.current.wheelRafMs+=performance.now()-ge)}),x&&(b.current.wheelHandlerMs+=performance.now()-C))};return e.addEventListener("wheel",V,{passive:!1}),()=>{e.removeEventListener("wheel",V),a.current!==null&&(cancelAnimationFrame(a.current),a.current=null),D.current=0}},[]),(0,c.jsx)(Ze,{detectInnerScroll:!0,track:ht,...N,children:(0,c.jsx)(f.TableContainer,{component:f.Box,...l,ref:e=>{h.current=e,typeof r=="function"?r(e):r&&(r.current=e)},sx:{userSelect:"auto",WebkitUserSelect:"auto",position:"relative",width:"100%",height:"100%",overflow:"auto",display:"flex",flexDirection:"column",scrollbarWidth:"none",msOverflowStyle:"none",transform:"translateZ(0)",backfaceVisibility:"hidden",willChange:"scroll-position","&::-webkit-scrollbar":{display:"none"},"& .MuiTable-root":{paddingRight:u,paddingTop:z,paddingBottom:le}}})})}),[]),He=(0,d.useMemo)(()=>{if(q===!0)return"#f5f5f5";if(typeof q=="string")return q},[q]),[Ye,pe]=(0,d.useState)(p),[Ce,_e]=(0,d.useState)(0);(0,d.useEffect)(()=>{p&&pe(!0)},[p]);let Ie=(0,d.useCallback)(()=>{pe(!1)},[]),fe=Ye,Ve=p&&i.length>0,Te=(0,d.useRef)(!1),oe=(0,d.useRef)(null),me=(0,d.useRef)(!1),Z=(0,d.useRef)(!1),F=(0,d.useRef)({x:0,y:0});(0,d.useEffect)(()=>{let l=document.querySelector('[data-testid="virtuoso-scroller"]');l&&l.querySelectorAll(".MuiTableSortLabel-root").forEach(h=>{let D=new MouseEvent("mouseleave",{bubbles:!0,cancelable:!0});h.dispatchEvent(D)})},[O]);let y=(0,d.useCallback)(l=>{if(!j)return;j(l,O===l&&W==="asc"?"desc":"asc")},[j,O,W]),_=(0,d.useCallback)(l=>{let r=x?performance.now():0;if(!X){x&&(b.current.rangeChangedCalls+=1,b.current.rangeChangedMs+=performance.now()-r);return}if(p&&i.length===0){x&&(b.current.rangeChangedCalls+=1,b.current.rangeChangedMs+=performance.now()-r);return}let h=i.length>=30;if(l>=i.length-1&&h&&!Te.current){Te.current=!0;let a=i.length;X(a,50)}x&&(b.current.rangeChangedCalls+=1,b.current.rangeChangedMs+=performance.now()-r)},[i.length,p,X,x]);(0,d.useEffect)(()=>{p||(Te.current=!1)},[p]),(0,d.useEffect)(()=>{i.length===0&&_e(l=>l+1)},[i.length]);let he=(0,d.useRef)(i.length);(0,d.useEffect)(()=>{let l=he.current,r=i.length;if(r>l&&l>0){he.current=r;return}oe.current&&r>0&&r<=l&&oe.current.scrollToIndex({index:0,align:"start",behavior:"auto"}),he.current=r},[i]);let T=(0,d.useCallback)(()=>{let l={},r=[];if(g.forEach(e=>{e.group?(l[e.group]||(l[e.group]=[]),l[e.group].push(e)):r.push(e)}),!(Object.keys(l).length>0))return(0,c.jsx)(f.TableRow,{children:g.map(e=>(0,c.jsx)(f.TableCell,{align:e.align||"left",style:{width:e.width,minWidth:e.width,...e.style,fontWeight:"bold",position:"sticky",top:0,zIndex:2,padding:"16px"},children:e.sortable?(0,c.jsx)("div",{style:{display:"flex",alignItems:"center",justifyContent:e.align==="center"?"center":e.align==="right"?"flex-end":"flex-start",position:"relative",width:"100%"},children:(0,c.jsxs)(f.Box,{sx:{position:"relative",cursor:"default","&:hover .MuiTableSortLabel-root":{opacity:"1 !important","& .MuiSvgIcon-root":{color:"#000",opacity:"1 !important"}}},onClick:()=>y(String(e.id)),children:[e.text,(0,c.jsx)(f.TableSortLabel,{active:O===e.id,direction:O===e.id?W:"desc",sx:{position:"absolute",left:"100%",top:"50%",transform:"translateY(-50%)",marginLeft:"4px",minWidth:"auto",width:"16px",height:"16px",cursor:"default",opacity:O===e.id?1:0,transition:"opacity 0.2s ease","& .MuiTableSortLabel-icon":{position:"relative",marginLeft:0,marginRight:0,opacity:1,transition:"color 0.2s ease"},"& .MuiTableSortLabel-iconDirectionAsc":{transform:"rotate(180deg)"},"& .MuiTableSortLabel-iconDirectionDesc":{transform:"rotate(0deg)"}}})]})}):e.text},String(e.id)))});let D=[...r.map(e=>(0,c.jsx)(f.TableCell,{rowSpan:2,align:e.align||"left",style:{width:e.width,minWidth:e.width,...e.style,fontWeight:"bold",position:"sticky",top:0,zIndex:2,padding:"16px"},children:e.sortable&&j?(0,c.jsx)("div",{style:{display:"flex",alignItems:"center",justifyContent:e.align==="center"?"center":e.align==="right"?"flex-end":"flex-start",position:"relative",width:"100%"},children:(0,c.jsxs)(f.Box,{sx:{position:"relative",cursor:"default","&:hover .MuiTableSortLabel-root":{opacity:"1 !important","& .MuiSvgIcon-root":{color:"#000",opacity:"1 !important"}}},onClick:()=>y(String(e.id)),children:[e.text,(0,c.jsx)(f.TableSortLabel,{active:O===e.id,direction:O===e.id?W:"desc",sx:{position:"absolute",left:"100%",top:"50%",transform:"translateY(-50%)",marginLeft:"4px",minWidth:"auto",width:"16px",height:"16px",cursor:"default",opacity:O===e.id?1:0,transition:"opacity 0.2s ease","&:hover":{opacity:"1 !important","& .MuiSvgIcon-root":{color:"#000",opacity:"1 !important"}},"& .MuiTableSortLabel-icon":{position:"relative",marginLeft:0,marginRight:0,opacity:1,transition:"color 0.2s ease"},"& .MuiTableSortLabel-iconDirectionAsc":{transform:"rotate(180deg)"},"& .MuiTableSortLabel-iconDirectionDesc":{transform:"rotate(0deg)"}}})]})}):e.text},String(e.id))),...Object.entries(l).map(([e,V])=>(0,c.jsx)(f.TableCell,{align:"center",colSpan:V.length,style:{fontWeight:"bold",position:"sticky",top:0,zIndex:2,padding:"16px"},children:e},e))],a=[...Object.values(l).flat().map(e=>(0,c.jsx)(f.TableCell,{align:e.align||"left",style:{width:e.width,minWidth:e.width,...e.style,fontWeight:"bold",position:"sticky",top:0,zIndex:2,padding:"16px"},children:e.sortable&&j?(0,c.jsx)("div",{style:{display:"flex",alignItems:"center",justifyContent:e.align==="center"?"center":e.align==="right"?"flex-end":"flex-start",position:"relative",width:"100%"},children:(0,c.jsxs)(f.Box,{sx:{position:"relative",cursor:"default","&:hover .MuiTableSortLabel-root":{opacity:"1 !important","& .MuiSvgIcon-root":{color:"#000",opacity:"1 !important"}}},onClick:()=>y(String(e.id)),children:[e.text,(0,c.jsx)(f.TableSortLabel,{active:O===e.id,direction:O===e.id?W:"desc",sx:{position:"absolute",left:"100%",top:"50%",transform:"translateY(-50%)",marginLeft:"4px",minWidth:"auto",width:"16px",height:"16px",cursor:"default",opacity:O===e.id?1:0,transition:"opacity 0.2s ease","&:hover":{opacity:"1 !important","& .MuiSvgIcon-root":{color:"#000",opacity:"1 !important"}},"& .MuiTableSortLabel-icon":{position:"relative",marginLeft:0,marginRight:0,opacity:1,transition:"color 0.2s ease"},"& .MuiTableSortLabel-iconDirectionAsc":{transform:"rotate(0deg)"},"& .MuiTableSortLabel-iconDirectionDesc":{transform:"rotate(180deg)"}}})]})}):e.text},String(e.id)))];return(0,c.jsxs)(c.Fragment,{children:[(0,c.jsx)(f.TableRow,{children:D}),(0,c.jsx)(f.TableRow,{children:a})]})},[g,O,W,y,j,I]),$=(0,d.useCallback)((l,r)=>{let h=x?performance.now():0;if(!r){if(x){b.current.rowContentCalls+=1;let a=performance.now()-h;b.current.rowContentMs+=a,b.current.rowContentMaxMs=Math.max(b.current.rowContentMaxMs,a)}return null}let D=g.map(a=>{let e=x?performance.now():0,V=a.render?a.render(r,l):String(r[a.id]||"");if(x){let M=performance.now()-e;b.current.cellRenderCalls+=1,b.current.cellRenderMs+=M,b.current.cellRenderMaxMs=Math.max(b.current.cellRenderMaxMs,M)}return(0,c.jsx)(f.TableCell,{align:a.align||"left",style:{width:a.width,minWidth:a.width,...a.style,padding:"8px 16px"},children:V},String(a.id))});if(x){b.current.rowContentCalls+=1;let a=performance.now()-h;b.current.rowContentMs+=a,b.current.rowContentMaxMs=Math.max(b.current.rowContentMaxMs,a)}return(0,c.jsx)(c.Fragment,{children:D})},[g,x]),ke=(0,d.useMemo)(()=>({Scroller:Re,Table:l=>(0,c.jsx)(f.Table,{...l,sx:{borderCollapse:"separate",tableLayout:"fixed",marginRight:"16px"}}),TableHead:(0,d.forwardRef)((l,r)=>(0,c.jsx)(f.TableHead,{...l,ref:r,sx:{userSelect:"none","& tr":{height:I,"& th":{padding:"16px",position:"sticky",top:0,zIndex:2,fontWeight:"bold"}}}})),TableRow:l=>{let{item:r,selected:h,"aria-selected":D,className:a,...e}=l,V=e["data-index"]??0,M=V%2===1,C=r&&w?w(r,V):V,Q=H!=null&&C===H,ge=Q&&k?typeof k=="function"?k(r,V):k:void 0,ce=String(a??"").split(/\s+/).filter(K=>K!=="Mui-selected"&&K!=="Mui-focusVisible").join(" ");return(0,c.jsx)(f.TableRow,{...e,className:ce||void 0,selected:Q,onMouseDown:K=>{Z.current=!1,F.current={x:K.clientX,y:K.clientY}},onClick:()=>{!Z.current&&!me.current&&r&&v&&v(r,V),Z.current=!1},sx:[{userSelect:"none",height:R,backgroundColor:M&&He?He:"transparent","& td":{padding:"8px 16px",borderBottom:U?"1px solid rgba(224, 224, 224, 1)":"none"},"& th":{padding:"8px 16px",borderBottom:"none"},"&:hover":v&&!Q?{backgroundColor:K=>{let je=K.palette.mode==="dark",Oe=ae??"#000000",be=P??.06;if(!ae)return je?`rgba(255, 255, 255, ${be})`:`rgba(0, 0, 0, ${be})`;let ue=Oe.replace("#","").trim();if(ue.length!==6)return Oe;let xe=parseInt(ue.substring(0,2),16),t=parseInt(ue.substring(2,4),16),o=parseInt(ue.substring(4,6),16);return`rgba(${xe}, ${t}, ${o}, ${be})`}}:void 0,cursor:v?"pointer":void 0},ge]})},TableBody:(0,d.forwardRef)((l,r)=>(0,c.jsx)(f.TableBody,{...l,ref:r}))}),[v,w,H,k,R,He,U,I,ae,P,Re]),G=(0,c.jsxs)(f.Box,{sx:{position:"relative",height:"100%",width:"100%","& .MuiTableHead-root":{backgroundColor:l=>l.palette.mode==="dark"?"#1e1e1e !important":"#ffffff !important"}},children:[(0,c.jsx)(Je.TableVirtuoso,{ref:oe,data:i,totalCount:X?i.length+1:i.length,defaultItemHeight:Me,fixedItemHeight:Me,fixedHeaderContent:T,itemContent:$,endReached:_,style:{height:"100%"},increaseViewportBy:{top:Se,bottom:ne},overscan:Ee,followOutput:!1,components:ke},Ce),i.length===0&&!p&&(0,c.jsx)(f.Box,{sx:{position:"absolute",top:0,left:0,right:0,bottom:0,display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",gap:2},children:typeof te=="string"?(0,c.jsxs)(c.Fragment,{children:[(0,c.jsx)(f.Box,{sx:{width:48,height:48,display:"flex",alignItems:"center",justifyContent:"center",borderRadius:"50%",backgroundColor:"#f5f5f5",color:"#999"},children:"\u{1F4C4}"}),(0,c.jsx)(f.Typography,{variant:"body1",sx:{color:"text.secondary"},children:te})]}):te}),fe&&(0,c.jsx)(c.Fragment,{children:re?(0,c.jsx)(re,{visible:p,onComplete:Ie}):(0,c.jsx)(Ue,{visible:p,onComplete:Ie,size:40,sx:{top:`${g.some(l=>l.group)?I*2:I}px`},background:{show:i.length===0,opacity:.8}})})]});return ie?(0,c.jsx)(f.Paper,{className:"grow",elevation:1,sx:{padding:0,paddingLeft:u,height:"100%",minHeight:0,flex:1,display:"flex",flexDirection:"column"},children:G}):(0,c.jsx)(f.Box,{className:"grow",style:{padding:0,paddingLeft:u,height:"100%",minHeight:0,flex:1,display:"flex",flexDirection:"column"},children:G})}var Qe=(0,d.memo)(gt);
|
|
21
|
+
`,document.head.appendChild(a),()=>{let h=document.getElementById(t);h&&h.remove()}},[]),(0,ee.jsxs)("div",{ref:ie,className:`overlay-scrollbar-wrapper ${l}`,style:{display:"flex",flexDirection:"column",position:"relative",minHeight:0,height:"100%",flex:"1 1 0%",...d},children:[(0,ee.jsx)("div",{ref:c,className:"overlay-scrollbar-container",tabIndex:-1,onMouseDown:De,style:{display:"flex",width:"100%",flex:"1 1 auto",minHeight:0,overflow:"auto",scrollbarWidth:"none",msOverflowStyle:"none",outline:"none",userSelect:y?"none":"auto",...b},children:(0,ee.jsx)("div",{ref:G,className:"overlay-scrollbar-content",style:{flex:"1 1 0%",minHeight:0,display:"flex",flexDirection:"column",...v},children:w})}),W&&xe&&(0,ee.jsxs)("div",{ref:le,className:"overlay-scrollbar-track",onMouseEnter:()=>{e(),Z.current=setTimeout(()=>{L(!0),Z.current=null},100)},onMouseLeave:()=>{j(),P||R(M.delay)},style:{position:"absolute",top:0,right:0,width:`${me}px`,height:"100%",opacity:X?1:0,transition:"opacity 0.2s ease-in-out",cursor:"pointer",zIndex:1e3,pointerEvents:"auto"},children:[T.visible&&(0,ee.jsx)("div",{className:"overlay-scrollbar-track-background",onClick:t=>{t.preventDefault(),t.stopPropagation(),Me(t)},style:{position:"absolute",top:o?`${N.width+T.margin*2}px`:`${T.margin}px`,right:T.alignment==="right"?"0px":`${(me-N.width)/2}px`,width:`${N.width}px`,height:o?`calc(100% - ${N.width*2+T.margin*4}px)`:`calc(100% - ${T.margin*2}px)`,backgroundColor:T.color,borderRadius:`${T.radius}px`,cursor:"pointer"}}),(0,ee.jsx)("div",{ref:ae,className:"overlay-scrollbar-thumb",onMouseDown:Se,onMouseEnter:()=>be(!0),onMouseLeave:()=>be(!1),style:{position:"absolute",top:`${(o?F+T.margin*2:T.margin)+Ve}px`,right:T.alignment==="right"?"0px":`${(me-F)/2}px`,width:`${F}px`,height:`${Math.max(ne,we)}px`,backgroundColor:re||P?N.hoverColor:N.color,opacity:re||P?N.hoverOpacity:N.opacity,borderRadius:`${N.radius}px`,cursor:"pointer",transition:"background-color 0.2s ease-in-out, opacity 0.2s ease-in-out"}})]}),W&&xe&&o&&(0,ee.jsx)("div",{className:"overlay-scrollbar-up-arrow",onClick:ke,onMouseEnter:()=>ye("up"),onMouseLeave:()=>ye(null),style:{position:"absolute",top:`${T.margin}px`,right:T.alignment==="right"?"0px":`${(me-F)/2}px`,width:`${F}px`,height:`${F}px`,cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",fontSize:`${Math.max(F*.75,8)}px`,color:pe==="up"?q.hoverColor:q.color,userSelect:"none",zIndex:1001,opacity:X?pe==="up"?q.hoverOpacity:q.opacity:0,transition:"opacity 0.2s ease-in-out, color 0.15s ease-in-out"},children:"\u25B2"}),W&&xe&&o&&(0,ee.jsx)("div",{className:"overlay-scrollbar-down-arrow",onClick:Le,onMouseEnter:()=>ye("down"),onMouseLeave:()=>ye(null),style:{position:"absolute",bottom:`${T.margin}px`,right:T.alignment==="right"?"0px":`${(me-F)/2}px`,width:`${F}px`,height:`${F}px`,cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",fontSize:`${Math.max(F*.75,8)}px`,color:pe==="down"?q.hoverColor:q.color,userSelect:"none",zIndex:1001,opacity:X?pe==="down"?q.hoverOpacity:q.opacity:0,transition:"opacity 0.2s ease-in-out, color 0.15s ease-in-out"},children:"\u25BC"})]})}),Ze=ht;var s=require("react/jsx-runtime"),gt={alignment:"right",margin:0,radius:0},Je=5;function bt({data:l,loading:d=!1,columns:b,onRowClick:v,getRowId:w,selectedRowId:I,selectedRowSx:k,rowHeight:E=50,columnHeight:O=56,striped:Y,rowDivider:K=!0,onSort:W,onLoadMore:U,sortBy:$,sortDirection:_,showPaper:ie=!0,paddingX:c="1rem",paddingTop:G=0,paddingBottom:le=0,rowHoverColor:ae,rowHoverOpacity:A,viewportBuffer:X,overscan:L,scrollbars:P,emptyMessage:te="NO DATA",LoadingComponent:re}){let be=Math.max(E*12,480),de=Math.max(E*12,480),Ce=typeof X=="number"?X:X?.top??be,ne=typeof X=="number"?X:X?.bottom??de,Be=Math.max(E*8,420),Ve=Math.max(E*10,520),Ie=typeof L=="number"?L:{main:L?.main??Be,reverse:L?.reverse??Ve},xe=E+(K?1:0),qe=typeof window<"u"&&(window.location.hostname==="localhost"||window.location.hostname==="127.0.0.1"),[y]=(0,u.useState)(()=>typeof window>"u"?!1:window.localStorage.getItem("vdt-perf-debug")==="1"),x=(0,u.useRef)({wheelEvents:0,wheelInputPx:0,wheelHandlerMs:0,wheelRafFlushes:0,wheelRafMs:0,rangeChangedCalls:0,rangeChangedMs:0,rowContentCalls:0,rowContentMs:0,rowContentMaxMs:0,cellRenderCalls:0,cellRenderMs:0,cellRenderMaxMs:0}),se=(0,u.useCallback)(o=>{if(!y)return;let n=x.current;if(!(n.wheelEvents>0||n.rangeChangedCalls>0||n.rowContentCalls>0||n.cellRenderCalls>0))return;let p=n.rowContentCalls>0?n.rowContentMs/n.rowContentCalls:0,f=n.cellRenderCalls>0?n.cellRenderMs/n.cellRenderCalls:0;console.log("[VDT perf]",{reason:o,wheel:{events:n.wheelEvents,inputPx:Math.round(n.wheelInputPx),handlerMs:Number(n.wheelHandlerMs.toFixed(2)),rafFlushes:n.wheelRafFlushes,rafMs:Number(n.wheelRafMs.toFixed(2))},rangeChanged:{calls:n.rangeChangedCalls,totalMs:Number(n.rangeChangedMs.toFixed(2))},rowContent:{calls:n.rowContentCalls,totalMs:Number(n.rowContentMs.toFixed(2)),avgMs:Number(p.toFixed(3)),maxMs:Number(n.rowContentMaxMs.toFixed(3))},cellRender:{calls:n.cellRenderCalls,totalMs:Number(n.cellRenderMs.toFixed(2)),avgMs:Number(f.toFixed(3)),maxMs:Number(n.cellRenderMaxMs.toFixed(3))}}),x.current={wheelEvents:0,wheelInputPx:0,wheelHandlerMs:0,wheelRafFlushes:0,wheelRafMs:0,rangeChangedCalls:0,rangeChangedMs:0,rowContentCalls:0,rowContentMs:0,rowContentMaxMs:0,cellRenderCalls:0,cellRenderMs:0,cellRenderMaxMs:0}},[y]);(0,u.useEffect)(()=>{if(!y||typeof window>"u")return;console.log("[VDT perf] enabled (localStorage vdt-perf-debug=1)");let o=window.setInterval(()=>{se("interval")},1500);return()=>{window.clearInterval(o),se("cleanup")}},[se,y]);let Oe=(0,u.useMemo)(()=>(0,u.forwardRef)((o,n)=>{let C=(0,u.useRef)(null),p=(0,u.useRef)(0),f=(0,u.useRef)(null);return(0,u.useEffect)(()=>{let e=C.current;if(!e)return;let j=J=>{let R=y?performance.now():0;J.preventDefault();let g=J.deltaY;J.deltaMode===1?g*=40:J.deltaMode===2&&(g*=e.clientHeight),y&&(x.current.wheelEvents+=1,x.current.wheelInputPx+=g),p.current+=g,f.current===null&&(f.current=requestAnimationFrame(()=>{let Se=y?performance.now():0,ce=Math.max(e.clientHeight*.4,160),H=Math.max(-ce,Math.min(ce,p.current));p.current=0,f.current=null,H!==0&&(e.scrollTop+=H),y&&(x.current.wheelRafFlushes+=1,x.current.wheelRafMs+=performance.now()-Se)}),y&&(x.current.wheelHandlerMs+=performance.now()-R))};return e.addEventListener("wheel",j,{passive:!1}),()=>{e.removeEventListener("wheel",j),f.current!==null&&(cancelAnimationFrame(f.current),f.current=null),p.current=0}},[]),(0,s.jsx)(Ze,{detectInnerScroll:!0,track:gt,...P,children:(0,s.jsx)(m.TableContainer,{component:m.Box,...o,ref:e=>{C.current=e,typeof n=="function"?n(e):n&&(n.current=e)},sx:{userSelect:"auto",WebkitUserSelect:"auto",position:"relative",width:"100%",height:"100%",overflow:"auto",display:"flex",flexDirection:"column",scrollbarWidth:"none",msOverflowStyle:"none",transform:"translateZ(0)",backfaceVisibility:"hidden",willChange:"scroll-position","&::-webkit-scrollbar":{display:"none"},"& .MuiTable-root":{paddingRight:c,paddingTop:G,paddingBottom:le}}})})}),[]),$e=(0,u.useMemo)(()=>{if(Y===!0)return"#f5f5f5";if(typeof Y=="string")return Y},[Y]),[Ge,pe]=(0,u.useState)(d),[ye,Xe]=(0,u.useState)(0);(0,u.useEffect)(()=>{d&&pe(!0)},[d]);let Ne=(0,u.useCallback)(()=>{pe(!1)},[]),fe=Ge,je=d&&l.length>0,ve=(0,u.useRef)(!1),oe=(0,u.useRef)(null),Z=(0,u.useRef)(!1),z=(0,u.useRef)({x:0,y:0});(0,u.useEffect)(()=>{let o=n=>{let C=n.clientX-z.current.x,p=n.clientY-z.current.y;Math.sqrt(C*C+p*p)>Je&&(Z.current=!0)};return document.addEventListener("mousemove",o),()=>{document.removeEventListener("mousemove",o)}},[]),(0,u.useEffect)(()=>{let o=document.querySelector('[data-testid="virtuoso-scroller"]');o&&o.querySelectorAll(".MuiTableSortLabel-root").forEach(C=>{let p=new MouseEvent("mouseleave",{bubbles:!0,cancelable:!0});C.dispatchEvent(p)})},[$]);let N=(0,u.useCallback)(o=>{if(!W)return;W(o,$===o&&_==="asc"?"desc":"asc")},[W,$,_]),T=(0,u.useCallback)(o=>{let n=y?performance.now():0;if(!U){y&&(x.current.rangeChangedCalls+=1,x.current.rangeChangedMs+=performance.now()-n);return}if(d&&l.length===0){y&&(x.current.rangeChangedCalls+=1,x.current.rangeChangedMs+=performance.now()-n);return}let C=l.length>=30;if(o>=l.length-1&&C&&!ve.current){ve.current=!0;let f=l.length;U(f,50)}y&&(x.current.rangeChangedCalls+=1,x.current.rangeChangedMs+=performance.now()-n)},[l.length,d,U,y]);(0,u.useEffect)(()=>{d||(ve.current=!1)},[d]),(0,u.useEffect)(()=>{l.length===0&&Xe(o=>o+1)},[l.length]);let q=(0,u.useRef)(l.length);(0,u.useEffect)(()=>{let o=q.current,n=l.length;if(n>o&&o>0){q.current=n;return}oe.current&&n>0&&n<=o&&oe.current.scrollToIndex({index:0,align:"start",behavior:"auto"}),q.current=n},[l]);let Te=(0,u.useCallback)(()=>{let o={},n=[];if(b.forEach(e=>{e.group?(o[e.group]||(o[e.group]=[]),o[e.group].push(e)):n.push(e)}),!(Object.keys(o).length>0))return(0,s.jsx)(m.TableRow,{children:b.map(e=>(0,s.jsx)(m.TableCell,{align:e.align||"left",style:{width:e.width,minWidth:e.width,...e.style,fontWeight:"bold",position:"sticky",top:0,zIndex:2,padding:"16px"},children:e.sortable?(0,s.jsx)("div",{style:{display:"flex",alignItems:"center",justifyContent:e.align==="center"?"center":e.align==="right"?"flex-end":"flex-start",position:"relative",width:"100%"},children:(0,s.jsxs)(m.Box,{sx:{position:"relative",cursor:"default","&:hover .MuiTableSortLabel-root":{opacity:"1 !important","& .MuiSvgIcon-root":{color:"#000",opacity:"1 !important"}}},onClick:()=>N(String(e.id)),children:[e.text,(0,s.jsx)(m.TableSortLabel,{active:$===e.id,direction:$===e.id?_:"desc",sx:{position:"absolute",left:"100%",top:"50%",transform:"translateY(-50%)",marginLeft:"4px",minWidth:"auto",width:"16px",height:"16px",cursor:"default",opacity:$===e.id?1:0,transition:"opacity 0.2s ease","& .MuiTableSortLabel-icon":{position:"relative",marginLeft:0,marginRight:0,opacity:1,transition:"color 0.2s ease"},"& .MuiTableSortLabel-iconDirectionAsc":{transform:"rotate(180deg)"},"& .MuiTableSortLabel-iconDirectionDesc":{transform:"rotate(0deg)"}}})]})}):e.text},String(e.id)))});let p=[...n.map(e=>(0,s.jsx)(m.TableCell,{rowSpan:2,align:e.align||"left",style:{width:e.width,minWidth:e.width,...e.style,fontWeight:"bold",position:"sticky",top:0,zIndex:2,padding:"16px"},children:e.sortable&&W?(0,s.jsx)("div",{style:{display:"flex",alignItems:"center",justifyContent:e.align==="center"?"center":e.align==="right"?"flex-end":"flex-start",position:"relative",width:"100%"},children:(0,s.jsxs)(m.Box,{sx:{position:"relative",cursor:"default","&:hover .MuiTableSortLabel-root":{opacity:"1 !important","& .MuiSvgIcon-root":{color:"#000",opacity:"1 !important"}}},onClick:()=>N(String(e.id)),children:[e.text,(0,s.jsx)(m.TableSortLabel,{active:$===e.id,direction:$===e.id?_:"desc",sx:{position:"absolute",left:"100%",top:"50%",transform:"translateY(-50%)",marginLeft:"4px",minWidth:"auto",width:"16px",height:"16px",cursor:"default",opacity:$===e.id?1:0,transition:"opacity 0.2s ease","&:hover":{opacity:"1 !important","& .MuiSvgIcon-root":{color:"#000",opacity:"1 !important"}},"& .MuiTableSortLabel-icon":{position:"relative",marginLeft:0,marginRight:0,opacity:1,transition:"color 0.2s ease"},"& .MuiTableSortLabel-iconDirectionAsc":{transform:"rotate(180deg)"},"& .MuiTableSortLabel-iconDirectionDesc":{transform:"rotate(0deg)"}}})]})}):e.text},String(e.id))),...Object.entries(o).map(([e,j])=>(0,s.jsx)(m.TableCell,{align:"center",colSpan:j.length,style:{fontWeight:"bold",position:"sticky",top:0,zIndex:2,padding:"16px"},children:e},e))],f=[...Object.values(o).flat().map(e=>(0,s.jsx)(m.TableCell,{align:e.align||"left",style:{width:e.width,minWidth:e.width,...e.style,fontWeight:"bold",position:"sticky",top:0,zIndex:2,padding:"16px"},children:e.sortable&&W?(0,s.jsx)("div",{style:{display:"flex",alignItems:"center",justifyContent:e.align==="center"?"center":e.align==="right"?"flex-end":"flex-start",position:"relative",width:"100%"},children:(0,s.jsxs)(m.Box,{sx:{position:"relative",cursor:"default","&:hover .MuiTableSortLabel-root":{opacity:"1 !important","& .MuiSvgIcon-root":{color:"#000",opacity:"1 !important"}}},onClick:()=>N(String(e.id)),children:[e.text,(0,s.jsx)(m.TableSortLabel,{active:$===e.id,direction:$===e.id?_:"desc",sx:{position:"absolute",left:"100%",top:"50%",transform:"translateY(-50%)",marginLeft:"4px",minWidth:"auto",width:"16px",height:"16px",cursor:"default",opacity:$===e.id?1:0,transition:"opacity 0.2s ease","&:hover":{opacity:"1 !important","& .MuiSvgIcon-root":{color:"#000",opacity:"1 !important"}},"& .MuiTableSortLabel-icon":{position:"relative",marginLeft:0,marginRight:0,opacity:1,transition:"color 0.2s ease"},"& .MuiTableSortLabel-iconDirectionAsc":{transform:"rotate(0deg)"},"& .MuiTableSortLabel-iconDirectionDesc":{transform:"rotate(180deg)"}}})]})}):e.text},String(e.id)))];return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(m.TableRow,{children:p}),(0,s.jsx)(m.TableRow,{children:f})]})},[b,$,_,N,W,O]),M=(0,u.useCallback)((o,n)=>{let C=y?performance.now():0;if(!n){if(y){x.current.rowContentCalls+=1;let f=performance.now()-C;x.current.rowContentMs+=f,x.current.rowContentMaxMs=Math.max(x.current.rowContentMaxMs,f)}return null}let p=b.map(f=>{let e=y?performance.now():0,j=f.render?f.render(n,o):String(n[f.id]||"");if(y){let J=performance.now()-e;x.current.cellRenderCalls+=1,x.current.cellRenderMs+=J,x.current.cellRenderMaxMs=Math.max(x.current.cellRenderMaxMs,J)}return(0,s.jsx)(m.TableCell,{align:f.align||"left",style:{width:f.width,minWidth:f.width,...f.style,padding:"8px 16px"},children:j},String(f.id))});if(y){x.current.rowContentCalls+=1;let f=performance.now()-C;x.current.rowContentMs+=f,x.current.rowContentMaxMs=Math.max(x.current.rowContentMaxMs,f)}return(0,s.jsx)(s.Fragment,{children:p})},[b,y]),We=(0,u.useMemo)(()=>({Scroller:Oe,Table:o=>(0,s.jsx)(m.Table,{...o,sx:{borderCollapse:"separate",tableLayout:"fixed",marginRight:"16px"}}),TableHead:(0,u.forwardRef)((o,n)=>(0,s.jsx)(m.TableHead,{...o,ref:n,sx:{userSelect:"none","& tr":{height:O,"& th":{padding:"16px",position:"sticky",top:0,zIndex:2,fontWeight:"bold"}}}})),TableRow:o=>{let{item:n,selected:C,"aria-selected":p,className:f,...e}=o,j=e["data-index"]??0,J=j%2===1,R=n&&w?w(n,j):j,g=I!=null&&R===I,Se=g&&k?typeof k=="function"?k(n,j):k:void 0,ce=String(f??"").split(/\s+/).filter(H=>H!=="Mui-selected"&&H!=="Mui-focusVisible").join(" ");return(0,s.jsx)(m.TableRow,{...e,className:ce||void 0,selected:g,onMouseDown:H=>{Z.current=!1,z.current={x:H.clientX,y:H.clientY}},onClick:H=>{let Me=H.clientX-z.current.x,ke=H.clientY-z.current.y;if(Math.sqrt(Me*Me+ke*ke)>Je||Z.current){H.preventDefault(),H.stopPropagation(),Z.current=!1;return}n&&v&&v(n,j),Z.current=!1},sx:[{userSelect:"none",height:E,backgroundColor:J&&$e?$e:"transparent","& td":{padding:"8px 16px",borderBottom:K?"1px solid rgba(224, 224, 224, 1)":"none"},"& th":{padding:"8px 16px",borderBottom:"none"},"&:hover":v&&!g?{backgroundColor:H=>{let Me=H.palette.mode==="dark",Le=ae??"#000000",De=A??.06;if(!ae)return Me?`rgba(255, 255, 255, ${De})`:`rgba(0, 0, 0, ${De})`;let ue=Le.replace("#","").trim();if(ue.length!==6)return Le;let Ee=parseInt(ue.substring(0,2),16),me=parseInt(ue.substring(2,4),16),t=parseInt(ue.substring(4,6),16);return`rgba(${Ee}, ${me}, ${t}, ${De})`}}:void 0,cursor:v?"pointer":void 0},Se]})},TableBody:(0,u.forwardRef)((o,n)=>(0,s.jsx)(m.TableBody,{...o,ref:n}))}),[v,w,I,k,E,$e,K,O,ae,A,Oe]),we=(0,s.jsxs)(m.Box,{sx:{position:"relative",height:"100%",width:"100%","& .MuiTableHead-root":{backgroundColor:o=>o.palette.mode==="dark"?"#1e1e1e !important":"#ffffff !important"}},children:[(0,s.jsx)(Qe.TableVirtuoso,{ref:oe,data:l,totalCount:U?l.length+1:l.length,defaultItemHeight:xe,fixedItemHeight:xe,fixedHeaderContent:Te,itemContent:M,endReached:T,style:{height:"100%"},increaseViewportBy:{top:Ce,bottom:ne},overscan:Ie,followOutput:!1,components:We},ye),l.length===0&&!d&&(0,s.jsx)(m.Box,{sx:{position:"absolute",top:0,left:0,right:0,bottom:0,display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",gap:2},children:typeof te=="string"?(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(m.Box,{sx:{width:48,height:48,display:"flex",alignItems:"center",justifyContent:"center",borderRadius:"50%",backgroundColor:"#f5f5f5",color:"#999"},children:"\u{1F4C4}"}),(0,s.jsx)(m.Typography,{variant:"body1",sx:{color:"text.secondary"},children:te})]}):te}),fe&&(0,s.jsx)(s.Fragment,{children:re?(0,s.jsx)(re,{visible:d,onComplete:Ne}):(0,s.jsx)(Ke,{visible:d,onComplete:Ne,size:40,sx:{top:`${b.some(o=>o.group)?O*2:O}px`},background:{show:l.length===0,opacity:.8}})})]});return ie?(0,s.jsx)(m.Paper,{className:"grow",elevation:1,sx:{padding:0,paddingLeft:c,height:"100%",minHeight:0,flex:1,display:"flex",flexDirection:"column"},children:we}):(0,s.jsx)(m.Box,{className:"grow",style:{padding:0,paddingLeft:c,height:"100%",minHeight:0,flex:1,display:"flex",flexDirection:"column"},children:we})}var et=(0,u.memo)(bt);
|
|
22
22
|
/**
|
|
23
23
|
* Virtual Data Table - A high-performance virtual data table component for React
|
|
24
24
|
*
|