@alaarab/ogrid-vue 2.7.3 → 2.9.0

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/esm/index.js CHANGED
@@ -1 +1 @@
1
- import {injectGlobalStyles,Z_INDEX,getStatusBarParts,measureRange,flattenColumns,getMultiSelectFilterFields,deriveFilterOptionsFromData,shouldUseWorkerSort,processClientSideData,processClientSideDataAsync,validateColumns,validateRowIds,computeRowSelectionState,parseTsvClipboard,applyPastedValues,applyCutClear,normalizeSelectionRange,applyCellDeletion,computeTabNavigation,computeArrowNavigation,buildCellIndex,applyFillValues,UndoRedoStack,CHECKBOX_COLUMN_WIDTH,estimateHeaderMinWidth,CELL_PADDING,measureColumnContentWidth,resolveResponsiveConfig,applyResponsiveHiding,DEFAULT_MIN_COLUMN_WIDTH,computeAggregations,getDataGridStatusBarConfig,formatDateForDisplay,DEFAULT_DATE_FORMAT,getPinStateForColumn,validateVirtualScrollConfig,computeVisibleRange,computeTotalHeight,computeVisibleColumnRange,getScrollTopForRow,partitionColumnsForVirtualization,formatCellReference,buildHeaderRows,indexToColumnLetter,ROW_NUMBER_COLUMN_ID,ROW_NUMBER_COLUMN_WIDTH,getHeaderFilterConfig,getDateInputPlaceholder,getCellRenderDescriptor,buildInlineEditorProps,buildPopoverEditorProps,resolveCellDisplayContent,resolveCellStyle,handleBooleanCellPointerDown,parseUserInputDate,rangesEqual,cellIndexKey,formatSelectionAsTsv,calculateDropTarget,reorderColumnArray,parseValue,getCellValue,computeNextSortState,mergeFilter,columnLetterToIndex,applyRangeRowSelection,ROW_NUMBER_COLUMN_MIN_WIDTH,createGridDataAccessor,computeAutoScrollSpeed}from'@alaarab/ogrid-core';export{AUTOSIZE_EXTRA_PX,AUTOSIZE_MAX_PX,CELL_PADDING,CHECKBOX_COLUMN_WIDTH,COLUMN_HEADER_MENU_ITEMS,CellDescriptorCache,DEFAULT_DEBOUNCE_MS,DEFAULT_MIN_COLUMN_WIDTH,GRID_BORDER_RADIUS,GRID_CONTEXT_MENU_ITEMS,MAX_PAGE_BUTTONS,PAGE_SIZE_OPTIONS,PEOPLE_SEARCH_DEBOUNCE_MS,RESPONSIVE_BREAKPOINTS,ROW_NUMBER_COLUMN_ID,ROW_NUMBER_COLUMN_MIN_WIDTH,ROW_NUMBER_COLUMN_WIDTH,SIDEBAR_TRANSITION_MS,UndoRedoStack,Z_INDEX,applyCellDeletion,applyCutClear,applyFillValues,applyPastedValues,applyRangeRowSelection,applyResponsiveHiding,areGridRowPropsEqual,booleanParser,buildCellIndex,buildCsvHeader,buildCsvRows,buildHeaderRows,buildInlineEditorProps,buildPopoverEditorProps,calculateDropTarget,clampSelectionToBounds,columnLetterToIndex,computeAggregations,computeArrowNavigation,computeAutoScrollSpeed,computeNextSortState,computeRowSelectionState,computeTabNavigation,computeTotalHeight,computeVisibleColumnRange,computeVisibleRange,createGridDataAccessor,createSortFilterWorker,currencyParser,dateParser,debounce,deriveFilterOptionsFromData,emailParser,escapeCsvValue,exportToCsv,extractValueMatrix,findCtrlArrowTarget,flattenColumns,formatCellReference,formatCellValueForTsv,formatSelectionAsTsv,formatShortcut,getCellRenderDescriptor,getCellValue,getColumnHeaderMenuItems,getContextMenuHandlers,getDataGridStatusBarConfig,getFilterField,getHeaderFilterConfig,getMultiSelectFilterFields,getPaginationViewModel,getPinStateForColumn,getResponsiveHiddenColumns,getScrollTopForRow,getStatusBarParts,handleBooleanCellPointerDown,indexToColumnLetter,injectGlobalStyles,isColumnEditable,isFilterConfig,isInSelectionRange,isRowInRange,measureColumnContentWidth,measureRange,mergeFilter,normalizeSelectionRange,numberParser,parseTsvClipboard,parseValue,partitionColumnsForVirtualization,processClientSideData,processClientSideDataAsync,rangesEqual,reorderColumnArray,resolveCellDisplayContent,resolveCellStyle,resolveResponsiveConfig,terminateSortFilterWorker,toUserLike,triggerCsvDownload,validateColumns,validateRowIds,validateVirtualScrollConfig}from'@alaarab/ogrid-core';import {FORMULA_BAR_STYLES,handleFormulaBarKeyDown,FORMULA_REF_COLORS,deriveFormulaBarText,extractFormulaReferences,processFormulaBarCommit,FormulaEngine}from'@alaarab/ogrid-core/formula';export{CIRC_ERROR,DIV_ZERO_ERROR,DependencyGraph,FORMULA_BAR_CSS,FORMULA_BAR_STYLES,FORMULA_REF_COLORS,FormulaEngine,FormulaError,FormulaEvaluator,GENERAL_ERROR,NAME_ERROR,NA_ERROR,REF_ERROR,VALUE_ERROR,adjustFormulaReferences,canInsertReference,createBuiltInFunctions,deriveFormulaBarText,extractFormulaReferences,flattenArgs,formatAddress,formulaToString,fromCellKey,handleFormulaBarKeyDown,insertReferenceAtCursor,isFormulaError,parse,parseCellRef,parseRange,processFormulaBarCommit,toBoolean,toCellKey,toNumber,tokenize}from'@alaarab/ogrid-core/formula';import {defineComponent,ref,computed,onMounted,watch,toValue,onUnmounted,h,shallowRef,isRef,triggerRef,nextTick,Teleport,isReadonly,unref,customRef}from'vue';var An=defineComponent({name:"MarchingAntsOverlay",props:{containerRef:{type:Object,required:true},selectionRange:{type:Object,default:null},copyRange:{type:Object,default:null},cutRange:{type:Object,default:null},colOffset:{type:Number,required:true},items:{type:Array,required:true},visibleColumns:{type:Array,default:void 0},columnSizingOverrides:{type:Object,required:true},columnOrder:{type:Array,default:void 0}},setup(e){let o=ref(null),n=ref(null),l=0,i,m=computed(()=>e.copyRange??e.cutRange),d=()=>{let s=toValue(e.containerRef);if(!s){o.value=null,n.value=null;return}o.value=e.selectionRange?measureRange(s,e.selectionRange,e.colOffset):null,n.value=m.value?measureRange(s,m.value,e.colOffset):null;};onMounted(()=>{injectGlobalStyles("ogrid-marching-ants-keyframes","@keyframes ogrid-marching-ants{to{stroke-dashoffset:-8}}");}),watch([()=>e.selectionRange,m,()=>toValue(e.containerRef),()=>e.items,()=>e.visibleColumns,()=>e.columnSizingOverrides,()=>e.columnOrder],()=>{if(!e.selectionRange&&!m.value){o.value=null,n.value=null;return}l=requestAnimationFrame(d);let s=toValue(e.containerRef);s&&(i?.disconnect(),i=new ResizeObserver(d),i.observe(s));},{immediate:true}),onUnmounted(()=>{cancelAnimationFrame(l),i?.disconnect();});let a=computed(()=>{let s=e.selectionRange,f=m.value;return s!=null&&f!=null&&s.startRow===f.startRow&&s.startCol===f.startCol&&s.endRow===f.endRow&&s.endCol===f.endCol});return ()=>!o.value&&!n.value?null:h("div",{style:{position:"relative"}},[o.value&&!a.value&&!(e.selectionRange&&e.selectionRange.startRow===e.selectionRange.endRow&&e.selectionRange.startCol===e.selectionRange.endCol)?h("svg",{style:{position:"absolute",top:`${o.value.top}px`,left:`${o.value.left}px`,width:`${o.value.width}px`,height:`${o.value.height}px`,pointerEvents:"none",zIndex:Z_INDEX.SELECTION_OVERLAY,overflow:"visible"},"aria-hidden":"true"},[h("rect",{x:1,y:1,width:Math.max(0,o.value.width-2),height:Math.max(0,o.value.height-2),fill:"none",stroke:"var(--ogrid-selection, #217346)","stroke-width":2})]):null,n.value?h("svg",{style:{position:"absolute",top:`${n.value.top}px`,left:`${n.value.left}px`,width:`${n.value.width}px`,height:`${n.value.height}px`,pointerEvents:"none",zIndex:Z_INDEX.CLIPBOARD_OVERLAY,overflow:"visible"},"aria-hidden":"true"},[h("rect",{x:1,y:1,width:Math.max(0,n.value.width-2),height:Math.max(0,n.value.height-2),fill:"none",stroke:"var(--ogrid-selection, #217346)","stroke-width":2,"stroke-dasharray":"4 4",style:{animation:"ogrid-marching-ants 0.5s linear infinite"}})]):null])}});var Ln=defineComponent({name:"StatusBar",props:{totalCount:{type:Number,required:true},filteredCount:{type:Number,default:void 0},selectedCount:{type:Number,default:void 0},selectedCellCount:{type:Number,default:void 0},aggregation:{type:Object,default:void 0},suppressRowCount:{type:Boolean,default:false}},setup(e){return ()=>{let o=getStatusBarParts(e);return h("div",{role:"status","aria-live":"polite",style:{marginTop:"auto",padding:"6px 12px",borderTop:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",backgroundColor:"var(--ogrid-header-bg, rgba(0,0,0,0.04))",display:"flex",alignItems:"center",gap:"16px",fontSize:"0.875rem",lineHeight:"20px",minHeight:"33px",boxSizing:"border-box"}},o.map((n,l)=>h("span",{key:n.key,style:{display:"inline-flex",alignItems:"center",gap:"4px",...l<o.length-1?{marginRight:"16px",borderRight:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",paddingRight:"16px"}:{}}},[h("span",{style:{color:"var(--ogrid-fg-secondary, rgba(0,0,0,0.6))"}},n.label),h("span",{style:{fontWeight:"600"}},n.value.toLocaleString())])))}}});var Bn=defineComponent({name:"FormulaBar",props:{cellRef:{type:[String,null],default:null},formulaText:{type:String,required:true},isEditing:{type:Boolean,required:true}},emits:["inputChange","commit","cancel","startEditing"],setup(e,{emit:o}){let n=ref(null);return watch(()=>e.isEditing,l=>{l&&n.value&&n.value.focus();}),()=>h("div",{style:FORMULA_BAR_STYLES.bar,role:"toolbar","aria-label":"Formula bar"},[h("div",{style:FORMULA_BAR_STYLES.nameBox,"aria-label":"Active cell reference"},e.cellRef??"\u2014"),h("div",{style:FORMULA_BAR_STYLES.fxLabel,"aria-hidden":"true"},"fx"),h("input",{ref:n,type:"text",style:FORMULA_BAR_STYLES.input,value:e.formulaText,readonly:!e.isEditing,onInput:l=>o("inputChange",l.target.value),onKeydown:l=>handleFormulaBarKeyDown(l.key,()=>l.preventDefault(),()=>o("commit"),()=>o("cancel")),onClick:()=>{e.isEditing||o("startEditing");},onDblclick:()=>{e.isEditing||o("startEditing");},"aria-label":"Formula input",spellcheck:false,autocomplete:"off"})])}});var al={display:"flex",alignItems:"center",borderTop:"1px solid var(--ogrid-border, #e0e0e0)",background:"var(--ogrid-header-bg, #f5f5f5)",minHeight:"30px",overflowX:"auto",overflowY:"hidden",gap:"0",fontSize:"12px"},il={background:"none",border:"none",cursor:"pointer",padding:"4px 10px",fontSize:"16px",lineHeight:"22px",color:"var(--ogrid-fg-secondary, #666)",flexShrink:0},co={background:"none",border:"none",borderBottom:"2px solid transparent",cursor:"pointer",padding:"4px 16px",fontSize:"12px",lineHeight:"22px",color:"var(--ogrid-fg, #242424)",whiteSpace:"nowrap",position:"relative"},sl={...co,fontWeight:600,borderBottomColor:"var(--ogrid-primary, #217346)",background:"var(--ogrid-bg, #fff)"},Vn=defineComponent({name:"SheetTabs",props:{sheets:{type:Array,required:true},activeSheet:{type:String,required:true},showAddButton:{type:Boolean,default:false}},emits:["sheetChange","sheetAdd"],setup(e,{emit:o}){return ()=>h("div",{style:al,role:"tablist","aria-label":"Sheet tabs"},[e.showAddButton?h("button",{type:"button",style:il,onClick:()=>o("sheetAdd"),title:"Add sheet","aria-label":"Add sheet"},"+"):null,...e.sheets.map(n=>{let l=n.id===e.activeSheet,i=l?sl:co,m=l&&n.color?{...i,borderBottomColor:n.color}:i;return h("button",{key:n.id,type:"button",role:"tab","aria-selected":l,style:m,onClick:()=>o("sheetChange",n.id)},n.name)})])}});function ml(e,o,n){let l=o.col+n,i=(o.endCol??o.col)+n,m=o.endRow??o.row,d=e.querySelector(`[data-row-index="${o.row}"][data-col-index="${l}"]`),a=e.querySelector(`[data-row-index="${m}"][data-col-index="${i}"]`);if(!d||!a)return null;let s=e.getBoundingClientRect(),f=d.getBoundingClientRect(),v=a.getBoundingClientRect();return {top:Math.round(f.top-s.top),left:Math.round(f.left-s.left),width:Math.round(v.right-f.left),height:Math.round(v.bottom-f.top),color:FORMULA_REF_COLORS[o.colorIndex%FORMULA_REF_COLORS.length]}}var zn=defineComponent({name:"FormulaRefOverlay",props:{containerEl:{type:Object,default:null},references:{type:Array,required:true},colOffset:{type:Number,required:true}},setup(e){let o=ref([]),n=0;function l(){let i=e.containerEl,m=e.references;if(!i||m.length===0){o.value=[];return}let d=[];for(let a of m){let s=ml(i,a,e.colOffset);s&&d.push(s);}o.value=d;}return watch(()=>[e.references,e.containerEl,e.colOffset],()=>{if(cancelAnimationFrame(n),!e.containerEl||e.references.length===0){o.value=[];return}n=requestAnimationFrame(l);},{immediate:true}),()=>o.value.length===0?null:o.value.map((i,m)=>h("svg",{key:m,style:{position:"absolute",top:`${i.top}px`,left:`${i.left}px`,width:`${i.width}px`,height:`${i.height}px`,pointerEvents:"none",zIndex:3,overflow:"visible"},"aria-hidden":"true"},[h("rect",{x:"1",y:"1",width:Math.max(0,i.width-2),height:Math.max(0,i.height-2),fill:"none",stroke:i.color,"stroke-width":"2",style:"shape-rendering: crispEdges"})]))}});function Gt(e,o){let n=ref({}),l=ref({}),i=computed(()=>[...o.value].sort().join(",")),m=async()=>{let d=e.value,a=o.value,s="fetchFilterOptions"in d&&typeof d.fetchFilterOptions=="function"?d.fetchFilterOptions.bind(d):void 0;if(!s){n.value={},l.value={};return}let f={};a.forEach(c=>{f[c]=true;}),l.value=f;let v={};await Promise.all(a.map(async c=>{try{v[c]=await s(c);}catch{v[c]=[];}})),n.value=v,l.value={};};return watch([e,i],()=>{m().catch(()=>{});},{immediate:true}),{filterOptions:n,loadingOptions:l}}function ut(e){let o=unref(e);return customRef((n,l)=>({get(){return isRef(e)&&(o=e.value),o},set(i){o=i,l();}}))}function vo(e){let{formulas:o,items:n,flatColumns:l,initialFormulas:i,onFormulaRecalc:m,formulaFunctions:d,namedRanges:a,sheets:s}=e,f=ut(n),v=ut(l),c=ut(m),u=shallowRef(null),g=false,r=computed(()=>o?.value??false);function p(){return createGridDataAccessor(f.value,v.value)}watch(r,x=>{if(x&&!u.value){if(u.value=new FormulaEngine({customFunctions:d,namedRanges:a}),s)for(let[T,M]of Object.entries(s))u.value.registerSheet(T,M);if(i&&!g){g=true;let T=p(),M=u.value.loadFormulas(i,T);M.updatedCells.length>0&&c.value?.(M);}}else !x&&u.value&&(u.value=null);},{immediate:true});function h(x,T){return u.value?.getValue(x,T)}function D(x,T){return u.value?.hasFormula(x,T)??false}function I(x,T){return u.value?.getFormula(x,T)}function b(x,T,M){if(!u.value)return;let k=p(),y=u.value.setFormula(x,T,M,k);y.updatedCells.length>0&&c.value?.(y);}function L(x,T){if(!u.value)return;let M=p(),k=u.value.onCellChanged(x,T,M);k.updatedCells.length>0&&c.value?.(k);}function H(x,T){return u.value?.getPrecedents(x,T)??[]}function G(x,T){return u.value?.getDependents(x,T)??[]}function F(x,T){return u.value?.getAuditTrail(x,T)??null}return {enabled:r,getFormulaValue:h,hasFormula:D,getFormula:I,setFormula:b,onCellChanged:L,getPrecedents:H,getDependents:G,getAuditTrail:F}}function Nt(e){let{activeCol:o,activeRow:n,activeCellRef:l,getFormula:i,getRawValue:m,setFormula:d,onCellValueChanged:a}=e,s=ref(false),f=ref(""),v=ref(false),c=computed(()=>deriveFormulaBarText(o.value,n.value,i,m));watch([o,n],()=>{s.value=false,v.value=false;});let u=()=>{f.value=c.value,s.value=true,v.value=true;},g=I=>{f.value=I;},r=()=>{let I=o.value,b=n.value;I==null||b==null||!d||(processFormulaBarCommit(f.value,I,b,d,a),s.value=false,v.value=false);},p=()=>{s.value=false,v.value=false,f.value="";},h=computed(()=>s.value?f.value:c.value),D=computed(()=>extractFormulaReferences(h.value));return {cellRef:l,formulaText:h,isEditing:s,onInputChange:g,onCommit:r,onCancel:p,startEditing:u,referencedCells:D,isFormulaBarEditing:v}}var go=["columns","filters"];function Ot(e){let{config:o}=e,n=o!=null&&o!==false,l=(()=>{if(!n||o===true)return {panels:go,position:"right",defaultPanel:null};let f=o;return {panels:f.panels??go,position:f.position??"right",defaultPanel:f.defaultPanel??null}})(),i=ref(l.defaultPanel),m=f=>{i.value=f;},d=f=>{i.value=i.value===f?null:f;},a=()=>{i.value=null;},s=computed(()=>i.value!==null);return {isEnabled:n,activePanel:i,setActivePanel:m,panels:l.panels,position:l.position,isOpen:s,toggle:d,close:a}}var Nl=25,Wl={};function _t(e){let o=computed(()=>{let t=e.value;return {columns:t.columns,columnOrder:t.columnOrder,onColumnOrderChange:t.onColumnOrderChange,onColumnResized:t.onColumnResized,onAutosizeColumn:t.onAutosizeColumn,onColumnPinned:t.onColumnPinned,columnChooser:t.columnChooser}}),n=computed(()=>{let t=e.value,O="data"in t?t.data:void 0,le="dataSource"in t?t.dataSource:void 0;return O&&le&&console.warn("[OGrid] Both data and dataSource provided. dataSource takes precedence."),{getRowId:t.getRowId,data:O,dataSource:le}}),l=computed(()=>{let t=e.value;return {page:t.page,pageSize:t.pageSize,sort:t.sort,filters:t.filters,visibleColumns:t.visibleColumns,isLoading:t.isLoading}}),i=computed(()=>{let t=e.value;return {onPageChange:t.onPageChange,onPageSizeChange:t.onPageSizeChange,onSortChange:t.onSortChange,onFiltersChange:t.onFiltersChange,onVisibleColumnsChange:t.onVisibleColumnsChange,onFirstDataRendered:t.onFirstDataRendered,onError:t.onError}}),m=computed(()=>{let t=e.value;return {defaultPageSize:t.defaultPageSize??Nl,defaultSortBy:t.defaultSortBy,defaultSortDirection:t.defaultSortDirection??"asc",entityLabelPlural:t.entityLabelPlural??"items"}}),d=computed(()=>o.value.columnChooser===false?"none":o.value.columnChooser==="sidebar"?"sidebar":"toolbar"),a=computed(()=>flattenColumns(o.value.columns)),s=computed(()=>n.value.dataSource!=null),f=computed(()=>!s.value),v=ref([]),c=ref(false),u=computed(()=>n.value.data??v.value),g=computed(()=>l.value.isLoading??c.value),r=computed(()=>m.value.defaultSortBy??a.value[0]?.columnId??""),p=ref(1),h$1=ref(m.value.defaultPageSize),D=ref({field:r.value,direction:m.value.defaultSortDirection}),I=ref({}),b=ref(void 0),L=ref((()=>{let t=a.value.filter(O=>O.defaultVisible!==false).map(O=>O.columnId);return new Set(t.length>0?t:a.value.map(O=>O.columnId))})()),H=ref({}),G={};for(let t of flattenColumns(e.value.columns))t.pinned&&(G[t.columnId]=t.pinned);let F=ref(G),x=computed(()=>l.value.page??p.value),T=computed(()=>l.value.pageSize??h$1.value),M=computed(()=>l.value.sort??D.value),k=computed(()=>l.value.filters??I.value),y=computed(()=>o.value.columnOrder??b.value),w=computed(()=>l.value.visibleColumns??L.value),S=t=>{l.value.page===void 0&&(p.value=t),i.value.onPageChange?.(t);},P=t=>{l.value.pageSize===void 0&&(h$1.value=t),i.value.onPageSizeChange?.(t),S(1);},C=ref(0),R=t=>{l.value.sort===void 0&&(D.value=t),i.value.onSortChange?.(t),S(1),C.value++;},E=t=>{l.value.filters===void 0&&(I.value=t),i.value.onFiltersChange?.(t),S(1);},_=t=>{l.value.visibleColumns===void 0&&(L.value=t),i.value.onVisibleColumnsChange?.(t);},W=(t,O)=>{R(computeNextSortState(M.value,t,O));},K=(t,O)=>{E(mergeFilter(k.value,t,O));},U=(t,O)=>{let le=new Set(w.value);O?le.add(t):le.delete(t),_(le);},X=ref(new Set),J=computed(()=>e.value.selectedRows),Y=computed(()=>J.value??X.value),q=t=>{J.value===void 0&&(X.value=new Set(t.selectedRowIds)),e.value.onSelectionChange?.(t);},B=computed(()=>getMultiSelectFilterFields(a.value)),Z=computed(()=>n.value.dataSource??{fetchFilterOptions:void 0}),{filterOptions:ne,loadingOptions:we}=Gt(Z,B),Fe=computed(()=>n.value.dataSource?.fetchFilterOptions!=null),Ke=computed(()=>Fe.value?ne.value:deriveFilterOptionsFromData(u.value,a.value)),Pe=computed(()=>shouldUseWorkerSort(e.value.workerSort,u.value.length,{columns:a.value,filters:k.value,sortBy:M.value.field})),xe=null,Ne=-1,He=null,We=null,$e=-1,et=computed(()=>{if(!f.value||Pe.value)return null;let t=u.value,O=a.value,le=k.value,Re=C.value,it=M.value.field,st=M.value.direction,Xe=Re!==Ne||le!==He||O!==We||t.length!==$e,fe;if(Xe||xe===null){Ne=Re,He=le,We=O,$e=t.length;let be=processClientSideData(t,O,le,it,st),Ae=new Map;for(let pe=0;pe<t.length;pe++)Ae.set(t[pe],pe);xe=be.map(pe=>{let De=Ae.get(pe);return De!==void 0?De:-1}).filter(pe=>pe!==-1),fe=be;}else fe=xe.map(be=>t[be]).filter(be=>be!==void 0);let pt=fe.length,je=(x.value-1)*T.value;return {items:fe.slice(je,je+T.value),totalCount:pt}}),tt=ref(null),ct=0,Ue=null,mt=-1,Ie=null,gt=null,ae=-1;watch([f,Pe,u,a,k,C,x,T],()=>{if(!f.value||!Pe.value)return;let t=u.value,O=a.value,le=k.value,Re=C.value,it=M.value.field,st=M.value.direction,Xe=x.value,fe=T.value,pt=++ct;if(Re!==mt||le!==Ie||O!==gt||t.length!==ae||Ue===null)mt=Re,Ie=le,gt=O,ae=t.length,Ue=null,processClientSideDataAsync(t,O,le,it,st).then(Ce=>{if(pt!==ct||_e)return;let be=new Map;for(let A=0;A<t.length;A++)be.set(t[A],A);Ue=Ce.map(A=>{let V=be.get(A);return V!==void 0?V:-1}).filter(A=>A!==-1);let Ae=Ce.length,pe=(Xe-1)*fe,De=Ce.slice(pe,pe+fe);tt.value={items:De,totalCount:Ae};}).catch(()=>{if(pt!==ct||_e)return;let Ce=processClientSideData(t,O,le,it,st),be=new Map;for(let A=0;A<t.length;A++)be.set(t[A],A);Ue=Ce.map(A=>{let V=be.get(A);return V!==void 0?V:-1}).filter(A=>A!==-1);let Ae=Ce.length,pe=(Xe-1)*fe,De=Ce.slice(pe,pe+fe);tt.value={items:De,totalCount:Ae};});else {let Ce=Ue.map(De=>t[De]).filter(De=>De!==void 0),be=Ce.length,Ae=(Xe-1)*fe,pe=Ce.slice(Ae,Ae+fe);tt.value={items:pe,totalCount:be};}},{immediate:true});let Oe=computed(()=>{let t=et.value;return t||tt.value}),nt=ref([]),ot=ref(0),Ee=ref(false),lt=0,rt=null,_e=false,Ct=ref(0),ht=()=>{if(!s.value||!n.value.dataSource){s.value||(Ee.value=false);return}let t=++lt;rt?.abort();let O=new AbortController;rt=O,Ee.value=true,n.value.dataSource.fetchPage({page:x.value,pageSize:T.value,sort:{field:M.value.field,direction:M.value.direction},filters:k.value,signal:O.signal}).then(le=>{t!==lt||_e||O.signal.aborted||(nt.value=le.items,ot.value=le.totalCount);}).catch(le=>{t!==lt||_e||O.signal.aborted||(i.value.onError?.(le),nt.value=[],ot.value=0);}).finally(()=>{t===lt&&!_e&&!O.signal.aborted&&(Ee.value=false);});};onMounted(()=>{validateColumns(a.value),ht();}),watch([()=>n.value.dataSource,x,T,()=>M.value.field,()=>M.value.direction,k,Ct],()=>{ht();}),onUnmounted(()=>{_e=true,rt?.abort(),rt=null;});let Ve=computed(()=>f.value&&Oe.value?Oe.value.items:nt.value),ft=computed(()=>f.value&&Oe.value?Oe.value.totalCount:ot.value),at=computed(()=>!!e.value.formulas),Rt=ref(0),xt=t=>{Rt.value+=1,e.value.onFormulaRecalc?.(t);},ve=vo({formulas:at,items:Ve,flatColumns:a,initialFormulas:e.value.initialFormulas,onFormulaRecalc:xt,formulaFunctions:e.value.formulaFunctions,namedRanges:e.value.namedRanges,sheets:e.value.sheets}),bt=false,It=false;watch(Ve,t=>{!bt&&t.length>0&&(bt=true,i.value.onFirstDataRendered?.()),!It&&t.length>0&&(It=true,validateRowIds(t,n.value.getRowId));});let qe=computed(()=>Object.values(k.value).some(t=>t!==void 0)),St=computed(()=>a.value.map(t=>({columnId:t.columnId,name:t.name,required:t.required===true}))),Tt=computed(()=>{let t=e.value.statusBar;if(!t)return;if(typeof t=="object")return t;let O=f.value?n.value.data?.length??0:ot.value,le=ft.value;return {totalCount:O,filteredCount:qe.value?le:void 0,selectedCount:Y.value.size,suppressRowCount:true}}),Pt=(t,O)=>{H.value={...H.value,[t]:O},o.value.onColumnResized?.(t,O);},te=(t,O)=>{H.value={...H.value,[t]:O},(o.value.onAutosizeColumn??o.value.onColumnResized)?.(t,O);},Q=(t,O)=>{if(O===null){let{[t]:le,...Re}=F.value;F.value=Re;}else F.value={...F.value,[t]:O};o.value.onColumnPinned?.(t,O);},re=shallowRef(Ot({config:e.value.sideBar}));watch(()=>e.value.sideBar,t=>{re.value=Ot({config:t});});let me=computed(()=>a.value.filter(t=>t.filterable&&t.filterable.type).map(t=>({columnId:t.columnId,name:t.name,filterField:t.filterable?.filterField??t.columnId,filterType:t.filterable?.type}))),se=computed(()=>{let t=re.value;if(!t.isEnabled)return null;t.activePanel.value;t.isOpen.value;return {get activePanel(){return t.activePanel.value},onPanelChange:t.setActivePanel,panels:t.panels,position:t.position,get isOpen(){return t.isOpen.value},toggle:t.toggle,close:t.close,columns:St.value,visibleColumns:w.value,onVisibilityChange:U,onSetVisibleColumns:_,filterableColumns:me.value,filters:k.value,onFilterChange:K,filterOptions:Ke.value}}),Me=()=>E({}),ye=computed(()=>s.value&&Ee.value||g.value),he=ref(null),ge=ref(null),yt=t=>{if(he.value=t,t){let O=t.match(/^([A-Z]+)(\d+)$/);O?ge.value={col:columnLetterToIndex(O[1]),row:parseInt(O[2],10)-1}:ge.value=null;}else ge.value=null;},Et=computed(()=>ge.value?.col??null),Dn=computed(()=>ge.value?.row??null),Fn=(t,O)=>{let le=Ve.value,Re=a.value;if(!(O<0||O>=le.length||t<0||t>=Re.length))return getCellValue(le[O],Re[t])},ke=Nt({activeCol:Et,activeRow:Dn,activeCellRef:he,getFormula:ve.enabled.value?ve.getFormula:void 0,getRawValue:Fn,setFormula:ve.enabled.value?ve.setFormula:void 0}),Un=computed(()=>{let t=e.value,O=n.value.dataSource;return {items:Ve.value,columns:o.value.columns,getRowId:n.value.getRowId,sortBy:M.value.field,sortDirection:M.value.direction,onColumnSort:W,visibleColumns:w.value,columnOrder:y.value,onColumnOrderChange:o.value.onColumnOrderChange,onColumnResized:Pt,onAutosizeColumn:te,onColumnPinned:Q,pinnedColumns:F.value,initialColumnWidths:H.value,editable:t.editable,cellSelection:t.cellSelection,onCellValueChanged:t.onCellValueChanged,onUndo:t.onUndo,onRedo:t.onRedo,canUndo:t.canUndo,canRedo:t.canRedo,rowSelection:t.rowSelection??"none",selectedRows:Y.value,onSelectionChange:q,showRowNumbers:t.showRowNumbers||t.cellReferences||t.formulas,showColumnLetters:!!(t.cellReferences||t.formulas),showNameBox:!!(t.cellReferences&&!t.formulas),onActiveCellChange:t.cellReferences||t.formulas?yt:void 0,currentPage:x.value,pageSize:T.value,statusBar:Tt.value,isLoading:ye.value,filters:k.value,onFilterChange:K,filterOptions:Ke.value,loadingFilterOptions:O?.fetchFilterOptions?we.value:Wl,peopleSearch:O?.searchPeople,getUserByEmail:O?.getUserByEmail,layoutMode:t.layoutMode,suppressHorizontalScroll:t.suppressHorizontalScroll,stickyHeader:t.stickyHeader??true,columnReorder:t.columnReorder,responsiveColumns:t.responsiveColumns,virtualScroll:t.virtualScroll,rowHeight:t.rowHeight,density:t.density??"normal","aria-label":t["aria-label"],"aria-labelledby":t["aria-labelledby"],emptyState:{hasActiveFilters:qe.value,onClearAll:Me,message:t.emptyState?.message,render:t.emptyState?.render},formulas:t.formulas,formulaVersion:Rt.value,...ve.enabled.value?{getFormulaValue:ve.getFormulaValue,hasFormula:ve.hasFormula,getFormula:ve.getFormula,setFormula:ve.setFormula,onFormulaCellChanged:ve.onCellChanged,getPrecedents:ve.getPrecedents,getDependents:ve.getDependents,getAuditTrail:ve.getAuditTrail}:{},formulaReferences:ke.referencedCells.value.length>0?ke.referencedCells.value:void 0}}),Dt=computed(()=>({page:x.value,pageSize:T.value,displayTotalCount:ft.value,setPage:S,setPageSize:P,pageSizeOptions:e.value.pageSizeOptions,entityLabelPlural:m.value.entityLabelPlural})),ze=computed(()=>({columns:St.value,visibleColumns:w.value,onVisibilityChange:U,placement:d.value})),Ft=computed(()=>{let t=e.value,O=!!t.formulas,le=!!t.cellReferences&&!O,Re=t.toolbar;le&&(Re=[h("div",{style:{display:"inline-flex",alignItems:"center",padding:"0 8px",fontFamily:"'Consolas', 'Courier New', monospace",fontSize:"12px",border:"1px solid rgba(0,0,0,0.12)",borderRadius:"3px",height:"24px",marginRight:"8px",background:"#fff",minWidth:"40px",color:"rgba(0,0,0,0.6)"},"aria-label":"Active cell reference"},he.value??"\u2014"),Re]);let it=O?h(Bn,{cellRef:ke.cellRef.value,formulaText:ke.formulaText.value,isEditing:ke.isEditing.value,onInputChange:ke.onInputChange,onCommit:ke.onCommit,onCancel:ke.onCancel,onStartEditing:ke.startEditing}):void 0,st=t.sheetDefs&&t.sheetDefs.length>0&&t.activeSheet&&t.onSheetChange?h(Vn,{sheets:t.sheetDefs,activeSheet:t.activeSheet,showAddButton:!!t.onSheetAdd,onSheetChange:t.onSheetChange,onSheetAdd:t.onSheetAdd??(()=>{})}):void 0;return {toolbar:Re,toolbarBelow:t.toolbarBelow,className:t.className,emptyState:t.emptyState,sideBarProps:se.value,fullScreen:t.fullScreen,formulaBar:it,sheetTabs:st}}),On=computed(()=>({hasActiveFilters:qe.value,setFilters:E})),Mn=computed(()=>({setRowData:t=>{s.value||(v.value=t);},setLoading:t=>{c.value=t;},getColumnState:()=>({visibleColumns:Array.from(w.value),sort:M.value,columnOrder:y.value??void 0,columnWidths:Object.keys(H.value).length>0?H.value:void 0,filters:Object.keys(k.value).length>0?k.value:void 0,pinnedColumns:Object.keys(F.value).length>0?F.value:void 0}),applyColumnState:t=>{t.visibleColumns&&_(new Set(t.visibleColumns)),t.sort&&R(t.sort),t.columnOrder&&(o.value.columnOrder===void 0&&(b.value=t.columnOrder),o.value.onColumnOrderChange?.(t.columnOrder)),t.columnWidths&&(H.value=t.columnWidths),t.filters&&E(t.filters),t.pinnedColumns&&(F.value=t.pinnedColumns);},setFilterModel:E,getSelectedRows:()=>Array.from(Y.value),setSelectedRows:t=>{J.value===void 0&&(X.value=new Set(t));},selectAll:()=>{let t=new Set(Ve.value.map(O=>n.value.getRowId(O)));J.value===void 0&&(X.value=t),e.value.onSelectionChange?.({selectedRowIds:Array.from(t),selectedItems:Ve.value});},deselectAll:()=>{J.value===void 0&&(X.value=new Set),e.value.onSelectionChange?.({selectedRowIds:[],selectedItems:[]});},clearFilters:()=>E({}),clearSort:()=>R({field:r.value,direction:m.value.defaultSortDirection}),resetGridState:t=>{E({}),R({field:r.value,direction:m.value.defaultSortDirection}),t?.keepSelection||(J.value===void 0&&(X.value=new Set),e.value.onSelectionChange?.({selectedRowIds:[],selectedItems:[]}));},getDisplayedRows:()=>Ve.value,refreshData:()=>{s.value&&Ct.value++;},scrollToRow:()=>{},getColumnOrder:()=>y.value??a.value.map(t=>t.columnId),setColumnOrder:t=>{o.value.columnOrder===void 0&&(b.value=t),o.value.onColumnOrderChange?.(t);}}));return {dataGridProps:Un,pagination:Dt,columnChooser:ze,layout:Ft,filters:On,api:Mn}}function Kt(e){let{items:o,getRowId:n,rowSelection:l,controlledSelectedRows:i,onSelectionChange:m}=e,d=shallowRef(new Set),a=-1,s=computed(()=>{let r=i.value;return r!=null?r instanceof Set?r:new Set(r):d.value}),f=r=>{i.value!==void 0?isReadonly(i)||(i.value=r):d.value=r,m?.({selectedRowIds:Array.from(r),selectedItems:o.value.filter(p=>r.has(n(p)))});},v=(r,p,h,D)=>{if(l.value==="single"){f(p?new Set([r]):new Set),a=h;return}let I=o.value,b;D&&a>=0&&a!==h?b=applyRangeRowSelection(a,h,p,I,n,s.value):(b=new Set(s.value),p?b.add(r):b.delete(r)),a=h,f(b);},c=r=>{f(r?new Set(o.value.map(p=>n(p))):new Set);},u=computed(()=>computeRowSelectionState(s.value,o.value,n).allSelected),g=computed(()=>computeRowSelectionState(s.value,o.value,n).someSelected);return {selectedRowIds:s,updateSelection:f,handleRowCheckboxChange:v,handleSelectAll:c,allSelected:u,someSelected:g}}function $t(e){let o=shallowRef(null),n=ref(void 0);return {editingCell:o,setEditingCell:m=>{if(m&&e?.scrollToRow&&e?.getRowIndex){let d=e.getRowIndex(m.rowId);d>=0&&e.scrollToRow(d,"center");}o.value=m;},pendingEditorValue:n,setPendingEditorValue:m=>{n.value=m;}}}function qt(e,o){let n=shallowRef(null),l=0,i=m=>{let d=n.value;d!==m&&(d&&m&&d.rowIndex===m.rowIndex&&d.columnIndex===m.columnIndex||(n.value=m));};return watch([n,()=>o?.value],()=>{if(l&&(cancelAnimationFrame(l),l=0),n.value==null||!e?.value||o?.value!=null)return;let{rowIndex:m,columnIndex:d}=n.value;l=requestAnimationFrame(()=>{l=0;let a=e.value;if(!a)return;let s=n.value;if(!s||s.rowIndex!==m||s.columnIndex!==d)return;let f=`[data-row-index="${m}"][data-col-index="${d}"]`,v=a.querySelector(f);if(v){let c=a.querySelector("thead"),u=c?c.getBoundingClientRect().height:0,g=a.getBoundingClientRect(),r=v.getBoundingClientRect(),p=g.top+u;r.top<p?a.scrollTop-=p-r.top:r.bottom>g.bottom&&(a.scrollTop+=r.bottom-g.bottom),a.scrollWidth>a.clientWidth&&(r.left<g.left?a.scrollLeft-=g.left-r.left:r.right>g.right&&(a.scrollLeft+=r.right-g.right)),document.activeElement!==v&&typeof v.focus=="function"&&v.focus({preventScroll:true});}});},{flush:"post"}),onUnmounted(()=>{l&&(cancelAnimationFrame(l),l=0);}),{activeCell:n,setActiveCell:i}}var qn="data-drag-range",Mt="data-drag-anchor",Se=40;function Xt(e){let o=ut(e),{wrapperRef:n,setActiveCell:l}=e,i=()=>isRef(e.colOffset)?e.colOffset.value:e.colOffset,m=shallowRef(null),d=ref(false),a=ref(false),s=ref(false),f=false,v=null,c=0,u=null,g=null,r=null,p=C=>{rangesEqual(m.value,C)||(m.value=C);},h=(C,R,E)=>{if(C.button!==0)return;let _=i();if(E<_)return;C.preventDefault();let W=E-_,K=m.value;if(C.shiftKey&&K!=null)p(normalizeSelectionRange({startRow:K.startRow,startCol:K.startCol,endRow:R,endCol:W})),l({rowIndex:R,columnIndex:E});else {v={row:R,col:W},f=false;let U={startRow:R,startCol:W,endRow:R,endCol:W};p(U),u=U,l({rowIndex:R,columnIndex:E}),a.value=true,G(U);}},D=()=>{let{rowCount:C,visibleColCount:R}=o.value;C.value===0||R.value===0||(p({startRow:0,startCol:0,endRow:C.value-1,endCol:R.value-1}),l({rowIndex:0,columnIndex:i()}));},I=new Set,b=null,L=(C,R,E,_,W,K,U,X)=>{C.hasAttribute(qn)||C.setAttribute(qn,""),X&&R===X.row&&E===X.col?C.hasAttribute(Mt)||C.setAttribute(Mt,""):C.hasAttribute(Mt)&&C.removeAttribute(Mt);let Y=[];R===_&&Y.push("inset 0 2px 0 0 var(--ogrid-selection, #217346)"),R===W&&Y.push("inset 0 -2px 0 0 var(--ogrid-selection, #217346)"),E===K&&Y.push("inset 2px 0 0 0 var(--ogrid-selection, #217346)"),E===U&&Y.push("inset -2px 0 0 0 var(--ogrid-selection, #217346)"),C.style.boxShadow=Y.length>0?Y.join(", "):"",I.add(C);},H=C=>{C.removeAttribute(qn),C.removeAttribute(Mt),C.style.boxShadow="";},G=C=>{if(!n.value)return;let E=Math.min(C.startRow,C.endRow),_=Math.max(C.startRow,C.endRow),W=Math.min(C.startCol,C.endCol),K=Math.max(C.startCol,C.endCol),U=v,X=i();for(let Y of I){let q=parseInt(Y.getAttribute("data-row-index")??"",10),B=parseInt(Y.getAttribute("data-col-index")??"",10)-X;q>=E&&q<=_&&B>=W&&B<=K||(H(Y),I.delete(Y));}b||(b=buildCellIndex(n.value));let J=false;for(let Y=E;Y<=_;Y++)for(let q=W;q<=K;q++){let B=cellIndexKey(Y,q+X),Z=b?.get(B);Z&&!Z.isConnected&&!J&&(J=true,b=buildCellIndex(n.value),Z=b?.get(B)),Z&&Z.isConnected&&L(Z,Y,q,E,_,W,K,U);}},F=()=>{for(let C of I)H(C);I.clear(),b=null;},x=(C,R)=>{if(!v)return null;let _=document.elementFromPoint(C,R)?.closest?.("[data-row-index][data-col-index]");if(!_)return null;let W=parseInt(_.getAttribute("data-row-index")??"",10),K=parseInt(_.getAttribute("data-col-index")??"",10),U=i();if(Number.isNaN(W)||Number.isNaN(K)||K<U)return null;let X=K-U;return normalizeSelectionRange({startRow:v.row,startCol:v.col,endRow:W,endCol:X})},T=()=>{g&&(cancelAnimationFrame(g),g=null);},M=()=>{let C=n.value,R=r;if(!C||!R||!a.value){g=null;return}let E=C.getBoundingClientRect(),_=0,W=0;if(R.cy<E.top+Se?W=-computeAutoScrollSpeed(E.top+Se-R.cy):R.cy>E.bottom-Se&&(W=computeAutoScrollSpeed(R.cy-(E.bottom-Se))),R.cx<E.left+Se?_=-computeAutoScrollSpeed(E.left+Se-R.cx):R.cx>E.right-Se&&(_=computeAutoScrollSpeed(R.cx-(E.right-Se))),_===0&&W===0){g=null;return}C.scrollTop+=W,C.scrollLeft+=_;let K=x(R.cx,R.cy);K&&(u=K,G(K)),g=requestAnimationFrame(M);},k=()=>{let C=n.value;if(!C||!r||!a.value){T();return}let R=C.getBoundingClientRect(),E=0,_=0;if(r.cy<R.top+Se?_=-computeAutoScrollSpeed(R.top+Se-r.cy):r.cy>R.bottom-Se&&(_=computeAutoScrollSpeed(r.cy-(R.bottom-Se))),r.cx<R.left+Se?E=-computeAutoScrollSpeed(R.left+Se-r.cx):r.cx>R.right-Se&&(E=computeAutoScrollSpeed(r.cx-(R.right-Se))),E===0&&_===0){T();return}g||(g=requestAnimationFrame(M));},y=C=>{!a.value||!v||(f||(f=true,d.value=true,b=buildCellIndex(n.value)),r={cx:C.clientX,cy:C.clientY},k(),c&&cancelAnimationFrame(c),c=requestAnimationFrame(()=>{if(c=0,!r)return;let R=x(r.cx,r.cy);if(!R)return;let E=u;E&&E.startRow===R.startRow&&E.startCol===R.startCol&&E.endRow===R.endRow&&E.endCol===R.endCol||(u=R,G(R));}));},w=()=>{if(!a.value)return;T(),c&&(cancelAnimationFrame(c),c=0),a.value=false;let C=f;if(C){if(r){let E=x(r.cx,r.cy);E&&(u=E);}let R=u;if(R){p(R);let E=v;E&&l({rowIndex:E.row,columnIndex:E.col+i()});}}F(),u=null,r=null,v=null,C&&(d.value=false);},S=C=>{s.value||y(C);},P=()=>{s.value||w();};return onMounted(()=>{window.addEventListener("pointermove",S,true),window.addEventListener("pointerup",P,true);}),onUnmounted(()=>{s.value=true,window.removeEventListener("pointermove",S,true),window.removeEventListener("pointerup",P,true),c&&cancelAnimationFrame(c),T();}),{selectionRange:m,setSelectionRange:p,handleCellMouseDown:h,handleSelectAllCells:D,isDragging:d}}function jt(){let e=shallowRef(null);return {contextMenuPosition:e,setContextMenuPosition:i=>{e.value=i;},handleCellContextMenu:i=>{i.preventDefault?.(),e.value={x:i.clientX,y:i.clientY};},closeContextMenu:()=>{e.value=null;}}}function Yt(e){let{items:o,visibleCols:n,selectionRange:l,activeCell:i,editable:m,onCellValueChanged:d,beginBatch:a,endBatch:s}=e,f=()=>isRef(e.colOffset)?e.colOffset.value:e.colOffset,v=shallowRef(null),c=shallowRef(null),u=ref(null),g=()=>{let I=l.value,b=i.value,L=f();return I??(b!=null?{startRow:b.rowIndex,startCol:b.columnIndex-L,endRow:b.rowIndex,endCol:b.columnIndex-L}:null)},r=()=>{let I=g();if(I==null)return;let b=normalizeSelectionRange(I),L=formatSelectionAsTsv(o.value,n.value,b);u.value=L,c.value=b,navigator.clipboard.writeText(L).catch(H=>{typeof console<"u"&&console.warn("[OGrid] Clipboard write failed:",H);});};return {handleCopy:r,handleCut:()=>{if(m.value===false)return;let I=g();if(I==null||d.value==null)return;let b=normalizeSelectionRange(I);v.value=b,c.value=null,r(),c.value=null;},handlePaste:async()=>{if(m.value===false)return;let I=d.value;if(I==null)return;let b;try{b=await navigator.clipboard.readText();}catch{b="";}if(!b.trim()&&u.value!=null&&(b=u.value),!b.trim())return;let L=g(),H=L?L.startRow:0,G=L?L.startCol:0,F=o.value,x=n.value,T=parseTsvClipboard(b);a?.();let M=applyPastedValues(T,H,G,F,x);for(let k of M)I(k);if(v.value){let k=applyCutClear(v.value,F,x);for(let y of k)I(y);v.value=null;}s?.(),c.value=null;},cutRange:v,copyRange:c,clearClipboardRanges:()=>{c.value=null,v.value=null;}}}function Zt(e){let o=ut(e);return {handleGridKeyDown:l=>{let{data:i,state:m,handlers:d,features:a}=o.value,s=i.items.value,f=i.visibleCols.value,{getRowId:v}=i,c=isRef(i.colOffset)?i.colOffset.value:i.colOffset,u=i.hasCheckboxCol.value,g=i.visibleColumnCount.value,r=m.activeCell.value,p=m.selectionRange.value,h=m.editingCell.value,D=m.selectedRowIds.value,{setActiveCell:I,setSelectionRange:b,setEditingCell:L,handleRowCheckboxChange:H,handleCopy:G,handleCut:F,handlePaste:x,setContextMenu:T,onUndo:M,onRedo:k,clearClipboardRanges:y}=d,w=a.editable.value,S=a.onCellValueChanged.value,P=a.rowSelection.value,C=a.wrapperRef,R=a.scrollToRow,{fillDown:E}=a,_=a.onKeyDown?.value;if(_&&(_(l),l.defaultPrevented))return;let W=s.length-1,K=g-1+c;if(s.length===0)return;if(r===null){["ArrowDown","ArrowUp","ArrowLeft","ArrowRight","Tab","Enter","Home","End","PageDown","PageUp"].includes(l.key)&&(I({rowIndex:0,columnIndex:c}),l.preventDefault());return}let{rowIndex:U,columnIndex:X}=r,J=X-c,Y=l.shiftKey,q=(B,Z)=>{if(B<0||B>=s.length||Z<0||Z>=f.length)return true;let ne=getCellValue(s[B],f[Z]);return ne==null||ne===""};switch(l.key){case "c":if(l.ctrlKey||l.metaKey){if(h!=null)break;l.preventDefault(),G();}break;case "x":if(l.ctrlKey||l.metaKey){if(h!=null)break;l.preventDefault(),F();}break;case "v":if(l.ctrlKey||l.metaKey){if(h!=null)break;l.preventDefault(),x();}break;case "d":if(l.ctrlKey||l.metaKey){if(h!=null)break;w!==false&&E&&(l.preventDefault(),E());}break;case "ArrowDown":case "ArrowUp":case "ArrowRight":case "ArrowLeft":{if(h!=null)break;l.preventDefault();let{newRowIndex:B,newColumnIndex:Z,newRange:ne}=computeArrowNavigation({direction:l.key,rowIndex:U,columnIndex:X,dataColIndex:J,colOffset:c,maxRowIndex:W,maxColIndex:K,visibleColCount:f.length,isCtrl:l.ctrlKey||l.metaKey,isShift:Y,selectionRange:p,isEmptyAt:q});b(ne),I({rowIndex:B,columnIndex:Z}),(l.key==="ArrowDown"||l.key==="ArrowUp")&&R?.(B,"center");break}case "Tab":{l.preventDefault();let{rowIndex:B,columnIndex:Z}=computeTabNavigation(U,X,W,K,c,l.shiftKey),ne=Z-c;b({startRow:B,startCol:ne,endRow:B,endCol:ne}),I({rowIndex:B,columnIndex:Z});break}case "Home":{l.preventDefault();let B=l.ctrlKey?0:U;b({startRow:B,startCol:0,endRow:B,endCol:0}),I({rowIndex:B,columnIndex:c});break}case "End":{l.preventDefault();let B=l.ctrlKey?W:U;b({startRow:B,startCol:g-1,endRow:B,endCol:g-1}),I({rowIndex:B,columnIndex:K});break}case "PageDown":case "PageUp":{l.preventDefault();let B=C.value,Z=10;if(B){let Fe=B.querySelector("tbody tr");Fe&&Fe.offsetHeight>0&&(Z=Math.max(1,Math.floor(B.clientHeight/Fe.offsetHeight)));}let ne=l.key==="PageDown"?1:-1,we=Math.max(0,Math.min(U+ne*Z,W));b(Y?{startRow:p?.startRow??U,startCol:p?.startCol??J,endRow:we,endCol:p?.endCol??J}:{startRow:we,startCol:J,endRow:we,endCol:J}),I({rowIndex:we,columnIndex:X}),R?.(we,"center");break}case "Enter":case "F2":{if(l.preventDefault(),J>=0&&J<f.length){let B=f[J],Z=s[U];if(Z&&B){let ne=B.editable===true||typeof B.editable=="function"&&B.editable(Z);w!==false&&ne&&S!=null&&L({rowId:v(Z),columnId:B.columnId});}}break}case "Escape":l.preventDefault(),h!=null?L(null):(y?.(),I(null),b(null));break;case " ":if(P!=="none"&&X===0&&u){l.preventDefault();let B=s[U];if(B){let Z=v(B),ne=D.has(Z);H(Z,!ne,U,l.shiftKey);}}break;case "z":(l.ctrlKey||l.metaKey)&&h==null&&(l.shiftKey&&k?(l.preventDefault(),k()):!l.shiftKey&&M&&(l.preventDefault(),M()));break;case "y":(l.ctrlKey||l.metaKey)&&h==null&&k&&(l.preventDefault(),k());break;case "a":if(l.ctrlKey||l.metaKey){if(h!=null)break;l.preventDefault(),s.length>0&&g>0&&(b({startRow:0,startCol:0,endRow:s.length-1,endCol:g-1}),I({rowIndex:0,columnIndex:c}));}break;case "Delete":case "Backspace":{if(h!=null||w===false||S==null)break;let B=p??(r!=null?{startRow:r.rowIndex,startCol:r.columnIndex-c,endRow:r.rowIndex,endCol:r.columnIndex-c}:null);if(B==null)break;l.preventDefault();let Z=applyCellDeletion(B,s,f);for(let ne of Z)S(ne);break}case "F10":if(l.shiftKey)if(l.preventDefault(),r!=null&&C.value){let B=`[data-row-index="${r.rowIndex}"][data-col-index="${r.columnIndex}"]`,Z=C.value.querySelector(B);if(Z){let ne=Z.getBoundingClientRect();T({x:ne.left+ne.width/2,y:ne.top+ne.height/2});}else T({x:100,y:100});}else T({x:100,y:100});break;}}}}var Jt="data-drag-range";function Qt(e){let{items:o,visibleCols:n,editable:l,onCellValueChanged:i,selectionRange:m,setSelectionRange:d,setActiveCell:a,wrapperRef:s,beginBatch:f,endBatch:v,visibleRange:c}=e,u=()=>isRef(e.colOffset)?e.colOffset.value:e.colOffset,g=shallowRef(null),r={endRow:0,endCol:0},p=0,h=null,D=null,I=null,b=F=>{g.value=F;},L=()=>{D&&(window.removeEventListener("pointermove",D,true),D=null),I&&(window.removeEventListener("pointerup",I,true),I=null),p&&(cancelAnimationFrame(p),p=0);};return watch(g,(F,x,T)=>{if(!F||l.value===false||!i.value||!s.value){L();return}r={endRow:F.startRow,endCol:F.startCol},h=null;let M=new Set,k=buildCellIndex(s.value),y=C=>{if(!s.value)return;let E=Math.min(C.startRow,C.endRow),_=Math.max(C.startRow,C.endRow),W=Math.min(C.startCol,C.endCol),K=Math.max(C.startCol,C.endCol),U=u();for(let X of M){let J=parseInt(X.getAttribute("data-row-index")??"",10),Y=parseInt(X.getAttribute("data-col-index")??"",10)-U;J>=E&&J<=_&&Y>=W&&Y<=K||(X.removeAttribute(Jt),M.delete(X));}for(let X=E;X<=_;X++)for(let J=W;J<=K;J++){let Y=cellIndexKey(X,J+U),q=k?.get(Y);q&&!q.isConnected&&(k=buildCellIndex(s.value),q=k.get(Y)),q&&(q.hasAttribute(Jt)||q.setAttribute(Jt,""),M.add(q));}},w=()=>{for(let C of M)C.removeAttribute(Jt);M.clear();},S=null,P=(C,R)=>{let _=document.elementFromPoint(C,R)?.closest?.("[data-row-index][data-col-index]");if(!_||!s.value?.contains(_))return null;let W=parseInt(_.getAttribute("data-row-index")??"",10),K=parseInt(_.getAttribute("data-col-index")??"",10),U=u();if(Number.isNaN(W)||Number.isNaN(K)||K<U)return null;let X=K-U;return normalizeSelectionRange({startRow:F.startRow,startCol:F.startCol,endRow:W,endCol:X})};D=C=>{S={cx:C.clientX,cy:C.clientY},p&&cancelAnimationFrame(p),p=requestAnimationFrame(()=>{if(p=0,!S)return;let R=P(S.cx,S.cy);if(!R)return;let E=h;E&&E.startRow===R.startRow&&E.startCol===R.startCol&&E.endRow===R.endRow&&E.endCol===R.endCol||(h=R,r={endRow:R.endRow,endCol:R.endCol},y(R));});},I=()=>{if(p&&(cancelAnimationFrame(p),p=0),S){let U=P(S.cx,S.cy);U&&(h=U,r={endRow:U.endRow,endCol:U.endCol});}w();let C=r,R=normalizeSelectionRange({startRow:F.startRow,startCol:F.startCol,endRow:C.endRow,endCol:C.endCol}),E=c?.value;E&&(R.startRow=Math.max(R.startRow,E.startIndex),R.endRow=Math.min(R.endRow,E.endIndex)),d(R),a({rowIndex:F.startRow,columnIndex:F.startCol+u()});let _=o.value,W=n.value,K=i.value;if(K){let U=applyFillValues(R,F.startRow,F.startCol,_,W);if(U.length>0){f?.();for(let X of U)K(X);v?.();}}g.value=null,h=null,L();},window.addEventListener("pointermove",D,true),window.addEventListener("pointerup",I,true),T(()=>{L();});}),onUnmounted(()=>L()),{fillDrag:g,setFillDrag:b,handleFillHandleMouseDown:F=>{F.preventDefault(),F.stopPropagation();let x=m.value;x&&(g.value={startRow:x.startRow,startCol:x.startCol});},fillDown:()=>{let F=m.value;if(!F||l.value===false||!i.value)return;let x=normalizeSelectionRange(F),T=o.value,M=n.value,k=i.value,y=applyFillValues(x,x.startRow,x.startCol,T,M);if(y.length>0){f?.();for(let w of y)k(w);v?.();}}}}function en(e){let{onCellValueChanged:o,maxUndoDepth:n=100,afterChange:l}=e,i=new UndoRedoStack(n),m=ref(false),d=ref(false),a=()=>{m.value=i.canUndo,d.value=i.canRedo;};return {onCellValueChanged:o?g=>{i.record(g),i.isBatching||a(),o(g),i.isBatching||l?.();}:void 0,undo:()=>{if(!o)return;let g=i.undo();if(g){a();for(let r=g.length-1;r>=0;r--){let p=g[r];o({...p,oldValue:p.newValue,newValue:p.oldValue});}l?.();}},redo:()=>{if(!o)return;let g=i.redo();if(g){a();for(let r of g)o(r);l?.();}},canUndo:m,canRedo:d,beginBatch:()=>{i.beginBatch();},endBatch:()=>{i.endBatch(),a(),l?.();},maxUndoDepth:n}}function tn(e){let{wrapperRef:o,visibleCols:n,flatColumns:l,hasCheckboxCol:i,initialColumnWidths:m,onColumnResized:d}=e,a=ref(0),s,f=()=>{let r=o.value;if(!r)return;let p=r.getBoundingClientRect(),h=window.getComputedStyle(r),D=(parseFloat(h.borderLeftWidth||"0")||0)+(parseFloat(h.borderRightWidth||"0")||0);a.value=Math.max(0,p.width-D);};onMounted(()=>{let r=o.value;r&&(typeof ResizeObserver<"u"&&(s=new ResizeObserver(f),s.observe(r)),f());}),onUnmounted(()=>{s?.disconnect();});let v=ref((()=>{if(!m)return {};let r={};for(let[p,h]of Object.entries(m))r[p]={widthPx:h};return r})()),c=r=>{v.value=r;},u=computed(()=>{let r=i.value?CHECKBOX_COLUMN_WIDTH:0;return n.value.reduce((p,h)=>p+(h.minWidth??estimateHeaderMinWidth(h.name))+CELL_PADDING,r)});watch(l,r=>{let p=new Set(r.map(b=>b.columnId)),h=v.value,D=Object.keys(h),I=D.filter(b=>p.has(b));if(I.length<D.length){let b={};for(let L of I)b[L]=h[L];v.value=b;}});let g=computed(()=>{let r=i.value?CHECKBOX_COLUMN_WIDTH:0;return n.value.reduce((p,h)=>{let D=v.value[h.columnId],I=h.minWidth??estimateHeaderMinWidth(h.name),b=D?D.widthPx:h.idealWidth??h.defaultWidth??I;return p+Math.max(I,b)+CELL_PADDING},r)});return {containerWidth:a,minTableWidth:u,desiredTableWidth:g,columnSizingOverrides:v,setColumnSizingOverrides:c,onColumnResized:d}}function nn(e){let{columns:o,pinnedColumns:n,onColumnPinned:l}=e,i={};for(let u of o.value)u.pinned&&(i[u.columnId]=u.pinned);let m=ref(i),d=computed(()=>n?.value??m.value);return {pinnedColumns:d,pinColumn:(u,g)=>{let r={...d.value,[u]:g};m.value=r,l?.(u,g);},unpinColumn:u=>{let{[u]:g,...r}=d.value;m.value=r,l?.(u,null);},isPinned:u=>d.value[u],computeLeftOffsets:(u,g,r,p,h)=>{let D={},I=p?h:0;for(let b of u)d.value[b.columnId]==="left"&&(D[b.columnId]=I,I+=g[b.columnId]??r);return D},computeRightOffsets:(u,g,r)=>{let p={},h=0;for(let D=u.length-1;D>=0;D--){let I=u[D];d.value[I.columnId]==="right"&&(p[I.columnId]=h,h+=g[I.columnId]??r);}return p}}}function ln(e){let{columns:o,pinnedColumns:n,onPinColumn:l,onUnpinColumn:i,onSort:m,onColumnResized:d,onAutosizeColumn:a,sortBy:s,sortDirection:f}=e,v=ref(false),c=ref(null),u=ref(null),g=(P,C)=>{c.value=P,u.value=C,v.value=true;},r=()=>{v.value=false,c.value=null,u.value=null;},p=computed(()=>c.value?o.value.find(P=>P.columnId===c.value):void 0),h=computed(()=>c.value?n.value[c.value]:void 0),D=computed(()=>h.value!=="left"),I=computed(()=>h.value!=="right"),b=computed(()=>!!h.value),L=computed(()=>!c.value||!s?.value||s.value!==c.value?null:f?.value??null),H=computed(()=>p.value?.sortable!==false),G=ref(true);return {isOpen:v,openForColumn:c,anchorElement:u,open:g,close:r,handlePinLeft:()=>{c.value&&D.value&&(l(c.value,"left"),r());},handlePinRight:()=>{c.value&&I.value&&(l(c.value,"right"),r());},handleUnpin:()=>{c.value&&b.value&&(i(c.value),r());},handleSortAsc:()=>{c.value&&m&&(m(c.value,"asc"),r());},handleSortDesc:()=>{c.value&&m&&(m(c.value,"desc"),r());},handleClearSort:()=>{c.value&&m&&(m(c.value,null),r());},handleAutosizeThis:()=>{let P=a??d;if(!c.value||!P||!G.value)return;let C=p.value;P(c.value,measureColumnContentWidth(c.value,C?.minWidth)),r();},handleAutosizeAll:()=>{let P=a??d;P&&(o.value.forEach(C=>{P(C.columnId,measureColumnContentWidth(C.columnId,C.minWidth));}),r());},canPinLeft:D,canPinRight:I,canUnpin:b,currentSort:L,isSortable:H,isResizable:G}}var Ze=()=>{},Br=async()=>{},Hr=(e,o,n)=>{},Vr=e=>{},zr=e=>{};function an(e){let{props:o,wrapperRef:n}=e,l=computed(()=>o.value.items),i=o.value.getRowId,m=computed(()=>o.value.rowSelection??"none"),d=computed(()=>o.value.selectedRows),a=computed(()=>o.value.editable),s=computed(()=>o.value.cellSelection!==false),f=computed(()=>o.value.pinnedColumns),v=ref(0),c=()=>{v.value++;},u=en({onCellValueChanged:o.value.onCellValueChanged,afterChange:c}),g=computed(()=>u.onCellValueChanged),r=computed(()=>flattenColumns(o.value.columns)),p=computed(()=>{let te=f.value;return !te||Object.keys(te).length===0?r.value:r.value.map(Q=>{let re=te[Q.columnId];return re&&Q.pinned!==re?{...Q,pinned:re}:Q})}),h=computed(()=>resolveResponsiveConfig(o.value.responsiveColumns)),D=computed(()=>{let te=o.value.visibleColumns,Q=o.value.columnOrder,re=te?p.value.filter(se=>te.has(se.columnId)):p.value;if(!Q?.length)return re;let me=new Map;for(let se=0;se<Q.length;se++)me.set(Q[se],se);return [...re].sort((se,Me)=>{let ye=me.get(se.columnId)??-1,he=me.get(Me.columnId)??-1;return ye===-1&&he===-1?0:ye===-1?1:he===-1?-1:ye-he})}),I=ref(0),b=computed(()=>applyResponsiveHiding(D.value,I.value,h.value)),L=computed(()=>b.value.length),H=computed(()=>m.value==="multiple"),G=computed(()=>!!o.value.showRowNumbers),F=computed(()=>(H.value?1:0)+(G.value?1:0)),x=computed(()=>L.value+F.value),T=F,M=shallowRef(new Map);watch(l,te=>{let Q=M.value;Q.clear(),te.forEach((re,me)=>Q.set(i(re),me)),triggerRef(M);},{immediate:true});let k=Kt({items:l,getRowId:i,rowSelection:m,controlledSelectedRows:d,onSelectionChange:o.value.onSelectionChange}),{editingCell:y,setEditingCell:w,pendingEditorValue:S,setPendingEditorValue:P}=$t(),{activeCell:C,setActiveCell:R}=qt(n,y),E=computed(()=>l.value.length),_=computed(()=>b.value.length),{selectionRange:W,setSelectionRange:K,handleCellMouseDown:U,handleSelectAllCells:X,isDragging:J}=Xt({colOffset:T,rowCount:E,visibleColCount:_,setActiveCell:R,wrapperRef:n}),{contextMenuPosition:Y,setContextMenuPosition:q,handleCellContextMenu:B,closeContextMenu:Z}=jt(),{handleCopy:ne,handleCut:we,handlePaste:Fe,cutRange:Ke,copyRange:Pe,clearClipboardRanges:xe}=Yt({items:l,visibleCols:b,colOffset:T,selectionRange:W,activeCell:C,editable:a,onCellValueChanged:g,beginBatch:u.beginBatch,endBatch:u.endBatch}),Ne=(te,Q,re)=>{te.button===0&&(n.value?.focus({preventScroll:true}),xe(),U(te,Q,re));},{handleFillHandleMouseDown:He,fillDown:We}=Qt({items:l,visibleCols:b,editable:a,onCellValueChanged:g,selectionRange:W,setSelectionRange:K,setActiveCell:R,colOffset:T,wrapperRef:n,beginBatch:u.beginBatch,endBatch:u.endBatch}),{handleGridKeyDown:$e}=Zt({data:{items:l,visibleCols:b,colOffset:T,hasCheckboxCol:H,visibleColumnCount:L,getRowId:i},state:{activeCell:C,selectionRange:W,editingCell:y,selectedRowIds:k.selectedRowIds},handlers:{setActiveCell:R,setSelectionRange:K,setEditingCell:w,handleRowCheckboxChange:k.handleRowCheckboxChange,handleCopy:ne,handleCut:we,handlePaste:Fe,setContextMenu:q,onUndo:u.undo,onRedo:u.redo,clearClipboardRanges:xe},features:{editable:a,onCellValueChanged:g,rowSelection:m,wrapperRef:n,fillDown:We,onKeyDown:computed(()=>o.value.onKeyDown)}}),{containerWidth:et,minTableWidth:tt,desiredTableWidth:ct,columnSizingOverrides:Ue,setColumnSizingOverrides:mt}=tn({wrapperRef:n,visibleCols:D,flatColumns:p,hasCheckboxCol:H,initialColumnWidths:o.value.initialColumnWidths,onColumnResized:(te,Q)=>o.value.onColumnResized?.(te,Q)});watch(et,te=>{I.value=te;},{immediate:true});let Ie=nn({columns:p,pinnedColumns:f,onColumnPinned:o.value.onColumnPinned}),gt=(te,Q)=>{mt({...Ue.value,[te]:{widthPx:Q}}),o.value.onColumnResized?.(te,Q);},ae=ln({columns:p,pinnedColumns:Ie.pinnedColumns,onPinColumn:Ie.pinColumn,onUnpinColumn:Ie.unpinColumn,onSort:o.value.onColumnSort,onColumnResized:o.value.onColumnResized,onAutosizeColumn:gt,sortBy:computed(()=>o.value.sortBy),sortDirection:computed(()=>o.value.sortDirection)}),Oe=ref({});watch([b,et,Ue],()=>{nextTick(()=>{let te=n.value;if(!te)return;let Q=te.querySelectorAll("th[data-column-id]");if(Q.length===0)return;let re={};Q.forEach(ye=>{let he=ye.getAttribute("data-column-id");he&&(re[he]=ye.offsetWidth);});let me=Oe.value,se=Object.keys(re),Me=se.length!==Object.keys(me).length;if(!Me){for(let ye of se)if(me[ye]!==re[ye]){Me=true;break}}Me&&(Oe.value=re);});},{flush:"post"});let nt=computed(()=>{let te={};for(let Q of b.value){let re=Ue.value[Q.columnId];te[Q.columnId]=re?re.widthPx:Q.idealWidth??Q.defaultWidth??Q.minWidth??DEFAULT_MIN_COLUMN_WIDTH;}return te}),ot=computed(()=>Ie.computeLeftOffsets(b.value,nt.value,DEFAULT_MIN_COLUMN_WIDTH,H.value,CHECKBOX_COLUMN_WIDTH)),Ee=computed(()=>Ie.computeRightOffsets(b.value,nt.value,DEFAULT_MIN_COLUMN_WIDTH)),lt=computed(()=>computeAggregations(l.value,b.value,s.value?W.value:null)),rt=computed(()=>{let te=getDataGridStatusBarConfig(o.value.statusBar,l.value.length,k.selectedRowIds.value.size);return te?{...te,aggregation:lt.value??void 0}:null}),_e=computed(()=>l.value.length===0&&!!o.value.emptyState&&!o.value.isLoading),Ct=computed(()=>W.value!=null||C.value!=null),ht=computed(()=>({sortBy:o.value.sortBy,sortDirection:o.value.sortDirection,onColumnSort:o.value.onColumnSort,filters:o.value.filters,onFilterChange:o.value.onFilterChange,filterOptions:o.value.filterOptions,loadingFilterOptions:o.value.loadingFilterOptions,peopleSearch:o.value.peopleSearch})),Ve=computed(()=>({editingCell:y.value,activeCell:s.value?C.value:null,selectionRange:s.value?W.value:null,cutRange:s.value?Ke.value:null,copyRange:s.value?Pe.value:null,colOffset:T.value,itemsLength:l.value.length,getRowId:i,editable:a.value,onCellValueChanged:g.value,isDragging:s.value?J.value:false,getFormulaValue:o.value.getFormulaValue,hasFormula:o.value.hasFormula,getFormula:o.value.getFormula,formulaVersion:o.value.formulaVersion})),ft=ref(null),at=te=>{ft.value=te;},Rt=(te,Q,re,me,se,Me,ye)=>{let he=b.value.find(ge=>ge.columnId===Q);if(he){let ge=parseValue(me,re,te,he);if(!ge.valid){w(null),at(null),P(void 0);return}me=ge.value;}if(w(null),at(null),P(void 0),Object.is(me,re)||g.value?.({item:te,columnId:Q,oldValue:re,newValue:me,rowIndex:se}),!ye?.skipAdvance&&se<l.value.length-1){let ge=se+1,yt=Me-T.value;R({rowIndex:ge,columnIndex:Me}),K({startRow:ge,startCol:yt,endRow:ge,endCol:yt});}},xt=()=>{w(null),at(null),P(void 0);},ve=computed(()=>({flatColumns:p.value,visibleCols:b.value,visibleColumnCount:L.value,totalColCount:x.value,colOffset:T.value,hasCheckboxCol:H.value,hasRowNumbersCol:G.value,rowIndexByRowId:M.value,containerWidth:et.value,minTableWidth:tt.value,desiredTableWidth:ct.value,columnSizingOverrides:Ue.value,setColumnSizingOverrides:mt,onColumnResized:o.value.onColumnResized,measuredColumnWidths:Oe.value,stickyHeader:o.value.stickyHeader??true})),bt=computed(()=>({selectedRowIds:k.selectedRowIds.value,updateSelection:k.updateSelection,handleRowCheckboxChange:k.handleRowCheckboxChange,handleSelectAll:k.handleSelectAll,allSelected:k.allSelected.value,someSelected:k.someSelected.value})),It=computed(()=>({editingCell:y.value,setEditingCell:w,pendingEditorValue:S.value,setPendingEditorValue:P,commitCellEdit:Rt,cancelPopoverEdit:xt,popoverAnchorEl:ft.value,setPopoverAnchorEl:at})),qe=computed(()=>(v.value,{activeCell:s.value?C.value:null,setActiveCell:s.value?R:Ze,selectionRange:s.value?W.value:null,setSelectionRange:s.value?K:Ze,handleCellMouseDown:s.value?Ne:Hr,handleSelectAllCells:s.value?X:Ze,hasCellSelection:s.value?Ct.value:false,handleGridKeyDown:s.value?$e:Vr,handleFillHandleMouseDown:s.value?He:Ze,handleCopy:s.value?ne:Ze,handleCut:s.value?we:Ze,handlePaste:s.value?Fe:Br,cutRange:s.value?Ke.value:null,copyRange:s.value?Pe.value:null,clearClipboardRanges:s.value?xe:Ze,canUndo:u.canUndo.value,canRedo:u.canRedo.value,onUndo:u.undo,onRedo:u.redo,isDragging:s.value?J.value:false})),St=computed(()=>({menuPosition:s.value?Y.value:null,setMenuPosition:s.value?q:Ze,handleCellContextMenu:s.value?B:zr,closeContextMenu:s.value?Z:Ze})),Tt=computed(()=>({headerFilterInput:ht.value,cellDescriptorInput:Ve.value,statusBarConfig:rt.value,showEmptyInGrid:_e.value,onCellError:o.value.onCellError})),Pt=computed(()=>({pinnedColumns:Ie.pinnedColumns.value,pinColumn:Ie.pinColumn,unpinColumn:Ie.unpinColumn,isPinned:Ie.isPinned,leftOffsets:ot.value,rightOffsets:Ee.value,headerMenu:{isOpen:ae.isOpen.value,openForColumn:ae.openForColumn.value,anchorElement:ae.anchorElement.value,open:ae.open,close:ae.close,handlePinLeft:ae.handlePinLeft,handlePinRight:ae.handlePinRight,handleUnpin:ae.handleUnpin,handleSortAsc:ae.handleSortAsc,handleSortDesc:ae.handleSortDesc,handleClearSort:ae.handleClearSort,handleAutosizeThis:ae.handleAutosizeThis,handleAutosizeAll:ae.handleAutosizeAll,canPinLeft:ae.canPinLeft.value,canPinRight:ae.canPinRight.value,canUnpin:ae.canUnpin.value,currentSort:ae.currentSort.value,isSortable:ae.isSortable.value,isResizable:ae.isResizable.value}}));return {layout:ve,rowSelection:bt,editing:It,interaction:qe,contextMenu:St,viewModels:Tt,pinning:Pt}}function sn(e){let{columnSizingOverrides:o,setColumnSizingOverrides:n,minWidth:l=80,defaultWidth:i=120,onColumnResized:m}=e,d=0,a=null;return onUnmounted(()=>{a?.(),a=null;}),{handleResizeStart:(c,u)=>{c.preventDefault(),c.stopPropagation();let g=c.clientX,r=u.columnId,p=c.currentTarget.parentElement,h=p?p.getBoundingClientRect().width:o.value[r]?.widthPx??u.idealWidth??u.defaultWidth??i,D=h,I=document.body.style.cursor,b=document.body.style.userSelect;document.body.style.cursor="col-resize",document.body.style.userSelect="none";let L=()=>{n({...o.value,[r]:{widthPx:D}});},H=r===ROW_NUMBER_COLUMN_ID?ROW_NUMBER_COLUMN_MIN_WIDTH:l,G=T=>{let M=T.clientX-g;D=Math.max(H,h+M),d||(d=requestAnimationFrame(()=>{d=0,L();}));},F=()=>{document.removeEventListener("pointermove",G),document.removeEventListener("pointerup",x),a=null,document.body.style.cursor=I,document.body.style.userSelect=b,d&&(cancelAnimationFrame(d),d=0);},x=()=>{F(),L(),m?.(r,D);};document.addEventListener("pointermove",G),document.addEventListener("pointerup",x),a=F;},handleResizeDoubleClick:(c,u)=>{c.preventDefault(),c.stopPropagation();let g=u.columnId,p=(c.currentTarget.closest("th")??c.currentTarget.parentElement)?.closest("table")?.parentElement??void 0,h=measureColumnContentWidth(g,l,p);n({...o.value,[g]:{widthPx:h}}),m?.(g,h);},getColumnWidth:c=>o.value[c.columnId]?.widthPx??c.idealWidth??c.defaultWidth??i}}function un(e,o){let n=ref(e.value),l;return watch(e,i=>{l!==void 0&&clearTimeout(l),l=setTimeout(()=>{n.value=i;},o);}),onUnmounted(()=>{l!==void 0&&clearTimeout(l);}),n}function Mo(e,o){let n,l=e,i,m=((...d)=>{l=e,i=d,n!==void 0&&clearTimeout(n),n=setTimeout(()=>{l(...d),i=void 0,n=void 0;},o);});return m.cancel=()=>{n!==void 0&&clearTimeout(n),n=void 0,i=void 0;},m.flush=()=>{if(n!==void 0&&i!==void 0){clearTimeout(n),n=void 0;let d=i;i=void 0,l(...d);}},onUnmounted(()=>{n!==void 0&&clearTimeout(n);}),m}function dn(e){let{textValue:o="",onTextChange:n}=e,l=ref(o);return watch(e.isFilterOpen,a=>{a&&(l.value=e.textValue??"");}),{tempTextValue:l,setTempTextValue:a=>{l.value=a;},handleTextApply:()=>{n?.(l.value.trim());},handleTextClear:()=>{l.value="";}}}var Zr=150,Zn=[];function cn(e){let{onFilterChange:o}=e,n=ref(new Set(e.selectedValues??Zn)),l=ref(""),i=un(l,Zr);watch(e.isFilterOpen,u=>{u&&(n.value=new Set(e.selectedValues??Zn),l.value="");});let m=computed(()=>{let u=e.options??Zn;if(!i.value.trim())return u;let g=i.value.toLowerCase().trim();return u.filter(r=>r.toLowerCase().includes(g))});return {tempSelected:n,setTempSelected:u=>{n.value=u;},searchText:l,setSearchText:u=>{l.value=u;},debouncedSearchText:i,filteredOptions:m,handleCheckboxChange:(u,g)=>{let r=new Set(n.value);g?r.add(u):r.delete(u),n.value=r;},handleSelectAll:()=>{n.value=new Set(m.value);},handleClearSelection:()=>{n.value=new Set;},handleApplyMultiSelect:()=>{o?.(Array.from(n.value));}}}var Qr=300;function fn(e){let{onUserChange:o,filterType:n}=e,l=ref(null),i,m=ref([]),d=ref(false),a=ref(""),s=c=>{a.value=c;};return watch(e.isFilterOpen,c=>{c&&(a.value="",m.value=[],n==="people"&&setTimeout(()=>l.value?.focus(),50));}),watch([a,()=>e.peopleSearch,e.isFilterOpen],([c,u,g])=>{if(i&&clearTimeout(i),!(!u||!g||n!=="people")){if(!c.trim()){m.value=[];return}d.value=true,i=setTimeout(async()=>{try{let r=await u(c);m.value=r.slice(0,10);}catch{m.value=[];}finally{d.value=false;}},Qr);}}),onUnmounted(()=>{i&&clearTimeout(i);}),{peopleSuggestions:m,isPeopleLoading:d,peopleSearchText:a,setPeopleSearchText:s,peopleInputRef:l,handleUserSelect:c=>{o?.(c);},handleClearUser:()=>{o?.(void 0);}}}function pn(e){let{onDateChange:o}=e,n=ref(e.dateValue?.from??""),l=ref(e.dateValue?.to??"");return watch(e.isFilterOpen,s=>{s&&(n.value=e.dateValue?.from??"",l.value=e.dateValue?.to??"");}),{tempDateFrom:n,setTempDateFrom:s=>{n.value=s;},tempDateTo:l,setTempDateTo:s=>{l.value=s;},handleDateApply:()=>{let s=n.value||void 0,f=l.value||void 0;o?.(s||f?{from:s,to:f}:void 0);},handleDateClear:()=>{n.value="",l.value="";}}}var oa=[];function Ho(e){let{filterType:o,onSort:n}=e,l=()=>e.selectedValues??oa,i=ref(null),m=ref(null),d=ref(false),a=ref(null),s=P=>{d.value=P;},f=dn({textValue:e.textValue,onTextChange:e.onTextChange,isFilterOpen:d}),v=cn({selectedValues:e.selectedValues,onFilterChange:e.onFilterChange,options:e.options,isFilterOpen:d}),c=fn({selectedUser:e.selectedUser,onUserChange:e.onUserChange,peopleSearch:e.peopleSearch,isFilterOpen:d,filterType:o}),u=pn({dateValue:e.dateValue,onDateChange:e.onDateChange,isFilterOpen:d});watch(d,P=>{P||(a.value=null);});let g=null,r=null,p,h=()=>{D(),g=P=>{let C=P.target;m.value&&!m.value.contains(C)&&i.value&&!i.value.contains(C)&&(d.value=false);},r=P=>{(P.key==="Escape"||P.key==="Esc")&&(P.preventDefault(),P.stopPropagation(),d.value=false);},p=setTimeout(()=>{g&&document.addEventListener("mousedown",g);},0),document.addEventListener("keydown",r,true);},D=()=>{p&&clearTimeout(p),g&&document.removeEventListener("mousedown",g),r&&document.removeEventListener("keydown",r,true),g=null,r=null;};watch(d,P=>{P?h():D();}),onUnmounted(()=>D());let I=P=>{if(P.stopPropagation(),P.preventDefault(),!d.value&&i.value){let C=i.value.getBoundingClientRect();a.value={top:C.bottom+4,left:C.left};}d.value=!d.value;},b=P=>{P.stopPropagation(),n?.();},L=()=>{v.handleApplyMultiSelect(),d.value=false;},H=()=>{f.handleTextApply(),d.value=false;},G=P=>{c.handleUserSelect(P),d.value=false;},F=()=>{c.handleClearUser(),d.value=false;},x=()=>{u.handleDateApply(),d.value=false;},T=P=>P.stopPropagation(),M=P=>P.stopPropagation(),k=P=>P.stopPropagation(),y=P=>P.stopPropagation(),w=P=>{P.key!=="Escape"&&P.key!=="Esc"&&P.stopPropagation();},S=computed(()=>o==="multiSelect"?l().length>0:o==="text"?!!(e.textValue??"").trim():o==="people"?!!e.selectedUser:o==="date"?!!(e.dateValue?.from||e.dateValue?.to):false);return {headerRef:i,popoverRef:m,peopleInputRef:c.peopleInputRef,isFilterOpen:d,setFilterOpen:s,tempSelected:v.tempSelected,setTempSelected:v.setTempSelected,tempTextValue:f.tempTextValue,setTempTextValue:f.setTempTextValue,searchText:v.searchText,setSearchText:v.setSearchText,debouncedSearchText:v.debouncedSearchText,filteredOptions:v.filteredOptions,peopleSuggestions:c.peopleSuggestions,isPeopleLoading:c.isPeopleLoading,peopleSearchText:c.peopleSearchText,setPeopleSearchText:c.setPeopleSearchText,tempDateFrom:u.tempDateFrom,setTempDateFrom:u.setTempDateFrom,tempDateTo:u.tempDateTo,setTempDateTo:u.setTempDateTo,hasActiveFilter:S,popoverPosition:a,handlers:{handleFilterIconClick:I,handleApplyMultiSelect:L,handleTextApply:H,handleTextClear:f.handleTextClear,handleUserSelect:G,handleClearUser:F,handleCheckboxChange:v.handleCheckboxChange,handleSelectAll:v.handleSelectAll,handleClearSelection:v.handleClearSelection,handlePopoverClick:T,handleInputFocus:M,handleInputMouseDown:k,handleInputClick:y,handleInputKeyDown:w,handleDateApply:x,handleDateClear:u.handleDateClear,handleSortClick:b}}}function zo(e){let{columns:o,visibleColumns:n,onVisibilityChange:l}=e,i=ref(false),m=null,d=()=>{a(),m=h=>{h.key==="Escape"&&(h.preventDefault(),i.value=false);},document.addEventListener("keydown",m,true);},a=()=>{m&&(document.removeEventListener("keydown",m,true),m=null);};watch(i,h=>{h?d():a();}),onUnmounted(()=>a());let s=h=>{i.value=h;},f=()=>{i.value=!i.value;},v=()=>{i.value=false;},c=h=>D=>{l(h,D);},u=()=>{o.value.forEach(h=>{n.value.has(h.columnId)||l(h.columnId,true);});},g=()=>{o.value.forEach(h=>{!h.required&&n.value.has(h.columnId)&&l(h.columnId,false);});},r=computed(()=>n.value.size),p=computed(()=>o.value.length);return {open:i,setOpen:s,handleToggle:f,handleClose:v,handleCheckboxChange:c,handleSelectAll:u,handleClearAll:g,visibleCount:r,totalCount:p}}function Go(e){let{value:o,editorType:n,onCommit:l,onCancel:i,dateFormat:m,dateEditorType:d}=e,a=m??DEFAULT_DATE_FORMAT,s=ref((()=>{if(o==null)return "";if(n==="date"){if(d==="native"){let p=String(o);return p.match(/^\d{4}-\d{2}-\d{2}/)?p.substring(0,10):p}return formatDateForDisplay(o,a)??""}return String(o)})()),f=p=>{s.value=p;},v=p=>{if(n==="date"&&d!=="native"){if(!p||!p.trim()){l(null);return}let h=parseUserInputDate(p,a);if(h!==null){let D=h.getUTCFullYear().toString().padStart(4,"0"),I=(h.getUTCMonth()+1).toString().padStart(2,"0"),b=h.getUTCDate().toString().padStart(2,"0");l(`${D}-${I}-${b}`);}else l(null);}else l(p);},c=p=>{l(p);},u=()=>{i();};return {localValue:s,setLocalValue:f,handleKeyDown:p=>{p.key==="Escape"&&(p.preventDefault(),p.stopPropagation(),u()),p.key==="Enter"&&(n==="text"||n==="date")&&(p.preventDefault(),p.stopPropagation(),v(s.value));},handleBlur:()=>{(n==="text"||n==="date")&&v(s.value);},commit:c,cancel:u}}function Wo(e){let{values:o,formatValue:n,initialValue:l,onCommit:i,onCancel:m}=e,d=ref(""),a=o.findIndex(r=>String(r)===String(l)),s=ref(Math.max(a,0)),f=r=>{d.value=r;},v=r=>n?n(r):r!=null?String(r):"",c=computed(()=>{if(!d.value.trim())return o;let r=d.value.toLowerCase();return o.filter(p=>v(p).toLowerCase().includes(r))}),u=r=>{i(r);};return {searchText:d,setSearchText:f,filteredValues:c,highlightedIndex:s,handleKeyDown:r=>{switch(r.key){case "ArrowDown":r.preventDefault(),s.value=Math.min(s.value+1,c.value.length-1);break;case "ArrowUp":r.preventDefault(),s.value=Math.max(s.value-1,0);break;case "Enter":r.preventDefault(),r.stopPropagation(),c.value.length>0&&s.value<c.value.length&&u(c.value[s.value]);break;case "Escape":r.preventDefault(),r.stopPropagation(),m();break}},selectValue:u,getDisplayText:v}}var ga=8,Ca=5;function gn(e){let{columnOrder:o,onColumnOrderChange:n,tableRef:l,pinnedColumns:i}=e,m=ref(false),d=ref(null),a=null,s="unpinned",f=0,v=null;return onUnmounted(()=>{v?.(),v=null;}),{isDragging:m,dropIndicatorX:d,handleHeaderMouseDown:(u,g)=>{if(g.button!==0)return;let r=g.target.closest("th");if(r){let T=r.getBoundingClientRect();if(g.clientX>T.right-ga)return}if(g.preventDefault(),!l.value||!n.value)return;a=u,s=getPinStateForColumn(u,i?.value),d.value=null;let h=g.clientX,D=false,I=g.clientX,b=-1,L=document.body.style.cursor,H=document.body.style.userSelect;document.body.style.cursor="grabbing",document.body.style.userSelect="none";let G=T=>{!D&&Math.abs(T.clientX-h)<Ca||(D||(D=true,m.value=true),I=T.clientX,f||(f=requestAnimationFrame(()=>{f=0;let M=l.value;if(!M||!a)return;let k=calculateDropTarget({mouseX:I,columnOrder:o.value,draggedColumnId:a,draggedPinState:s,tableElement:M,pinnedColumns:i?.value});k?(b=k.targetIndex,d.value=k.indicatorX):d.value=null;})));},F=()=>{window.removeEventListener("pointermove",G,true),window.removeEventListener("pointerup",x,true),v=null,document.body.style.cursor=L,document.body.style.userSelect=H,f&&(cancelAnimationFrame(f),f=0);},x=()=>{if(F(),D&&a&&b>=0&&n.value){let T=reorderColumnArray(o.value,a,b);n.value(T);}a=null,m.value=false,d.value=null,b=-1;};window.addEventListener("pointermove",G,true),window.addEventListener("pointerup",x,true),v=F;}}}var Ta=100;function hn(e){let{totalRows:o,rowHeight:n,enabled:l,overscan:i=5,threshold:m=Ta,columnsEnabled:d,columnWidths:a,columnOverscan:s=2}=e;onMounted(()=>{validateVirtualScrollConfig({enabled:l.value,rowHeight:n});});let f=ref(null),v=ref(0),c=ref(0),u=ref(0),g=ref(0),r=0,p,h=null,D=computed(()=>l.value&&o.value>=m),I=computed(()=>D.value?computeVisibleRange(v.value,n,u.value,o.value,i):{startIndex:0,endIndex:Math.max(0,o.value-1),offsetTop:0,offsetBottom:0}),b=computed(()=>l.value?computeTotalHeight(o.value,n):0),L=computed(()=>{if(!d?.value)return null;let x=a?.value;return !x||x.length===0?null:computeVisibleColumnRange(c.value,x,g.value,s)}),H=()=>{r||(r=requestAnimationFrame(()=>{r=0;let x=f.value;x&&(v.value=x.scrollTop,c.value=x.scrollLeft);}));},G=()=>{let x=f.value;x&&(u.value=x.clientHeight,g.value=x.clientWidth);};return watch(f,x=>{x!==h&&(h&&h.removeEventListener("scroll",H),p&&(p.disconnect(),p=void 0),h=x,x&&(x.addEventListener("scroll",H,{passive:true}),typeof ResizeObserver<"u"&&(p=new ResizeObserver(G),p.observe(x)),G(),v.value=x.scrollTop,c.value=x.scrollLeft));}),onUnmounted(()=>{let x=f.value;x&&x.removeEventListener("scroll",H),p?.disconnect(),r&&(cancelAnimationFrame(r),r=0);}),{containerRef:f,visibleRange:I,totalHeight:b,scrollToRow:(x,T="start")=>{let M=f.value;M&&(M.scrollTop=getScrollTopForRow(x,n,u.value,T));},columnRange:L,scrollLeft:c}}function bn(e){let{props:o}=e,n=ref(null),l=ref(null),i=ref(null),m=ref(false),d=an({props:o,wrapperRef:n}),a=computed(()=>{let G=o.value;return G.columnOrder?G.columnOrder:flattenColumns(G.columns).filter(F=>G.visibleColumns?.has(F.columnId)??true).map(F=>F.columnId)}),s=computed(()=>o.value.onColumnOrderChange),f=gn({columnOrder:a,onColumnOrderChange:s,tableRef:i}),v=computed(()=>o.value.virtualScroll?.enabled??false),c=computed(()=>o.value.items.length),u=o.value.virtualScroll?.rowHeight??36,g=o.value.virtualScroll?.overscan??5,r=computed(()=>o.value.virtualScroll?.columns===true),p=o.value.virtualScroll?.columnOverscan??2,h=computed(()=>{let G=d.layout.value,{visibleCols:F,columnSizingOverrides:x}=G,T=o.value.pinnedColumns??{},M=[];for(let k of F){if(T[k.columnId]||k.pinned)continue;let y=x[k.columnId];M.push(y?y.widthPx:k.defaultWidth??k.minWidth??DEFAULT_MIN_COLUMN_WIDTH);}return M}),D=hn({totalRows:c,rowHeight:u,enabled:v,overscan:g,columnsEnabled:r,columnWidths:h,columnOverscan:p}),I=computed(()=>{if(!r.value)return null;let F=d.layout.value.visibleCols,x=D.columnRange.value,T=o.value.pinnedColumns;return partitionColumnsForVirtualization(F,x,T)}),b=computed(()=>{let F=d.layout.value.visibleCols,x=new Map;for(let T=0;T<F.length;T++)x.set(F[T].columnId,T);return x}),L=computed(()=>d.layout.value.columnSizingOverrides),H=sn({columnSizingOverrides:L,setColumnSizingOverrides:G=>d.layout.value.setColumnSizingOverrides(G)});return {wrapperRef:n,tableContainerRef:l,tableRef:i,lastMouseShift:m,state:d,columnReorder:f,virtualScroll:D,virtualScrollEnabled:v,columnResize:H,columnPartition:I,globalColIndexMap:b}}function Sn(e,o,n){let l={"data-row-index":e.rowIndex,"data-col-index":e.globalColIndex,...e.isActive?{"data-active-cell":"true"}:{},...e.isInRange?{"data-in-range":"true"}:{},tabindex:e.isActive?0:-1,onPointerdown:i=>{n.setEditingCell(null),n.handleCellMouseDown(i,e.rowIndex,e.globalColIndex);},onClick:()=>n.setActiveCell({rowIndex:e.rowIndex,columnIndex:e.globalColIndex}),onContextmenu:i=>n.handleCellContextMenu(i)};return e.canEditAny&&(l.role="button",l.onDblclick=()=>n.setEditingCell({rowId:e.rowId,columnId:o})),l}var Ko=()=>{};function Ha(e){return defineComponent({name:"DataGridTable",props:{gridProps:{type:Object,required:true}},setup(o){let n=computed(()=>o.gridProps),{wrapperRef:l,tableContainerRef:i,tableRef:m,lastMouseShift:d,state:a,columnReorder:{isDragging:s,dropIndicatorX:f,handleHeaderMouseDown:v},virtualScroll:{containerRef:c,visibleRange:u,totalHeight:g,scrollToRow:r},virtualScrollEnabled:p,columnResize:{handleResizeStart:h$1,handleResizeDoubleClick:D,getColumnWidth:I},columnPartition:b,globalColIndexMap:L}=bn({props:n}),H=computed(()=>{let S=n.value;return S.showRowNumbers||S.showColumnLetters?((S.currentPage??1)-1)*(S.pageSize??25):0});watch([()=>a.interaction.value.activeCell,H],([S,P])=>{let C=n.value.onActiveCellChange;C&&C(S?formatCellReference(S.columnIndex-a.layout.value.colOffset,P+S.rowIndex+1):null);},{immediate:true});let G=S=>{d.value=S.shiftKey;},F=S=>{S.button===0&&S.preventDefault();},x=S=>{S.button===0&&S.preventDefault();},T=S=>{S.preventDefault();},M=S=>S.preventDefault(),k=S=>S.stopPropagation(),y=computed(()=>buildHeaderRows(n.value.columns,n.value.visibleColumns)),w=computed(()=>{let S=a.layout.value,P=a.pinning.value,{visibleCols:C,columnSizingOverrides:R,measuredColumnWidths:E}=S,{leftOffsets:_,rightOffsets:W}=P,K={},U={},X={},J={};for(let Y=0;Y<C.length;Y++){let q=C[Y],B=q.pinned==="left",Z=q.pinned==="right",ne=I(q),we=!!R[q.columnId],Fe=E[q.columnId],Ke=q.minWidth??estimateHeaderMinWidth(q.name),Pe=we?ne:Math.max(Ke,Fe??0),xe=q.width,Ne={minWidth:`${Pe}px`,width:xe??`${ne}px`,...xe?{}:{maxWidth:`${ne}px`}},He={minWidth:`${Pe}px`,width:xe??`${ne}px`,...xe?{}:{maxWidth:`${ne}px`}},We=["ogrid-data-cell"],$e=["ogrid-header-cell"];B?(We.push("ogrid-data-cell--pinned-left"),Ne.left=`${_[q.columnId]??0}px`,$e.push("ogrid-header-cell--pinned-left"),He.left=`${_[q.columnId]??0}px`):Z&&(We.push("ogrid-data-cell--pinned-right"),Ne.right=`${W[q.columnId]??0}px`,$e.push("ogrid-header-cell--pinned-right"),He.right=`${W[q.columnId]??0}px`),K[q.columnId]=Ne,U[q.columnId]=We.join(" "),X[q.columnId]=He,J[q.columnId]=$e.join(" ");}return {cellStyles:K,cellClasses:U,hdrStyles:X,hdrClasses:J}});return ()=>{let S=o.gridProps,P=a.layout.value,C=a.rowSelection.value,R=a.editing.value,E=a.interaction.value,_=a.contextMenu.value,W=a.viewModels.value,K=a.pinning.value,{headerMenu:U}=K,{visibleCols:X,hasCheckboxCol:J,hasRowNumbersCol:Y,colOffset:q,containerWidth:B,minTableWidth:Z,desiredTableWidth:ne}=P,we=S.currentPage??1,Fe=S.pageSize??25,Ke=Y?(we-1)*Fe:0,{selectedRowIds:Pe,handleRowCheckboxChange:xe,handleSelectAll:Ne,allSelected:He,someSelected:We}=C,{editingCell:$e,setEditingCell:et,pendingEditorValue:tt,setPendingEditorValue:ct,commitCellEdit:Ue,cancelPopoverEdit:mt,popoverAnchorEl:Ie,setPopoverAnchorEl:gt}=R,{setActiveCell:ae,setSelectionRange:Oe,handleCellMouseDown:nt,handleSelectAllCells:ot,selectionRange:Ee,hasCellSelection:lt,handleGridKeyDown:rt,handleFillHandleMouseDown:_e,handleCopy:Ct,handleCut:ht,handlePaste:Ve,cutRange:ft,copyRange:at,canUndo:Rt,canRedo:xt,onUndo:ve,onRedo:bt,isDragging:It}=E,{menuPosition:qe,handleCellContextMenu:St,closeContextMenu:Tt}=_,{headerFilterInput:Pt,cellDescriptorInput:te,statusBarConfig:Q,showEmptyInGrid:re,onCellError:me}=W,se=S.items,Me=S.getRowId,ye=S.layoutMode??"fill",he=S.rowSelection??"none",ge=S.suppressHorizontalScroll,yt=S.stickyHeader??true,Et=S.isLoading??false,Dn=S.loadingMessage??"Loading\u2026",Fn=S["aria-label"],ke=S["aria-labelledby"],Un=ye==="content",Dt=!ge&&B>0&&(Z>B||ne>B),ze=y.value,Ft={commitCellEdit:Ue,setEditingCell:et,setPendingEditorValue:ct,cancelPopoverEdit:mt},On={handleCellMouseDown:nt,setActiveCell:ae,setEditingCell:et,handleCellContextMenu:St},Mn=A=>{if(he!=="single")return;let ie=A.currentTarget.dataset.rowId;ie&&C.updateSelection(Pe.has(ie)?new Set:new Set([ie]));},t=(A,V,ie,Le)=>{try{return O(A,V,ie,Le)}catch(N){return me&&me(N instanceof Error?N:new Error(String(N)),void 0),""}},O=(A,V,ie,Le)=>{let N=getCellRenderDescriptor(A,V,ie,Le,te);if(N.mode==="editing-inline"){let ue=buildInlineEditorProps(A,V,N,Ft);return h("div",{class:"ogrid-editing-cell"},h(e.InlineCellEditor,{value:ue.value,item:ue.item,column:ue.column,rowIndex:ue.rowIndex,editorType:ue.editorType,onCommit:ue.onCommit,onCancel:ue.onCancel}))}if(N.mode==="editing-popover"&&V.cellEditor!=null&&typeof V.cellEditor!="string"){let ue=buildPopoverEditorProps(A,V,N,tt,Ft),oe=V.cellEditor,Bt=resolveCellDisplayContent(V,A,N.displayValue),to=resolveCellStyle(V,A,N.displayValue);return h("div",[h("div",{ref:no=>{no&&gt(no);},class:"ogrid-popover-anchor"},[to?h("span",{style:to},[Bt]):Bt]),Ie?h(oe,ue):null])}let Be=Sn(N,V.columnId,On),Te=["ogrid-cell-content"];V.type==="numeric"?Te.push("ogrid-cell-content--numeric"):V.type==="boolean"&&Te.push("ogrid-cell-content--boolean"),N.canEditAny&&Te.push("ogrid-cell-content--editable"),N.isActive&&Te.push("ogrid-cell-content--active"),N.isActive&&N.isInRange&&Te.push("ogrid-cell-content--active-in-range"),N.isInRange&&!N.isActive&&Te.push("ogrid-cell-in-range"),N.isInCutRange&&Te.push("ogrid-cell-cut");let Ye;if(N.columnType==="boolean"){let ue=!!N.displayValue;Ye=h("input",{type:"checkbox",checked:ue,disabled:!N.canEditAny,onChange:N.canEditAny?()=>{let oe=N.rowIndex,Bt=N.globalColIndex;Ft.commitCellEdit(A,V.columnId,ue,!ue,oe,Bt,{skipAdvance:true});}:void 0,onPointerdown:oe=>handleBooleanCellPointerDown(oe,N.rowIndex,N.globalColIndex,q,{setActiveCell:ae,setSelectionRange:Oe}),onClick:oe=>oe.stopPropagation(),style:`margin:0;cursor:${N.canEditAny?"pointer":"default"};outline:none`,"aria-label":ue?"Checked":"Unchecked"});}else {let ue=resolveCellDisplayContent(V,A,N.displayValue),oe=resolveCellStyle(V,A,N.displayValue);Ye=oe?h("span",{style:oe},ue):ue;}return h("div",{...Be,class:Te.join(" ")},[Ye,...N.canEditAny&&N.isSelectionEndCell?[h("div",{onPointerdown:_e,"aria-label":"Fill handle",class:"ogrid-fill-handle"})]:[]])},{cellStyles:le,cellClasses:Re,hdrStyles:it,hdrClasses:st}=w.value,Xe=X.map(A=>({col:A,tdClasses:Re[A.columnId]||"ogrid-data-cell",tdDynamicStyle:le[A.columnId]||{}})),fe=b.value,pt=Xe,je=0,Ce=0;if(fe){let A=new Set;for(let V of fe.pinnedLeft)A.add(V.columnId);for(let V of fe.virtualizedUnpinned)A.add(V.columnId);for(let V of fe.pinnedRight)A.add(V.columnId);pt=Xe.filter(V=>A.has(V.col.columnId)),je=fe.leftSpacerWidth,Ce=fe.rightSpacerWidth;}let be=L.value,Ae=A=>{let V=it[A.columnId]||{};return {classes:st[A.columnId]||"ogrid-header-cell",style:{...V,cursor:s.value?"grabbing":"grab"}}},pe=p.value,De={position:"relative",width:Un?"fit-content":"100%",maxWidth:"100%",overflowX:ge?"hidden":Dt?"auto":"hidden",overflowY:"auto",backgroundColor:"#fff",willChange:"scroll-position",...pe?{flex:"1",minHeight:"0"}:{minHeight:Et&&se.length===0?"200px":"auto"}};return S.rowHeight&&(De["--ogrid-row-height"]=`${S.rowHeight}px`),h("div",{class:"ogrid-outer-container"},[h("div",{ref:A=>{l.value=A,c.value=A;},tabindex:0,role:"region","aria-label":Fn??(ke?void 0:"Data grid"),"aria-labelledby":ke,onPointerdown:G,onKeydown:rt,onContextmenu:M,"data-overflow-x":Dt?"true":"false","data-ogrid-scroll-container":"",style:De},[h("div",{class:"ogrid-scroll-wrapper"},[h("div",{style:{minWidth:Dt?`${Z}px`:void 0,overflowX:"clip"}},[h("div",{ref:A=>{i.value=A;},class:["ogrid-table-container",Et&&se.length>0?"ogrid-table-container--loading":""]},[...s.value&&f.value!==null?[h("div",{class:"ogrid-drop-indicator",style:{left:`${f.value}px`}})]:[],h("table",{ref:A=>{m.value=A;},class:"ogrid-table",role:"grid",style:{minWidth:`${Z}px`},...p.value?{"data-virtual-scroll":""}:{}},[h("thead",{class:yt?"ogrid-thead ogrid-sticky-header":"ogrid-thead"},[...S.showColumnLetters?[h("tr",{class:"ogrid-column-letter-row"},[...J?[h("th",{class:"ogrid-column-letter-cell"})]:[],...Y?[h("th",{class:"ogrid-column-letter-cell"})]:[],...X.map((A,V)=>{let{classes:ie,style:Le}=Ae(A);return h("th",{key:A.columnId,class:`ogrid-column-letter-cell ${ie}`,style:Le},indexToColumnLetter(V))})])]:[],...ze.map((A,V)=>h("tr",{key:V,class:"ogrid-header-row"},[...V===ze.length-1&&J?[h("th",{class:"ogrid-checkbox-header",style:{width:`${CHECKBOX_COLUMN_WIDTH}px`,minWidth:`${CHECKBOX_COLUMN_WIDTH}px`,maxWidth:`${CHECKBOX_COLUMN_WIDTH}px`}},e.renderCheckbox({modelValue:He,indeterminate:We&&!He,ariaLabel:"Select all rows",onChange:ie=>Ne(!!ie)}))]:[],...V===0&&V<ze.length-1&&J?[h("th",{rowSpan:ze.length-1,class:"ogrid-checkbox-spacer",style:{width:`${CHECKBOX_COLUMN_WIDTH}px`,minWidth:`${CHECKBOX_COLUMN_WIDTH}px`}})]:[],...V===ze.length-1&&Y?[(()=>{let ie=P.columnSizingOverrides[ROW_NUMBER_COLUMN_ID]?.widthPx??ROW_NUMBER_COLUMN_WIDTH;return h("th",{class:"ogrid-row-number-header",style:{width:`${ie}px`,minWidth:`${ie}px`,maxWidth:`${ie}px`,position:"sticky",left:J?`${CHECKBOX_COLUMN_WIDTH}px`:"0",zIndex:3},onPointerdown:F,onMousedown:x,onSelectstart:T},["#",h("div",{onPointerdown:Le=>{ae(null),Oe(null),l.value?.focus({preventScroll:true}),Le.stopPropagation(),h$1(Le,{columnId:ROW_NUMBER_COLUMN_ID,name:"#"});},class:"ogrid-resize-handle",role:"separator","aria-label":"Resize row numbers"})])})()]:[],...V===0&&V<ze.length-1&&Y?[(()=>{let ie=P.columnSizingOverrides[ROW_NUMBER_COLUMN_ID]?.widthPx??ROW_NUMBER_COLUMN_WIDTH;return h("th",{rowSpan:ze.length-1,class:"ogrid-row-number-spacer",style:{width:`${ie}px`,position:"sticky",left:J?`${CHECKBOX_COLUMN_WIDTH}px`:"0",zIndex:3}})})()]:[],...A.map((ie,Le)=>{if(ie.isGroup)return h("th",{key:Le,colSpan:ie.colSpan,scope:"colgroup",class:"ogrid-column-group-header"},ie.label);if(!ie.columnDef)return null;let N=ie.columnDef,{classes:Be,style:Te}=Ae(N),ue=S.sortBy===N.columnId?S.sortDirection==="asc"?"ascending":"descending":void 0;return h("th",{key:N.columnId,scope:"col","data-column-id":N.columnId,rowSpan:ze.length>1?ze.length-V:void 0,class:Be,style:Te,"aria-sort":ue,onPointerdown:oe=>v(N.columnId,oe)},[h("div",{class:"ogrid-header-content"},[h(e.ColumnHeaderFilter,getHeaderFilterConfig(N,Pt)),h("button",{onClick:oe=>{oe.stopPropagation(),U.isOpen&&U.openForColumn===N.columnId?U.close():U.open(N.columnId,oe.currentTarget);},"aria-label":"Column options",title:"Column options",class:"ogrid-column-menu-btn"},"\u22EE")]),h("div",{onPointerdown:oe=>{ae(null),Oe(null),l.value?.focus({preventScroll:true}),oe.stopPropagation(),h$1(oe,N);},onDblclick:oe=>D(oe,N),class:"ogrid-resize-handle",role:"separator","aria-label":`Resize ${N.name??N.columnId}`})])})]))]),...re?[]:[h("tbody",{},(()=>{let A=p.value,V=u.value,ie=A?V.startIndex:0,Le=A?Math.min(V.endIndex,se.length-1):se.length-1,N=[];A&&V.offsetTop>0&&N.push(h("tr",{key:"__vs-top",style:{height:`${V.offsetTop}px`}}));for(let Be=ie;Be<=Le;Be++){let Te=se[Be];if(!Te)continue;let Ye=Me(Te),ue=Pe.has(Ye);N.push(h("tr",{key:Ye,"data-row-id":Ye,"aria-selected":ue||void 0,onClick:Mn,style:{cursor:he==="single"?"pointer":void 0}},[...J?[h("td",{class:"ogrid-checkbox-cell",style:{width:`${CHECKBOX_COLUMN_WIDTH}px`,minWidth:`${CHECKBOX_COLUMN_WIDTH}px`,maxWidth:`${CHECKBOX_COLUMN_WIDTH}px`}},h("div",{"data-row-index":Be,"data-col-index":0,onClick:k,class:"ogrid-checkbox-wrapper"},e.renderCheckbox({modelValue:ue,ariaLabel:`Select row ${Be+1}`,onChange:oe=>xe(Ye,oe,Be,d.value)})))]:[],...Y?[(()=>{let oe=P.columnSizingOverrides[ROW_NUMBER_COLUMN_ID]?.widthPx??ROW_NUMBER_COLUMN_WIDTH;return h("td",{class:"ogrid-row-number-cell",style:{width:`${oe}px`,minWidth:`${oe}px`,maxWidth:`${oe}px`,padding:"6px",position:"sticky",left:J?`${CHECKBOX_COLUMN_WIDTH}px`:"0",zIndex:2,userSelect:"none",WebkitUserSelect:"none"},onPointerdown:F,onMousedown:x,onSelectstart:T},String(Ke+Be+1))})()]:[],...je>0?[h("td",{key:"__col-spacer-left",style:{width:`${je}px`,minWidth:`${je}px`,maxWidth:`${je}px`,padding:"0"}})]:[],...pt.map(oe=>h("td",{key:oe.col.columnId,"data-column-id":oe.col.columnId,class:oe.tdClasses,style:{...oe.tdDynamicStyle,userSelect:"none",WebkitUserSelect:"none"},onPointerdown:F,onMousedown:x,onSelectstart:T},[t(Te,oe.col,Be,be.get(oe.col.columnId)??0)])),...Ce>0?[h("td",{key:"__col-spacer-right",style:{width:`${Ce}px`,minWidth:`${Ce}px`,maxWidth:`${Ce}px`,padding:"0"}})]:[]]));}return A&&V.offsetBottom>0&&N.push(h("tr",{key:"__vs-bottom",style:{height:`${V.offsetBottom}px`}})),N})())]]),...re&&S.emptyState?[e.renderEmptyState(S.emptyState)]:[]])])])]),...qe?[h(Teleport,{to:"body"},h(e.GridContextMenu,{x:qe.x,y:qe.y,hasSelection:lt,canUndo:Rt,canRedo:xt,onUndo:ve??Ko,onRedo:bt??Ko,onCopy:Ct,onCut:ht,onPaste:()=>{Ve();},onSelectAll:ot,onClose:Tt}))]:[],h(An,{containerRef:i,selectionRange:Ee,copyRange:at,cutRange:ft,colOffset:q,items:se,visibleColumns:S.visibleColumns instanceof Set?Array.from(S.visibleColumns):S.visibleColumns,columnSizingOverrides:P.columnSizingOverrides,columnOrder:S.columnOrder}),...S.formulaReferences&&S.formulaReferences.length>0?[h(zn,{containerEl:i.value,references:S.formulaReferences,colOffset:q})]:[],h(e.ColumnHeaderMenu,{isOpen:U.isOpen,anchorElement:U.anchorElement,onClose:U.close,onPinLeft:U.handlePinLeft,onPinRight:U.handlePinRight,onUnpin:U.handleUnpin,onSortAsc:U.handleSortAsc,onSortDesc:U.handleSortDesc,onClearSort:U.handleClearSort,onAutosizeThis:U.handleAutosizeThis,onAutosizeAll:U.handleAutosizeAll,canPinLeft:U.canPinLeft,canPinRight:U.canPinRight,canUnpin:U.canUnpin,currentSort:U.currentSort,isSortable:U.isSortable,isResizable:U.isResizable}),...Q?[h(Ln,{totalCount:Q.totalCount,filteredCount:Q.filteredCount,selectedCount:Q.selectedCount??Pe.size,selectedCellCount:Ee?(Math.abs(Ee.endRow-Ee.startRow)+1)*(Math.abs(Ee.endCol-Ee.startCol)+1):void 0,aggregation:Q.aggregation,suppressRowCount:Q.suppressRowCount})]:[],...Et?[h("div",{class:"ogrid-loading-overlay"},e.renderSpinner(Dn))]:[]])}}})}var wt={width:"100%",height:"100%",display:"flex",alignItems:"center",paddingTop:"var(--ogrid-cell-padding-vertical, 6px)",paddingBottom:"var(--ogrid-cell-padding-vertical, 6px)",paddingLeft:"var(--ogrid-cell-padding-horizontal, 10px)",paddingRight:"var(--ogrid-cell-padding-horizontal, 10px)",boxSizing:"border-box",overflow:"hidden",minWidth:"0"};function qa(e){let{renderCheckbox:o}=e;return defineComponent({name:"InlineCellEditor",props:{value:{default:void 0},item:{type:Object,required:true},column:{type:Object,required:true},rowIndex:{type:Number,required:true},editorType:{type:String,required:true},onCommit:{type:Function,required:true},onCancel:{type:Function,required:true}},setup(n){let l=ref(null),i=ref(null),m=ref(null),d=ref(n.value),a=ref(0),s=ref(false),f=y=>{d.value=y.target.value;},v=y=>y?.target?.value??String(d.value??""),c=y=>{if(n.editorType==="date"){let w=n.column.cellEditorParams?.dateFormat??n.column.dateFormat??DEFAULT_DATE_FORMAT;if((n.column.cellEditorParams?.editorType??"text")==="native"){if(y==null){d.value="";return}let P=String(y);d.value=P.match(/^\d{4}-\d{2}-\d{2}/)?P.substring(0,10):P;return}d.value=formatDateForDisplay(y,w)??"";return}d.value=y;};c(n.value);let u=y=>{s.value=true,n.onCommit(y);},g=()=>{s.value=true,n.onCancel();},r=()=>s.value?(s.value=false,true):false,p=()=>{let y=i.value,w=m.value;if(!y||!w)return;let S=y.getBoundingClientRect(),P=200,C=window.innerHeight-S.bottom,R=C<P&&S.top>C;w.style.position="fixed",w.style.left=`${S.left}px`,w.style.width=`${S.width}px`,w.style.maxHeight=`${P}px`,w.style.zIndex="9999",w.style.right="auto",w.style.textAlign="left",R?(w.style.top="auto",w.style.bottom=`${window.innerHeight-S.top}px`):w.style.top=`${S.bottom}px`;},h$1=null,D=null;onMounted(()=>{let y=w=>{w.key==="Escape"&&(w.preventDefault(),w.stopPropagation(),g());};document.addEventListener("keydown",y,true),D=()=>{document.removeEventListener("keydown",y,true);},nextTick(()=>{if(i.value){n.editorType==="richSelect"&&F.value?F.value.focus({preventScroll:true}):i.value.focus({preventScroll:true}),p();let w=i.value,S=w.closest("[data-ogrid-scroll-container]")??w.closest('[style*="overflow"]'),P=()=>{n.onCancel&&n.onCancel();},C=requestAnimationFrame(()=>{S&&S.addEventListener("scroll",P,{passive:true}),window.addEventListener("scroll",P,{passive:true});});h$1=()=>{cancelAnimationFrame(C),S&&S.removeEventListener("scroll",P),window.removeEventListener("scroll",P);};return}l.value?.focus({preventScroll:true}),l.value?.select();});}),onUnmounted(()=>{h$1?.(),D?.();}),watch(()=>n.value,c),(()=>{let w=(n.column.cellEditorParams?.values??[]).findIndex(S=>String(S)===String(n.value));a.value=Math.max(w,0);})();let b=()=>{nextTick(()=>{let y=m.value;if(!y)return;y.children[a.value]?.scrollIntoView({block:"nearest"});});},L=y=>{let w=n.column.cellEditorParams?.formatValue;return w?w(y):y!=null?String(y):""},H=y=>{let w=n.column.cellEditorParams?.values??[];switch(y.key){case "ArrowDown":y.preventDefault(),a.value=Math.min(a.value+1,w.length-1),b();break;case "ArrowUp":y.preventDefault(),a.value=Math.max(a.value-1,0),b();break;case "Enter":y.preventDefault(),y.stopPropagation(),w.length>0&&a.value<w.length&&u(w[a.value]);break;case "Tab":y.preventDefault(),w.length>0&&a.value<w.length&&u(w[a.value]);break;case "Escape":y.preventDefault(),y.stopPropagation(),g();break}},G=ref(""),F=ref(null),x=ref(null),T=computed(()=>{let y=n.column.cellEditorParams?.values??[],w=G.value.trim().toLowerCase();return w?y.filter(S=>L(S).toLowerCase().includes(w)):y}),M=()=>{nextTick(()=>{let y=x.value;if(!y)return;y.children[a.value]?.scrollIntoView({block:"nearest"});});},k=y=>{let w=T.value;switch(y.key){case "ArrowDown":y.preventDefault(),a.value=Math.min(a.value+1,w.length-1),M();break;case "ArrowUp":y.preventDefault(),a.value=Math.max(a.value-1,0),M();break;case "Enter":y.preventDefault(),y.stopPropagation(),w.length>0&&a.value<w.length&&u(w[a.value]);break;case "Escape":y.preventDefault(),y.stopPropagation(),g();break}};return ()=>{if(n.editorType==="checkbox"){let y=!!n.value;return h("div",{style:{...wt,justifyContent:"center"}},o({checked:y,onChange:w=>u(w),onCancel:g}))}if(n.editorType==="select"){let y=n.column.cellEditorParams?.values??[];return h("div",{ref:w=>{i.value=w;},tabindex:0,style:{...wt,position:"relative"},onKeydown:H},[h("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",width:"100%",cursor:"pointer",fontSize:"13px",color:"inherit"}},[h("span",L(n.value)),h("span",{style:{marginLeft:"4px",fontSize:"10px",opacity:"0.5"}},"\u25BE")]),h("div",{ref:w=>{m.value=w;},role:"listbox",style:{position:"absolute",top:"100%",left:"0",right:"0",maxHeight:"200px",overflowY:"auto",background:"var(--ogrid-bg, #fff)",border:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",zIndex:"10",boxShadow:"0 4px 16px rgba(0,0,0,0.2)",textAlign:"left",fontSize:"13px",fontFamily:"inherit"}},[...y.map((w,S)=>h("div",{key:String(w),role:"option","aria-selected":S===a.value,onClick:()=>u(w),style:{padding:"6px 8px",cursor:"pointer",color:"var(--ogrid-fg, #242424)",fontSize:"13px",...S===a.value?{background:"var(--ogrid-bg-hover, #e8f0fe)"}:{}}},L(w)))])])}if(n.editorType==="richSelect"){let y=T.value;return h("div",{ref:w=>{i.value=w;},style:{...wt,position:"relative"}},[h("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",width:"100%",cursor:"pointer",fontSize:"13px",color:"inherit"}},[h("span",L(n.value)),h("span",{style:{marginLeft:"4px",fontSize:"10px",opacity:"0.5"}},"\u25BE")]),h("div",{ref:w=>{m.value=w;},role:"listbox",style:{position:"absolute",top:"100%",left:"0",right:"0",maxHeight:"200px",overflowY:"auto",background:"var(--ogrid-bg, #fff)",border:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",zIndex:"10",boxShadow:"0 4px 16px rgba(0,0,0,0.2)",textAlign:"left",fontSize:"13px",fontFamily:"inherit"}},[h("input",{ref:w=>{F.value=w;},type:"text",value:G.value,placeholder:"Search...",onInput:w=>{G.value=w.target.value,a.value=0;},onKeydown:k,style:{width:"100%",padding:"6px 8px",border:"none",borderBottom:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",background:"var(--ogrid-bg, #fff)",color:"inherit",font:"inherit",fontSize:"13px",outline:"none",boxSizing:"border-box",position:"sticky",top:"0",zIndex:"1"}}),h("div",{ref:w=>{x.value=w;}},y.map((w,S)=>h("div",{key:String(w),role:"option","aria-selected":S===a.value,onClick:()=>u(w),style:{padding:"6px 8px",cursor:"pointer",color:"var(--ogrid-fg, #242424)",fontSize:"13px",...S===a.value?{background:"var(--ogrid-bg-hover, #e8f0fe)"}:{}}},L(w)))),...y.length===0?[h("div",{style:{padding:"6px 8px",color:"var(--ogrid-muted, #999)",fontSize:"13px"}},"No matches")]:[]])])}if(n.editorType==="date"){let y=n.column.cellEditorParams?.dateFormat??n.column.dateFormat??DEFAULT_DATE_FORMAT,w=n.column.cellEditorParams?.editorType??"text",S=R=>{if(w!=="native"){let E=parseUserInputDate(R,y);if(E!==null){let _=E.getUTCFullYear().toString().padStart(4,"0"),W=(E.getUTCMonth()+1).toString().padStart(2,"0"),K=E.getUTCDate().toString().padStart(2,"0");u(`${_}-${W}-${K}`);}else u(R||null);}else u(R);},P=R=>{R.stopPropagation(),R.key==="Enter"&&(R.preventDefault(),S(v(R))),R.key==="Escape"&&(R.preventDefault(),g()),R.key==="Tab"&&(R.preventDefault(),S(v(R)));};if(w==="native"){let R=(()=>{if(d.value==null)return "";let E=String(d.value);return E.match(/^\d{4}-\d{2}-\d{2}/)?E.substring(0,10):E})();return h("div",{style:wt},h("input",{ref:E=>{l.value=E;},type:"date",value:R,style:{width:"100%",height:"100%",border:"none",outline:"none",padding:"0 4px",fontSize:"inherit",boxSizing:"border-box"},onInput:f,onChange:f,onKeyup:f,onKeydown:P,onBlur:E=>{r()||S(v(E));}}))}let C=getDateInputPlaceholder(y);return h("div",{style:wt},h("input",{ref:R=>{l.value=R;},type:"text",value:String(d.value??""),placeholder:C,style:{width:"100%",height:"100%",border:"none",outline:"none",padding:"0 4px",fontSize:"inherit",boxSizing:"border-box"},onInput:f,onChange:f,onKeyup:f,onKeydown:P,onBlur:R=>{r()||S(v(R));}}))}return h("div",{style:wt},h("input",{ref:y=>{l.value=y;},type:"text",value:d.value!=null?String(d.value):"",style:{width:"100%",height:"100%",border:"none",outline:"none",padding:"0 4px",fontSize:"inherit",boxSizing:"border-box"},onInput:f,onChange:f,onKeyup:f,onKeydown:y=>{y.stopPropagation(),y.key==="Enter"&&(y.preventDefault(),u(v(y))),y.key==="Escape"&&(y.preventDefault(),g()),y.key==="Tab"&&(y.preventDefault(),u(v(y)));},onBlur:y=>{r()||u(v(y));}}))}}})}var Qa=240,eo=36,En={columns:"Columns",filters:"Filters"},ei={columns:"\u2261",filters:"\u2A65"};function qo(e){let o=e.activePanel!==null,n=e.position??"right",l={display:"flex",flexDirection:"column",width:`${eo}px`,background:"var(--ogrid-header-bg, #f5f5f5)",...n==="right"?{borderLeft:"1px solid var(--ogrid-border, #e0e0e0)"}:{borderRight:"1px solid var(--ogrid-border, #e0e0e0)"}},i=h("div",{style:l,role:"tablist","aria-label":"Side bar tabs"},e.panels.map(a=>h("button",{key:a,role:"tab","aria-selected":e.activePanel===a,"aria-label":En[a],title:En[a],onClick:()=>e.onPanelChange(e.activePanel===a?null:a),style:{width:`${eo}px`,height:`${eo}px`,border:"none",cursor:"pointer",color:"var(--ogrid-fg, #242424)",fontSize:"14px",display:"flex",alignItems:"center",justifyContent:"center",background:e.activePanel===a?"var(--ogrid-bg, #fff)":"transparent",fontWeight:e.activePanel===a?"bold":"normal"}},ei[a]))),m=null;if(o&&e.activePanel){let a={width:`${Qa}px`,display:"flex",flexDirection:"column",overflow:"hidden",background:"var(--ogrid-bg, #fff)",color:"var(--ogrid-fg, #242424)",...n==="right"?{borderLeft:"1px solid var(--ogrid-border, #e0e0e0)"}:{borderRight:"1px solid var(--ogrid-border, #e0e0e0)"}},s=[];if(e.activePanel==="columns"){let f=e.columns.every(v=>e.visibleColumns.has(v.columnId));s.push(h("div",{style:{display:"flex",gap:"8px",marginBottom:"8px"}},[h("button",{disabled:f,onClick:()=>{let v=new Set(e.visibleColumns);e.columns.forEach(c=>v.add(c.columnId)),e.onSetVisibleColumns(v);},style:{flex:"1",cursor:"pointer",background:"var(--ogrid-bg-subtle, #f3f2f1)",color:"var(--ogrid-fg, #242424)",border:"1px solid var(--ogrid-border, #e0e0e0)",borderRadius:"4px",padding:"4px 8px"}},"Select All"),h("button",{onClick:()=>{let v=new Set;e.columns.forEach(c=>{c.required&&e.visibleColumns.has(c.columnId)&&v.add(c.columnId);}),e.onSetVisibleColumns(v);},style:{flex:"1",cursor:"pointer",background:"var(--ogrid-bg-subtle, #f3f2f1)",color:"var(--ogrid-fg, #242424)",border:"1px solid var(--ogrid-border, #e0e0e0)",borderRadius:"4px",padding:"4px 8px"}},"Clear All")])),e.columns.forEach(v=>{s.push(h("label",{key:v.columnId,style:{display:"flex",alignItems:"center",gap:"6px",padding:"2px 0",cursor:"pointer"}},[h("input",{type:"checkbox",checked:e.visibleColumns.has(v.columnId),disabled:v.required,onChange:c=>e.onVisibilityChange(v.columnId,c.target.checked)}),h("span",null,v.name)]));});}e.activePanel==="filters"&&(e.filterableColumns.length===0?s.push(h("div",{style:{color:"var(--ogrid-muted, #999)",fontStyle:"italic"}},"No filterable columns")):e.filterableColumns.forEach(f=>{let v=f.filterField,c=[h("div",{style:{fontWeight:"500",marginBottom:"4px",fontSize:"13px"}},f.name)];if(f.filterType==="text"){let u=e.filters[v],g=u?.type==="text"?u.value:"";c.push(h("input",{type:"text",value:g,onInput:r=>{let p=r.target.value;e.onFilterChange(v,p?{type:"text",value:p}:void 0);},placeholder:`Filter ${f.name}...`,"aria-label":`Filter ${f.name}`,style:{width:"100%",boxSizing:"border-box",padding:"4px 6px",background:"var(--ogrid-bg, #fff)",color:"var(--ogrid-fg, #242424)",border:"1px solid var(--ogrid-border, #e0e0e0)",borderRadius:"4px"}}));}if(f.filterType==="multiSelect"){let g=(e.filterOptions[v]??[]).map(r=>{let p=e.filters[v],h$1=p?.type==="multiSelect"?p.value.includes(r):false;return h("label",{key:r,style:{display:"flex",alignItems:"center",gap:"4px",padding:"1px 0",cursor:"pointer",fontSize:"13px"}},[h("input",{type:"checkbox",checked:h$1,onChange:D=>{let I=e.filters[v],b=I?.type==="multiSelect"?I.value:[],L=D.target.checked?[...b,r]:b.filter(H=>H!==r);e.onFilterChange(v,L.length>0?{type:"multiSelect",value:L}:void 0);}}),h("span",null,r)])});c.push(h("div",{style:{maxHeight:"120px",overflowY:"auto"},role:"group","aria-label":`${f.name} options`},g));}if(f.filterType==="date"){let u=e.filters[v],g=u?.type==="date"?u.value:{from:void 0,to:void 0};c.push(h("div",{style:{display:"flex",flexDirection:"column",gap:"4px"}},[h("label",{style:{display:"flex",alignItems:"center",gap:"4px",fontSize:"12px"}},["From:",h("input",{type:"date",value:g.from??"",onInput:r=>{let p=r.target.value||void 0,h=g.to;e.onFilterChange(v,p||h?{type:"date",value:{from:p,to:h}}:void 0);},"aria-label":`${f.name} from date`,style:{flex:"1",padding:"2px 4px",background:"var(--ogrid-bg, #fff)",color:"var(--ogrid-fg, #242424)",border:"1px solid var(--ogrid-border, #e0e0e0)",borderRadius:"4px"}})]),h("label",{style:{display:"flex",alignItems:"center",gap:"4px",fontSize:"12px"}},["To:",h("input",{type:"date",value:g.to??"",onInput:r=>{let p=r.target.value||void 0,h=g.from;e.onFilterChange(v,h||p?{type:"date",value:{from:h,to:p}}:void 0);},"aria-label":`${f.name} to date`,style:{flex:"1",padding:"2px 4px",background:"var(--ogrid-bg, #fff)",color:"var(--ogrid-fg, #242424)",border:"1px solid var(--ogrid-border, #e0e0e0)",borderRadius:"4px"}})])]));}s.push(h("div",{key:f.columnId,style:{marginBottom:"12px"}},c));})),m=h("div",{role:"tabpanel","aria-label":En[e.activePanel],style:a},[h("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",padding:"8px 12px",borderBottom:"1px solid var(--ogrid-border, #e0e0e0)",fontWeight:"600"}},[h("span",null,En[e.activePanel]),h("button",{onClick:()=>e.onPanelChange(null),style:{border:"none",background:"transparent",cursor:"pointer",fontSize:"16px",color:"var(--ogrid-fg, #242424)"},"aria-label":"Close panel"},"\xD7")]),h("div",{style:{flex:"1",overflowY:"auto",padding:"8px 12px"}},s)]);}let d=[];return n==="left"?(d.push(i),m&&d.push(m)):(m&&d.push(m),d.push(i)),h("div",{style:{display:"flex",flexDirection:"row",flexShrink:"0"},role:"complementary","aria-label":"Side bar"},d)}function ti(e){return defineComponent({name:"OGrid",props:{gridProps:{type:Object,required:true}},setup(o,{expose:n}){let l=computed(()=>o.gridProps),{dataGridProps:i,pagination:m,columnChooser:d,layout:a,api:s}=_t(l);n({api:s});let f=ref(false),v=()=>{f.value=!f.value;},c=u=>{u.key==="Escape"&&f.value&&(f.value=false);};return onMounted(()=>{document.addEventListener("keydown",c);}),onUnmounted(()=>{document.removeEventListener("keydown",c);}),()=>{let u=a.value.sideBarProps,g=u!=null,r=u?.position??"right",p=[];a.value.toolbar&&p.push(a.value.toolbar);let D=a.value.fullScreen===true?h("button",{type:"button",title:f.value?"Exit fullscreen":"Fullscreen","aria-label":f.value?"Exit fullscreen":"Fullscreen",onClick:v,style:{background:"none",border:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",borderRadius:"4px",padding:"4px 6px",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",color:"var(--ogrid-fg, rgba(0,0,0,0.87))"}},[f.value?h("svg",{width:16,height:16,viewBox:"0 0 16 16",fill:"none",stroke:"currentColor","stroke-width":"1.5","stroke-linecap":"round","stroke-linejoin":"round",innerHTML:'<polyline points="4 10 0 10 0 14"/><polyline points="12 6 16 6 16 2"/><line x1="0" y1="10" x2="4" y2="6"/><line x1="16" y1="6" x2="12" y2="10"/>'}):h("svg",{width:16,height:16,viewBox:"0 0 16 16",fill:"none",stroke:"currentColor","stroke-width":"1.5","stroke-linecap":"round","stroke-linejoin":"round",innerHTML:'<polyline points="10 2 14 2 14 6"/><polyline points="6 14 2 14 2 10"/><line x1="14" y1="2" x2="10" y2="6"/><line x1="2" y1="14" x2="6" y2="10"/>'})]):null,I=d.value.placement==="toolbar"?h(e.ColumnChooser,{columns:d.value.columns,visibleColumns:d.value.visibleColumns,onVisibilityChange:d.value.onVisibilityChange}):null,b=h(e.PaginationControls,{currentPage:m.value.page,pageSize:m.value.pageSize,totalCount:m.value.displayTotalCount,onPageChange:m.value.setPage,onPageSizeChange:T=>{m.value.setPageSize(T);},pageSizeOptions:m.value.pageSizeOptions,entityLabelPlural:m.value.entityLabelPlural}),L=h("div",{style:{flex:"1",minWidth:"0",minHeight:"0",display:"flex",flexDirection:"column"}},[h(e.DataGridTable,{gridProps:i.value})]),H=[];g&&r==="left"&&H.push(qo(u)),H.push(L),g&&r!=="left"&&H.push(qo(u));let G=p.length>0||I!=null||D!=null,F=f.value?{position:"fixed",inset:"0",zIndex:9999,display:"flex",flexDirection:"column",background:"var(--ogrid-bg, #fff)"}:{display:"flex",flexDirection:"column",border:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",borderRadius:"4px",overflow:"hidden"},x=f.value?{display:"flex",flexDirection:"column",flex:"1",minHeight:"0",overflow:"hidden",background:"var(--ogrid-bg, #fff)"}:void 0;return h("div",{class:a.value.className,style:F},[h("div",{style:x??{}},[...G?[h("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"8px 12px",borderBottom:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",gap:"8px"}},[h("div",{style:{display:"flex",alignItems:"center",gap:"8px",flex:"1"}},p),h("div",{style:{display:"flex",alignItems:"center",gap:"8px"}},[...I?[I]:[],...D?[D]:[]])])]:[],...a.value.toolbarBelow?[h("div",{style:{padding:"8px 12px",borderBottom:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))"}},[a.value.toolbarBelow])]:[],...a.value.formulaBar?[a.value.formulaBar]:[],h("div",{style:{display:"flex",flex:"1",minHeight:"0"}},H),...a.value.sheetTabs?[a.value.sheetTabs]:[],h("div",{style:{display:"flex",alignItems:"center",padding:"8px 0",borderTop:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))"}},[b])])])}}})}export{Bn as FormulaBar,zn as FormulaRefOverlay,An as MarchingAntsOverlay,Vn as SheetTabs,Ln as StatusBar,Ha as createDataGridTable,qa as createInlineCellEditor,ti as createOGrid,Sn as getCellInteractionProps,qt as useActiveCell,$t as useCellEditing,Xt as useCellSelection,Yt as useClipboard,zo as useColumnChooserState,Ho as useColumnHeaderFilterState,ln as useColumnHeaderMenuState,nn as useColumnPinning,gn as useColumnReorder,sn as useColumnResize,jt as useContextMenu,an as useDataGridState,bn as useDataGridTableSetup,pn as useDateFilterState,un as useDebounce,Mo as useDebouncedCallback,Qt as useFillHandle,Gt as useFilterOptions,Nt as useFormulaBar,Go as useInlineCellEditorState,Zt as useKeyboardNavigation,cn as useMultiSelectFilterState,_t as useOGrid,fn as usePeopleFilterState,Wo as useRichSelectState,Kt as useRowSelection,Ot as useSideBarState,tn as useTableLayout,dn as useTextFilterState,en as useUndoRedo,hn as useVirtualScroll};
1
+ import {injectGlobalStyles,Z_INDEX,getStatusBarParts,measureRange,flattenColumns,getMultiSelectFilterFields,deriveFilterOptionsFromData,shouldUseWorkerSort,processClientSideData,processClientSideDataAsync,validateColumns,validateRowIds,computeRowSelectionState,parseTsvClipboard,applyPastedValues,applyCutClear,normalizeSelectionRange,applyCellDeletion,computeTabNavigation,computeArrowNavigation,UndoRedoStack,CHECKBOX_COLUMN_WIDTH,estimateHeaderMinWidth,CELL_PADDING,measureColumnContentWidth,resolveResponsiveConfig,applyResponsiveHiding,DEFAULT_MIN_COLUMN_WIDTH,computeAggregations,getDataGridStatusBarConfig,isInSelectionRange,applyFillValues,formatSelectionAsTsv,formatDateForDisplay,DEFAULT_DATE_FORMAT,getPinStateForColumn,validateVirtualScrollConfig,computeVisibleRange,computeTotalHeight,computeVisibleColumnRange,getScrollTopForRow,partitionColumnsForVirtualization,formatCellReference,buildHeaderRows,indexToColumnLetter,ROW_NUMBER_COLUMN_ID,ROW_NUMBER_COLUMN_WIDTH,getHeaderFilterConfig,getDateInputPlaceholder,getCellRenderDescriptor,buildInlineEditorProps,buildPopoverEditorProps,resolveCellDisplayContent,resolveCellStyle,handleBooleanCellPointerDown,parseUserInputDate,rangesEqual,buildCellIndex,cellIndexKey,calculateDropTarget,reorderColumnArray,parseValue,computeNextSortState,mergeFilter,getCellValue,isColumnEditable,columnLetterToIndex,applyRangeRowSelection,ROW_NUMBER_COLUMN_MIN_WIDTH,createGridDataAccessor,computeAutoScrollSpeed}from'@alaarab/ogrid-core';export{AUTOSIZE_EXTRA_PX,AUTOSIZE_MAX_PX,CELL_PADDING,CHECKBOX_COLUMN_WIDTH,COLUMN_HEADER_MENU_ITEMS,CellDescriptorCache,DEFAULT_DEBOUNCE_MS,DEFAULT_MIN_COLUMN_WIDTH,GRID_BORDER_RADIUS,GRID_CONTEXT_MENU_ITEMS,MAX_PAGE_BUTTONS,PAGE_SIZE_OPTIONS,PEOPLE_SEARCH_DEBOUNCE_MS,RESPONSIVE_BREAKPOINTS,ROW_NUMBER_COLUMN_ID,ROW_NUMBER_COLUMN_MIN_WIDTH,ROW_NUMBER_COLUMN_WIDTH,SIDEBAR_TRANSITION_MS,UndoRedoStack,Z_INDEX,applyCellDeletion,applyCutClear,applyFillValues,applyPastedValues,applyRangeRowSelection,applyResponsiveHiding,areGridRowPropsEqual,booleanParser,buildCellIndex,buildCsvHeader,buildCsvRows,buildHeaderRows,buildInlineEditorProps,buildPopoverEditorProps,calculateDropTarget,clampSelectionToBounds,columnLetterToIndex,computeAggregations,computeArrowNavigation,computeAutoScrollSpeed,computeNextSortState,computeRowSelectionState,computeTabNavigation,computeTotalHeight,computeVisibleColumnRange,computeVisibleRange,createGridDataAccessor,createSortFilterWorker,currencyParser,dateParser,debounce,deriveFilterOptionsFromData,emailParser,escapeCsvValue,exportToCsv,extractValueMatrix,findCtrlArrowTarget,flattenColumns,formatCellReference,formatCellValueForTsv,formatSelectionAsTsv,formatShortcut,getCellRenderDescriptor,getCellValue,getColumnHeaderMenuItems,getContextMenuHandlers,getDataGridStatusBarConfig,getFilterField,getHeaderFilterConfig,getMultiSelectFilterFields,getPaginationViewModel,getPinStateForColumn,getResponsiveHiddenColumns,getScrollTopForRow,getStatusBarParts,handleBooleanCellPointerDown,indexToColumnLetter,injectGlobalStyles,isColumnEditable,isFilterConfig,isInSelectionRange,isRowInRange,measureColumnContentWidth,measureRange,mergeFilter,normalizeSelectionRange,numberParser,parseTsvClipboard,parseValue,partitionColumnsForVirtualization,processClientSideData,processClientSideDataAsync,rangesEqual,reorderColumnArray,resolveCellDisplayContent,resolveCellStyle,resolveResponsiveConfig,terminateSortFilterWorker,toUserLike,triggerCsvDownload,validateColumns,validateRowIds,validateVirtualScrollConfig}from'@alaarab/ogrid-core';import {FORMULA_BAR_STYLES,handleFormulaBarKeyDown,FORMULA_REF_COLORS,deriveFormulaBarText,extractFormulaReferences,processFormulaBarCommit,FormulaEngine}from'@alaarab/ogrid-core/formula';export{CIRC_ERROR,DIV_ZERO_ERROR,DependencyGraph,FORMULA_BAR_CSS,FORMULA_BAR_STYLES,FORMULA_REF_COLORS,FormulaEngine,FormulaError,FormulaEvaluator,GENERAL_ERROR,NAME_ERROR,NA_ERROR,REF_ERROR,VALUE_ERROR,adjustFormulaReferences,canInsertReference,createBuiltInFunctions,deriveFormulaBarText,extractFormulaReferences,flattenArgs,formatAddress,formulaToString,fromCellKey,handleFormulaBarKeyDown,insertReferenceAtCursor,isFormulaError,parse,parseCellRef,parseRange,processFormulaBarCommit,toBoolean,toCellKey,toNumber,tokenize}from'@alaarab/ogrid-core/formula';import {defineComponent,ref,computed,onMounted,watch,toValue,onUnmounted,h,shallowRef,isRef,triggerRef,nextTick,Teleport,isReadonly,unref,customRef}from'vue';var Ln=defineComponent({name:"MarchingAntsOverlay",props:{containerRef:{type:Object,required:true},selectionRange:{type:Object,default:null},copyRange:{type:Object,default:null},cutRange:{type:Object,default:null},colOffset:{type:Number,required:true},items:{type:Array,required:true},visibleColumns:{type:Array,default:void 0},columnSizingOverrides:{type:Object,required:true},columnOrder:{type:Array,default:void 0}},setup(e){let l=ref(null),n=ref(null),t=0,i,s=computed(()=>e.copyRange??e.cutRange),d=()=>{let u=toValue(e.containerRef);if(!u){l.value=null,n.value=null;return}l.value=e.selectionRange?measureRange(u,e.selectionRange,e.colOffset):null,n.value=s.value?measureRange(u,s.value,e.colOffset):null;};onMounted(()=>{injectGlobalStyles("ogrid-marching-ants-keyframes","@keyframes ogrid-marching-ants{to{stroke-dashoffset:-8}}");}),watch([()=>e.selectionRange,s,()=>toValue(e.containerRef),()=>e.items,()=>e.visibleColumns,()=>e.columnSizingOverrides,()=>e.columnOrder],()=>{if(!e.selectionRange&&!s.value){l.value=null,n.value=null;return}t=requestAnimationFrame(d);let u=toValue(e.containerRef);u&&(i?.disconnect(),i=new ResizeObserver(d),i.observe(u));},{immediate:true}),onUnmounted(()=>{cancelAnimationFrame(t),i?.disconnect();});let a=computed(()=>{let u=e.selectionRange,v=s.value;return u!=null&&v!=null&&u.startRow===v.startRow&&u.startCol===v.startCol&&u.endRow===v.endRow&&u.endCol===v.endCol});return ()=>!l.value&&!n.value?null:h("div",{style:{position:"relative"}},[l.value&&!a.value&&!(e.selectionRange&&e.selectionRange.startRow===e.selectionRange.endRow&&e.selectionRange.startCol===e.selectionRange.endCol)?h("svg",{style:{position:"absolute",top:`${l.value.top}px`,left:`${l.value.left}px`,width:`${l.value.width}px`,height:`${l.value.height}px`,pointerEvents:"none",zIndex:Z_INDEX.SELECTION_OVERLAY,overflow:"visible"},"aria-hidden":"true"},[h("rect",{x:1,y:1,width:Math.max(0,l.value.width-2),height:Math.max(0,l.value.height-2),fill:"none",stroke:"var(--ogrid-selection-color, #217346)","stroke-width":2})]):null,n.value?h("svg",{style:{position:"absolute",top:`${n.value.top}px`,left:`${n.value.left}px`,width:`${n.value.width}px`,height:`${n.value.height}px`,pointerEvents:"none",zIndex:Z_INDEX.CLIPBOARD_OVERLAY,overflow:"visible"},"aria-hidden":"true"},[h("rect",{x:1,y:1,width:Math.max(0,n.value.width-2),height:Math.max(0,n.value.height-2),fill:"none",stroke:"var(--ogrid-selection-color, #217346)","stroke-width":2,"stroke-dasharray":"4 4",style:{animation:"ogrid-marching-ants 0.5s linear infinite"}})]):null])}});var Hn=defineComponent({name:"StatusBar",props:{totalCount:{type:Number,required:true},filteredCount:{type:Number,default:void 0},selectedCount:{type:Number,default:void 0},selectedCellCount:{type:Number,default:void 0},aggregation:{type:Object,default:void 0},suppressRowCount:{type:Boolean,default:false}},setup(e){return ()=>{let l=getStatusBarParts(e);return h("div",{role:"status","aria-live":"polite",style:{marginTop:"auto",padding:"6px 12px",borderTop:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",backgroundColor:"var(--ogrid-header-bg, rgba(0,0,0,0.04))",display:"flex",alignItems:"center",gap:"16px",fontSize:"0.875rem",lineHeight:"20px",minHeight:"33px",boxSizing:"border-box"}},l.map((n,t)=>h("span",{key:n.key,style:{display:"inline-flex",alignItems:"center",gap:"4px",...t<l.length-1?{marginRight:"16px",borderRight:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",paddingRight:"16px"}:{}}},[h("span",{style:{color:"var(--ogrid-fg-secondary, rgba(0,0,0,0.6))"}},n.label),h("span",{style:{fontWeight:"600"}},n.value.toLocaleString())])))}}});var Vn=defineComponent({name:"FormulaBar",props:{cellRef:{type:[String,null],default:null},formulaText:{type:String,required:true},isEditing:{type:Boolean,required:true}},emits:["inputChange","commit","cancel","startEditing"],setup(e,{emit:l}){let n=ref(null);return watch(()=>e.isEditing,t=>{t&&n.value&&n.value.focus();}),()=>h("div",{style:FORMULA_BAR_STYLES.bar,role:"toolbar","aria-label":"Formula bar"},[h("div",{style:FORMULA_BAR_STYLES.nameBox,"aria-label":"Active cell reference"},e.cellRef??"\u2014"),h("div",{style:FORMULA_BAR_STYLES.fxLabel,"aria-hidden":"true"},"fx"),h("input",{ref:n,type:"text",style:FORMULA_BAR_STYLES.input,value:e.formulaText,readonly:!e.isEditing,onInput:t=>l("inputChange",t.target.value),onKeydown:t=>handleFormulaBarKeyDown(t.key,()=>t.preventDefault(),()=>l("commit"),()=>l("cancel")),onClick:()=>{e.isEditing||l("startEditing");},onDblclick:()=>{e.isEditing||l("startEditing");},"aria-label":"Formula input",spellcheck:false,autocomplete:"off"})])}});var wl={display:"flex",alignItems:"center",borderTop:"1px solid var(--ogrid-border, #e0e0e0)",background:"var(--ogrid-header-bg, #f5f5f5)",minHeight:"30px",overflowX:"auto",overflowY:"hidden",gap:"0",fontSize:"12px"},yl={background:"none",border:"none",cursor:"pointer",padding:"4px 10px",fontSize:"16px",lineHeight:"22px",color:"var(--ogrid-fg-secondary, #666)",flexShrink:0},mo={background:"none",border:"none",borderBottom:"2px solid transparent",cursor:"pointer",padding:"4px 16px",fontSize:"12px",lineHeight:"22px",color:"var(--ogrid-fg, #242424)",whiteSpace:"nowrap",position:"relative"},xl={...mo,fontWeight:600,borderBottomColor:"var(--ogrid-primary, #217346)",background:"var(--ogrid-bg, #fff)"},Gn=defineComponent({name:"SheetTabs",props:{sheets:{type:Array,required:true},activeSheet:{type:String,required:true},showAddButton:{type:Boolean,default:false}},emits:["sheetChange","sheetAdd"],setup(e,{emit:l}){return ()=>h("div",{style:wl,role:"tablist","aria-label":"Sheet tabs"},[e.showAddButton?h("button",{type:"button",style:yl,onClick:()=>l("sheetAdd"),title:"Add sheet","aria-label":"Add sheet"},"+"):null,...e.sheets.map(n=>{let t=n.id===e.activeSheet,i=t?xl:mo,s=t&&n.color?{...i,borderBottomColor:n.color}:i;return h("button",{key:n.id,type:"button",role:"tab","aria-selected":t,style:s,onClick:()=>l("sheetChange",n.id)},n.name)})])}});function El(e,l,n){let t=l.col+n,i=(l.endCol??l.col)+n,s=l.endRow??l.row,d=e.querySelector(`[data-row-index="${l.row}"][data-col-index="${t}"]`),a=e.querySelector(`[data-row-index="${s}"][data-col-index="${i}"]`);if(!d||!a)return null;let u=e.getBoundingClientRect(),v=d.getBoundingClientRect(),C=a.getBoundingClientRect();return {top:Math.round(v.top-u.top),left:Math.round(v.left-u.left),width:Math.round(C.right-v.left),height:Math.round(C.bottom-v.top),color:FORMULA_REF_COLORS[l.colorIndex%FORMULA_REF_COLORS.length]}}var zn=defineComponent({name:"FormulaRefOverlay",props:{containerEl:{type:Object,default:null},references:{type:Array,required:true},colOffset:{type:Number,required:true}},setup(e){let l=ref([]),n=0;function t(){let i=e.containerEl,s=e.references;if(!i||s.length===0){l.value=[];return}let d=[];for(let a of s){let u=El(i,a,e.colOffset);u&&d.push(u);}l.value=d;}return watch(()=>[e.references,e.containerEl,e.colOffset],()=>{if(cancelAnimationFrame(n),!e.containerEl||e.references.length===0){l.value=[];return}n=requestAnimationFrame(t);},{immediate:true}),()=>l.value.length===0?null:l.value.map((i,s)=>h("svg",{key:s,style:{position:"absolute",top:`${i.top}px`,left:`${i.left}px`,width:`${i.width}px`,height:`${i.height}px`,pointerEvents:"none",zIndex:3,overflow:"visible"},"aria-hidden":"true"},[h("rect",{x:"1",y:"1",width:Math.max(0,i.width-2),height:Math.max(0,i.height-2),fill:"none",stroke:i.color,"stroke-width":"2",style:"shape-rendering: crispEdges"})]))}});function Wt(e,l){let n=ref({}),t=ref({}),i=computed(()=>[...l.value].sort().join(",")),s=async()=>{let d=e.value,a=l.value,u="fetchFilterOptions"in d&&typeof d.fetchFilterOptions=="function"?d.fetchFilterOptions.bind(d):void 0;if(!u){n.value={},t.value={};return}let v={};a.forEach(p=>{v[p]=true;}),t.value=v;let C={};await Promise.all(a.map(async p=>{try{C[p]=await u(p);}catch{C[p]=[];}})),n.value=C,t.value={};};return watch([e,i],()=>{s().catch(()=>{});},{immediate:true}),{filterOptions:n,loadingOptions:t}}function dt(e){let l=unref(e);return customRef((n,t)=>({get(){return isRef(e)&&(l=e.value),l},set(i){l=i,t();}}))}function go(e){let{formulas:l,items:n,flatColumns:t,initialFormulas:i,onFormulaRecalc:s,formulaFunctions:d,namedRanges:a,sheets:u}=e,v=dt(n),C=dt(t),p=dt(s),f=shallowRef(null),c=false,o=computed(()=>l?.value??false);function m(){return createGridDataAccessor(v.value,C.value)}watch(o,T=>{if(T&&!f.value){if(f.value=new FormulaEngine({customFunctions:d,namedRanges:a}),u)for(let[E,O]of Object.entries(u))f.value.registerSheet(E,O);if(i&&!c){c=true;let E=m(),O=f.value.loadFormulas(i,E);O.updatedCells.length>0&&p.value?.(O);}}else !T&&f.value&&(f.value=null);},{immediate:true});function g(T,E){return f.value?.getValue(T,E)}function R(T,E){return f.value?.hasFormula(T,E)??false}function S(T,E){return f.value?.getFormula(T,E)}function b(T,E,O){if(!f.value)return;let A=m(),y=f.value.setFormula(T,E,O,A);y.updatedCells.length>0&&p.value?.(y);}function U(T,E){if(!f.value)return;let O=m(),A=f.value.onCellChanged(T,E,O);A.updatedCells.length>0&&p.value?.(A);}function k(T,E){return f.value?.getPrecedents(T,E)??[]}function B(T,E){return f.value?.getDependents(T,E)??[]}function F(T,E){return f.value?.getAuditTrail(T,E)??null}return {enabled:o,getFormulaValue:g,hasFormula:R,getFormula:S,setFormula:b,onCellChanged:U,getPrecedents:k,getDependents:B,getAuditTrail:F}}function _t(e){let{activeCol:l,activeRow:n,activeCellRef:t,getFormula:i,getRawValue:s,setFormula:d,onCellValueChanged:a}=e,u=ref(false),v=ref(""),C=ref(false),p=computed(()=>deriveFormulaBarText(l.value,n.value,i,s));watch([l,n],()=>{u.value=false,C.value=false;});let f=()=>{v.value=p.value,u.value=true,C.value=true;},c=S=>{v.value=S;},o=()=>{let S=l.value,b=n.value;S==null||b==null||!d||(processFormulaBarCommit(v.value,S,b,d,a),u.value=false,C.value=false);},m=()=>{u.value=false,C.value=false,v.value="";},g=computed(()=>u.value?v.value:p.value),R=computed(()=>extractFormulaReferences(g.value));return {cellRef:t,formulaText:g,isEditing:u,onInputChange:c,onCommit:o,onCancel:m,startEditing:f,referencedCells:R,isFormulaBarEditing:C}}var Co=["columns","filters"];function Mt(e){let{config:l}=e,n=l!=null&&l!==false,t=(()=>{if(!n||l===true)return {panels:Co,position:"right",defaultPanel:null};let v=l;return {panels:v.panels??Co,position:v.position??"right",defaultPanel:v.defaultPanel??null}})(),i=ref(t.defaultPanel),s=v=>{i.value=v;},d=v=>{i.value=i.value===v?null:v;},a=()=>{i.value=null;},u=computed(()=>i.value!==null);return {isEnabled:n,activePanel:i,setActivePanel:s,panels:t.panels,position:t.position,isOpen:u,toggle:d,close:a}}var lr=25,rr={};function $t(e){let l=computed(()=>{let r=e.value;return {columns:r.columns,columnOrder:r.columnOrder,onColumnOrderChange:r.onColumnOrderChange,onColumnResized:r.onColumnResized,onAutosizeColumn:r.onAutosizeColumn,onColumnPinned:r.onColumnPinned,columnChooser:r.columnChooser}}),n=computed(()=>{let r=e.value,L="data"in r?r.data:void 0,le="dataSource"in r?r.dataSource:void 0;return L&&le&&console.warn("[OGrid] Both data and dataSource provided. dataSource takes precedence."),{getRowId:r.getRowId,data:L,dataSource:le}}),t=computed(()=>{let r=e.value;return {page:r.page,pageSize:r.pageSize,sort:r.sort,filters:r.filters,visibleColumns:r.visibleColumns,isLoading:r.isLoading}}),i=computed(()=>{let r=e.value;return {onPageChange:r.onPageChange,onPageSizeChange:r.onPageSizeChange,onSortChange:r.onSortChange,onFiltersChange:r.onFiltersChange,onVisibleColumnsChange:r.onVisibleColumnsChange,onFirstDataRendered:r.onFirstDataRendered,onError:r.onError}}),s=computed(()=>{let r=e.value;return {defaultPageSize:r.defaultPageSize??lr,defaultSortBy:r.defaultSortBy,defaultSortDirection:r.defaultSortDirection??"asc",entityLabelPlural:r.entityLabelPlural??"items"}}),d=computed(()=>l.value.columnChooser===false?"none":l.value.columnChooser==="sidebar"?"sidebar":"toolbar"),a=computed(()=>flattenColumns(l.value.columns)),u=computed(()=>n.value.dataSource!=null),v=computed(()=>!u.value),C=ref([]),p=ref(false),f=computed(()=>n.value.data??C.value),c=computed(()=>t.value.isLoading??p.value),o=computed(()=>s.value.defaultSortBy??a.value[0]?.columnId??""),m=ref(1),g=ref(s.value.defaultPageSize),R=ref({field:o.value,direction:s.value.defaultSortDirection}),S=ref({}),b=ref(void 0),U=ref((()=>{let r=a.value.filter(L=>L.defaultVisible!==false).map(L=>L.columnId);return new Set(r.length>0?r:a.value.map(L=>L.columnId))})()),k=ref({}),B={};for(let r of flattenColumns(e.value.columns))r.pinned&&(B[r.columnId]=r.pinned);let F=ref(B),T=computed(()=>t.value.page??m.value),E=computed(()=>t.value.pageSize??g.value),O=computed(()=>t.value.sort??R.value),A=computed(()=>t.value.filters??S.value),y=computed(()=>l.value.columnOrder??b.value),I=computed(()=>t.value.visibleColumns??U.value),x=r=>{t.value.page===void 0&&(m.value=r),i.value.onPageChange?.(r);},D=r=>{t.value.pageSize===void 0&&(g.value=r),i.value.onPageSizeChange?.(r),x(1);},w=ref(0),h$1=r=>{t.value.sort===void 0&&(R.value=r),i.value.onSortChange?.(r),x(1),w.value++;},P=r=>{t.value.filters===void 0&&(S.value=r),i.value.onFiltersChange?.(r),x(1);},V=r=>{t.value.visibleColumns===void 0&&(U.value=r),i.value.onVisibleColumnsChange?.(r);},_=(r,L)=>{h$1(computeNextSortState(O.value,r,L));},K=(r,L)=>{P(mergeFilter(A.value,r,L));},M=(r,L)=>{let le=new Set(I.value);L?le.add(r):le.delete(r),V(le);},j=ref(new Set),J=computed(()=>e.value.selectedRows),Y=computed(()=>J.value??j.value),q=r=>{J.value===void 0&&(j.value=new Set(r.selectedRowIds)),e.value.onSelectionChange?.(r);},G=computed(()=>getMultiSelectFilterFields(a.value)),Z=computed(()=>n.value.dataSource??{fetchFilterOptions:void 0}),{filterOptions:ne,loadingOptions:ye}=Wt(Z,G),Fe=computed(()=>n.value.dataSource?.fetchFilterOptions!=null),Ke=computed(()=>Fe.value?ne.value:deriveFilterOptionsFromData(f.value,a.value)),Pe=computed(()=>shouldUseWorkerSort(e.value.workerSort,f.value.length,{columns:a.value,filters:A.value,sortBy:O.value.field})),xe=null,Ne=-1,Ve=null,We=null,$e=-1,tt=computed(()=>{if(!v.value||Pe.value)return null;let r=f.value,L=a.value,le=A.value,Re=w.value,st=O.value.field,ut=O.value.direction,je=Re!==Ne||le!==Ve||L!==We||r.length!==$e,fe;if(je||xe===null){Ne=Re,Ve=le,We=L,$e=r.length;let be=processClientSideData(r,L,le,st,ut),Ae=new Map;for(let pe=0;pe<r.length;pe++)Ae.set(r[pe],pe);xe=be.map(pe=>{let De=Ae.get(pe);return De!==void 0?De:-1}).filter(pe=>pe!==-1),fe=be;}else fe=xe.map(be=>r[be]).filter(be=>be!==void 0);let vt=fe.length,Xe=(T.value-1)*E.value;return {items:fe.slice(Xe,Xe+E.value),totalCount:vt}}),nt=ref(null),mt=0,Ue=null,ft=-1,Ie=null,Ct=null,ae=-1;watch([v,Pe,f,a,A,w,T,E],()=>{if(!v.value||!Pe.value)return;let r=f.value,L=a.value,le=A.value,Re=w.value,st=O.value.field,ut=O.value.direction,je=T.value,fe=E.value,vt=++mt;if(Re!==ft||le!==Ie||L!==Ct||r.length!==ae||Ue===null)ft=Re,Ie=le,Ct=L,ae=r.length,Ue=null,processClientSideDataAsync(r,L,le,st,ut).then(Ce=>{if(vt!==mt||_e)return;let be=new Map;for(let H=0;H<r.length;H++)be.set(r[H],H);Ue=Ce.map(H=>{let z=be.get(H);return z!==void 0?z:-1}).filter(H=>H!==-1);let Ae=Ce.length,pe=(je-1)*fe,De=Ce.slice(pe,pe+fe);nt.value={items:De,totalCount:Ae};}).catch(()=>{if(vt!==mt||_e)return;let Ce=processClientSideData(r,L,le,st,ut),be=new Map;for(let H=0;H<r.length;H++)be.set(r[H],H);Ue=Ce.map(H=>{let z=be.get(H);return z!==void 0?z:-1}).filter(H=>H!==-1);let Ae=Ce.length,pe=(je-1)*fe,De=Ce.slice(pe,pe+fe);nt.value={items:De,totalCount:Ae};});else {let Ce=Ue.map(De=>r[De]).filter(De=>De!==void 0),be=Ce.length,Ae=(je-1)*fe,pe=Ce.slice(Ae,Ae+fe);nt.value={items:pe,totalCount:be};}},{immediate:true});let ke=computed(()=>{let r=tt.value;return r||nt.value}),ot=ref([]),lt=ref(0),Ee=ref(false),rt=0,at=null,_e=false,ht=ref(0),Rt=()=>{if(!u.value||!n.value.dataSource){u.value||(Ee.value=false);return}let r=++rt;at?.abort();let L=new AbortController;at=L,Ee.value=true,n.value.dataSource.fetchPage({page:T.value,pageSize:E.value,sort:{field:O.value.field,direction:O.value.direction},filters:A.value,signal:L.signal}).then(le=>{r!==rt||_e||L.signal.aborted||(ot.value=le.items,lt.value=le.totalCount);}).catch(le=>{r!==rt||_e||L.signal.aborted||(i.value.onError?.(le),ot.value=[],lt.value=0);}).finally(()=>{r===rt&&!_e&&!L.signal.aborted&&(Ee.value=false);});};onMounted(()=>{validateColumns(a.value),Rt();}),watch([()=>n.value.dataSource,T,E,()=>O.value.field,()=>O.value.direction,A,ht],()=>{Rt();}),onUnmounted(()=>{_e=true,at?.abort(),at=null;});let Be=computed(()=>v.value&&ke.value?ke.value.items:ot.value),pt=computed(()=>v.value&&ke.value?ke.value.totalCount:lt.value),it=computed(()=>!!e.value.formulas),bt=ref(0),It=r=>{bt.value+=1,e.value.onFormulaRecalc?.(r);},ve=go({formulas:it,items:Be,flatColumns:a,initialFormulas:e.value.initialFormulas,onFormulaRecalc:It,formulaFunctions:e.value.formulaFunctions,namedRanges:e.value.namedRanges,sheets:e.value.sheets}),St=false,Tt=false;watch(Be,r=>{!St&&r.length>0&&(St=true,i.value.onFirstDataRendered?.()),!Tt&&r.length>0&&(Tt=true,validateRowIds(r,n.value.getRowId));});let qe=computed(()=>Object.values(A.value).some(r=>r!==void 0)),wt=computed(()=>a.value.map(r=>({columnId:r.columnId,name:r.name,required:r.required===true}))),Pt=computed(()=>{let r=e.value.statusBar;if(!r)return;if(typeof r=="object")return r;let L=v.value?n.value.data?.length??0:lt.value,le=pt.value;return {totalCount:L,filteredCount:qe.value?le:void 0,selectedCount:Y.value.size,suppressRowCount:true}}),Et=(r,L)=>{k.value={...k.value,[r]:L},l.value.onColumnResized?.(r,L);},te=(r,L)=>{k.value={...k.value,[r]:L},(l.value.onAutosizeColumn??l.value.onColumnResized)?.(r,L);},Q=(r,L)=>{if(L===null){let{[r]:le,...Re}=F.value;F.value=Re;}else F.value={...F.value,[r]:L};l.value.onColumnPinned?.(r,L);},re=shallowRef(Mt({config:e.value.sideBar}));watch(()=>e.value.sideBar,r=>{re.value=Mt({config:r});});let me=computed(()=>a.value.filter(r=>r.filterable&&r.filterable.type).map(r=>({columnId:r.columnId,name:r.name,filterField:r.filterable?.filterField??r.columnId,filterType:r.filterable?.type}))),se=computed(()=>{let r=re.value;if(!r.isEnabled)return null;r.activePanel.value;r.isOpen.value;return {get activePanel(){return r.activePanel.value},onPanelChange:r.setActivePanel,panels:r.panels,position:r.position,get isOpen(){return r.isOpen.value},toggle:r.toggle,close:r.close,columns:wt.value,visibleColumns:I.value,onVisibilityChange:M,onSetVisibleColumns:V,filterableColumns:me.value,filters:A.value,onFilterChange:K,filterOptions:Ke.value}}),Me=()=>P({}),we=computed(()=>u.value&&Ee.value||c.value),he=ref(null),ge=ref(null),yt=r=>{if(he.value=r,r){let L=r.match(/^([A-Z]+)(\d+)$/);L?ge.value={col:columnLetterToIndex(L[1]),row:parseInt(L[2],10)-1}:ge.value=null;}else ge.value=null;},Dt=computed(()=>ge.value?.col??null),Fn=computed(()=>ge.value?.row??null),Un=(r,L)=>{let le=Be.value,Re=a.value;if(!(L<0||L>=le.length||r<0||r>=Re.length))return getCellValue(le[L],Re[r])},Oe=_t({activeCol:Dt,activeRow:Fn,activeCellRef:he,getFormula:ve.enabled.value?ve.getFormula:void 0,getRawValue:Un,setFormula:ve.enabled.value?ve.setFormula:void 0}),kn=computed(()=>{let r=e.value,L=n.value.dataSource;return {items:Be.value,columns:l.value.columns,getRowId:n.value.getRowId,sortBy:O.value.field,sortDirection:O.value.direction,onColumnSort:_,visibleColumns:I.value,columnOrder:y.value,onColumnOrderChange:l.value.onColumnOrderChange,onColumnResized:Et,onAutosizeColumn:te,onColumnPinned:Q,pinnedColumns:F.value,initialColumnWidths:k.value,editable:r.editable,cellSelection:r.cellSelection,onCellValueChanged:r.onCellValueChanged,onUndo:r.onUndo,onRedo:r.onRedo,canUndo:r.canUndo,canRedo:r.canRedo,rowSelection:r.rowSelection??"none",selectedRows:Y.value,onSelectionChange:q,showRowNumbers:r.showRowNumbers||r.cellReferences||r.formulas,showColumnLetters:!!(r.cellReferences||r.formulas),showNameBox:!!(r.cellReferences&&!r.formulas),onActiveCellChange:r.cellReferences||r.formulas?yt:void 0,currentPage:T.value,pageSize:E.value,statusBar:Pt.value,isLoading:we.value,filters:A.value,onFilterChange:K,filterOptions:Ke.value,loadingFilterOptions:L?.fetchFilterOptions?ye.value:rr,peopleSearch:L?.searchPeople,getUserByEmail:L?.getUserByEmail,layoutMode:r.layoutMode,suppressHorizontalScroll:r.suppressHorizontalScroll,stickyHeader:r.stickyHeader??true,columnReorder:r.columnReorder,responsiveColumns:r.responsiveColumns,virtualScroll:r.virtualScroll,rowHeight:r.rowHeight,density:r.density??"normal","aria-label":r["aria-label"],"aria-labelledby":r["aria-labelledby"],emptyState:{hasActiveFilters:qe.value,onClearAll:Me,message:r.emptyState?.message,render:r.emptyState?.render},formulas:r.formulas,formulaVersion:bt.value,...ve.enabled.value?{getFormulaValue:ve.getFormulaValue,hasFormula:ve.hasFormula,getFormula:ve.getFormula,setFormula:ve.setFormula,onFormulaCellChanged:ve.onCellChanged,getPrecedents:ve.getPrecedents,getDependents:ve.getDependents,getAuditTrail:ve.getAuditTrail}:{},formulaReferences:Oe.referencedCells.value.length>0?Oe.referencedCells.value:void 0}}),Ft=computed(()=>({page:T.value,pageSize:E.value,displayTotalCount:pt.value,setPage:x,setPageSize:D,pageSizeOptions:e.value.pageSizeOptions,entityLabelPlural:s.value.entityLabelPlural})),Ge=computed(()=>({columns:wt.value,visibleColumns:I.value,onVisibilityChange:M,placement:d.value})),Ut=computed(()=>{let r=e.value,L=!!r.formulas,le=!!r.cellReferences&&!L,Re=r.toolbar;le&&(Re=[h("div",{style:{display:"inline-flex",alignItems:"center",padding:"0 8px",fontFamily:"'Consolas', 'Courier New', monospace",fontSize:"12px",border:"1px solid rgba(0,0,0,0.12)",borderRadius:"3px",height:"24px",marginRight:"8px",background:"#fff",minWidth:"40px",color:"rgba(0,0,0,0.6)"},"aria-label":"Active cell reference"},he.value??"\u2014"),Re]);let st=L?h(Vn,{cellRef:Oe.cellRef.value,formulaText:Oe.formulaText.value,isEditing:Oe.isEditing.value,onInputChange:Oe.onInputChange,onCommit:Oe.onCommit,onCancel:Oe.onCancel,onStartEditing:Oe.startEditing}):void 0,ut=r.sheetDefs&&r.sheetDefs.length>0&&r.activeSheet&&r.onSheetChange?h(Gn,{sheets:r.sheetDefs,activeSheet:r.activeSheet,showAddButton:!!r.onSheetAdd,onSheetChange:r.onSheetChange,onSheetAdd:r.onSheetAdd??(()=>{})}):void 0;return {toolbar:Re,toolbarBelow:r.toolbarBelow,className:r.className,emptyState:r.emptyState,sideBarProps:se.value,fullScreen:r.fullScreen,formulaBar:st,sheetTabs:ut}}),Mn=computed(()=>({hasActiveFilters:qe.value,setFilters:P})),On=computed(()=>({setRowData:r=>{u.value||(C.value=r);},setLoading:r=>{p.value=r;},getColumnState:()=>({visibleColumns:Array.from(I.value),sort:O.value,columnOrder:y.value??void 0,columnWidths:Object.keys(k.value).length>0?k.value:void 0,filters:Object.keys(A.value).length>0?A.value:void 0,pinnedColumns:Object.keys(F.value).length>0?F.value:void 0}),applyColumnState:r=>{r.visibleColumns&&V(new Set(r.visibleColumns)),r.sort&&h$1(r.sort),r.columnOrder&&(l.value.columnOrder===void 0&&(b.value=r.columnOrder),l.value.onColumnOrderChange?.(r.columnOrder)),r.columnWidths&&(k.value=r.columnWidths),r.filters&&P(r.filters),r.pinnedColumns&&(F.value=r.pinnedColumns);},setFilterModel:P,getSelectedRows:()=>Array.from(Y.value),setSelectedRows:r=>{J.value===void 0&&(j.value=new Set(r));},selectAll:()=>{let r=new Set(Be.value.map(L=>n.value.getRowId(L)));J.value===void 0&&(j.value=r),e.value.onSelectionChange?.({selectedRowIds:Array.from(r),selectedItems:Be.value});},deselectAll:()=>{J.value===void 0&&(j.value=new Set),e.value.onSelectionChange?.({selectedRowIds:[],selectedItems:[]});},clearFilters:()=>P({}),clearSort:()=>h$1({field:o.value,direction:s.value.defaultSortDirection}),resetGridState:r=>{P({}),h$1({field:o.value,direction:s.value.defaultSortDirection}),r?.keepSelection||(J.value===void 0&&(j.value=new Set),e.value.onSelectionChange?.({selectedRowIds:[],selectedItems:[]}));},getDisplayedRows:()=>Be.value,refreshData:()=>{u.value&&ht.value++;},scrollToRow:()=>{},getColumnOrder:()=>y.value??a.value.map(r=>r.columnId),setColumnOrder:r=>{l.value.columnOrder===void 0&&(b.value=r),l.value.onColumnOrderChange?.(r);}}));return {dataGridProps:kn,pagination:Ft,columnChooser:Ge,layout:Ut,filters:Mn,api:On}}var dr=25;function So(e){let{columns:l,data:n,getRowId:t,initialSort:i,initialFilters:s={},initialPage:d=1,initialPageSize:a=dr}=e,u=ref(i??{field:"",direction:"asc"}),v=ref({...s}),C=ref(d),p=ref(a),f=computed(()=>toValue(l)),c=computed(()=>toValue(n)),o=computed(()=>{let h=u.value.field;return processClientSideData(c.value,f.value,v.value,h||void 0,h?u.value.direction:void 0)}),m=computed(()=>o.value.length),g=computed(()=>Math.max(1,Math.ceil(m.value/p.value))),R=computed(()=>{let h=(C.value-1)*p.value;return o.value.slice(h,h+p.value)}),S=h=>{C.value=h;},b=h=>{p.value=h,C.value=1;},U=h=>{u.value=h,C.value=1;},k=h=>{U(computeNextSortState(u.value,h));},B=h=>{v.value=h,C.value=1;},F=(h,P)=>{B(mergeFilter(v.value,h,P));},T=computed(()=>Object.values(v.value).some(h=>h!==void 0)),E=computed(()=>{let h=new Map;for(let P of f.value)h.set(P.columnId,P);return h}),O=(h,P)=>{let V=E.value.get(P);if(V)return getCellValue(h,V)},A=h=>computed(()=>u.value.field!==h?"":u.value.direction==="asc"?"\u25B2":"\u25BC"),y=ref(new Set);return {columns:f,rows:R,totalCount:m,totalPages:g,allFilteredRows:o,sort:u,setSort:U,toggleSort:k,sortIndicator:A,filters:v,setFilters:B,setFilter:F,hasActiveFilters:T,page:C,pageSize:p,setPage:S,setPageSize:b,getRowId:t,getCellValue:O,selectedRowIds:y,isRowSelected:h=>y.value.has(t(h)),toggleRowSelection:h=>{let P=t(h),V=new Set(y.value);V.has(P)?V.delete(P):V.add(P),y.value=V;},selectAllOnPage:()=>{let h=new Set(y.value);for(let P of R.value)h.add(t(P));y.value=h;},clearSelection:()=>{y.value=new Set;}}}function qt(e){let{items:l,getRowId:n,rowSelection:t,controlledSelectedRows:i,onSelectionChange:s}=e,d=shallowRef(new Set),a=-1,u=computed(()=>{let o=i.value;return o!=null?o instanceof Set?o:new Set(o):d.value}),v=o=>{i.value!==void 0?isReadonly(i)||(i.value=o):d.value=o,s?.({selectedRowIds:Array.from(o),selectedItems:l.value.filter(m=>o.has(n(m)))});},C=(o,m,g,R)=>{if(t.value==="single"){v(m?new Set([o]):new Set),a=g;return}let S=l.value,b;R&&a>=0&&a!==g?b=applyRangeRowSelection(a,g,m,S,n,u.value):(b=new Set(u.value),m?b.add(o):b.delete(o)),a=g,v(b);},p=o=>{v(o?new Set(l.value.map(m=>n(m))):new Set);},f=computed(()=>computeRowSelectionState(u.value,l.value,n).allSelected),c=computed(()=>computeRowSelectionState(u.value,l.value,n).someSelected);return {selectedRowIds:u,updateSelection:v,handleRowCheckboxChange:C,handleSelectAll:p,allSelected:f,someSelected:c}}function jt(e){let l=shallowRef(null),n=ref(void 0);return {editingCell:l,setEditingCell:s=>{if(s&&e?.scrollToRow&&e?.getRowIndex){let d=e.getRowIndex(s.rowId);d>=0&&e.scrollToRow(d,"center");}l.value=s;},pendingEditorValue:n,setPendingEditorValue:s=>{n.value=s;}}}function Xt(e,l){let n=shallowRef(null),t=0,i=s=>{let d=n.value;d!==s&&(d&&s&&d.rowIndex===s.rowIndex&&d.columnIndex===s.columnIndex||(n.value=s));};return watch([n,()=>l?.value],()=>{if(t&&(cancelAnimationFrame(t),t=0),n.value==null||!e?.value||l?.value!=null)return;let{rowIndex:s,columnIndex:d}=n.value;t=requestAnimationFrame(()=>{t=0;let a=e.value;if(!a)return;let u=n.value;if(!u||u.rowIndex!==s||u.columnIndex!==d)return;let v=`[data-row-index="${s}"][data-col-index="${d}"]`,C=a.querySelector(v);if(C){let p=a.querySelector("thead"),f=p?p.getBoundingClientRect().height:0,c=a.getBoundingClientRect(),o=C.getBoundingClientRect(),m=c.top+f;o.top<m?a.scrollTop-=m-o.top:o.bottom>c.bottom&&(a.scrollTop+=o.bottom-c.bottom),a.scrollWidth>a.clientWidth&&(o.left<c.left?a.scrollLeft-=c.left-o.left:o.right>c.right&&(a.scrollLeft+=o.right-c.right)),document.activeElement!==C&&typeof C.focus=="function"&&C.focus({preventScroll:true});}});},{flush:"post"}),onUnmounted(()=>{t&&(cancelAnimationFrame(t),t=0);}),{activeCell:n,setActiveCell:i}}var jn="data-drag-range",At="data-drag-anchor",Se=40;function Yt(e){let l=dt(e),{wrapperRef:n,setActiveCell:t}=e,i=()=>isRef(e.colOffset)?e.colOffset.value:e.colOffset,s=shallowRef(null),d=ref(false),a=ref(false),u=ref(false),v=false,C=null,p=0,f=null,c=null,o=null,m=w=>{rangesEqual(s.value,w)||(s.value=w);},g=(w,h,P)=>{if(w.button!==0)return;let V=i();if(P<V)return;w.preventDefault();let _=P-V,K=s.value;if(w.shiftKey&&K!=null)m(normalizeSelectionRange({startRow:K.startRow,startCol:K.startCol,endRow:h,endCol:_})),t({rowIndex:h,columnIndex:P});else {C={row:h,col:_},v=false;let M={startRow:h,startCol:_,endRow:h,endCol:_};m(M),f=M,t({rowIndex:h,columnIndex:P}),a.value=true,B(M);}},R=()=>{let{rowCount:w,visibleColCount:h}=l.value;w.value===0||h.value===0||(m({startRow:0,startCol:0,endRow:w.value-1,endCol:h.value-1}),t({rowIndex:0,columnIndex:i()}));},S=new Set,b=null,U=(w,h,P,V,_,K,M,j)=>{w.hasAttribute(jn)||w.setAttribute(jn,""),j&&h===j.row&&P===j.col?w.hasAttribute(At)||w.setAttribute(At,""):w.hasAttribute(At)&&w.removeAttribute(At);let Y=[];h===V&&Y.push("inset 0 2px 0 0 var(--ogrid-selection-color, #217346)"),h===_&&Y.push("inset 0 -2px 0 0 var(--ogrid-selection-color, #217346)"),P===K&&Y.push("inset 2px 0 0 0 var(--ogrid-selection-color, #217346)"),P===M&&Y.push("inset -2px 0 0 0 var(--ogrid-selection-color, #217346)"),w.style.boxShadow=Y.length>0?Y.join(", "):"",S.add(w);},k=w=>{w.removeAttribute(jn),w.removeAttribute(At),w.style.boxShadow="";},B=w=>{if(!n.value)return;let P=Math.min(w.startRow,w.endRow),V=Math.max(w.startRow,w.endRow),_=Math.min(w.startCol,w.endCol),K=Math.max(w.startCol,w.endCol),M=C,j=i();for(let Y of S){let q=parseInt(Y.getAttribute("data-row-index")??"",10),G=parseInt(Y.getAttribute("data-col-index")??"",10)-j;q>=P&&q<=V&&G>=_&&G<=K||(k(Y),S.delete(Y));}b||(b=buildCellIndex(n.value));let J=false;for(let Y=P;Y<=V;Y++)for(let q=_;q<=K;q++){let G=cellIndexKey(Y,q+j),Z=b?.get(G);Z&&!Z.isConnected&&!J&&(J=true,b=buildCellIndex(n.value),Z=b?.get(G)),Z&&Z.isConnected&&U(Z,Y,q,P,V,_,K,M);}},F=()=>{for(let w of S)k(w);S.clear(),b=null;},T=(w,h)=>{if(!C)return null;let V=document.elementFromPoint(w,h)?.closest?.("[data-row-index][data-col-index]");if(!V)return null;let _=parseInt(V.getAttribute("data-row-index")??"",10),K=parseInt(V.getAttribute("data-col-index")??"",10),M=i();if(Number.isNaN(_)||Number.isNaN(K)||K<M)return null;let j=K-M;return normalizeSelectionRange({startRow:C.row,startCol:C.col,endRow:_,endCol:j})},E=()=>{c&&(cancelAnimationFrame(c),c=null);},O=()=>{let w=n.value,h=o;if(!w||!h||!a.value){c=null;return}let P=w.getBoundingClientRect(),V=0,_=0;if(h.cy<P.top+Se?_=-computeAutoScrollSpeed(P.top+Se-h.cy):h.cy>P.bottom-Se&&(_=computeAutoScrollSpeed(h.cy-(P.bottom-Se))),h.cx<P.left+Se?V=-computeAutoScrollSpeed(P.left+Se-h.cx):h.cx>P.right-Se&&(V=computeAutoScrollSpeed(h.cx-(P.right-Se))),V===0&&_===0){c=null;return}w.scrollTop+=_,w.scrollLeft+=V;let K=T(h.cx,h.cy);K&&(f=K,B(K)),c=requestAnimationFrame(O);},A=()=>{let w=n.value;if(!w||!o||!a.value){E();return}let h=w.getBoundingClientRect(),P=0,V=0;if(o.cy<h.top+Se?V=-computeAutoScrollSpeed(h.top+Se-o.cy):o.cy>h.bottom-Se&&(V=computeAutoScrollSpeed(o.cy-(h.bottom-Se))),o.cx<h.left+Se?P=-computeAutoScrollSpeed(h.left+Se-o.cx):o.cx>h.right-Se&&(P=computeAutoScrollSpeed(o.cx-(h.right-Se))),P===0&&V===0){E();return}c||(c=requestAnimationFrame(O));},y=w=>{!a.value||!C||(v||(v=true,d.value=true,b=buildCellIndex(n.value)),o={cx:w.clientX,cy:w.clientY},A(),p&&cancelAnimationFrame(p),p=requestAnimationFrame(()=>{if(p=0,!o)return;let h=T(o.cx,o.cy);if(!h)return;let P=f;P&&P.startRow===h.startRow&&P.startCol===h.startCol&&P.endRow===h.endRow&&P.endCol===h.endCol||(f=h,B(h));}));},I=()=>{if(!a.value)return;E(),p&&(cancelAnimationFrame(p),p=0),a.value=false;let w=v;if(w){if(o){let P=T(o.cx,o.cy);P&&(f=P);}let h=f;if(h){m(h);let P=C;P&&t({rowIndex:P.row,columnIndex:P.col+i()});}}F(),f=null,o=null,C=null,w&&(d.value=false);},x=w=>{u.value||y(w);},D=()=>{u.value||I();};return onMounted(()=>{window.addEventListener("pointermove",x,true),window.addEventListener("pointerup",D,true);}),onUnmounted(()=>{u.value=true,window.removeEventListener("pointermove",x,true),window.removeEventListener("pointerup",D,true),p&&cancelAnimationFrame(p),E();}),{selectionRange:s,setSelectionRange:m,handleCellMouseDown:g,handleSelectAllCells:R,isDragging:d}}function Zt(){let e=shallowRef(null);return {contextMenuPosition:e,setContextMenuPosition:i=>{e.value=i;},handleCellContextMenu:i=>{i.preventDefault?.(),e.value={x:i.clientX,y:i.clientY};},closeContextMenu:()=>{e.value=null;}}}function Jt(e){let{items:l,visibleCols:n,selectionRange:t,activeCell:i,editable:s,onCellValueChanged:d,beginBatch:a,endBatch:u}=e,v=()=>isRef(e.colOffset)?e.colOffset.value:e.colOffset,C=shallowRef(null),p=shallowRef(null),f=ref(null),c=()=>{let S=t.value,b=i.value,U=v();return S??(b!=null?{startRow:b.rowIndex,startCol:b.columnIndex-U,endRow:b.rowIndex,endCol:b.columnIndex-U}:null)},o=()=>{let S=c();if(S==null)return;let b=normalizeSelectionRange(S),U=formatSelectionAsTsv(l.value,n.value,b);f.value=U,p.value=b,navigator.clipboard.writeText(U).catch(k=>{typeof console<"u"&&console.warn("[OGrid] Clipboard write failed:",k);});};return {handleCopy:o,handleCut:()=>{if(s.value===false)return;let S=c();if(S==null||d.value==null)return;let b=normalizeSelectionRange(S);C.value=b,p.value=null,o(),p.value=null;},handlePaste:async()=>{if(s.value===false)return;let S=d.value;if(S==null)return;let b;try{b=await navigator.clipboard.readText();}catch{b="";}if(!b.trim()&&f.value!=null&&(b=f.value),!b.trim())return;let U=c(),k=U?U.startRow:0,B=U?U.startCol:0,F=l.value,T=n.value,E=parseTsvClipboard(b);a?.();let O=applyPastedValues(E,k,B,F,T);for(let A of O)S(A);if(C.value){let A=applyCutClear(C.value,F,T);for(let y of A)S(y);C.value=null;}u?.(),p.value=null;},cutRange:C,copyRange:p,clearClipboardRanges:()=>{p.value=null,C.value=null;}}}function Qt(e){let l=dt(e);return {handleGridKeyDown:t=>{let{data:i,state:s,handlers:d,features:a}=l.value,u=i.items.value,v=i.visibleCols.value,{getRowId:C}=i,p=isRef(i.colOffset)?i.colOffset.value:i.colOffset,f=i.hasCheckboxCol.value,c=i.visibleColumnCount.value,o=s.activeCell.value,m=s.selectionRange.value,g=s.editingCell.value,R=s.selectedRowIds.value,{setActiveCell:S,setSelectionRange:b,setEditingCell:U,handleRowCheckboxChange:k,handleCopy:B,handleCut:F,handlePaste:T,setContextMenu:E,onUndo:O,onRedo:A,clearClipboardRanges:y}=d,I=a.editable.value,x=a.onCellValueChanged.value,D=a.rowSelection.value,w=a.wrapperRef,h=a.scrollToRow,{fillDown:P}=a,V=a.onKeyDown?.value;if(V&&(V(t),t.defaultPrevented))return;let _=u.length-1,K=c-1+p;if(u.length===0)return;if(o===null){["ArrowDown","ArrowUp","ArrowLeft","ArrowRight","Tab","Enter","Home","End","PageDown","PageUp"].includes(t.key)&&(S({rowIndex:0,columnIndex:p}),t.preventDefault());return}let{rowIndex:M,columnIndex:j}=o,J=j-p,Y=t.shiftKey,q=(G,Z)=>{if(G<0||G>=u.length||Z<0||Z>=v.length)return true;let ne=getCellValue(u[G],v[Z]);return ne==null||ne===""};switch(t.key){case "c":if(t.ctrlKey||t.metaKey){if(g!=null)break;t.preventDefault(),B();}break;case "x":if(t.ctrlKey||t.metaKey){if(g!=null)break;t.preventDefault(),F();}break;case "v":if(t.ctrlKey||t.metaKey){if(g!=null)break;t.preventDefault(),T();}break;case "d":if(t.ctrlKey||t.metaKey){if(g!=null)break;I!==false&&P&&(t.preventDefault(),P());}break;case "ArrowDown":case "ArrowUp":case "ArrowRight":case "ArrowLeft":{if(g!=null)break;t.preventDefault();let{newRowIndex:G,newColumnIndex:Z,newRange:ne}=computeArrowNavigation({direction:t.key,rowIndex:M,columnIndex:j,dataColIndex:J,colOffset:p,maxRowIndex:_,maxColIndex:K,visibleColCount:v.length,isCtrl:t.ctrlKey||t.metaKey,isShift:Y,selectionRange:m,isEmptyAt:q});b(ne),S({rowIndex:G,columnIndex:Z}),(t.key==="ArrowDown"||t.key==="ArrowUp")&&h?.(G,"center");break}case "Tab":{t.preventDefault();let{rowIndex:G,columnIndex:Z}=computeTabNavigation(M,j,_,K,p,t.shiftKey),ne=Z-p;b({startRow:G,startCol:ne,endRow:G,endCol:ne}),S({rowIndex:G,columnIndex:Z});break}case "Home":{t.preventDefault();let G=t.ctrlKey?0:M;b({startRow:G,startCol:0,endRow:G,endCol:0}),S({rowIndex:G,columnIndex:p});break}case "End":{t.preventDefault();let G=t.ctrlKey?_:M;b({startRow:G,startCol:c-1,endRow:G,endCol:c-1}),S({rowIndex:G,columnIndex:K});break}case "PageDown":case "PageUp":{t.preventDefault();let G=w.value,Z=10;if(G){let Fe=G.querySelector("tbody tr");Fe&&Fe.offsetHeight>0&&(Z=Math.max(1,Math.floor(G.clientHeight/Fe.offsetHeight)));}let ne=t.key==="PageDown"?1:-1,ye=Math.max(0,Math.min(M+ne*Z,_));b(Y?{startRow:m?.startRow??M,startCol:m?.startCol??J,endRow:ye,endCol:m?.endCol??J}:{startRow:ye,startCol:J,endRow:ye,endCol:J}),S({rowIndex:ye,columnIndex:j}),h?.(ye,"center");break}case "Enter":case "F2":{if(t.preventDefault(),J>=0&&J<v.length){let G=v[J],Z=u[M];if(Z&&G){let ne=G.editable===true||typeof G.editable=="function"&&G.editable(Z);I!==false&&ne&&x!=null&&U({rowId:C(Z),columnId:G.columnId});}}break}case "Escape":t.preventDefault(),g!=null?U(null):(y?.(),S(null),b(null));break;case " ":if(D!=="none"&&j===0&&f){t.preventDefault();let G=u[M];if(G){let Z=C(G),ne=R.has(Z);k(Z,!ne,M,t.shiftKey);}}break;case "z":(t.ctrlKey||t.metaKey)&&g==null&&(t.shiftKey&&A?(t.preventDefault(),A()):!t.shiftKey&&O&&(t.preventDefault(),O()));break;case "y":(t.ctrlKey||t.metaKey)&&g==null&&A&&(t.preventDefault(),A());break;case "a":if(t.ctrlKey||t.metaKey){if(g!=null)break;t.preventDefault(),u.length>0&&c>0&&(b({startRow:0,startCol:0,endRow:u.length-1,endCol:c-1}),S({rowIndex:0,columnIndex:p}));}break;case "Delete":case "Backspace":{if(g!=null||I===false||x==null)break;let G=m??(o!=null?{startRow:o.rowIndex,startCol:o.columnIndex-p,endRow:o.rowIndex,endCol:o.columnIndex-p}:null);if(G==null)break;t.preventDefault();let Z=applyCellDeletion(G,u,v);for(let ne of Z)x(ne);break}case "F10":if(t.shiftKey)if(t.preventDefault(),o!=null&&w.value){let G=`[data-row-index="${o.rowIndex}"][data-col-index="${o.columnIndex}"]`,Z=w.value.querySelector(G);if(Z){let ne=Z.getBoundingClientRect();E({x:ne.left+ne.width/2,y:ne.top+ne.height/2});}else E({x:100,y:100});}else E({x:100,y:100});break;}}}}var en="data-drag-range";function Eo(e){let{items:l,visibleCols:n,editable:t,onCellValueChanged:i,selectionRange:s,setSelectionRange:d,setActiveCell:a,wrapperRef:u,beginBatch:v,endBatch:C,visibleRange:p}=e,f=()=>isRef(e.colOffset)?e.colOffset.value:e.colOffset,c=shallowRef(null),o={endRow:0,endCol:0},m=0,g=null,R=null,S=null,b=F=>{c.value=F;},U=()=>{R&&(window.removeEventListener("pointermove",R,true),R=null),S&&(window.removeEventListener("pointerup",S,true),S=null),m&&(cancelAnimationFrame(m),m=0);};return watch(c,(F,T,E)=>{if(!F||t.value===false||!i.value||!u.value){U();return}o={endRow:F.startRow,endCol:F.startCol},g=null;let O=new Set,A=buildCellIndex(u.value),y=w=>{if(!u.value)return;let P=Math.min(w.startRow,w.endRow),V=Math.max(w.startRow,w.endRow),_=Math.min(w.startCol,w.endCol),K=Math.max(w.startCol,w.endCol),M=f();for(let j of O){let J=parseInt(j.getAttribute("data-row-index")??"",10),Y=parseInt(j.getAttribute("data-col-index")??"",10)-M;J>=P&&J<=V&&Y>=_&&Y<=K||(j.removeAttribute(en),O.delete(j));}for(let j=P;j<=V;j++)for(let J=_;J<=K;J++){let Y=cellIndexKey(j,J+M),q=A?.get(Y);q&&!q.isConnected&&(A=buildCellIndex(u.value),q=A.get(Y)),q&&(q.hasAttribute(en)||q.setAttribute(en,""),O.add(q));}},I=()=>{for(let w of O)w.removeAttribute(en);O.clear();},x=null,D=(w,h)=>{let V=document.elementFromPoint(w,h)?.closest?.("[data-row-index][data-col-index]");if(!V||!u.value?.contains(V))return null;let _=parseInt(V.getAttribute("data-row-index")??"",10),K=parseInt(V.getAttribute("data-col-index")??"",10),M=f();if(Number.isNaN(_)||Number.isNaN(K)||K<M)return null;let j=K-M;return normalizeSelectionRange({startRow:F.startRow,startCol:F.startCol,endRow:_,endCol:j})};R=w=>{x={cx:w.clientX,cy:w.clientY},m&&cancelAnimationFrame(m),m=requestAnimationFrame(()=>{if(m=0,!x)return;let h=D(x.cx,x.cy);if(!h)return;let P=g;P&&P.startRow===h.startRow&&P.startCol===h.startCol&&P.endRow===h.endRow&&P.endCol===h.endCol||(g=h,o={endRow:h.endRow,endCol:h.endCol},y(h));});},S=()=>{if(m&&(cancelAnimationFrame(m),m=0),x){let M=D(x.cx,x.cy);M&&(g=M,o={endRow:M.endRow,endCol:M.endCol});}I();let w=o,h=normalizeSelectionRange({startRow:F.startRow,startCol:F.startCol,endRow:w.endRow,endCol:w.endCol}),P=p?.value;P&&(h.startRow=Math.max(h.startRow,P.startIndex),h.endRow=Math.min(h.endRow,P.endIndex)),d(h),a({rowIndex:F.startRow,columnIndex:F.startCol+f()});let V=l.value,_=n.value,K=i.value;if(K){let M=applyFillValues(h,F.startRow,F.startCol,V,_);if(M.length>0){v?.();for(let j of M)K(j);C?.();}}c.value=null,g=null,U();},window.addEventListener("pointermove",R,true),window.addEventListener("pointerup",S,true),E(()=>{U();});}),onUnmounted(()=>U()),{fillDrag:c,setFillDrag:b,handleFillHandleMouseDown:F=>{F.preventDefault(),F.stopPropagation();let T=s.value;T&&(c.value={startRow:T.startRow,startCol:T.startCol});},fillDown:()=>{let F=s.value;if(!F||t.value===false||!i.value)return;let T=normalizeSelectionRange(F),E=l.value,O=n.value,A=i.value,y=applyFillValues(T,T.startRow,T.startCol,E,O);if(y.length>0){v?.();for(let I of y)A(I);C?.();}}}}function tn(e){let{onCellValueChanged:l,maxUndoDepth:n=100,afterChange:t}=e,i=new UndoRedoStack(n),s=ref(false),d=ref(false),a=()=>{s.value=i.canUndo,d.value=i.canRedo;};return {onCellValueChanged:l?c=>{i.record(c),i.isBatching||a(),l(c),i.isBatching||t?.();}:void 0,undo:()=>{if(!l)return;let c=i.undo();if(c){a();for(let o=c.length-1;o>=0;o--){let m=c[o];l({...m,oldValue:m.newValue,newValue:m.oldValue});}t?.();}},redo:()=>{if(!l)return;let c=i.redo();if(c){a();for(let o of c)l(o);t?.();}},canUndo:s,canRedo:d,beginBatch:()=>{i.beginBatch();},endBatch:()=>{i.endBatch(),a(),t?.();},maxUndoDepth:n}}function nn(e){let{wrapperRef:l,visibleCols:n,flatColumns:t,hasCheckboxCol:i,initialColumnWidths:s,onColumnResized:d}=e,a=ref(0),u,v=()=>{let o=l.value;if(!o)return;let m=o.getBoundingClientRect(),g=window.getComputedStyle(o),R=(parseFloat(g.borderLeftWidth||"0")||0)+(parseFloat(g.borderRightWidth||"0")||0);a.value=Math.max(0,m.width-R);};onMounted(()=>{let o=l.value;o&&(typeof ResizeObserver<"u"&&(u=new ResizeObserver(v),u.observe(o)),v());}),onUnmounted(()=>{u?.disconnect();});let C=ref((()=>{if(!s)return {};let o={};for(let[m,g]of Object.entries(s))o[m]={widthPx:g};return o})()),p=o=>{C.value=o;},f=computed(()=>{let o=i.value?CHECKBOX_COLUMN_WIDTH:0;return n.value.reduce((m,g)=>m+(g.minWidth??estimateHeaderMinWidth(g.name))+CELL_PADDING,o)});watch(t,o=>{let m=new Set(o.map(b=>b.columnId)),g=C.value,R=Object.keys(g),S=R.filter(b=>m.has(b));if(S.length<R.length){let b={};for(let U of S)b[U]=g[U];C.value=b;}});let c=computed(()=>{let o=i.value?CHECKBOX_COLUMN_WIDTH:0;return n.value.reduce((m,g)=>{let R=C.value[g.columnId],S=g.minWidth??estimateHeaderMinWidth(g.name),b=R?R.widthPx:g.idealWidth??g.defaultWidth??S;return m+Math.max(S,b)+CELL_PADDING},o)});return {containerWidth:a,minTableWidth:f,desiredTableWidth:c,columnSizingOverrides:C,setColumnSizingOverrides:p,onColumnResized:d}}function on(e){let{columns:l,pinnedColumns:n,onColumnPinned:t}=e,i={};for(let f of l.value)f.pinned&&(i[f.columnId]=f.pinned);let s=ref(i),d=computed(()=>n?.value??s.value);return {pinnedColumns:d,pinColumn:(f,c)=>{let o={...d.value,[f]:c};s.value=o,t?.(f,c);},unpinColumn:f=>{let{[f]:c,...o}=d.value;s.value=o,t?.(f,null);},isPinned:f=>d.value[f],computeLeftOffsets:(f,c,o,m,g)=>{let R={},S=m?g:0;for(let b of f)d.value[b.columnId]==="left"&&(R[b.columnId]=S,S+=c[b.columnId]??o);return R},computeRightOffsets:(f,c,o)=>{let m={},g=0;for(let R=f.length-1;R>=0;R--){let S=f[R];d.value[S.columnId]==="right"&&(m[S.columnId]=g,g+=c[S.columnId]??o);}return m}}}function rn(e){let{columns:l,pinnedColumns:n,onPinColumn:t,onUnpinColumn:i,onSort:s,onColumnResized:d,onAutosizeColumn:a,sortBy:u,sortDirection:v}=e,C=ref(false),p=ref(null),f=ref(null),c=(D,w)=>{p.value=D,f.value=w,C.value=true;},o=()=>{C.value=false,p.value=null,f.value=null;},m=computed(()=>p.value?l.value.find(D=>D.columnId===p.value):void 0),g=computed(()=>p.value?n.value[p.value]:void 0),R=computed(()=>g.value!=="left"),S=computed(()=>g.value!=="right"),b=computed(()=>!!g.value),U=computed(()=>!p.value||!u?.value||u.value!==p.value?null:v?.value??null),k=computed(()=>m.value?.sortable!==false),B=ref(true);return {isOpen:C,openForColumn:p,anchorElement:f,open:c,close:o,handlePinLeft:()=>{p.value&&R.value&&(t(p.value,"left"),o());},handlePinRight:()=>{p.value&&S.value&&(t(p.value,"right"),o());},handleUnpin:()=>{p.value&&b.value&&(i(p.value),o());},handleSortAsc:()=>{p.value&&s&&(s(p.value,"asc"),o());},handleSortDesc:()=>{p.value&&s&&(s(p.value,"desc"),o());},handleClearSort:()=>{p.value&&s&&(s(p.value,null),o());},handleAutosizeThis:()=>{let D=a??d;if(!p.value||!D||!B.value)return;let w=m.value;D(p.value,measureColumnContentWidth(p.value,w?.minWidth)),o();},handleAutosizeAll:()=>{let D=a??d;D&&(l.value.forEach(w=>{D(w.columnId,measureColumnContentWidth(w.columnId,w.minWidth));}),o());},canPinLeft:R,canPinRight:S,canUnpin:b,currentSort:U,isSortable:k,isResizable:B}}var Je=()=>{},la=async()=>{},ra=(e,l,n)=>{},aa=e=>{},ia=e=>{};function sn(e){let{props:l,wrapperRef:n}=e,t=computed(()=>l.value.items),i=l.value.getRowId,s=computed(()=>l.value.rowSelection??"none"),d=computed(()=>l.value.selectedRows),a=computed(()=>l.value.editable),u=computed(()=>l.value.cellSelection!==false),v=computed(()=>l.value.pinnedColumns),C=ref(0),p=()=>{C.value++;},f=tn({onCellValueChanged:l.value.onCellValueChanged,afterChange:p}),c=computed(()=>f.onCellValueChanged),o=computed(()=>flattenColumns(l.value.columns)),m=computed(()=>{let te=v.value;return !te||Object.keys(te).length===0?o.value:o.value.map(Q=>{let re=te[Q.columnId];return re&&Q.pinned!==re?{...Q,pinned:re}:Q})}),g=computed(()=>resolveResponsiveConfig(l.value.responsiveColumns)),R=computed(()=>{let te=l.value.visibleColumns,Q=l.value.columnOrder,re=te?m.value.filter(se=>te.has(se.columnId)):m.value;if(!Q?.length)return re;let me=new Map;for(let se=0;se<Q.length;se++)me.set(Q[se],se);return [...re].sort((se,Me)=>{let we=me.get(se.columnId)??-1,he=me.get(Me.columnId)??-1;return we===-1&&he===-1?0:we===-1?1:he===-1?-1:we-he})}),S=ref(0),b=computed(()=>applyResponsiveHiding(R.value,S.value,g.value)),U=computed(()=>b.value.length),k=computed(()=>s.value==="multiple"),B=computed(()=>!!l.value.showRowNumbers),F=computed(()=>(k.value?1:0)+(B.value?1:0)),T=computed(()=>U.value+F.value),E=F,O=shallowRef(new Map);watch(t,te=>{let Q=O.value;Q.clear(),te.forEach((re,me)=>Q.set(i(re),me)),triggerRef(O);},{immediate:true});let A=qt({items:t,getRowId:i,rowSelection:s,controlledSelectedRows:d,onSelectionChange:l.value.onSelectionChange}),{editingCell:y,setEditingCell:I,pendingEditorValue:x,setPendingEditorValue:D}=jt(),{activeCell:w,setActiveCell:h}=Xt(n,y),P=computed(()=>t.value.length),V=computed(()=>b.value.length),{selectionRange:_,setSelectionRange:K,handleCellMouseDown:M,handleSelectAllCells:j,isDragging:J}=Yt({colOffset:E,rowCount:P,visibleColCount:V,setActiveCell:h,wrapperRef:n}),{contextMenuPosition:Y,setContextMenuPosition:q,handleCellContextMenu:G,closeContextMenu:Z}=Zt(),{handleCopy:ne,handleCut:ye,handlePaste:Fe,cutRange:Ke,copyRange:Pe,clearClipboardRanges:xe}=Jt({items:t,visibleCols:b,colOffset:E,selectionRange:_,activeCell:w,editable:a,onCellValueChanged:c,beginBatch:f.beginBatch,endBatch:f.endBatch}),Ne=(te,Q,re)=>{te.button===0&&(n.value?.focus({preventScroll:true}),xe(),M(te,Q,re));},{handleFillHandleMouseDown:Ve,fillDown:We}=Eo({items:t,visibleCols:b,editable:a,onCellValueChanged:c,selectionRange:_,setSelectionRange:K,setActiveCell:h,colOffset:E,wrapperRef:n,beginBatch:f.beginBatch,endBatch:f.endBatch}),{handleGridKeyDown:$e}=Qt({data:{items:t,visibleCols:b,colOffset:E,hasCheckboxCol:k,visibleColumnCount:U,getRowId:i},state:{activeCell:w,selectionRange:_,editingCell:y,selectedRowIds:A.selectedRowIds},handlers:{setActiveCell:h,setSelectionRange:K,setEditingCell:I,handleRowCheckboxChange:A.handleRowCheckboxChange,handleCopy:ne,handleCut:ye,handlePaste:Fe,setContextMenu:q,onUndo:f.undo,onRedo:f.redo,clearClipboardRanges:xe},features:{editable:a,onCellValueChanged:c,rowSelection:s,wrapperRef:n,fillDown:We,onKeyDown:computed(()=>l.value.onKeyDown)}}),{containerWidth:tt,minTableWidth:nt,desiredTableWidth:mt,columnSizingOverrides:Ue,setColumnSizingOverrides:ft}=nn({wrapperRef:n,visibleCols:R,flatColumns:m,hasCheckboxCol:k,initialColumnWidths:l.value.initialColumnWidths,onColumnResized:(te,Q)=>l.value.onColumnResized?.(te,Q)});watch(tt,te=>{S.value=te;},{immediate:true});let Ie=on({columns:m,pinnedColumns:v,onColumnPinned:l.value.onColumnPinned}),Ct=(te,Q)=>{ft({...Ue.value,[te]:{widthPx:Q}}),l.value.onColumnResized?.(te,Q);},ae=rn({columns:m,pinnedColumns:Ie.pinnedColumns,onPinColumn:Ie.pinColumn,onUnpinColumn:Ie.unpinColumn,onSort:l.value.onColumnSort,onColumnResized:l.value.onColumnResized,onAutosizeColumn:Ct,sortBy:computed(()=>l.value.sortBy),sortDirection:computed(()=>l.value.sortDirection)}),ke=ref({});watch([b,tt,Ue],()=>{nextTick(()=>{let te=n.value;if(!te)return;let Q=te.querySelectorAll("th[data-column-id]");if(Q.length===0)return;let re={};Q.forEach(we=>{let he=we.getAttribute("data-column-id");he&&(re[he]=we.offsetWidth);});let me=ke.value,se=Object.keys(re),Me=se.length!==Object.keys(me).length;if(!Me){for(let we of se)if(me[we]!==re[we]){Me=true;break}}Me&&(ke.value=re);});},{flush:"post"});let ot=computed(()=>{let te={};for(let Q of b.value){let re=Ue.value[Q.columnId];te[Q.columnId]=re?re.widthPx:Q.idealWidth??Q.defaultWidth??Q.minWidth??DEFAULT_MIN_COLUMN_WIDTH;}return te}),lt=computed(()=>Ie.computeLeftOffsets(b.value,ot.value,DEFAULT_MIN_COLUMN_WIDTH,k.value,CHECKBOX_COLUMN_WIDTH)),Ee=computed(()=>Ie.computeRightOffsets(b.value,ot.value,DEFAULT_MIN_COLUMN_WIDTH)),rt=computed(()=>computeAggregations(t.value,b.value,u.value?_.value:null)),at=computed(()=>{let te=getDataGridStatusBarConfig(l.value.statusBar,t.value.length,A.selectedRowIds.value.size);return te?{...te,aggregation:rt.value??void 0}:null}),_e=computed(()=>t.value.length===0&&!!l.value.emptyState&&!l.value.isLoading),ht=computed(()=>_.value!=null||w.value!=null),Rt=computed(()=>({sortBy:l.value.sortBy,sortDirection:l.value.sortDirection,onColumnSort:l.value.onColumnSort,filters:l.value.filters,onFilterChange:l.value.onFilterChange,filterOptions:l.value.filterOptions,loadingFilterOptions:l.value.loadingFilterOptions,peopleSearch:l.value.peopleSearch})),Be=computed(()=>({editingCell:y.value,activeCell:u.value?w.value:null,selectionRange:u.value?_.value:null,cutRange:u.value?Ke.value:null,copyRange:u.value?Pe.value:null,colOffset:E.value,itemsLength:t.value.length,getRowId:i,editable:a.value,onCellValueChanged:c.value,isDragging:u.value?J.value:false,getFormulaValue:l.value.getFormulaValue,hasFormula:l.value.hasFormula,getFormula:l.value.getFormula,formulaVersion:l.value.formulaVersion})),pt=ref(null),it=te=>{pt.value=te;},bt=(te,Q,re,me,se,Me,we)=>{let he=b.value.find(ge=>ge.columnId===Q);if(he){let ge=parseValue(me,re,te,he);if(!ge.valid){I(null),it(null),D(void 0);return}me=ge.value;}if(I(null),it(null),D(void 0),Object.is(me,re)||c.value?.({item:te,columnId:Q,oldValue:re,newValue:me,rowIndex:se}),!we?.skipAdvance&&se<t.value.length-1){let ge=se+1,yt=Me-E.value;h({rowIndex:ge,columnIndex:Me}),K({startRow:ge,startCol:yt,endRow:ge,endCol:yt});}},It=()=>{I(null),it(null),D(void 0);},ve=computed(()=>({flatColumns:m.value,visibleCols:b.value,visibleColumnCount:U.value,totalColCount:T.value,colOffset:E.value,hasCheckboxCol:k.value,hasRowNumbersCol:B.value,rowIndexByRowId:O.value,containerWidth:tt.value,minTableWidth:nt.value,desiredTableWidth:mt.value,columnSizingOverrides:Ue.value,setColumnSizingOverrides:ft,onColumnResized:l.value.onColumnResized,measuredColumnWidths:ke.value,stickyHeader:l.value.stickyHeader??true})),St=computed(()=>({selectedRowIds:A.selectedRowIds.value,updateSelection:A.updateSelection,handleRowCheckboxChange:A.handleRowCheckboxChange,handleSelectAll:A.handleSelectAll,allSelected:A.allSelected.value,someSelected:A.someSelected.value})),Tt=computed(()=>({editingCell:y.value,setEditingCell:I,pendingEditorValue:x.value,setPendingEditorValue:D,commitCellEdit:bt,cancelPopoverEdit:It,popoverAnchorEl:pt.value,setPopoverAnchorEl:it})),qe=computed(()=>(C.value,{activeCell:u.value?w.value:null,setActiveCell:u.value?h:Je,selectionRange:u.value?_.value:null,setSelectionRange:u.value?K:Je,handleCellMouseDown:u.value?Ne:ra,handleSelectAllCells:u.value?j:Je,hasCellSelection:u.value?ht.value:false,handleGridKeyDown:u.value?$e:aa,handleFillHandleMouseDown:u.value?Ve:Je,handleCopy:u.value?ne:Je,handleCut:u.value?ye:Je,handlePaste:u.value?Fe:la,cutRange:u.value?Ke.value:null,copyRange:u.value?Pe.value:null,clearClipboardRanges:u.value?xe:Je,canUndo:f.canUndo.value,canRedo:f.canRedo.value,onUndo:f.undo,onRedo:f.redo,isDragging:u.value?J.value:false})),wt=computed(()=>({menuPosition:u.value?Y.value:null,setMenuPosition:u.value?q:Je,handleCellContextMenu:u.value?G:ia,closeContextMenu:u.value?Z:Je})),Pt=computed(()=>({headerFilterInput:Rt.value,cellDescriptorInput:Be.value,statusBarConfig:at.value,showEmptyInGrid:_e.value,onCellError:l.value.onCellError})),Et=computed(()=>({pinnedColumns:Ie.pinnedColumns.value,pinColumn:Ie.pinColumn,unpinColumn:Ie.unpinColumn,isPinned:Ie.isPinned,leftOffsets:lt.value,rightOffsets:Ee.value,headerMenu:{isOpen:ae.isOpen.value,openForColumn:ae.openForColumn.value,anchorElement:ae.anchorElement.value,open:ae.open,close:ae.close,handlePinLeft:ae.handlePinLeft,handlePinRight:ae.handlePinRight,handleUnpin:ae.handleUnpin,handleSortAsc:ae.handleSortAsc,handleSortDesc:ae.handleSortDesc,handleClearSort:ae.handleClearSort,handleAutosizeThis:ae.handleAutosizeThis,handleAutosizeAll:ae.handleAutosizeAll,canPinLeft:ae.canPinLeft.value,canPinRight:ae.canPinRight.value,canUnpin:ae.canUnpin.value,currentSort:ae.currentSort.value,isSortable:ae.isSortable.value,isResizable:ae.isResizable.value}}));return {layout:ve,rowSelection:St,editing:Tt,interaction:qe,contextMenu:wt,viewModels:Pt,pinning:Et}}function Ho(e){let{rangeSelection:l,rows:n,columns:t,onFillCells:i}=e,s=ref(null),d=computed(()=>s.value!==null),a=computed(()=>{let c=l.range.value;return c?s.value?normalizeSelectionRange({startRow:Math.min(c.startRow,s.value.row),startCol:Math.min(c.startCol,s.value.col),endRow:Math.max(c.endRow,s.value.row),endCol:Math.max(c.endCol,s.value.col)}):c:null});return {fillTarget:s,isFilling:d,startFill:()=>{let c=l.range.value;c&&(s.value={row:c.endRow,col:c.endCol});},updateFill:(c,o)=>{s.value!==null&&(s.value={row:c,col:o});},commitFill:()=>{let c=l.range.value,o=a.value;if(!c||!o){s.value=null;return}if(o.startRow===c.startRow&&o.startCol===c.startCol&&o.endRow===c.endRow&&o.endCol===c.endCol){s.value=null;return}let m=applyFillValues(o,c.startRow,c.startCol,n,t);m.length>0&&i(m),s.value=null;},cancelFill:()=>{s.value=null;},fillRange:a,isInFillRange:(c,o)=>{let m=a.value;return m?isInSelectionRange(m,c,o):false}}}function Bo(e){let{columns:l,getRowId:n,onCellEdit:t,isCellEditable:i}=e,s=ref(null),d=ref(void 0),a=shallowRef(null),u=g=>l.find(R=>R.columnId===g),v=(g,R)=>{if(i)return i(g,R);let S=u(R);return S?isColumnEditable(S,g):false},C=(g,R)=>{let S=s.value;return S?S.rowId===n(g)&&S.columnId===R:false},p=g=>{d.value=g;},f=(g,R)=>{if(!v(g,R))return;let S=u(R);if(!S)return;let b=getCellValue(g,S);s.value={rowId:n(g),columnId:R},a.value={item:g,oldValue:b},d.value=b;},c=()=>{s.value=null,a.value=null,d.value=void 0;},o=()=>{let g=s.value,R=a.value;if(!g||!R)return;let S=u(g.columnId);if(!S){c();return}let b=d.value,U=parseValue(b,R.oldValue,R.item,S);if(!U.valid){c();return}if(b=U.value,b===R.oldValue){c();return}t({item:R.item,columnId:g.columnId,oldValue:R.oldValue,newValue:b}),s.value=null,a.value=null,d.value=void 0;};return {editingCell:s,pendingValue:d,setPendingValue:p,startEdit:f,commitEdit:o,cancelEdit:c,isEditing:C,canEdit:v,getEditorProps:(g,R)=>({value:d.value,onChange:p,onCommit:o,onCancel:c,onKeyDown:S=>{S.key==="Enter"?(S.preventDefault?.(),o()):S.key==="Escape"&&(S.preventDefault?.(),c());},onBlur:o})}}function No(e){let{rowCount:l,colCount:n}=e,t=ref(null),i=ref(null),s=computed(()=>!t.value||!i.value?null:normalizeSelectionRange({startRow:t.value.row,startCol:t.value.col,endRow:i.value.row,endCol:i.value.col}));return {range:s,anchor:t,focus:i,startRange:(o,m)=>{t.value={row:o,col:m},i.value={row:o,col:m};},extendRange:(o,m)=>{t.value||(t.value={row:o,col:m}),i.value={row:o,col:m};},setRange:o=>{if(!o){t.value=null,i.value=null;return}let m=normalizeSelectionRange(o);t.value={row:m.startRow,col:m.startCol},i.value={row:m.endRow,col:m.endCol};},clearRange:()=>{t.value=null,i.value=null;},selectAll:()=>{l<=0||n<=0||(t.value={row:0,col:0},i.value={row:l-1,col:n-1});},isInRange:(o,m)=>{let g=s.value;return g?isInSelectionRange(g,o,m):false},getRangeRows:()=>{let o=s.value;if(!o)return [];let m=[];for(let g=o.startRow;g<=o.endRow;g+=1)m.push(g);return m},getRangeCells:()=>{let o=s.value;if(!o)return [];let m=[];for(let g=o.startRow;g<=o.endRow;g+=1)for(let R=o.startCol;R<=o.endCol;R+=1)m.push({row:g,col:R});return m}}}var wa={readText:()=>typeof navigator<"u"&&navigator.clipboard?.readText?navigator.clipboard.readText():Promise.resolve(""),writeText:e=>typeof navigator<"u"&&navigator.clipboard?.writeText?navigator.clipboard.writeText(e):Promise.resolve()};function Ko(e){let{rangeSelection:l,rows:n,columns:t,onCellEdit:i,clipboard:s=wa}=e,d=ref(null),a=ref(null),u=computed(()=>typeof navigator<"u"&&!!navigator.clipboard?.readText);return {copyRange:async()=>{let c=l.range.value;if(!c)return;let o=formatSelectionAsTsv(n,t,c);await s.writeText(o),a.value=c,d.value=null;},cutRange:async()=>{let c=l.range.value;if(!c)return;let o=formatSelectionAsTsv(n,t,c);await s.writeText(o),d.value=c,a.value=null;},pasteRange:async()=>{let c=l.range.value;if(!c)return;let o=await s.readText(),m=parseTsvClipboard(o);if(m.length===0)return;let g=applyPastedValues(m,c.startRow,c.startCol,n,t),R=g;if(d.value){let S=applyCutClear(d.value,n,t),b=new Set(g.map(k=>`${k.rowIndex}|${k.columnId}`)),U=S.filter(k=>!b.has(`${k.rowIndex}|${k.columnId}`));R=[...g,...U];}R.length>0&&i(R),d.value=null,a.value=null;},canPaste:u,activeCutRange:d,activeCopyRange:a,clearClipboard:()=>{d.value=null,a.value=null;}}}var $o=(e,l,n)=>Math.max(l,Math.min(n,e));function qo(e){let{rowCount:l,colCount:n,pageSize:t=10,rangeSelection:i}=e,s=ref(null),d=R=>{s.value=R;},a=(R,S,b=false)=>{if(l<=0||n<=0)return;let U=s.value??{row:0,col:0},k={row:$o(U.row+R,0,l-1),col:$o(U.col+S,0,n-1)};i&&(b?i.extendRange(k.row,k.col):i.startRange(k.row,k.col)),s.value=k;},u=(R=1)=>a(-R,0),v=(R=1)=>a(R,0),C=(R=1)=>a(0,-R),p=(R=1)=>a(0,R),f=()=>{let R=s.value?.row??0;s.value={row:R,col:0},i?.startRange(R,0);},c=()=>{let R=s.value?.row??0,S=Math.max(0,n-1);s.value={row:R,col:S},i?.startRange(R,S);},o=()=>{s.value={row:0,col:0},i?.startRange(0,0);},m=()=>{let R={row:Math.max(0,l-1),col:Math.max(0,n-1)};s.value=R,i?.startRange(R.row,R.col);};return {activeCell:s,setActiveCell:d,moveUp:u,moveDown:v,moveLeft:C,moveRight:p,moveToRowStart:f,moveToRowEnd:c,moveToStart:o,moveToEnd:m,getKeyDownHandler:()=>R=>{let S=R.shiftKey===true,b=R.ctrlKey===true||R.metaKey===true;switch(R.key){case "ArrowUp":R.preventDefault?.(),a(-1,0,S);break;case "ArrowDown":R.preventDefault?.(),a(1,0,S);break;case "ArrowLeft":R.preventDefault?.(),a(0,-1,S);break;case "ArrowRight":case "Tab":R.preventDefault?.(),a(0,S&&R.key==="Tab"?-1:1,false);break;case "Enter":R.preventDefault?.(),a(S?-1:1,0,false);break;case "Home":R.preventDefault?.(),b?o():f();break;case "End":R.preventDefault?.(),b?m():c();break;case "PageUp":R.preventDefault?.(),a(-t,0,S);break;case "PageDown":R.preventDefault?.(),a(t,0,S);break;}}}}function un(e){let{columnSizingOverrides:l,setColumnSizingOverrides:n,minWidth:t=80,defaultWidth:i=120,onColumnResized:s}=e,d=0,a=null;return onUnmounted(()=>{a?.(),a=null;}),{handleResizeStart:(p,f)=>{p.preventDefault(),p.stopPropagation();let c=p.clientX,o=f.columnId,m=p.currentTarget.parentElement,g=m?m.getBoundingClientRect().width:l.value[o]?.widthPx??f.idealWidth??f.defaultWidth??i,R=g,S=document.body.style.cursor,b=document.body.style.userSelect;document.body.style.cursor="col-resize",document.body.style.userSelect="none";let U=()=>{n({...l.value,[o]:{widthPx:R}});},k=o===ROW_NUMBER_COLUMN_ID?ROW_NUMBER_COLUMN_MIN_WIDTH:t,B=E=>{let O=E.clientX-c;R=Math.max(k,g+O),d||(d=requestAnimationFrame(()=>{d=0,U();}));},F=()=>{document.removeEventListener("pointermove",B),document.removeEventListener("pointerup",T),a=null,document.body.style.cursor=S,document.body.style.userSelect=b,d&&(cancelAnimationFrame(d),d=0);},T=()=>{F(),U(),s?.(o,R);};document.addEventListener("pointermove",B),document.addEventListener("pointerup",T),a=F;},handleResizeDoubleClick:(p,f)=>{p.preventDefault(),p.stopPropagation();let c=f.columnId,m=(p.currentTarget.closest("th")??p.currentTarget.parentElement)?.closest("table")?.parentElement??void 0,g=measureColumnContentWidth(c,t,m);n({...l.value,[c]:{widthPx:g}}),s?.(c,g);},getColumnWidth:p=>l.value[p.columnId]?.widthPx??p.idealWidth??p.defaultWidth??i}}function dn(e,l){let n=ref(e.value),t;return watch(e,i=>{t!==void 0&&clearTimeout(t),t=setTimeout(()=>{n.value=i;},l);}),onUnmounted(()=>{t!==void 0&&clearTimeout(t);}),n}function Xo(e,l){let n,t=e,i,s=((...d)=>{t=e,i=d,n!==void 0&&clearTimeout(n),n=setTimeout(()=>{t(...d),i=void 0,n=void 0;},l);});return s.cancel=()=>{n!==void 0&&clearTimeout(n),n=void 0,i=void 0;},s.flush=()=>{if(n!==void 0&&i!==void 0){clearTimeout(n),n=void 0;let d=i;i=void 0,t(...d);}},onUnmounted(()=>{n!==void 0&&clearTimeout(n);}),s}function cn(e){let{textValue:l="",onTextChange:n}=e,t=ref(l);return watch(e.isFilterOpen,a=>{a&&(t.value=e.textValue??"");}),{tempTextValue:t,setTempTextValue:a=>{t.value=a;},handleTextApply:()=>{n?.(t.value.trim());},handleTextClear:()=>{t.value="";}}}var Oa=150,Jn=[];function mn(e){let{onFilterChange:l}=e,n=ref(new Set(e.selectedValues??Jn)),t=ref(""),i=dn(t,Oa);watch(e.isFilterOpen,f=>{f&&(n.value=new Set(e.selectedValues??Jn),t.value="");});let s=computed(()=>{let f=e.options??Jn;if(!i.value.trim())return f;let c=i.value.toLowerCase().trim();return f.filter(o=>o.toLowerCase().includes(c))});return {tempSelected:n,setTempSelected:f=>{n.value=f;},searchText:t,setSearchText:f=>{t.value=f;},debouncedSearchText:i,filteredOptions:s,handleCheckboxChange:(f,c)=>{let o=new Set(n.value);c?o.add(f):o.delete(f),n.value=o;},handleSelectAll:()=>{n.value=new Set(s.value);},handleClearSelection:()=>{n.value=new Set;},handleApplyMultiSelect:()=>{l?.(Array.from(n.value));}}}var La=300;function pn(e){let{onUserChange:l,filterType:n}=e,t=ref(null),i,s=ref([]),d=ref(false),a=ref(""),u=p=>{a.value=p;};return watch(e.isFilterOpen,p=>{p&&(a.value="",s.value=[],n==="people"&&setTimeout(()=>t.value?.focus(),50));}),watch([a,()=>e.peopleSearch,e.isFilterOpen],([p,f,c])=>{if(i&&clearTimeout(i),!(!f||!c||n!=="people")){if(!p.trim()){s.value=[];return}d.value=true,i=setTimeout(async()=>{try{let o=await f(p);s.value=o.slice(0,10);}catch{s.value=[];}finally{d.value=false;}},La);}}),onUnmounted(()=>{i&&clearTimeout(i);}),{peopleSuggestions:s,isPeopleLoading:d,peopleSearchText:a,setPeopleSearchText:u,peopleInputRef:t,handleUserSelect:p=>{l?.(p);},handleClearUser:()=>{l?.(void 0);}}}function vn(e){let{onDateChange:l}=e,n=ref(e.dateValue?.from??""),t=ref(e.dateValue?.to??"");return watch(e.isFilterOpen,u=>{u&&(n.value=e.dateValue?.from??"",t.value=e.dateValue?.to??"");}),{tempDateFrom:n,setTempDateFrom:u=>{n.value=u;},tempDateTo:t,setTempDateTo:u=>{t.value=u;},handleDateApply:()=>{let u=n.value||void 0,v=t.value||void 0;l?.(u||v?{from:u,to:v}:void 0);},handleDateClear:()=>{n.value="",t.value="";}}}var Ga=[];function el(e){let{filterType:l,onSort:n}=e,t=()=>e.selectedValues??Ga,i=ref(null),s=ref(null),d=ref(false),a=ref(null),u=D=>{d.value=D;},v=cn({textValue:e.textValue,onTextChange:e.onTextChange,isFilterOpen:d}),C=mn({selectedValues:e.selectedValues,onFilterChange:e.onFilterChange,options:e.options,isFilterOpen:d}),p=pn({selectedUser:e.selectedUser,onUserChange:e.onUserChange,peopleSearch:e.peopleSearch,isFilterOpen:d,filterType:l}),f=vn({dateValue:e.dateValue,onDateChange:e.onDateChange,isFilterOpen:d});watch(d,D=>{D||(a.value=null);});let c=null,o=null,m,g=()=>{R(),c=D=>{let w=D.target;s.value&&!s.value.contains(w)&&i.value&&!i.value.contains(w)&&(d.value=false);},o=D=>{(D.key==="Escape"||D.key==="Esc")&&(D.preventDefault(),D.stopPropagation(),d.value=false);},m=setTimeout(()=>{c&&document.addEventListener("mousedown",c);},0),document.addEventListener("keydown",o,true);},R=()=>{m&&clearTimeout(m),c&&document.removeEventListener("mousedown",c),o&&document.removeEventListener("keydown",o,true),c=null,o=null;};watch(d,D=>{D?g():R();}),onUnmounted(()=>R());let S=D=>{if(D.stopPropagation(),D.preventDefault(),!d.value&&i.value){let w=i.value.getBoundingClientRect();a.value={top:w.bottom+4,left:w.left};}d.value=!d.value;},b=D=>{D.stopPropagation(),n?.();},U=()=>{C.handleApplyMultiSelect(),d.value=false;},k=()=>{v.handleTextApply(),d.value=false;},B=D=>{p.handleUserSelect(D),d.value=false;},F=()=>{p.handleClearUser(),d.value=false;},T=()=>{f.handleDateApply(),d.value=false;},E=D=>D.stopPropagation(),O=D=>D.stopPropagation(),A=D=>D.stopPropagation(),y=D=>D.stopPropagation(),I=D=>{D.key!=="Escape"&&D.key!=="Esc"&&D.stopPropagation();},x=computed(()=>l==="multiSelect"?t().length>0:l==="text"?!!(e.textValue??"").trim():l==="people"?!!e.selectedUser:l==="date"?!!(e.dateValue?.from||e.dateValue?.to):false);return {headerRef:i,popoverRef:s,peopleInputRef:p.peopleInputRef,isFilterOpen:d,setFilterOpen:u,tempSelected:C.tempSelected,setTempSelected:C.setTempSelected,tempTextValue:v.tempTextValue,setTempTextValue:v.setTempTextValue,searchText:C.searchText,setSearchText:C.setSearchText,debouncedSearchText:C.debouncedSearchText,filteredOptions:C.filteredOptions,peopleSuggestions:p.peopleSuggestions,isPeopleLoading:p.isPeopleLoading,peopleSearchText:p.peopleSearchText,setPeopleSearchText:p.setPeopleSearchText,tempDateFrom:f.tempDateFrom,setTempDateFrom:f.setTempDateFrom,tempDateTo:f.tempDateTo,setTempDateTo:f.setTempDateTo,hasActiveFilter:x,popoverPosition:a,handlers:{handleFilterIconClick:S,handleApplyMultiSelect:U,handleTextApply:k,handleTextClear:v.handleTextClear,handleUserSelect:B,handleClearUser:F,handleCheckboxChange:C.handleCheckboxChange,handleSelectAll:C.handleSelectAll,handleClearSelection:C.handleClearSelection,handlePopoverClick:E,handleInputFocus:O,handleInputMouseDown:A,handleInputClick:y,handleInputKeyDown:I,handleDateApply:T,handleDateClear:f.handleDateClear,handleSortClick:b}}}function nl(e){let{columns:l,visibleColumns:n,onVisibilityChange:t}=e,i=ref(false),s=null,d=()=>{a(),s=g=>{g.key==="Escape"&&(g.preventDefault(),i.value=false);},document.addEventListener("keydown",s,true);},a=()=>{s&&(document.removeEventListener("keydown",s,true),s=null);};watch(i,g=>{g?d():a();}),onUnmounted(()=>a());let u=g=>{i.value=g;},v=()=>{i.value=!i.value;},C=()=>{i.value=false;},p=g=>R=>{t(g,R);},f=()=>{l.value.forEach(g=>{n.value.has(g.columnId)||t(g.columnId,true);});},c=()=>{l.value.forEach(g=>{!g.required&&n.value.has(g.columnId)&&t(g.columnId,false);});},o=computed(()=>n.value.size),m=computed(()=>l.value.length);return {open:i,setOpen:u,handleToggle:v,handleClose:C,handleCheckboxChange:p,handleSelectAll:f,handleClearAll:c,visibleCount:o,totalCount:m}}function ol(e){let{value:l,editorType:n,onCommit:t,onCancel:i,dateFormat:s,dateEditorType:d}=e,a=s??DEFAULT_DATE_FORMAT,u=ref((()=>{if(l==null)return "";if(n==="date"){if(d==="native"){let m=String(l);return m.match(/^\d{4}-\d{2}-\d{2}/)?m.substring(0,10):m}return formatDateForDisplay(l,a)??""}return String(l)})()),v=m=>{u.value=m;},C=m=>{if(n==="date"&&d!=="native"){if(!m||!m.trim()){t(null);return}let g=parseUserInputDate(m,a);if(g!==null){let R=g.getUTCFullYear().toString().padStart(4,"0"),S=(g.getUTCMonth()+1).toString().padStart(2,"0"),b=g.getUTCDate().toString().padStart(2,"0");t(`${R}-${S}-${b}`);}else t(null);}else t(m);},p=m=>{t(m);},f=()=>{i();};return {localValue:u,setLocalValue:v,handleKeyDown:m=>{m.key==="Escape"&&(m.preventDefault(),m.stopPropagation(),f()),m.key==="Enter"&&(n==="text"||n==="date")&&(m.preventDefault(),m.stopPropagation(),C(u.value));},handleBlur:()=>{(n==="text"||n==="date")&&C(u.value);},commit:p,cancel:f}}function rl(e){let{values:l,formatValue:n,initialValue:t,onCommit:i,onCancel:s}=e,d=ref(""),a=l.findIndex(o=>String(o)===String(t)),u=ref(Math.max(a,0)),v=o=>{d.value=o;},C=o=>n?n(o):o!=null?String(o):"",p=computed(()=>{if(!d.value.trim())return l;let o=d.value.toLowerCase();return l.filter(m=>C(m).toLowerCase().includes(o))}),f=o=>{i(o);};return {searchText:d,setSearchText:v,filteredValues:p,highlightedIndex:u,handleKeyDown:o=>{switch(o.key){case "ArrowDown":o.preventDefault(),u.value=Math.min(u.value+1,p.value.length-1);break;case "ArrowUp":o.preventDefault(),u.value=Math.max(u.value-1,0);break;case "Enter":o.preventDefault(),o.stopPropagation(),p.value.length>0&&u.value<p.value.length&&f(p.value[u.value]);break;case "Escape":o.preventDefault(),o.stopPropagation(),s();break}},selectValue:f,getDisplayText:C}}var Qa=8,ei=5;function Cn(e){let{columnOrder:l,onColumnOrderChange:n,tableRef:t,pinnedColumns:i}=e,s=ref(false),d=ref(null),a=null,u="unpinned",v=0,C=null;return onUnmounted(()=>{C?.(),C=null;}),{isDragging:s,dropIndicatorX:d,handleHeaderMouseDown:(f,c)=>{if(c.button!==0)return;let o=c.target.closest("th");if(o){let E=o.getBoundingClientRect();if(c.clientX>E.right-Qa)return}if(c.preventDefault(),!t.value||!n.value)return;a=f,u=getPinStateForColumn(f,i?.value),d.value=null;let g=c.clientX,R=false,S=c.clientX,b=-1,U=document.body.style.cursor,k=document.body.style.userSelect;document.body.style.cursor="grabbing",document.body.style.userSelect="none";let B=E=>{!R&&Math.abs(E.clientX-g)<ei||(R||(R=true,s.value=true),S=E.clientX,v||(v=requestAnimationFrame(()=>{v=0;let O=t.value;if(!O||!a)return;let A=calculateDropTarget({mouseX:S,columnOrder:l.value,draggedColumnId:a,draggedPinState:u,tableElement:O,pinnedColumns:i?.value});A?(b=A.targetIndex,d.value=A.indicatorX):d.value=null;})));},F=()=>{window.removeEventListener("pointermove",B,true),window.removeEventListener("pointerup",T,true),C=null,document.body.style.cursor=U,document.body.style.userSelect=k,v&&(cancelAnimationFrame(v),v=0);},T=()=>{if(F(),R&&a&&b>=0&&n.value){let E=reorderColumnArray(l.value,a,b);n.value(E);}a=null,s.value=false,d.value=null,b=-1;};window.addEventListener("pointermove",B,true),window.addEventListener("pointerup",T,true),C=F;}}}var ui=100;function Rn(e){let{totalRows:l,rowHeight:n,enabled:t,overscan:i=5,threshold:s=ui,columnsEnabled:d,columnWidths:a,columnOverscan:u=2}=e;onMounted(()=>{validateVirtualScrollConfig({enabled:t.value,rowHeight:n});});let v=ref(null),C=ref(0),p=ref(0),f=ref(0),c=ref(0),o=0,m,g=null,R=computed(()=>t.value&&l.value>=s),S=computed(()=>R.value?computeVisibleRange(C.value,n,f.value,l.value,i):{startIndex:0,endIndex:Math.max(0,l.value-1),offsetTop:0,offsetBottom:0}),b=computed(()=>t.value?computeTotalHeight(l.value,n):0),U=computed(()=>{if(!d?.value)return null;let T=a?.value;return !T||T.length===0?null:computeVisibleColumnRange(p.value,T,c.value,u)}),k=()=>{o||(o=requestAnimationFrame(()=>{o=0;let T=v.value;T&&(C.value=T.scrollTop,p.value=T.scrollLeft);}));},B=()=>{let T=v.value;T&&(f.value=T.clientHeight,c.value=T.clientWidth);};return watch(v,T=>{T!==g&&(g&&g.removeEventListener("scroll",k),m&&(m.disconnect(),m=void 0),g=T,T&&(T.addEventListener("scroll",k,{passive:true}),typeof ResizeObserver<"u"&&(m=new ResizeObserver(B),m.observe(T)),B(),C.value=T.scrollTop,p.value=T.scrollLeft));}),onUnmounted(()=>{let T=v.value;T&&T.removeEventListener("scroll",k),m?.disconnect(),o&&(cancelAnimationFrame(o),o=0);}),{containerRef:v,visibleRange:S,totalHeight:b,scrollToRow:(T,E="start")=>{let O=v.value;O&&(O.scrollTop=getScrollTopForRow(T,n,f.value,E));},columnRange:U,scrollLeft:p}}function Sn(e){let{props:l}=e,n=ref(null),t=ref(null),i=ref(null),s=ref(false),d=sn({props:l,wrapperRef:n}),a=computed(()=>{let B=l.value;return B.columnOrder?B.columnOrder:flattenColumns(B.columns).filter(F=>B.visibleColumns?.has(F.columnId)??true).map(F=>F.columnId)}),u=computed(()=>l.value.onColumnOrderChange),v=Cn({columnOrder:a,onColumnOrderChange:u,tableRef:i}),C=computed(()=>l.value.virtualScroll?.enabled??false),p=computed(()=>l.value.items.length),f=l.value.virtualScroll?.rowHeight??36,c=l.value.virtualScroll?.overscan??5,o=computed(()=>l.value.virtualScroll?.columns===true),m=l.value.virtualScroll?.columnOverscan??2,g=computed(()=>{let B=d.layout.value,{visibleCols:F,columnSizingOverrides:T}=B,E=l.value.pinnedColumns??{},O=[];for(let A of F){if(E[A.columnId]||A.pinned)continue;let y=T[A.columnId];O.push(y?y.widthPx:A.defaultWidth??A.minWidth??DEFAULT_MIN_COLUMN_WIDTH);}return O}),R=Rn({totalRows:p,rowHeight:f,enabled:C,overscan:c,columnsEnabled:o,columnWidths:g,columnOverscan:m}),S=computed(()=>{if(!o.value)return null;let F=d.layout.value.visibleCols,T=R.columnRange.value,E=l.value.pinnedColumns;return partitionColumnsForVirtualization(F,T,E)}),b=computed(()=>{let F=d.layout.value.visibleCols,T=new Map;for(let E=0;E<F.length;E++)T.set(F[E].columnId,E);return T}),U=computed(()=>d.layout.value.columnSizingOverrides),k=un({columnSizingOverrides:U,setColumnSizingOverrides:B=>d.layout.value.setColumnSizingOverrides(B)});return {wrapperRef:n,tableContainerRef:t,tableRef:i,lastMouseShift:s,state:d,columnReorder:v,virtualScroll:R,virtualScrollEnabled:C,columnResize:k,columnPartition:S,globalColIndexMap:b}}function wn(e,l,n){let t={"data-row-index":e.rowIndex,"data-col-index":e.globalColIndex,...e.isActive?{"data-active-cell":"true"}:{},...e.isInRange?{"data-in-range":"true"}:{},tabindex:e.isActive?0:-1,onPointerdown:i=>{n.setEditingCell(null),n.handleCellMouseDown(i,e.rowIndex,e.globalColIndex);},onClick:()=>n.setActiveCell({rowIndex:e.rowIndex,columnIndex:e.globalColIndex}),onContextmenu:i=>n.handleCellContextMenu(i)};return e.canEditAny&&(t.role="button",t.onDblclick=()=>n.setEditingCell({rowId:e.rowId,columnId:l})),t}var il=()=>{};function Si(e){return defineComponent({name:"DataGridTable",props:{gridProps:{type:Object,required:true}},setup(l){let n=computed(()=>l.gridProps),{wrapperRef:t,tableContainerRef:i,tableRef:s,lastMouseShift:d,state:a,columnReorder:{isDragging:u,dropIndicatorX:v,handleHeaderMouseDown:C},virtualScroll:{containerRef:p,visibleRange:f,totalHeight:c,scrollToRow:o},virtualScrollEnabled:m,columnResize:{handleResizeStart:g,handleResizeDoubleClick:R,getColumnWidth:S},columnPartition:b,globalColIndexMap:U}=Sn({props:n}),k=computed(()=>{let x=n.value;return x.showRowNumbers||x.showColumnLetters?((x.currentPage??1)-1)*(x.pageSize??25):0});watch([()=>a.interaction.value.activeCell,k],([x,D])=>{let w=n.value.onActiveCellChange;w&&w(x?formatCellReference(x.columnIndex-a.layout.value.colOffset,D+x.rowIndex+1):null);},{immediate:true});let B=x=>{d.value=x.shiftKey;},F=x=>{x.button===0&&x.preventDefault();},T=x=>{x.button===0&&x.preventDefault();},E=x=>{x.preventDefault();},O=x=>x.preventDefault(),A=x=>x.stopPropagation(),y=computed(()=>buildHeaderRows(n.value.columns,n.value.visibleColumns)),I=computed(()=>{let x=a.layout.value,D=a.pinning.value,{visibleCols:w,columnSizingOverrides:h,measuredColumnWidths:P}=x,{leftOffsets:V,rightOffsets:_}=D,K={},M={},j={},J={};for(let Y=0;Y<w.length;Y++){let q=w[Y],G=q.pinned==="left",Z=q.pinned==="right",ne=S(q),ye=!!h[q.columnId],Fe=P[q.columnId],Ke=q.minWidth??estimateHeaderMinWidth(q.name),Pe=ye?ne:Math.max(Ke,Fe??0),xe=q.width,Ne={minWidth:`${Pe}px`,width:xe??`${ne}px`,...xe?{}:{maxWidth:`${ne}px`}},Ve={minWidth:`${Pe}px`,width:xe??`${ne}px`,...xe?{}:{maxWidth:`${ne}px`}},We=["ogrid-data-cell"],$e=["ogrid-header-cell"];G?(We.push("ogrid-data-cell--pinned-left"),Ne.left=`${V[q.columnId]??0}px`,$e.push("ogrid-header-cell--pinned-left"),Ve.left=`${V[q.columnId]??0}px`):Z&&(We.push("ogrid-data-cell--pinned-right"),Ne.right=`${_[q.columnId]??0}px`,$e.push("ogrid-header-cell--pinned-right"),Ve.right=`${_[q.columnId]??0}px`),K[q.columnId]=Ne,M[q.columnId]=We.join(" "),j[q.columnId]=Ve,J[q.columnId]=$e.join(" ");}return {cellStyles:K,cellClasses:M,hdrStyles:j,hdrClasses:J}});return ()=>{let x=l.gridProps,D=a.layout.value,w=a.rowSelection.value,h$1=a.editing.value,P=a.interaction.value,V=a.contextMenu.value,_=a.viewModels.value,K=a.pinning.value,{headerMenu:M}=K,{visibleCols:j,hasCheckboxCol:J,hasRowNumbersCol:Y,colOffset:q,containerWidth:G,minTableWidth:Z,desiredTableWidth:ne}=D,ye=x.currentPage??1,Fe=x.pageSize??25,Ke=Y?(ye-1)*Fe:0,{selectedRowIds:Pe,handleRowCheckboxChange:xe,handleSelectAll:Ne,allSelected:Ve,someSelected:We}=w,{editingCell:$e,setEditingCell:tt,pendingEditorValue:nt,setPendingEditorValue:mt,commitCellEdit:Ue,cancelPopoverEdit:ft,popoverAnchorEl:Ie,setPopoverAnchorEl:Ct}=h$1,{setActiveCell:ae,setSelectionRange:ke,handleCellMouseDown:ot,handleSelectAllCells:lt,selectionRange:Ee,hasCellSelection:rt,handleGridKeyDown:at,handleFillHandleMouseDown:_e,handleCopy:ht,handleCut:Rt,handlePaste:Be,cutRange:pt,copyRange:it,canUndo:bt,canRedo:It,onUndo:ve,onRedo:St,isDragging:Tt}=P,{menuPosition:qe,handleCellContextMenu:wt,closeContextMenu:Pt}=V,{headerFilterInput:Et,cellDescriptorInput:te,statusBarConfig:Q,showEmptyInGrid:re,onCellError:me}=_,se=x.items,Me=x.getRowId,we=x.layoutMode??"fill",he=x.rowSelection??"none",ge=x.suppressHorizontalScroll,yt=x.stickyHeader??true,Dt=x.isLoading??false,Fn=x.loadingMessage??"Loading\u2026",Un=x["aria-label"],Oe=x["aria-labelledby"],kn=we==="content",Ft=!ge&&G>0&&(Z>G||ne>G),Ge=y.value,Ut={commitCellEdit:Ue,setEditingCell:tt,setPendingEditorValue:mt,cancelPopoverEdit:ft},Mn={handleCellMouseDown:ot,setActiveCell:ae,setEditingCell:tt,handleCellContextMenu:wt},On=H=>{if(he!=="single")return;let ie=H.currentTarget.dataset.rowId;ie&&w.updateSelection(Pe.has(ie)?new Set:new Set([ie]));},r=(H,z,ie,Le)=>{try{return L(H,z,ie,Le)}catch(W){return me&&me(W instanceof Error?W:new Error(String(W)),void 0),""}},L=(H,z,ie,Le)=>{let W=getCellRenderDescriptor(H,z,ie,Le,te);if(W.mode==="editing-inline"){let ue=buildInlineEditorProps(H,z,W,Ut);return h("div",{class:"ogrid-editing-cell"},h(e.InlineCellEditor,{value:ue.value,item:ue.item,column:ue.column,rowIndex:ue.rowIndex,editorType:ue.editorType,onCommit:ue.onCommit,onCancel:ue.onCancel}))}if(W.mode==="editing-popover"&&z.cellEditor!=null&&typeof z.cellEditor!="string"){let ue=buildPopoverEditorProps(H,z,W,nt,Ut),oe=z.cellEditor,Bt=resolveCellDisplayContent(z,H,W.displayValue),no=resolveCellStyle(z,H,W.displayValue);return h("div",[h("div",{ref:oo=>{oo&&Ct(oo);},class:"ogrid-popover-anchor"},[no?h("span",{style:no},[Bt]):Bt]),Ie?h(oe,ue):null])}let He=wn(W,z.columnId,Mn),Te=["ogrid-cell-content"];z.type==="numeric"?Te.push("ogrid-cell-content--numeric"):z.type==="boolean"&&Te.push("ogrid-cell-content--boolean"),W.canEditAny&&Te.push("ogrid-cell-content--editable"),W.isActive&&Te.push("ogrid-cell-content--active"),W.isActive&&W.isInRange&&Te.push("ogrid-cell-content--active-in-range"),W.isInRange&&!W.isActive&&Te.push("ogrid-cell-in-range"),W.isInCutRange&&Te.push("ogrid-cell-cut");let Ye;if(W.columnType==="boolean"){let ue=!!W.displayValue;Ye=h("input",{type:"checkbox",checked:ue,disabled:!W.canEditAny,onChange:W.canEditAny?()=>{let oe=W.rowIndex,Bt=W.globalColIndex;Ut.commitCellEdit(H,z.columnId,ue,!ue,oe,Bt,{skipAdvance:true});}:void 0,onPointerdown:oe=>handleBooleanCellPointerDown(oe,W.rowIndex,W.globalColIndex,q,{setActiveCell:ae,setSelectionRange:ke}),onClick:oe=>oe.stopPropagation(),style:`margin:0;cursor:${W.canEditAny?"pointer":"default"};outline:none`,"aria-label":ue?"Checked":"Unchecked"});}else {let ue=resolveCellDisplayContent(z,H,W.displayValue),oe=resolveCellStyle(z,H,W.displayValue);Ye=oe?h("span",{style:oe},ue):ue;}return h("div",{...He,class:Te.join(" ")},[Ye,...W.canEditAny&&W.isSelectionEndCell?[h("div",{onPointerdown:_e,"aria-label":"Fill handle",class:"ogrid-fill-handle"})]:[]])},{cellStyles:le,cellClasses:Re,hdrStyles:st,hdrClasses:ut}=I.value,je=j.map(H=>({col:H,tdClasses:Re[H.columnId]||"ogrid-data-cell",tdDynamicStyle:le[H.columnId]||{}})),fe=b.value,vt=je,Xe=0,Ce=0;if(fe){let H=new Set;for(let z of fe.pinnedLeft)H.add(z.columnId);for(let z of fe.virtualizedUnpinned)H.add(z.columnId);for(let z of fe.pinnedRight)H.add(z.columnId);vt=je.filter(z=>H.has(z.col.columnId)),Xe=fe.leftSpacerWidth,Ce=fe.rightSpacerWidth;}let be=U.value,Ae=H=>{let z=st[H.columnId]||{};return {classes:ut[H.columnId]||"ogrid-header-cell",style:{...z,cursor:u.value?"grabbing":"grab"}}},pe=m.value,De={position:"relative",width:kn?"fit-content":"100%",maxWidth:"100%",overflowX:ge?"hidden":Ft?"auto":"hidden",overflowY:"auto",backgroundColor:"#fff",willChange:"scroll-position",...pe?{flex:"1",minHeight:"0"}:{minHeight:Dt&&se.length===0?"200px":"auto"}};return x.rowHeight&&(De["--ogrid-row-height"]=`${x.rowHeight}px`),h("div",{class:"ogrid-outer-container"},[h("div",{ref:H=>{t.value=H,p.value=H;},tabindex:0,role:"region","aria-label":Un??(Oe?void 0:"Data grid"),"aria-labelledby":Oe,onPointerdown:B,onKeydown:at,onContextmenu:O,"data-overflow-x":Ft?"true":"false","data-ogrid-scroll-container":"",style:De},[h("div",{class:"ogrid-scroll-wrapper"},[h("div",{style:{minWidth:Ft?`${Z}px`:void 0,overflowX:"clip"}},[h("div",{ref:H=>{i.value=H;},class:["ogrid-table-container",Dt&&se.length>0?"ogrid-table-container--loading":""]},[...u.value&&v.value!==null?[h("div",{class:"ogrid-drop-indicator",style:{left:`${v.value}px`}})]:[],h("table",{ref:H=>{s.value=H;},class:"ogrid-table",role:"grid",style:{minWidth:`${Z}px`},...m.value?{"data-virtual-scroll":""}:{}},[h("thead",{class:yt?"ogrid-thead ogrid-sticky-header":"ogrid-thead"},[...x.showColumnLetters?[h("tr",{class:"ogrid-column-letter-row"},[...J?[h("th",{class:"ogrid-column-letter-cell"})]:[],...Y?[h("th",{class:"ogrid-column-letter-cell"})]:[],...j.map((H,z)=>{let{classes:ie,style:Le}=Ae(H);return h("th",{key:H.columnId,class:`ogrid-column-letter-cell ${ie}`,style:Le},indexToColumnLetter(z))})])]:[],...Ge.map((H,z)=>h("tr",{key:z,class:"ogrid-header-row"},[...z===Ge.length-1&&J?[h("th",{class:"ogrid-checkbox-header",style:{width:`${CHECKBOX_COLUMN_WIDTH}px`,minWidth:`${CHECKBOX_COLUMN_WIDTH}px`,maxWidth:`${CHECKBOX_COLUMN_WIDTH}px`}},e.renderCheckbox({modelValue:Ve,indeterminate:We&&!Ve,ariaLabel:"Select all rows",onChange:ie=>Ne(!!ie)}))]:[],...z===0&&z<Ge.length-1&&J?[h("th",{rowSpan:Ge.length-1,class:"ogrid-checkbox-spacer",style:{width:`${CHECKBOX_COLUMN_WIDTH}px`,minWidth:`${CHECKBOX_COLUMN_WIDTH}px`}})]:[],...z===Ge.length-1&&Y?[(()=>{let ie=D.columnSizingOverrides[ROW_NUMBER_COLUMN_ID]?.widthPx??ROW_NUMBER_COLUMN_WIDTH;return h("th",{class:"ogrid-row-number-header",style:{width:`${ie}px`,minWidth:`${ie}px`,maxWidth:`${ie}px`,position:"sticky",left:J?`${CHECKBOX_COLUMN_WIDTH}px`:"0",zIndex:3},onPointerdown:F,onMousedown:T,onSelectstart:E},["#",h("div",{onPointerdown:Le=>{ae(null),ke(null),t.value?.focus({preventScroll:true}),Le.stopPropagation(),g(Le,{columnId:ROW_NUMBER_COLUMN_ID,name:"#"});},class:"ogrid-resize-handle",role:"separator","aria-label":"Resize row numbers"})])})()]:[],...z===0&&z<Ge.length-1&&Y?[(()=>{let ie=D.columnSizingOverrides[ROW_NUMBER_COLUMN_ID]?.widthPx??ROW_NUMBER_COLUMN_WIDTH;return h("th",{rowSpan:Ge.length-1,class:"ogrid-row-number-spacer",style:{width:`${ie}px`,position:"sticky",left:J?`${CHECKBOX_COLUMN_WIDTH}px`:"0",zIndex:3}})})()]:[],...H.map((ie,Le)=>{if(ie.isGroup)return h("th",{key:Le,colSpan:ie.colSpan,scope:"colgroup",class:"ogrid-column-group-header"},ie.label);if(!ie.columnDef)return null;let W=ie.columnDef,{classes:He,style:Te}=Ae(W),ue=x.sortBy===W.columnId?x.sortDirection==="asc"?"ascending":"descending":void 0;return h("th",{key:W.columnId,scope:"col","data-column-id":W.columnId,rowSpan:Ge.length>1?Ge.length-z:void 0,class:He,style:Te,"aria-sort":ue,onPointerdown:oe=>C(W.columnId,oe)},[h("div",{class:"ogrid-header-content"},[h(e.ColumnHeaderFilter,getHeaderFilterConfig(W,Et)),h("button",{onClick:oe=>{oe.stopPropagation(),M.isOpen&&M.openForColumn===W.columnId?M.close():M.open(W.columnId,oe.currentTarget);},"aria-label":"Column options",title:"Column options",class:"ogrid-column-menu-btn"},"\u22EE")]),h("div",{onPointerdown:oe=>{ae(null),ke(null),t.value?.focus({preventScroll:true}),oe.stopPropagation(),g(oe,W);},onDblclick:oe=>R(oe,W),class:"ogrid-resize-handle",role:"separator","aria-label":`Resize ${W.name??W.columnId}`})])})]))]),...re?[]:[h("tbody",{},(()=>{let H=m.value,z=f.value,ie=H?z.startIndex:0,Le=H?Math.min(z.endIndex,se.length-1):se.length-1,W=[];H&&z.offsetTop>0&&W.push(h("tr",{key:"__vs-top",style:{height:`${z.offsetTop}px`}}));for(let He=ie;He<=Le;He++){let Te=se[He];if(!Te)continue;let Ye=Me(Te),ue=Pe.has(Ye);W.push(h("tr",{key:Ye,"data-row-id":Ye,"aria-selected":ue||void 0,onClick:On,style:{cursor:he==="single"?"pointer":void 0}},[...J?[h("td",{class:"ogrid-checkbox-cell",style:{width:`${CHECKBOX_COLUMN_WIDTH}px`,minWidth:`${CHECKBOX_COLUMN_WIDTH}px`,maxWidth:`${CHECKBOX_COLUMN_WIDTH}px`}},h("div",{"data-row-index":He,"data-col-index":0,onClick:A,class:"ogrid-checkbox-wrapper"},e.renderCheckbox({modelValue:ue,ariaLabel:`Select row ${He+1}`,onChange:oe=>xe(Ye,oe,He,d.value)})))]:[],...Y?[(()=>{let oe=D.columnSizingOverrides[ROW_NUMBER_COLUMN_ID]?.widthPx??ROW_NUMBER_COLUMN_WIDTH;return h("td",{class:"ogrid-row-number-cell",style:{width:`${oe}px`,minWidth:`${oe}px`,maxWidth:`${oe}px`,padding:"6px",position:"sticky",left:J?`${CHECKBOX_COLUMN_WIDTH}px`:"0",zIndex:2,userSelect:"none",WebkitUserSelect:"none"},onPointerdown:F,onMousedown:T,onSelectstart:E},String(Ke+He+1))})()]:[],...Xe>0?[h("td",{key:"__col-spacer-left",style:{width:`${Xe}px`,minWidth:`${Xe}px`,maxWidth:`${Xe}px`,padding:"0"}})]:[],...vt.map(oe=>h("td",{key:oe.col.columnId,"data-column-id":oe.col.columnId,class:oe.tdClasses,style:{...oe.tdDynamicStyle,userSelect:"none",WebkitUserSelect:"none"},onPointerdown:F,onMousedown:T,onSelectstart:E},[r(Te,oe.col,He,be.get(oe.col.columnId)??0)])),...Ce>0?[h("td",{key:"__col-spacer-right",style:{width:`${Ce}px`,minWidth:`${Ce}px`,maxWidth:`${Ce}px`,padding:"0"}})]:[]]));}return H&&z.offsetBottom>0&&W.push(h("tr",{key:"__vs-bottom",style:{height:`${z.offsetBottom}px`}})),W})())]]),...re&&x.emptyState?[e.renderEmptyState(x.emptyState)]:[]])])])]),...qe?[h(Teleport,{to:"body"},h(e.GridContextMenu,{x:qe.x,y:qe.y,hasSelection:rt,canUndo:bt,canRedo:It,onUndo:ve??il,onRedo:St??il,onCopy:ht,onCut:Rt,onPaste:()=>{Be();},onSelectAll:lt,onClose:Pt}))]:[],h(Ln,{containerRef:i,selectionRange:Ee,copyRange:it,cutRange:pt,colOffset:q,items:se,visibleColumns:x.visibleColumns instanceof Set?Array.from(x.visibleColumns):x.visibleColumns,columnSizingOverrides:D.columnSizingOverrides,columnOrder:x.columnOrder}),...x.formulaReferences&&x.formulaReferences.length>0?[h(zn,{containerEl:i.value,references:x.formulaReferences,colOffset:q})]:[],h(e.ColumnHeaderMenu,{isOpen:M.isOpen,anchorElement:M.anchorElement,onClose:M.close,onPinLeft:M.handlePinLeft,onPinRight:M.handlePinRight,onUnpin:M.handleUnpin,onSortAsc:M.handleSortAsc,onSortDesc:M.handleSortDesc,onClearSort:M.handleClearSort,onAutosizeThis:M.handleAutosizeThis,onAutosizeAll:M.handleAutosizeAll,canPinLeft:M.canPinLeft,canPinRight:M.canPinRight,canUnpin:M.canUnpin,currentSort:M.currentSort,isSortable:M.isSortable,isResizable:M.isResizable}),...Q?[h(Hn,{totalCount:Q.totalCount,filteredCount:Q.filteredCount,selectedCount:Q.selectedCount??Pe.size,selectedCellCount:Ee?(Math.abs(Ee.endRow-Ee.startRow)+1)*(Math.abs(Ee.endCol-Ee.startCol)+1):void 0,aggregation:Q.aggregation,suppressRowCount:Q.suppressRowCount})]:[],...Dt?[h("div",{class:"ogrid-loading-overlay"},e.renderSpinner(Fn))]:[]])}}})}var xt={width:"100%",height:"100%",display:"flex",alignItems:"center",paddingTop:"var(--ogrid-cell-padding-vertical, 6px)",paddingBottom:"var(--ogrid-cell-padding-vertical, 6px)",paddingLeft:"var(--ogrid-cell-padding-horizontal, 10px)",paddingRight:"var(--ogrid-cell-padding-horizontal, 10px)",boxSizing:"border-box",overflow:"hidden",minWidth:"0"};function Fi(e){let{renderCheckbox:l}=e;return defineComponent({name:"InlineCellEditor",props:{value:{default:void 0},item:{type:Object,required:true},column:{type:Object,required:true},rowIndex:{type:Number,required:true},editorType:{type:String,required:true},onCommit:{type:Function,required:true},onCancel:{type:Function,required:true}},setup(n){let t=ref(null),i=ref(null),s=ref(null),d=ref(n.value),a=ref(0),u=ref(false),v=y=>{d.value=y.target.value;},C=y=>y?.target?.value??String(d.value??""),p=y=>{if(n.editorType==="date"){let I=n.column.cellEditorParams?.dateFormat??n.column.dateFormat??DEFAULT_DATE_FORMAT;if((n.column.cellEditorParams?.editorType??"text")==="native"){if(y==null){d.value="";return}let D=String(y);d.value=D.match(/^\d{4}-\d{2}-\d{2}/)?D.substring(0,10):D;return}d.value=formatDateForDisplay(y,I)??"";return}d.value=y;};p(n.value);let f=y=>{u.value=true,n.onCommit(y);},c=()=>{u.value=true,n.onCancel();},o=()=>u.value?(u.value=false,true):false,m=()=>{let y=i.value,I=s.value;if(!y||!I)return;let x=y.getBoundingClientRect(),D=200,w=window.innerHeight-x.bottom,h=w<D&&x.top>w;I.style.position="fixed",I.style.left=`${x.left}px`,I.style.width=`${x.width}px`,I.style.maxHeight=`${D}px`,I.style.zIndex="9999",I.style.right="auto",I.style.textAlign="left",h?(I.style.top="auto",I.style.bottom=`${window.innerHeight-x.top}px`):I.style.top=`${x.bottom}px`;},g=null,R=null;onMounted(()=>{let y=I=>{I.key==="Escape"&&(I.preventDefault(),I.stopPropagation(),c());};document.addEventListener("keydown",y,true),R=()=>{document.removeEventListener("keydown",y,true);},nextTick(()=>{if(i.value){n.editorType==="richSelect"&&F.value?F.value.focus({preventScroll:true}):i.value.focus({preventScroll:true}),m();let I=i.value,x=I.closest("[data-ogrid-scroll-container]")??I.closest('[style*="overflow"]'),D=()=>{n.onCancel&&n.onCancel();},w=requestAnimationFrame(()=>{x&&x.addEventListener("scroll",D,{passive:true}),window.addEventListener("scroll",D,{passive:true});});g=()=>{cancelAnimationFrame(w),x&&x.removeEventListener("scroll",D),window.removeEventListener("scroll",D);};return}t.value?.focus({preventScroll:true}),t.value?.select();});}),onUnmounted(()=>{g?.(),R?.();}),watch(()=>n.value,p),(()=>{let I=(n.column.cellEditorParams?.values??[]).findIndex(x=>String(x)===String(n.value));a.value=Math.max(I,0);})();let b=()=>{nextTick(()=>{let y=s.value;if(!y)return;y.children[a.value]?.scrollIntoView({block:"nearest"});});},U=y=>{let I=n.column.cellEditorParams?.formatValue;return I?I(y):y!=null?String(y):""},k=y=>{let I=n.column.cellEditorParams?.values??[];switch(y.key){case "ArrowDown":y.preventDefault(),a.value=Math.min(a.value+1,I.length-1),b();break;case "ArrowUp":y.preventDefault(),a.value=Math.max(a.value-1,0),b();break;case "Enter":y.preventDefault(),y.stopPropagation(),I.length>0&&a.value<I.length&&f(I[a.value]);break;case "Tab":y.preventDefault(),I.length>0&&a.value<I.length&&f(I[a.value]);break;case "Escape":y.preventDefault(),y.stopPropagation(),c();break}},B=ref(""),F=ref(null),T=ref(null),E=computed(()=>{let y=n.column.cellEditorParams?.values??[],I=B.value.trim().toLowerCase();return I?y.filter(x=>U(x).toLowerCase().includes(I)):y}),O=()=>{nextTick(()=>{let y=T.value;if(!y)return;y.children[a.value]?.scrollIntoView({block:"nearest"});});},A=y=>{let I=E.value;switch(y.key){case "ArrowDown":y.preventDefault(),a.value=Math.min(a.value+1,I.length-1),O();break;case "ArrowUp":y.preventDefault(),a.value=Math.max(a.value-1,0),O();break;case "Enter":y.preventDefault(),y.stopPropagation(),I.length>0&&a.value<I.length&&f(I[a.value]);break;case "Escape":y.preventDefault(),y.stopPropagation(),c();break}};return ()=>{if(n.editorType==="checkbox"){let y=!!n.value;return h("div",{style:{...xt,justifyContent:"center"}},l({checked:y,onChange:I=>f(I),onCancel:c}))}if(n.editorType==="select"){let y=n.column.cellEditorParams?.values??[];return h("div",{ref:I=>{i.value=I;},tabindex:0,style:{...xt,position:"relative"},onKeydown:k},[h("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",width:"100%",cursor:"pointer",fontSize:"13px",color:"inherit"}},[h("span",U(n.value)),h("span",{style:{marginLeft:"4px",fontSize:"10px",opacity:"0.5"}},"\u25BE")]),h("div",{ref:I=>{s.value=I;},role:"listbox",style:{position:"absolute",top:"100%",left:"0",right:"0",maxHeight:"200px",overflowY:"auto",background:"var(--ogrid-bg, #fff)",border:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",zIndex:"10",boxShadow:"0 4px 16px rgba(0,0,0,0.2)",textAlign:"left",fontSize:"13px",fontFamily:"inherit"}},[...y.map((I,x)=>h("div",{key:String(I),role:"option","aria-selected":x===a.value,onClick:()=>f(I),style:{padding:"6px 8px",cursor:"pointer",color:"var(--ogrid-fg, #242424)",fontSize:"13px",...x===a.value?{background:"var(--ogrid-bg-hover, #e8f0fe)"}:{}}},U(I)))])])}if(n.editorType==="richSelect"){let y=E.value;return h("div",{ref:I=>{i.value=I;},style:{...xt,position:"relative"}},[h("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",width:"100%",cursor:"pointer",fontSize:"13px",color:"inherit"}},[h("span",U(n.value)),h("span",{style:{marginLeft:"4px",fontSize:"10px",opacity:"0.5"}},"\u25BE")]),h("div",{ref:I=>{s.value=I;},role:"listbox",style:{position:"absolute",top:"100%",left:"0",right:"0",maxHeight:"200px",overflowY:"auto",background:"var(--ogrid-bg, #fff)",border:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",zIndex:"10",boxShadow:"0 4px 16px rgba(0,0,0,0.2)",textAlign:"left",fontSize:"13px",fontFamily:"inherit"}},[h("input",{ref:I=>{F.value=I;},type:"text",value:B.value,placeholder:"Search...",onInput:I=>{B.value=I.target.value,a.value=0;},onKeydown:A,style:{width:"100%",padding:"6px 8px",border:"none",borderBottom:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",background:"var(--ogrid-bg, #fff)",color:"inherit",font:"inherit",fontSize:"13px",outline:"none",boxSizing:"border-box",position:"sticky",top:"0",zIndex:"1"}}),h("div",{ref:I=>{T.value=I;}},y.map((I,x)=>h("div",{key:String(I),role:"option","aria-selected":x===a.value,onClick:()=>f(I),style:{padding:"6px 8px",cursor:"pointer",color:"var(--ogrid-fg, #242424)",fontSize:"13px",...x===a.value?{background:"var(--ogrid-bg-hover, #e8f0fe)"}:{}}},U(I)))),...y.length===0?[h("div",{style:{padding:"6px 8px",color:"var(--ogrid-muted, #999)",fontSize:"13px"}},"No matches")]:[]])])}if(n.editorType==="date"){let y=n.column.cellEditorParams?.dateFormat??n.column.dateFormat??DEFAULT_DATE_FORMAT,I=n.column.cellEditorParams?.editorType??"text",x=h=>{if(I!=="native"){let P=parseUserInputDate(h,y);if(P!==null){let V=P.getUTCFullYear().toString().padStart(4,"0"),_=(P.getUTCMonth()+1).toString().padStart(2,"0"),K=P.getUTCDate().toString().padStart(2,"0");f(`${V}-${_}-${K}`);}else f(h||null);}else f(h);},D=h=>{h.stopPropagation(),h.key==="Enter"&&(h.preventDefault(),x(C(h))),h.key==="Escape"&&(h.preventDefault(),c()),h.key==="Tab"&&(h.preventDefault(),x(C(h)));};if(I==="native"){let h$1=(()=>{if(d.value==null)return "";let P=String(d.value);return P.match(/^\d{4}-\d{2}-\d{2}/)?P.substring(0,10):P})();return h("div",{style:xt},h("input",{ref:P=>{t.value=P;},type:"date",value:h$1,style:{width:"100%",height:"100%",border:"none",outline:"none",padding:"0 4px",fontSize:"inherit",boxSizing:"border-box"},onInput:v,onChange:v,onKeyup:v,onKeydown:D,onBlur:P=>{o()||x(C(P));}}))}let w=getDateInputPlaceholder(y);return h("div",{style:xt},h("input",{ref:h=>{t.value=h;},type:"text",value:String(d.value??""),placeholder:w,style:{width:"100%",height:"100%",border:"none",outline:"none",padding:"0 4px",fontSize:"inherit",boxSizing:"border-box"},onInput:v,onChange:v,onKeyup:v,onKeydown:D,onBlur:h=>{o()||x(C(h));}}))}return h("div",{style:xt},h("input",{ref:y=>{t.value=y;},type:"text",value:d.value!=null?String(d.value):"",style:{width:"100%",height:"100%",border:"none",outline:"none",padding:"0 4px",fontSize:"inherit",boxSizing:"border-box"},onInput:v,onChange:v,onKeyup:v,onKeydown:y=>{y.stopPropagation(),y.key==="Enter"&&(y.preventDefault(),f(C(y))),y.key==="Escape"&&(y.preventDefault(),c()),y.key==="Tab"&&(y.preventDefault(),f(C(y)));},onBlur:y=>{o()||f(C(y));}}))}}})}var Li=240,to=36,Dn={columns:"Columns",filters:"Filters"},Hi={columns:"\u2261",filters:"\u2A65"};function ul(e){let l=e.activePanel!==null,n=e.position??"right",t={display:"flex",flexDirection:"column",width:`${to}px`,background:"var(--ogrid-header-bg, #f5f5f5)",...n==="right"?{borderLeft:"1px solid var(--ogrid-border, #e0e0e0)"}:{borderRight:"1px solid var(--ogrid-border, #e0e0e0)"}},i=h("div",{style:t,role:"tablist","aria-label":"Side bar tabs"},e.panels.map(a=>h("button",{key:a,role:"tab","aria-selected":e.activePanel===a,"aria-label":Dn[a],title:Dn[a],onClick:()=>e.onPanelChange(e.activePanel===a?null:a),style:{width:`${to}px`,height:`${to}px`,border:"none",cursor:"pointer",color:"var(--ogrid-fg, #242424)",fontSize:"14px",display:"flex",alignItems:"center",justifyContent:"center",background:e.activePanel===a?"var(--ogrid-bg, #fff)":"transparent",fontWeight:e.activePanel===a?"bold":"normal"}},Hi[a]))),s=null;if(l&&e.activePanel){let a={width:`${Li}px`,display:"flex",flexDirection:"column",overflow:"hidden",background:"var(--ogrid-bg, #fff)",color:"var(--ogrid-fg, #242424)",...n==="right"?{borderLeft:"1px solid var(--ogrid-border, #e0e0e0)"}:{borderRight:"1px solid var(--ogrid-border, #e0e0e0)"}},u=[];if(e.activePanel==="columns"){let v=e.columns.every(C=>e.visibleColumns.has(C.columnId));u.push(h("div",{style:{display:"flex",gap:"8px",marginBottom:"8px"}},[h("button",{disabled:v,onClick:()=>{let C=new Set(e.visibleColumns);e.columns.forEach(p=>C.add(p.columnId)),e.onSetVisibleColumns(C);},style:{flex:"1",cursor:"pointer",background:"var(--ogrid-bg-subtle, #f3f2f1)",color:"var(--ogrid-fg, #242424)",border:"1px solid var(--ogrid-border, #e0e0e0)",borderRadius:"4px",padding:"4px 8px"}},"Select All"),h("button",{onClick:()=>{let C=new Set;e.columns.forEach(p=>{p.required&&e.visibleColumns.has(p.columnId)&&C.add(p.columnId);}),e.onSetVisibleColumns(C);},style:{flex:"1",cursor:"pointer",background:"var(--ogrid-bg-subtle, #f3f2f1)",color:"var(--ogrid-fg, #242424)",border:"1px solid var(--ogrid-border, #e0e0e0)",borderRadius:"4px",padding:"4px 8px"}},"Clear All")])),e.columns.forEach(C=>{u.push(h("label",{key:C.columnId,style:{display:"flex",alignItems:"center",gap:"6px",padding:"2px 0",cursor:"pointer"}},[h("input",{type:"checkbox",checked:e.visibleColumns.has(C.columnId),disabled:C.required,onChange:p=>e.onVisibilityChange(C.columnId,p.target.checked)}),h("span",null,C.name)]));});}e.activePanel==="filters"&&(e.filterableColumns.length===0?u.push(h("div",{style:{color:"var(--ogrid-muted, #999)",fontStyle:"italic"}},"No filterable columns")):e.filterableColumns.forEach(v=>{let C=v.filterField,p=[h("div",{style:{fontWeight:"500",marginBottom:"4px",fontSize:"13px"}},v.name)];if(v.filterType==="text"){let f=e.filters[C],c=f?.type==="text"?f.value:"";p.push(h("input",{type:"text",value:c,onInput:o=>{let m=o.target.value;e.onFilterChange(C,m?{type:"text",value:m}:void 0);},placeholder:`Filter ${v.name}...`,"aria-label":`Filter ${v.name}`,style:{width:"100%",boxSizing:"border-box",padding:"4px 6px",background:"var(--ogrid-bg, #fff)",color:"var(--ogrid-fg, #242424)",border:"1px solid var(--ogrid-border, #e0e0e0)",borderRadius:"4px"}}));}if(v.filterType==="multiSelect"){let c=(e.filterOptions[C]??[]).map(o=>{let m=e.filters[C],g=m?.type==="multiSelect"?m.value.includes(o):false;return h("label",{key:o,style:{display:"flex",alignItems:"center",gap:"4px",padding:"1px 0",cursor:"pointer",fontSize:"13px"}},[h("input",{type:"checkbox",checked:g,onChange:R=>{let S=e.filters[C],b=S?.type==="multiSelect"?S.value:[],U=R.target.checked?[...b,o]:b.filter(k=>k!==o);e.onFilterChange(C,U.length>0?{type:"multiSelect",value:U}:void 0);}}),h("span",null,o)])});p.push(h("div",{style:{maxHeight:"120px",overflowY:"auto"},role:"group","aria-label":`${v.name} options`},c));}if(v.filterType==="date"){let f=e.filters[C],c=f?.type==="date"?f.value:{from:void 0,to:void 0};p.push(h("div",{style:{display:"flex",flexDirection:"column",gap:"4px"}},[h("label",{style:{display:"flex",alignItems:"center",gap:"4px",fontSize:"12px"}},["From:",h("input",{type:"date",value:c.from??"",onInput:o=>{let m=o.target.value||void 0,g=c.to;e.onFilterChange(C,m||g?{type:"date",value:{from:m,to:g}}:void 0);},"aria-label":`${v.name} from date`,style:{flex:"1",padding:"2px 4px",background:"var(--ogrid-bg, #fff)",color:"var(--ogrid-fg, #242424)",border:"1px solid var(--ogrid-border, #e0e0e0)",borderRadius:"4px"}})]),h("label",{style:{display:"flex",alignItems:"center",gap:"4px",fontSize:"12px"}},["To:",h("input",{type:"date",value:c.to??"",onInput:o=>{let m=o.target.value||void 0,g=c.from;e.onFilterChange(C,g||m?{type:"date",value:{from:g,to:m}}:void 0);},"aria-label":`${v.name} to date`,style:{flex:"1",padding:"2px 4px",background:"var(--ogrid-bg, #fff)",color:"var(--ogrid-fg, #242424)",border:"1px solid var(--ogrid-border, #e0e0e0)",borderRadius:"4px"}})])]));}u.push(h("div",{key:v.columnId,style:{marginBottom:"12px"}},p));})),s=h("div",{role:"tabpanel","aria-label":Dn[e.activePanel],style:a},[h("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",padding:"8px 12px",borderBottom:"1px solid var(--ogrid-border, #e0e0e0)",fontWeight:"600"}},[h("span",null,Dn[e.activePanel]),h("button",{onClick:()=>e.onPanelChange(null),style:{border:"none",background:"transparent",cursor:"pointer",fontSize:"16px",color:"var(--ogrid-fg, #242424)"},"aria-label":"Close panel"},"\xD7")]),h("div",{style:{flex:"1",overflowY:"auto",padding:"8px 12px"}},u)]);}let d=[];return n==="left"?(d.push(i),s&&d.push(s)):(s&&d.push(s),d.push(i)),h("div",{style:{display:"flex",flexDirection:"row",flexShrink:"0"},role:"complementary","aria-label":"Side bar"},d)}function Vi(e){return defineComponent({name:"OGrid",props:{gridProps:{type:Object,required:true}},setup(l,{expose:n}){let t=computed(()=>l.gridProps),{dataGridProps:i,pagination:s,columnChooser:d,layout:a,api:u}=$t(t);n({api:u});let v=ref(false),C=()=>{v.value=!v.value;},p=f=>{f.key==="Escape"&&v.value&&(v.value=false);};return onMounted(()=>{document.addEventListener("keydown",p);}),onUnmounted(()=>{document.removeEventListener("keydown",p);}),()=>{let f=a.value.sideBarProps,c=f!=null,o=f?.position??"right",m=[];a.value.toolbar&&m.push(a.value.toolbar);let R=a.value.fullScreen===true?h("button",{type:"button",title:v.value?"Exit fullscreen":"Fullscreen","aria-label":v.value?"Exit fullscreen":"Fullscreen",onClick:C,style:{background:"none",border:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",borderRadius:"4px",padding:"4px 6px",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",color:"var(--ogrid-fg, rgba(0,0,0,0.87))"}},[v.value?h("svg",{width:16,height:16,viewBox:"0 0 16 16",fill:"none",stroke:"currentColor","stroke-width":"1.5","stroke-linecap":"round","stroke-linejoin":"round",innerHTML:'<polyline points="4 10 0 10 0 14"/><polyline points="12 6 16 6 16 2"/><line x1="0" y1="10" x2="4" y2="6"/><line x1="16" y1="6" x2="12" y2="10"/>'}):h("svg",{width:16,height:16,viewBox:"0 0 16 16",fill:"none",stroke:"currentColor","stroke-width":"1.5","stroke-linecap":"round","stroke-linejoin":"round",innerHTML:'<polyline points="10 2 14 2 14 6"/><polyline points="6 14 2 14 2 10"/><line x1="14" y1="2" x2="10" y2="6"/><line x1="2" y1="14" x2="6" y2="10"/>'})]):null,S=d.value.placement==="toolbar"?h(e.ColumnChooser,{columns:d.value.columns,visibleColumns:d.value.visibleColumns,onVisibilityChange:d.value.onVisibilityChange}):null,b=h(e.PaginationControls,{currentPage:s.value.page,pageSize:s.value.pageSize,totalCount:s.value.displayTotalCount,onPageChange:s.value.setPage,onPageSizeChange:E=>{s.value.setPageSize(E);},pageSizeOptions:s.value.pageSizeOptions,entityLabelPlural:s.value.entityLabelPlural}),U=h("div",{style:{flex:"1",minWidth:"0",minHeight:"0",display:"flex",flexDirection:"column"}},[h(e.DataGridTable,{gridProps:i.value})]),k=[];c&&o==="left"&&k.push(ul(f)),k.push(U),c&&o!=="left"&&k.push(ul(f));let B=m.length>0||S!=null||R!=null,F=v.value?{position:"fixed",inset:"0",zIndex:9999,display:"flex",flexDirection:"column",background:"var(--ogrid-bg, #fff)"}:{display:"flex",flexDirection:"column",border:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",borderRadius:"4px",overflow:"hidden"},T=v.value?{display:"flex",flexDirection:"column",flex:"1",minHeight:"0",overflow:"hidden",background:"var(--ogrid-bg, #fff)"}:void 0;return h("div",{class:a.value.className,style:F},[h("div",{style:T??{}},[...B?[h("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"8px 12px",borderBottom:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))",gap:"8px"}},[h("div",{style:{display:"flex",alignItems:"center",gap:"8px",flex:"1"}},m),h("div",{style:{display:"flex",alignItems:"center",gap:"8px"}},[...S?[S]:[],...R?[R]:[]])])]:[],...a.value.toolbarBelow?[h("div",{style:{padding:"8px 12px",borderBottom:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))"}},[a.value.toolbarBelow])]:[],...a.value.formulaBar?[a.value.formulaBar]:[],h("div",{style:{display:"flex",flex:"1",minHeight:"0"}},k),...a.value.sheetTabs?[a.value.sheetTabs]:[],h("div",{style:{display:"flex",alignItems:"center",padding:"8px 0",borderTop:"1px solid var(--ogrid-border, rgba(0,0,0,0.12))"}},[b])])])}}})}export{Vn as FormulaBar,zn as FormulaRefOverlay,Ln as MarchingAntsOverlay,Gn as SheetTabs,Hn as StatusBar,Si as createDataGridTable,Fi as createInlineCellEditor,Vi as createOGrid,wn as getCellInteractionProps,Xt as useActiveCell,Ko as useCellClipboard,jt as useCellEditing,Yt as useCellSelection,Jt as useClipboard,nl as useColumnChooserState,el as useColumnHeaderFilterState,rn as useColumnHeaderMenuState,on as useColumnPinning,Cn as useColumnReorder,un as useColumnResize,Zt as useContextMenu,sn as useDataGridState,Sn as useDataGridTableSetup,vn as useDateFilterState,dn as useDebounce,Xo as useDebouncedCallback,Ho as useFillHandle,Wt as useFilterOptions,_t as useFormulaBar,qo as useGridFocus,So as useHeadlessGrid,ol as useInlineCellEditorState,Bo as useInlineEdit,Qt as useKeyboardNavigation,mn as useMultiSelectFilterState,$t as useOGrid,pn as usePeopleFilterState,No as useRangeSelection,rl as useRichSelectState,qt as useRowSelection,Mt as useSideBarState,nn as useTableLayout,cn as useTextFilterState,tn as useUndoRedo,Rn as useVirtualScroll};