@alaarab/ogrid-vue 2.5.9 → 2.6.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/esm/index.js CHANGED
@@ -1 +1 @@
1
- import {injectGlobalStyles,Z_INDEX,getStatusBarParts,measureRange,flattenColumns,getMultiSelectFilterFields,deriveFilterOptionsFromData,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,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 Un=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),t=ref(null),n=0,i,m=computed(()=>e.copyRange??e.cutRange),s=()=>{let u=toValue(e.containerRef);if(!u){o.value=null,t.value=null;return}o.value=e.selectionRange?measureRange(u,e.selectionRange,e.colOffset):null,t.value=m.value?measureRange(u,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,t.value=null;return}n=requestAnimationFrame(s);let u=toValue(e.containerRef);u&&(i?.disconnect(),i=new ResizeObserver(s),i.observe(u));},{immediate:true}),onUnmounted(()=>{cancelAnimationFrame(n),i?.disconnect();});let a=computed(()=>{let u=e.selectionRange,f=m.value;return u!=null&&f!=null&&u.startRow===f.startRow&&u.startCol===f.startCol&&u.endRow===f.endRow&&u.endCol===f.endCol});return ()=>!o.value&&!t.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,t.value?h("svg",{style:{position:"absolute",top:`${t.value.top}px`,left:`${t.value.left}px`,width:`${t.value.width}px`,height:`${t.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,t.value.width-2),height:Math.max(0,t.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 On=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((t,n)=>h("span",{key:t.key,style:{display:"inline-flex",alignItems:"center",gap:"4px",...n<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))"}},t.label),h("span",{style:{fontWeight:"600"}},t.value.toLocaleString())])))}}});var Mn=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 t=ref(null);return watch(()=>e.isEditing,n=>{n&&t.value&&t.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:t,type:"text",style:FORMULA_BAR_STYLES.input,value:e.formulaText,readonly:!e.isEditing,onInput:n=>o("inputChange",n.target.value),onKeydown:n=>handleFormulaBarKeyDown(n.key,()=>n.preventDefault(),()=>o("commit"),()=>o("cancel")),onClick:()=>{e.isEditing||o("startEditing");},onDblclick:()=>{e.isEditing||o("startEditing");},"aria-label":"Formula input",spellcheck:false,autocomplete:"off"})])}});var nl={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"},ol={background:"none",border:"none",cursor:"pointer",padding:"4px 10px",fontSize:"16px",lineHeight:"22px",color:"var(--ogrid-fg-secondary, #666)",flexShrink:0},io={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"},ll={...io,fontWeight:600,borderBottomColor:"var(--ogrid-primary, #217346)",background:"var(--ogrid-bg, #fff)"},An=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:nl,role:"tablist","aria-label":"Sheet tabs"},[e.showAddButton?h("button",{type:"button",style:ol,onClick:()=>o("sheetAdd"),title:"Add sheet","aria-label":"Add sheet"},"+"):null,...e.sheets.map(t=>{let n=t.id===e.activeSheet,i=n?ll:io,m=n&&t.color?{...i,borderBottomColor:t.color}:i;return h("button",{key:t.id,type:"button",role:"tab","aria-selected":n,style:m,onClick:()=>o("sheetChange",t.id)},t.name)})])}});function sl(e,o,t){let n=o.col+t,i=(o.endCol??o.col)+t,m=o.endRow??o.row,s=e.querySelector(`[data-row-index="${o.row}"][data-col-index="${n}"]`),a=e.querySelector(`[data-row-index="${m}"][data-col-index="${i}"]`);if(!s||!a)return null;let u=e.getBoundingClientRect(),f=s.getBoundingClientRect(),p=a.getBoundingClientRect();return {top:Math.round(f.top-u.top),left:Math.round(f.left-u.left),width:Math.round(p.right-f.left),height:Math.round(p.bottom-f.top),color:FORMULA_REF_COLORS[o.colorIndex%FORMULA_REF_COLORS.length]}}var Ln=defineComponent({name:"FormulaRefOverlay",props:{containerEl:{type:Object,default:null},references:{type:Array,required:true},colOffset:{type:Number,required:true}},setup(e){let o=ref([]),t=0;function n(){let i=e.containerEl,m=e.references;if(!i||m.length===0){o.value=[];return}let s=[];for(let a of m){let u=sl(i,a,e.colOffset);u&&s.push(u);}o.value=s;}return watch(()=>[e.references,e.containerEl,e.colOffset],()=>{if(cancelAnimationFrame(t),!e.containerEl||e.references.length===0){o.value=[];return}t=requestAnimationFrame(n);},{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 t=ref({}),n=ref({}),i=computed(()=>[...o.value].sort().join(",")),m=async()=>{let s=e.value,a=o.value,u="fetchFilterOptions"in s&&typeof s.fetchFilterOptions=="function"?s.fetchFilterOptions.bind(s):void 0;if(!u){t.value={},n.value={};return}let f={};a.forEach(d=>{f[d]=true;}),n.value=f;let p={};await Promise.all(a.map(async d=>{try{p[d]=await u(d);}catch{p[d]=[];}})),t.value=p,n.value={};};return watch([e,i],()=>{m().catch(()=>{});},{immediate:true}),{filterOptions:t,loadingOptions:n}}function rt(e){let o=unref(e);return customRef((t,n)=>({get(){return isRef(e)&&(o=e.value),o},set(i){o=i,n();}}))}function mo(e){let{formulas:o,items:t,flatColumns:n,initialFormulas:i,onFormulaRecalc:m,formulaFunctions:s,namedRanges:a,sheets:u}=e,f=rt(t),p=rt(n),d=rt(m),c=shallowRef(null),C=false,r=computed(()=>o?.value??false);function v(){return createGridDataAccessor(f.value,p.value)}watch(r,y=>{if(y&&!c.value){if(c.value=new FormulaEngine({customFunctions:s,namedRanges:a}),u)for(let[x,F]of Object.entries(u))c.value.registerSheet(x,F);if(i&&!C){C=true;let x=v(),F=c.value.loadFormulas(i,x);F.updatedCells.length>0&&d.value?.(F);}}else !y&&c.value&&(c.value=null);},{immediate:true});function h(y,x){return c.value?.getValue(y,x)}function P(y,x){return c.value?.hasFormula(y,x)??false}function I(y,x){return c.value?.getFormula(y,x)}function w(y,x,F){if(!c.value)return;let S=v(),X=c.value.setFormula(y,x,F,S);X.updatedCells.length>0&&d.value?.(X);}function g(y,x){if(!c.value)return;let F=v(),S=c.value.onCellChanged(y,x,F);S.updatedCells.length>0&&d.value?.(S);}function b(y,x){return c.value?.getPrecedents(y,x)??[]}function E(y,x){return c.value?.getDependents(y,x)??[]}function D(y,x){return c.value?.getAuditTrail(y,x)??null}return {enabled:r,getFormulaValue:h,hasFormula:P,getFormula:I,setFormula:w,onCellChanged:g,getPrecedents:b,getDependents:E,getAuditTrail:D}}function zt(e){let{activeCol:o,activeRow:t,activeCellRef:n,getFormula:i,getRawValue:m,setFormula:s,onCellValueChanged:a}=e,u=ref(false),f=ref(""),p=ref(false),d=computed(()=>deriveFormulaBarText(o.value,t.value,i,m));watch([o,t],()=>{u.value=false,p.value=false;});let c=()=>{f.value=d.value,u.value=true,p.value=true;},C=I=>{f.value=I;},r=()=>{let I=o.value,w=t.value;I==null||w==null||!s||(processFormulaBarCommit(f.value,I,w,s,a),u.value=false,p.value=false);},v=()=>{u.value=false,p.value=false,f.value="";},h=computed(()=>u.value?f.value:d.value),P=computed(()=>extractFormulaReferences(h.value));return {cellRef:n,formulaText:h,isEditing:u,onInputChange:C,onCommit:r,onCancel:v,startEditing:c,referencedCells:P,isFormulaBarEditing:p}}var fo=["columns","filters"];function Ft(e){let{config:o}=e,t=o!=null&&o!==false,n=(()=>{if(!t||o===true)return {panels:fo,position:"right",defaultPanel:null};let f=o;return {panels:f.panels??fo,position:f.position??"right",defaultPanel:f.defaultPanel??null}})(),i=ref(n.defaultPanel),m=f=>{i.value=f;},s=f=>{i.value=i.value===f?null:f;},a=()=>{i.value=null;},u=computed(()=>i.value!==null);return {isEnabled:t,activePanel:i,setActivePanel:m,panels:n.panels,position:n.position,isOpen:u,toggle:s,close:a}}var Bl=25,Hl={};function _t(e){let o=computed(()=>{let l=e.value;return {columns:l.columns,columnOrder:l.columnOrder,onColumnOrderChange:l.onColumnOrderChange,onColumnResized:l.onColumnResized,onColumnPinned:l.onColumnPinned,columnChooser:l.columnChooser}}),t=computed(()=>{let l=e.value,M="data"in l?l.data:void 0,oe="dataSource"in l?l.dataSource:void 0;return M&&oe&&console.warn("[OGrid] Both data and dataSource provided. dataSource takes precedence."),{getRowId:l.getRowId,data:M,dataSource:oe}}),n=computed(()=>{let l=e.value;return {page:l.page,pageSize:l.pageSize,sort:l.sort,filters:l.filters,visibleColumns:l.visibleColumns,isLoading:l.isLoading}}),i=computed(()=>{let l=e.value;return {onPageChange:l.onPageChange,onPageSizeChange:l.onPageSizeChange,onSortChange:l.onSortChange,onFiltersChange:l.onFiltersChange,onVisibleColumnsChange:l.onVisibleColumnsChange,onFirstDataRendered:l.onFirstDataRendered,onError:l.onError}}),m=computed(()=>{let l=e.value;return {defaultPageSize:l.defaultPageSize??Bl,defaultSortBy:l.defaultSortBy,defaultSortDirection:l.defaultSortDirection??"asc",entityLabelPlural:l.entityLabelPlural??"items"}}),s=computed(()=>o.value.columnChooser===false?"none":o.value.columnChooser==="sidebar"?"sidebar":"toolbar"),a=computed(()=>flattenColumns(o.value.columns)),u=computed(()=>t.value.dataSource!=null),f=computed(()=>!u.value),p=ref([]),d=ref(false),c=computed(()=>t.value.data??p.value),C=computed(()=>n.value.isLoading??d.value),r=computed(()=>m.value.defaultSortBy??a.value[0]?.columnId??""),v=ref(1),h$1=ref(m.value.defaultPageSize),P=ref({field:r.value,direction:m.value.defaultSortDirection}),I=ref({}),w=ref((()=>{let l=a.value.filter(M=>M.defaultVisible!==false).map(M=>M.columnId);return new Set(l.length>0?l:a.value.map(M=>M.columnId))})()),g=ref({}),b={};for(let l of flattenColumns(e.value.columns))l.pinned&&(b[l.columnId]=l.pinned);let E=ref(b),D=computed(()=>n.value.page??v.value),y=computed(()=>n.value.pageSize??h$1.value),x=computed(()=>n.value.sort??P.value),F=computed(()=>n.value.filters??I.value),S=computed(()=>n.value.visibleColumns??w.value),X=l=>{n.value.page===void 0&&(v.value=l),i.value.onPageChange?.(l);},Q=l=>{n.value.pageSize===void 0&&(h$1.value=l),i.value.onPageSizeChange?.(l),X(1);},Z=ref(0),R=l=>{n.value.sort===void 0&&(P.value=l),i.value.onSortChange?.(l),X(1),Z.value++;},T=l=>{n.value.filters===void 0&&(I.value=l),i.value.onFiltersChange?.(l),X(1);},U=l=>{n.value.visibleColumns===void 0&&(w.value=l),i.value.onVisibleColumnsChange?.(l);},G=(l,M)=>{R(computeNextSortState(x.value,l,M));},O=(l,M)=>{T(mergeFilter(F.value,l,M));},V=(l,M)=>{let oe=new Set(S.value);M?oe.add(l):oe.delete(l),U(oe);},A=ref(new Set),k=computed(()=>e.value.selectedRows),L=computed(()=>k.value??A.value),z=l=>{k.value===void 0&&(A.value=new Set(l.selectedRowIds)),e.value.onSelectionChange?.(l);},le=computed(()=>getMultiSelectFilterFields(a.value)),ne=computed(()=>t.value.dataSource??{fetchFilterOptions:void 0}),{filterOptions:B,loadingOptions:ee}=Gt(ne,le),te=computed(()=>t.value.dataSource?.fetchFilterOptions!=null),Ce=computed(()=>te.value?B.value:deriveFilterOptionsFromData(c.value,a.value)),be=computed(()=>!!e.value.workerSort),Ee=null,Ae=-1,Ne=null,St=null,st=-1,ut=computed(()=>{if(!f.value||be.value)return null;let l=c.value,M=a.value,oe=F.value,Se=Z.value,nt=x.value.field,ot=x.value.direction,lt=Se!==Ae||oe!==Ne||M!==St||l.length!==st,Te;if(lt||Ee===null){Ae=Se,Ne=oe,St=M,st=l.length;let me=processClientSideData(l,M,oe,nt,ot),Ge=new Map;for(let ve=0;ve<l.length;ve++)Ge.set(l[ve],ve);Ee=me.map(ve=>{let Oe=Ge.get(ve);return Oe!==void 0?Oe:-1}).filter(ve=>ve!==-1),Te=me;}else Te=Ee.map(me=>l[me]).filter(me=>me!==void 0);let Ve=Te.length,Rt=(D.value-1)*y.value;return {items:Te.slice(Rt,Rt+y.value),totalCount:Ve}}),Ze=ref(null),dt=0,Fe=null,ct=-1,we=null,Ke=null,re=-1;watch([f,be,c,a,F,Z,D,y],()=>{if(!f.value||!be.value)return;let l=c.value,M=a.value,oe=F.value,Se=Z.value,nt=x.value.field,ot=x.value.direction,lt=D.value,Te=y.value,Ve=++dt;if(Se!==ct||oe!==we||M!==Ke||l.length!==re||Fe===null)ct=Se,we=oe,Ke=M,re=l.length,Fe=null,processClientSideDataAsync(l,M,oe,nt,ot).then(Re=>{if(Ve!==dt||We)return;let me=new Map;for(let fe=0;fe<l.length;fe++)me.set(l[fe],fe);Fe=Re.map(fe=>{let N=me.get(fe);return N!==void 0?N:-1}).filter(fe=>fe!==-1);let Ge=Re.length,ve=(lt-1)*Te,Oe=Re.slice(ve,ve+Te);Ze.value={items:Oe,totalCount:Ge};}).catch(()=>{if(Ve!==dt||We)return;let Re=processClientSideData(l,M,oe,nt,ot),me=new Map;for(let fe=0;fe<l.length;fe++)me.set(l[fe],fe);Fe=Re.map(fe=>{let N=me.get(fe);return N!==void 0?N:-1}).filter(fe=>fe!==-1);let Ge=Re.length,ve=(lt-1)*Te,Oe=Re.slice(ve,ve+Te);Ze.value={items:Oe,totalCount:Ge};});else {let Re=Fe.map(Oe=>l[Oe]).filter(Oe=>Oe!==void 0),me=Re.length,Ge=(lt-1)*Te,ve=Re.slice(Ge,Ge+Te);Ze.value={items:ve,totalCount:me};}},{immediate:true});let _e=computed(()=>{let l=ut.value;return l||Ze.value}),Je=ref([]),De=ref(0),Qe=ref(false),et=0,We=false,ft=ref(0),pt=()=>{if(!u.value||!t.value.dataSource){u.value||(Qe.value=false);return}let l=++et;Qe.value=true,t.value.dataSource.fetchPage({page:D.value,pageSize:y.value,sort:{field:x.value.field,direction:x.value.direction},filters:F.value}).then(M=>{l!==et||We||(Je.value=M.items,De.value=M.totalCount);}).catch(M=>{l!==et||We||(i.value.onError?.(M),Je.value=[],De.value=0);}).finally(()=>{l===et&&!We&&(Qe.value=false);});};onMounted(()=>{validateColumns(a.value),pt();}),watch([()=>t.value.dataSource,D,y,()=>x.value.field,()=>x.value.direction,F,ft],()=>{pt();}),onUnmounted(()=>{We=true;});let Le=computed(()=>f.value&&_e.value?_e.value.items:Je.value),vt=computed(()=>f.value&&_e.value?_e.value.totalCount:De.value),gt=computed(()=>!!e.value.formulas),$e=ref(0),yt=l=>{$e.value+=1,e.value.onFormulaRecalc?.(l);},he=mo({formulas:gt,items:Le,flatColumns:a,initialFormulas:e.value.initialFormulas,onFormulaRecalc:yt,formulaFunctions:e.value.formulaFunctions,namedRanges:e.value.namedRanges,sheets:e.value.sheets}),Ct=false,wt=false;watch(Le,l=>{!Ct&&l.length>0&&(Ct=true,i.value.onFirstDataRendered?.()),!wt&&l.length>0&&(wt=true,validateRowIds(l,t.value.getRowId));});let qe=computed(()=>Object.values(F.value).some(l=>l!==void 0)),ht=computed(()=>a.value.map(l=>({columnId:l.columnId,name:l.name,required:l.required===true}))),xt=computed(()=>{let l=e.value.statusBar;if(!l)return;if(typeof l=="object")return l;let M=f.value?t.value.data?.length??0:De.value,oe=vt.value;return {totalCount:M,filteredCount:qe.value?oe:void 0,selectedCount:L.value.size,suppressRowCount:true}}),It=(l,M)=>{g.value={...g.value,[l]:M},o.value.onColumnResized?.(l,M);},Tt=(l,M)=>{if(M===null){let{[l]:oe,...Se}=E.value;E.value=Se;}else E.value={...E.value,[l]:M};o.value.onColumnPinned?.(l,M);},$=shallowRef(Ft({config:e.value.sideBar}));watch(()=>e.value.sideBar,l=>{$.value=Ft({config:l});});let Y=computed(()=>a.value.filter(l=>l.filterable&&l.filterable.type).map(l=>({columnId:l.columnId,name:l.name,filterField:l.filterable?.filterField??l.columnId,filterType:l.filterable?.type}))),ae=computed(()=>{let l=$.value;if(!l.isEnabled)return null;l.activePanel.value;l.isOpen.value;return {get activePanel(){return l.activePanel.value},onPanelChange:l.setActivePanel,panels:l.panels,position:l.position,get isOpen(){return l.isOpen.value},toggle:l.toggle,close:l.close,columns:ht.value,visibleColumns:S.value,onVisibilityChange:V,onSetVisibleColumns:U,filterableColumns:Y.value,filters:F.value,onFilterChange:O,filterOptions:Ce.value}}),de=()=>T({}),pe=computed(()=>u.value&&Qe.value||C.value),xe=ref(null),ce=ref(null),Ie=l=>{if(xe.value=l,l){let M=l.match(/^([A-Z]+)(\d+)$/);M?ce.value={col:columnLetterToIndex(M[1]),row:parseInt(M[2],10)-1}:ce.value=null;}else ce.value=null;},Ue=computed(()=>ce.value?.col??null),tt=computed(()=>ce.value?.row??null),Pn=(l,M)=>{let oe=Le.value,Se=a.value;if(!(M<0||M>=oe.length||l<0||l>=Se.length))return getCellValue(oe[M],Se[l])},Be=zt({activeCol:Ue,activeRow:tt,activeCellRef:xe,getFormula:he.enabled.value?he.getFormula:void 0,getRawValue:Pn,setFormula:he.enabled.value?he.setFormula:void 0}),At=computed(()=>{let l=e.value,M=t.value.dataSource;return {items:Le.value,columns:o.value.columns,getRowId:t.value.getRowId,sortBy:x.value.field,sortDirection:x.value.direction,onColumnSort:G,visibleColumns:S.value,columnOrder:o.value.columnOrder,onColumnOrderChange:o.value.onColumnOrderChange,onColumnResized:It,onColumnPinned:Tt,pinnedColumns:E.value,initialColumnWidths:g.value,editable:l.editable,cellSelection:l.cellSelection,onCellValueChanged:l.onCellValueChanged,onUndo:l.onUndo,onRedo:l.onRedo,canUndo:l.canUndo,canRedo:l.canRedo,rowSelection:l.rowSelection??"none",selectedRows:L.value,onSelectionChange:z,showRowNumbers:l.showRowNumbers||l.cellReferences||l.formulas,showColumnLetters:!!(l.cellReferences||l.formulas),showNameBox:!!(l.cellReferences&&!l.formulas),onActiveCellChange:l.cellReferences||l.formulas?Ie:void 0,currentPage:D.value,pageSize:y.value,statusBar:xt.value,isLoading:pe.value,filters:F.value,onFilterChange:O,filterOptions:Ce.value,loadingFilterOptions:M?.fetchFilterOptions?ee.value:Hl,peopleSearch:M?.searchPeople,getUserByEmail:M?.getUserByEmail,layoutMode:l.layoutMode,suppressHorizontalScroll:l.suppressHorizontalScroll,stickyHeader:l.stickyHeader??true,columnReorder:l.columnReorder,responsiveColumns:l.responsiveColumns,virtualScroll:l.virtualScroll,rowHeight:l.rowHeight,density:l.density??"normal","aria-label":l["aria-label"],"aria-labelledby":l["aria-labelledby"],emptyState:{hasActiveFilters:qe.value,onClearAll:de,message:l.emptyState?.message,render:l.emptyState?.render},formulas:l.formulas,formulaVersion:$e.value,...he.enabled.value?{getFormulaValue:he.getFormulaValue,hasFormula:he.hasFormula,getFormula:he.getFormula,setFormula:he.setFormula,onFormulaCellChanged:he.onCellChanged,getPrecedents:he.getPrecedents,getDependents:he.getDependents,getAuditTrail:he.getAuditTrail}:{},formulaReferences:Be.referencedCells.value.length>0?Be.referencedCells.value:void 0}}),En=computed(()=>({page:D.value,pageSize:y.value,displayTotalCount:vt.value,setPage:X,setPageSize:Q,pageSizeOptions:e.value.pageSizeOptions,entityLabelPlural:m.value.entityLabelPlural})),Pt=computed(()=>({columns:ht.value,visibleColumns:S.value,onVisibilityChange:V,placement:s.value})),He=computed(()=>{let l=e.value,M=!!l.formulas,oe=!!l.cellReferences&&!M,Se=l.toolbar;oe&&(Se=[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"},xe.value??"\u2014"),Se]);let nt=M?h(Mn,{cellRef:Be.cellRef.value,formulaText:Be.formulaText.value,isEditing:Be.isEditing.value,onInputChange:Be.onInputChange,onCommit:Be.onCommit,onCancel:Be.onCancel,onStartEditing:Be.startEditing}):void 0,ot=l.sheetDefs&&l.sheetDefs.length>0&&l.activeSheet&&l.onSheetChange?h(An,{sheets:l.sheetDefs,activeSheet:l.activeSheet,showAddButton:!!l.onSheetAdd,onSheetChange:l.onSheetChange,onSheetAdd:l.onSheetAdd??(()=>{})}):void 0;return {toolbar:Se,toolbarBelow:l.toolbarBelow,className:l.className,emptyState:l.emptyState,sideBarProps:ae.value,fullScreen:l.fullScreen,formulaBar:nt,sheetTabs:ot}}),Et=computed(()=>({hasActiveFilters:qe.value,setFilters:T})),Dn=computed(()=>({setRowData:l=>{u.value||(p.value=l);},setLoading:l=>{d.value=l;},getColumnState:()=>({visibleColumns:Array.from(S.value),sort:x.value,columnOrder:o.value.columnOrder??void 0,columnWidths:Object.keys(g.value).length>0?g.value:void 0,filters:Object.keys(F.value).length>0?F.value:void 0,pinnedColumns:Object.keys(E.value).length>0?E.value:void 0}),applyColumnState:l=>{l.visibleColumns&&U(new Set(l.visibleColumns)),l.sort&&R(l.sort),l.columnOrder&&o.value.onColumnOrderChange&&o.value.onColumnOrderChange(l.columnOrder),l.columnWidths&&(g.value=l.columnWidths),l.filters&&T(l.filters),l.pinnedColumns&&(E.value=l.pinnedColumns);},setFilterModel:T,getSelectedRows:()=>Array.from(L.value),setSelectedRows:l=>{k.value===void 0&&(A.value=new Set(l));},selectAll:()=>{let l=new Set(Le.value.map(M=>t.value.getRowId(M)));k.value===void 0&&(A.value=l),e.value.onSelectionChange?.({selectedRowIds:Array.from(l),selectedItems:Le.value});},deselectAll:()=>{k.value===void 0&&(A.value=new Set),e.value.onSelectionChange?.({selectedRowIds:[],selectedItems:[]});},clearFilters:()=>T({}),clearSort:()=>R({field:r.value,direction:m.value.defaultSortDirection}),resetGridState:l=>{T({}),R({field:r.value,direction:m.value.defaultSortDirection}),l?.keepSelection||(k.value===void 0&&(A.value=new Set),e.value.onSelectionChange?.({selectedRowIds:[],selectedItems:[]}));},getDisplayedRows:()=>Le.value,refreshData:()=>{u.value&&ft.value++;},scrollToRow:()=>{},getColumnOrder:()=>o.value.columnOrder??a.value.map(l=>l.columnId),setColumnOrder:l=>{o.value.onColumnOrderChange?.(l);}}));return {dataGridProps:At,pagination:En,columnChooser:Pt,layout:He,filters:Et,api:Dn}}function Wt(e){let{items:o,getRowId:t,rowSelection:n,controlledSelectedRows:i,onSelectionChange:m}=e,s=shallowRef(new Set),a=-1,u=computed(()=>{let r=i.value;return r!=null?r instanceof Set?r:new Set(r):s.value}),f=r=>{i.value!==void 0?isReadonly(i)||(i.value=r):s.value=r,m?.({selectedRowIds:Array.from(r),selectedItems:o.value.filter(v=>r.has(t(v)))});},p=(r,v,h,P)=>{if(n.value==="single"){f(v?new Set([r]):new Set),a=h;return}let I=o.value,w;P&&a>=0&&a!==h?w=applyRangeRowSelection(a,h,v,I,t,u.value):(w=new Set(u.value),v?w.add(r):w.delete(r)),a=h,f(w);},d=r=>{f(r?new Set(o.value.map(v=>t(v))):new Set);},c=computed(()=>computeRowSelectionState(u.value,o.value,t).allSelected),C=computed(()=>computeRowSelectionState(u.value,o.value,t).someSelected);return {selectedRowIds:u,updateSelection:f,handleRowCheckboxChange:p,handleSelectAll:d,allSelected:c,someSelected:C}}function Kt(e){let o=shallowRef(null),t=ref(void 0);return {editingCell:o,setEditingCell:m=>{if(m&&e?.scrollToRow&&e?.getRowIndex){let s=e.getRowIndex(m.rowId);s>=0&&e.scrollToRow(s,"center");}o.value=m;},pendingEditorValue:t,setPendingEditorValue:m=>{t.value=m;}}}function $t(e,o){let t=shallowRef(null),n=0,i=m=>{let s=t.value;s!==m&&(s&&m&&s.rowIndex===m.rowIndex&&s.columnIndex===m.columnIndex||(t.value=m));};return watch([t,()=>o?.value],()=>{if(n&&(cancelAnimationFrame(n),n=0),t.value==null||!e?.value||o?.value!=null)return;let{rowIndex:m,columnIndex:s}=t.value;n=requestAnimationFrame(()=>{n=0;let a=e.value;if(!a)return;let u=t.value;if(!u||u.rowIndex!==m||u.columnIndex!==s)return;let f=`[data-row-index="${m}"][data-col-index="${s}"]`,p=a.querySelector(f);if(p){let d=a.querySelector("thead"),c=d?d.getBoundingClientRect().height:0,C=a.getBoundingClientRect(),r=p.getBoundingClientRect(),v=C.top+c;r.top<v?a.scrollTop-=v-r.top:r.bottom>C.bottom&&(a.scrollTop+=r.bottom-C.bottom),a.scrollWidth>a.clientWidth&&(r.left<C.left?a.scrollLeft-=C.left-r.left:r.right>C.right&&(a.scrollLeft+=r.right-C.right)),document.activeElement!==p&&typeof p.focus=="function"&&p.focus({preventScroll:true});}});},{flush:"post"}),onUnmounted(()=>{n&&(cancelAnimationFrame(n),n=0);}),{activeCell:t,setActiveCell:i}}var _n="data-drag-range",Ut="data-drag-anchor",ye=40,Jl=16;function qt(e){let o=rt(e),{wrapperRef:t,setActiveCell:n}=e,i=()=>isRef(e.colOffset)?e.colOffset.value:e.colOffset,m=shallowRef(null),s=ref(false),a=ref(false),u=ref(false),f=false,p=null,d=0,c=null,C=null,r=null,v=R=>{rangesEqual(m.value,R)||(m.value=R);},h=(R,T,U)=>{if(R.button!==0)return;let G=i();if(U<G)return;R.preventDefault();let O=U-G,V=m.value;if(R.shiftKey&&V!=null)v(normalizeSelectionRange({startRow:V.startRow,startCol:V.startCol,endRow:T,endCol:O})),n({rowIndex:T,columnIndex:U});else {p={row:T,col:O},f=false;let A={startRow:T,startCol:O,endRow:T,endCol:O};v(A),c=A,n({rowIndex:T,columnIndex:U}),a.value=true,E(A);}},P=()=>{let{rowCount:R,visibleColCount:T}=o.value;R.value===0||T.value===0||(v({startRow:0,startCol:0,endRow:R.value-1,endCol:T.value-1}),n({rowIndex:0,columnIndex:i()}));},I=new Set,w=null,g=(R,T,U,G,O,V,A,k)=>{R.hasAttribute(_n)||R.setAttribute(_n,""),k&&T===k.row&&U===k.col?R.hasAttribute(Ut)||R.setAttribute(Ut,""):R.hasAttribute(Ut)&&R.removeAttribute(Ut);let z=[];T===G&&z.push("inset 0 2px 0 0 var(--ogrid-selection, #217346)"),T===O&&z.push("inset 0 -2px 0 0 var(--ogrid-selection, #217346)"),U===V&&z.push("inset 2px 0 0 0 var(--ogrid-selection, #217346)"),U===A&&z.push("inset -2px 0 0 0 var(--ogrid-selection, #217346)"),R.style.boxShadow=z.length>0?z.join(", "):"",I.add(R);},b=R=>{R.removeAttribute(_n),R.removeAttribute(Ut),R.style.boxShadow="";},E=R=>{if(!t.value)return;let U=Math.min(R.startRow,R.endRow),G=Math.max(R.startRow,R.endRow),O=Math.min(R.startCol,R.endCol),V=Math.max(R.startCol,R.endCol),A=p,k=i();for(let z of I){let le=parseInt(z.getAttribute("data-row-index")??"",10),ne=parseInt(z.getAttribute("data-col-index")??"",10)-k;le>=U&&le<=G&&ne>=O&&ne<=V||(b(z),I.delete(z));}w||(w=buildCellIndex(t.value));let L=false;for(let z=U;z<=G;z++)for(let le=O;le<=V;le++){let ne=`${z},${le+k}`,B=w?.get(ne);B&&!B.isConnected&&!L&&(L=true,w=buildCellIndex(t.value),B=w?.get(ne)),B&&B.isConnected&&g(B,z,le,U,G,O,V,A);}},D=()=>{for(let R of I)b(R);I.clear(),w=null;},y=(R,T)=>{if(!p)return null;let G=document.elementFromPoint(R,T)?.closest?.("[data-row-index][data-col-index]");if(!G)return null;let O=parseInt(G.getAttribute("data-row-index")??"",10),V=parseInt(G.getAttribute("data-col-index")??"",10),A=i();if(Number.isNaN(O)||Number.isNaN(V)||V<A)return null;let k=V-A;return normalizeSelectionRange({startRow:p.row,startCol:p.col,endRow:O,endCol:k})},x=()=>{C&&(clearInterval(C),C=null);},F=()=>{let R=t.value;if(!R||!r||!a.value){x();return}let T=R.getBoundingClientRect(),U=0,G=0;if(r.cy<T.top+ye?G=-computeAutoScrollSpeed(T.top+ye-r.cy):r.cy>T.bottom-ye&&(G=computeAutoScrollSpeed(r.cy-(T.bottom-ye))),r.cx<T.left+ye?U=-computeAutoScrollSpeed(T.left+ye-r.cx):r.cx>T.right-ye&&(U=computeAutoScrollSpeed(r.cx-(T.right-ye))),U===0&&G===0){x();return}C||(C=setInterval(()=>{let O=t.value,V=r;if(!O||!V||!a.value){x();return}let A=O.getBoundingClientRect(),k=0,L=0;if(V.cy<A.top+ye?L=-computeAutoScrollSpeed(A.top+ye-V.cy):V.cy>A.bottom-ye&&(L=computeAutoScrollSpeed(V.cy-(A.bottom-ye))),V.cx<A.left+ye?k=-computeAutoScrollSpeed(A.left+ye-V.cx):V.cx>A.right-ye&&(k=computeAutoScrollSpeed(V.cx-(A.right-ye))),k===0&&L===0){x();return}O.scrollTop+=L,O.scrollLeft+=k;let z=y(V.cx,V.cy);z&&(c=z,E(z));},Jl));},S=R=>{!a.value||!p||(f||(f=true,s.value=true,w=buildCellIndex(t.value)),r={cx:R.clientX,cy:R.clientY},F(),d&&cancelAnimationFrame(d),d=requestAnimationFrame(()=>{if(d=0,!r)return;let T=y(r.cx,r.cy);if(!T)return;let U=c;U&&U.startRow===T.startRow&&U.startCol===T.startCol&&U.endRow===T.endRow&&U.endCol===T.endCol||(c=T,E(T));}));},X=()=>{if(!a.value)return;x(),d&&(cancelAnimationFrame(d),d=0),a.value=false;let R=f;if(R){if(r){let U=y(r.cx,r.cy);U&&(c=U);}let T=c;if(T){v(T);let U=p;U&&n({rowIndex:U.row,columnIndex:U.col+i()});}}D(),c=null,r=null,p=null,R&&(s.value=false);},Q=R=>{u.value||S(R);},Z=()=>{u.value||X();};return onMounted(()=>{window.addEventListener("pointermove",Q,true),window.addEventListener("pointerup",Z,true);}),onUnmounted(()=>{u.value=true,window.removeEventListener("pointermove",Q,true),window.removeEventListener("pointerup",Z,true),d&&cancelAnimationFrame(d),x();}),{selectionRange:m,setSelectionRange:v,handleCellMouseDown:h,handleSelectAllCells:P,isDragging:s}}function Xt(){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:o,visibleCols:t,selectionRange:n,activeCell:i,editable:m,onCellValueChanged:s,beginBatch:a,endBatch:u}=e,f=()=>isRef(e.colOffset)?e.colOffset.value:e.colOffset,p=shallowRef(null),d=shallowRef(null),c=ref(null),C=()=>{let I=n.value,w=i.value,g=f();return I??(w!=null?{startRow:w.rowIndex,startCol:w.columnIndex-g,endRow:w.rowIndex,endCol:w.columnIndex-g}:null)},r=()=>{let I=C();if(I==null)return;let w=normalizeSelectionRange(I),g=formatSelectionAsTsv(o.value,t.value,w);c.value=g,d.value=w,navigator.clipboard.writeText(g).catch(b=>{typeof console<"u"&&console.warn("[OGrid] Clipboard write failed:",b);});};return {handleCopy:r,handleCut:()=>{if(m.value===false)return;let I=C();if(I==null||s.value==null)return;let w=normalizeSelectionRange(I);p.value=w,d.value=null,r(),d.value=null;},handlePaste:async()=>{if(m.value===false)return;let I=s.value;if(I==null)return;let w;try{w=await navigator.clipboard.readText();}catch{w="";}if(!w.trim()&&c.value!=null&&(w=c.value),!w.trim())return;let g=C(),b=g?g.startRow:0,E=g?g.startCol:0,D=o.value,y=t.value,x=parseTsvClipboard(w);a?.();let F=applyPastedValues(x,b,E,D,y);for(let S of F)I(S);if(p.value){let S=applyCutClear(p.value,D,y);for(let X of S)I(X);p.value=null;}u?.(),d.value=null;},cutRange:p,copyRange:d,clearClipboardRanges:()=>{d.value=null,p.value=null;}}}function Yt(e){let o=rt(e);return {handleGridKeyDown:n=>{let{data:i,state:m,handlers:s,features:a}=o.value,u=i.items.value,f=i.visibleCols.value,{getRowId:p}=i,d=isRef(i.colOffset)?i.colOffset.value:i.colOffset,c=i.hasCheckboxCol.value,C=i.visibleColumnCount.value,r=m.activeCell.value,v=m.selectionRange.value,h=m.editingCell.value,P=m.selectedRowIds.value,{setActiveCell:I,setSelectionRange:w,setEditingCell:g,handleRowCheckboxChange:b,handleCopy:E,handleCut:D,handlePaste:y,setContextMenu:x,onUndo:F,onRedo:S,clearClipboardRanges:X}=s,Q=a.editable.value,Z=a.onCellValueChanged.value,R=a.rowSelection.value,T=a.wrapperRef,U=a.scrollToRow,{fillDown:G}=a,O=a.onKeyDown?.value;if(O&&(O(n),n.defaultPrevented))return;let V=u.length-1,A=C-1+d;if(u.length===0)return;if(r===null){["ArrowDown","ArrowUp","ArrowLeft","ArrowRight","Tab","Enter","Home","End","PageDown","PageUp"].includes(n.key)&&(I({rowIndex:0,columnIndex:d}),n.preventDefault());return}let{rowIndex:k,columnIndex:L}=r,z=L-d,le=n.shiftKey,ne=(B,ee)=>{if(B<0||B>=u.length||ee<0||ee>=f.length)return true;let te=getCellValue(u[B],f[ee]);return te==null||te===""};switch(n.key){case "c":if(n.ctrlKey||n.metaKey){if(h!=null)break;n.preventDefault(),E();}break;case "x":if(n.ctrlKey||n.metaKey){if(h!=null)break;n.preventDefault(),D();}break;case "v":if(n.ctrlKey||n.metaKey){if(h!=null)break;n.preventDefault(),y();}break;case "d":if(n.ctrlKey||n.metaKey){if(h!=null)break;Q!==false&&G&&(n.preventDefault(),G());}break;case "ArrowDown":case "ArrowUp":case "ArrowRight":case "ArrowLeft":{if(h!=null)break;n.preventDefault();let{newRowIndex:B,newColumnIndex:ee,newRange:te}=computeArrowNavigation({direction:n.key,rowIndex:k,columnIndex:L,dataColIndex:z,colOffset:d,maxRowIndex:V,maxColIndex:A,visibleColCount:f.length,isCtrl:n.ctrlKey||n.metaKey,isShift:le,selectionRange:v,isEmptyAt:ne});w(te),I({rowIndex:B,columnIndex:ee}),(n.key==="ArrowDown"||n.key==="ArrowUp")&&U?.(B,"center");break}case "Tab":{n.preventDefault();let{rowIndex:B,columnIndex:ee}=computeTabNavigation(k,L,V,A,d,n.shiftKey),te=ee-d;w({startRow:B,startCol:te,endRow:B,endCol:te}),I({rowIndex:B,columnIndex:ee});break}case "Home":{n.preventDefault();let B=n.ctrlKey?0:k;w({startRow:B,startCol:0,endRow:B,endCol:0}),I({rowIndex:B,columnIndex:d});break}case "End":{n.preventDefault();let B=n.ctrlKey?V:k;w({startRow:B,startCol:C-1,endRow:B,endCol:C-1}),I({rowIndex:B,columnIndex:A});break}case "PageDown":case "PageUp":{n.preventDefault();let B=T.value,ee=10;if(B){let be=B.querySelector("tbody tr");be&&be.offsetHeight>0&&(ee=Math.max(1,Math.floor(B.clientHeight/be.offsetHeight)));}let te=n.key==="PageDown"?1:-1,Ce=Math.max(0,Math.min(k+te*ee,V));w(le?{startRow:v?.startRow??k,startCol:v?.startCol??z,endRow:Ce,endCol:v?.endCol??z}:{startRow:Ce,startCol:z,endRow:Ce,endCol:z}),I({rowIndex:Ce,columnIndex:L}),U?.(Ce,"center");break}case "Enter":case "F2":{if(n.preventDefault(),z>=0&&z<f.length){let B=f[z],ee=u[k];if(ee&&B){let te=B.editable===true||typeof B.editable=="function"&&B.editable(ee);Q!==false&&te&&Z!=null&&g({rowId:p(ee),columnId:B.columnId});}}break}case "Escape":n.preventDefault(),h!=null?g(null):(X?.(),I(null),w(null));break;case " ":if(R!=="none"&&L===0&&c){n.preventDefault();let B=u[k];if(B){let ee=p(B),te=P.has(ee);b(ee,!te,k,n.shiftKey);}}break;case "z":(n.ctrlKey||n.metaKey)&&h==null&&(n.shiftKey&&S?(n.preventDefault(),S()):!n.shiftKey&&F&&(n.preventDefault(),F()));break;case "y":(n.ctrlKey||n.metaKey)&&h==null&&S&&(n.preventDefault(),S());break;case "a":if(n.ctrlKey||n.metaKey){if(h!=null)break;n.preventDefault(),u.length>0&&C>0&&(w({startRow:0,startCol:0,endRow:u.length-1,endCol:C-1}),I({rowIndex:0,columnIndex:d}));}break;case "Delete":case "Backspace":{if(h!=null||Q===false||Z==null)break;let B=v??(r!=null?{startRow:r.rowIndex,startCol:r.columnIndex-d,endRow:r.rowIndex,endCol:r.columnIndex-d}:null);if(B==null)break;n.preventDefault();let ee=applyCellDeletion(B,u,f);for(let te of ee)Z(te);break}case "F10":if(n.shiftKey)if(n.preventDefault(),r!=null&&T.value){let B=`[data-row-index="${r.rowIndex}"][data-col-index="${r.columnIndex}"]`,ee=T.value.querySelector(B);if(ee){let te=ee.getBoundingClientRect();x({x:te.left+te.width/2,y:te.top+te.height/2});}else x({x:100,y:100});}else x({x:100,y:100});break;}}}}var Zt="data-drag-range";function Jt(e){let{items:o,visibleCols:t,editable:n,onCellValueChanged:i,selectionRange:m,setSelectionRange:s,setActiveCell:a,wrapperRef:u,beginBatch:f,endBatch:p,visibleRange:d}=e,c=()=>isRef(e.colOffset)?e.colOffset.value:e.colOffset,C=shallowRef(null),r={endRow:0,endCol:0},v=0,h=null,P=null,I=null,w=D=>{C.value=D;},g=()=>{P&&(window.removeEventListener("pointermove",P,true),P=null),I&&(window.removeEventListener("pointerup",I,true),I=null),v&&(cancelAnimationFrame(v),v=0);};return watch(C,(D,y,x)=>{if(!D||n.value===false||!i.value||!u.value){g();return}r={endRow:D.startRow,endCol:D.startCol},h=null;let F=new Set,S=buildCellIndex(u.value),X=T=>{if(!u.value)return;let G=Math.min(T.startRow,T.endRow),O=Math.max(T.startRow,T.endRow),V=Math.min(T.startCol,T.endCol),A=Math.max(T.startCol,T.endCol),k=c();for(let L of F){let z=parseInt(L.getAttribute("data-row-index")??"",10),le=parseInt(L.getAttribute("data-col-index")??"",10)-k;z>=G&&z<=O&&le>=V&&le<=A||(L.removeAttribute(Zt),F.delete(L));}for(let L=G;L<=O;L++)for(let z=V;z<=A;z++){let le=`${L},${z+k}`,ne=S?.get(le);ne&&!ne.isConnected&&(S=buildCellIndex(u.value),ne=S.get(le)),ne&&(ne.hasAttribute(Zt)||ne.setAttribute(Zt,""),F.add(ne));}},Q=()=>{for(let T of F)T.removeAttribute(Zt);F.clear();},Z=null,R=(T,U)=>{let O=document.elementFromPoint(T,U)?.closest?.("[data-row-index][data-col-index]");if(!O||!u.value?.contains(O))return null;let V=parseInt(O.getAttribute("data-row-index")??"",10),A=parseInt(O.getAttribute("data-col-index")??"",10),k=c();if(Number.isNaN(V)||Number.isNaN(A)||A<k)return null;let L=A-k;return normalizeSelectionRange({startRow:D.startRow,startCol:D.startCol,endRow:V,endCol:L})};P=T=>{Z={cx:T.clientX,cy:T.clientY},v&&cancelAnimationFrame(v),v=requestAnimationFrame(()=>{if(v=0,!Z)return;let U=R(Z.cx,Z.cy);if(!U)return;let G=h;G&&G.startRow===U.startRow&&G.startCol===U.startCol&&G.endRow===U.endRow&&G.endCol===U.endCol||(h=U,r={endRow:U.endRow,endCol:U.endCol},X(U));});},I=()=>{if(v&&(cancelAnimationFrame(v),v=0),Z){let k=R(Z.cx,Z.cy);k&&(h=k,r={endRow:k.endRow,endCol:k.endCol});}Q();let T=r,U=normalizeSelectionRange({startRow:D.startRow,startCol:D.startCol,endRow:T.endRow,endCol:T.endCol}),G=d?.value;G&&(U.startRow=Math.max(U.startRow,G.startIndex),U.endRow=Math.min(U.endRow,G.endIndex)),s(U),a({rowIndex:D.startRow,columnIndex:D.startCol+c()});let O=o.value,V=t.value,A=i.value;if(A){let k=applyFillValues(U,D.startRow,D.startCol,O,V);if(k.length>0){f?.();for(let L of k)A(L);p?.();}}C.value=null,h=null,g();},window.addEventListener("pointermove",P,true),window.addEventListener("pointerup",I,true),x(()=>{g();});}),onUnmounted(()=>g()),{fillDrag:C,setFillDrag:w,handleFillHandleMouseDown:D=>{D.preventDefault(),D.stopPropagation();let y=m.value;y&&(C.value={startRow:y.startRow,startCol:y.startCol});},fillDown:()=>{let D=m.value;if(!D||n.value===false||!i.value)return;let y=normalizeSelectionRange(D),x=o.value,F=t.value,S=i.value,X=applyFillValues(y,y.startRow,y.startCol,x,F);if(X.length>0){f?.();for(let Q of X)S(Q);p?.();}}}}function Qt(e){let{onCellValueChanged:o,maxUndoDepth:t=100}=e,n=new UndoRedoStack(t),i=ref(false),m=ref(false),s=()=>{i.value=n.canUndo,m.value=n.canRedo;};return {onCellValueChanged:o?c=>{n.record(c),n.isBatching||s(),o(c);}:void 0,undo:()=>{if(!o)return;let c=n.undo();if(c){s();for(let C=c.length-1;C>=0;C--){let r=c[C];o({...r,oldValue:r.newValue,newValue:r.oldValue});}}},redo:()=>{if(!o)return;let c=n.redo();if(c){s();for(let C of c)o(C);}},canUndo:i,canRedo:m,beginBatch:()=>{n.beginBatch();},endBatch:()=>{n.endBatch(),s();},maxUndoDepth:t}}function en(e){let{wrapperRef:o,visibleCols:t,flatColumns:n,hasCheckboxCol:i,initialColumnWidths:m,onColumnResized:s}=e,a=ref(0),u,f=()=>{let r=o.value;if(!r)return;let v=r.getBoundingClientRect(),h=window.getComputedStyle(r),P=(parseFloat(h.borderLeftWidth||"0")||0)+(parseFloat(h.borderRightWidth||"0")||0);a.value=Math.max(0,v.width-P);};onMounted(()=>{let r=o.value;r&&(typeof ResizeObserver<"u"&&(u=new ResizeObserver(f),u.observe(r)),f());}),onUnmounted(()=>{u?.disconnect();});let p=ref((()=>{if(!m)return {};let r={};for(let[v,h]of Object.entries(m))r[v]={widthPx:h};return r})()),d=r=>{p.value=r;},c=computed(()=>{let r=i.value?CHECKBOX_COLUMN_WIDTH:0;return t.value.reduce((v,h)=>v+(h.minWidth??estimateHeaderMinWidth(h.name))+CELL_PADDING,r)});watch(n,r=>{let v=new Set(r.map(w=>w.columnId)),h=p.value,P=Object.keys(h),I=P.filter(w=>v.has(w));if(I.length<P.length){let w={};for(let g of I)w[g]=h[g];p.value=w;}});let C=computed(()=>{let r=i.value?CHECKBOX_COLUMN_WIDTH:0;return t.value.reduce((v,h)=>{let P=p.value[h.columnId],I=h.minWidth??estimateHeaderMinWidth(h.name),w=P?P.widthPx:h.idealWidth??h.defaultWidth??I;return v+Math.max(I,w)+CELL_PADDING},r)});return {containerWidth:a,minTableWidth:c,desiredTableWidth:C,columnSizingOverrides:p,setColumnSizingOverrides:d,onColumnResized:s}}function tn(e){let{columns:o,pinnedColumns:t,onColumnPinned:n}=e,i={};for(let c of o.value)c.pinned&&(i[c.columnId]=c.pinned);let m=ref(i),s=computed(()=>t?.value??m.value);return {pinnedColumns:s,pinColumn:(c,C)=>{let r={...s.value,[c]:C};m.value=r,n?.(c,C);},unpinColumn:c=>{let{[c]:C,...r}=s.value;m.value=r,n?.(c,null);},isPinned:c=>s.value[c],computeLeftOffsets:(c,C,r,v,h)=>{let P={},I=v?h:0;for(let w of c)s.value[w.columnId]==="left"&&(P[w.columnId]=I,I+=C[w.columnId]??r);return P},computeRightOffsets:(c,C,r)=>{let v={},h=0;for(let P=c.length-1;P>=0;P--){let I=c[P];s.value[I.columnId]==="right"&&(v[I.columnId]=h,h+=C[I.columnId]??r);}return v}}}function on(e){let{columns:o,pinnedColumns:t,onPinColumn:n,onUnpinColumn:i,onSort:m,onColumnResized:s,onAutosizeColumn:a,sortBy:u,sortDirection:f}=e,p=ref(false),d=ref(null),c=ref(null),C=(R,T)=>{d.value=R,c.value=T,p.value=true;},r=()=>{p.value=false,d.value=null,c.value=null;},v=computed(()=>d.value?o.value.find(R=>R.columnId===d.value):void 0),h=computed(()=>d.value?t.value[d.value]:void 0),P=computed(()=>h.value!=="left"),I=computed(()=>h.value!=="right"),w=computed(()=>!!h.value),g=computed(()=>!d.value||!u?.value||u.value!==d.value?null:f?.value??null),b=computed(()=>v.value?.sortable!==false),E=ref(true);return {isOpen:p,openForColumn:d,anchorElement:c,open:C,close:r,handlePinLeft:()=>{d.value&&P.value&&(n(d.value,"left"),r());},handlePinRight:()=>{d.value&&I.value&&(n(d.value,"right"),r());},handleUnpin:()=>{d.value&&w.value&&(i(d.value),r());},handleSortAsc:()=>{d.value&&m&&(m(d.value,"asc"),r());},handleSortDesc:()=>{d.value&&m&&(m(d.value,"desc"),r());},handleClearSort:()=>{d.value&&m&&(m(d.value,null),r());},handleAutosizeThis:()=>{let R=a??s;if(!d.value||!R||!E.value)return;let T=v.value;R(d.value,measureColumnContentWidth(d.value,T?.minWidth)),r();},handleAutosizeAll:()=>{let R=a??s;R&&(o.value.forEach(T=>{R(T.columnId,measureColumnContentWidth(T.columnId,T.minWidth));}),r());},canPinLeft:P,canPinRight:I,canUnpin:w,currentSort:g,isSortable:b,isResizable:E}}var je=()=>{},Ur=async()=>{},Or=(e,o,t)=>{},Mr=e=>{},kr=e=>{};function ln(e){let{props:o,wrapperRef:t}=e,n=computed(()=>o.value.items),i=o.value.getRowId,m=computed(()=>o.value.rowSelection??"none"),s=computed(()=>o.value.selectedRows),a=computed(()=>o.value.editable),u=computed(()=>o.value.cellSelection!==false),f=computed(()=>o.value.pinnedColumns),p=Qt({onCellValueChanged:o.value.onCellValueChanged}),d=computed(()=>p.onCellValueChanged),c=computed(()=>flattenColumns(o.value.columns)),C=computed(()=>{let $=f.value;return !$||Object.keys($).length===0?c.value:c.value.map(Y=>{let ae=$[Y.columnId];return ae&&Y.pinned!==ae?{...Y,pinned:ae}:Y})}),r=computed(()=>resolveResponsiveConfig(o.value.responsiveColumns)),v=computed(()=>{let $=o.value.visibleColumns,Y=o.value.columnOrder,ae=$?C.value.filter(pe=>$.has(pe.columnId)):C.value;if(!Y?.length)return ae;let de=new Map;for(let pe=0;pe<Y.length;pe++)de.set(Y[pe],pe);return [...ae].sort((pe,xe)=>{let ce=de.get(pe.columnId)??-1,Ie=de.get(xe.columnId)??-1;return ce===-1&&Ie===-1?0:ce===-1?1:Ie===-1?-1:ce-Ie})}),h=ref(0),P=computed(()=>applyResponsiveHiding(v.value,h.value,r.value)),I=computed(()=>P.value.length),w=computed(()=>m.value==="multiple"),g=computed(()=>!!o.value.showRowNumbers),b=computed(()=>(w.value?1:0)+(g.value?1:0)),E=computed(()=>I.value+b.value),D=b,y=shallowRef(new Map);watch(n,$=>{let Y=y.value;Y.clear(),$.forEach((ae,de)=>Y.set(i(ae),de)),triggerRef(y);},{immediate:true});let x=Wt({items:n,getRowId:i,rowSelection:m,controlledSelectedRows:s,onSelectionChange:o.value.onSelectionChange}),{editingCell:F,setEditingCell:S,pendingEditorValue:X,setPendingEditorValue:Q}=Kt(),{activeCell:Z,setActiveCell:R}=$t(t,F),T=computed(()=>n.value.length),U=computed(()=>P.value.length),{selectionRange:G,setSelectionRange:O,handleCellMouseDown:V,handleSelectAllCells:A,isDragging:k}=qt({colOffset:D,rowCount:T,visibleColCount:U,setActiveCell:R,wrapperRef:t}),{contextMenuPosition:L,setContextMenuPosition:z,handleCellContextMenu:le,closeContextMenu:ne}=Xt(),{handleCopy:B,handleCut:ee,handlePaste:te,cutRange:Ce,copyRange:be,clearClipboardRanges:Ee}=jt({items:n,visibleCols:P,colOffset:D,selectionRange:G,activeCell:Z,editable:a,onCellValueChanged:d,beginBatch:p.beginBatch,endBatch:p.endBatch}),Ae=($,Y,ae)=>{$.button===0&&(t.value?.focus({preventScroll:true}),Ee(),V($,Y,ae));},{handleFillHandleMouseDown:Ne,fillDown:St}=Jt({items:n,visibleCols:P,editable:a,onCellValueChanged:d,selectionRange:G,setSelectionRange:O,setActiveCell:R,colOffset:D,wrapperRef:t,beginBatch:p.beginBatch,endBatch:p.endBatch}),{handleGridKeyDown:st}=Yt({data:{items:n,visibleCols:P,colOffset:D,hasCheckboxCol:w,visibleColumnCount:I,getRowId:i},state:{activeCell:Z,selectionRange:G,editingCell:F,selectedRowIds:x.selectedRowIds},handlers:{setActiveCell:R,setSelectionRange:O,setEditingCell:S,handleRowCheckboxChange:x.handleRowCheckboxChange,handleCopy:B,handleCut:ee,handlePaste:te,setContextMenu:z,onUndo:p.undo,onRedo:p.redo,clearClipboardRanges:Ee},features:{editable:a,onCellValueChanged:d,rowSelection:m,wrapperRef:t,fillDown:St,onKeyDown:computed(()=>o.value.onKeyDown)}}),{containerWidth:ut,minTableWidth:Ze,desiredTableWidth:dt,columnSizingOverrides:Fe,setColumnSizingOverrides:ct}=en({wrapperRef:t,visibleCols:v,flatColumns:C,hasCheckboxCol:w,initialColumnWidths:o.value.initialColumnWidths,onColumnResized:($,Y)=>o.value.onColumnResized?.($,Y)});watch(ut,$=>{h.value=$;},{immediate:true});let we=tn({columns:C,pinnedColumns:f,onColumnPinned:o.value.onColumnPinned}),Ke=($,Y)=>{ct({...Fe.value,[$]:{widthPx:Y}}),o.value.onColumnResized?.($,Y);},re=on({columns:C,pinnedColumns:we.pinnedColumns,onPinColumn:we.pinColumn,onUnpinColumn:we.unpinColumn,onSort:o.value.onColumnSort,onColumnResized:o.value.onColumnResized,onAutosizeColumn:Ke,sortBy:computed(()=>o.value.sortBy),sortDirection:computed(()=>o.value.sortDirection)}),_e=ref({});watch([P,ut,Fe],()=>{nextTick(()=>{let $=t.value;if(!$)return;let Y=$.querySelectorAll("th[data-column-id]");if(Y.length===0)return;let ae={};Y.forEach(ce=>{let Ie=ce.getAttribute("data-column-id");Ie&&(ae[Ie]=ce.offsetWidth);});let de=_e.value,pe=Object.keys(ae),xe=pe.length!==Object.keys(de).length;if(!xe){for(let ce of pe)if(de[ce]!==ae[ce]){xe=true;break}}xe&&(_e.value=ae);});},{flush:"post"});let Je=computed(()=>{let $={};for(let Y of P.value){let ae=Fe.value[Y.columnId];$[Y.columnId]=ae?ae.widthPx:Y.idealWidth??Y.defaultWidth??Y.minWidth??DEFAULT_MIN_COLUMN_WIDTH;}return $}),De=computed(()=>we.computeLeftOffsets(P.value,Je.value,DEFAULT_MIN_COLUMN_WIDTH,w.value,CHECKBOX_COLUMN_WIDTH)),Qe=computed(()=>we.computeRightOffsets(P.value,Je.value,DEFAULT_MIN_COLUMN_WIDTH)),et=computed(()=>computeAggregations(n.value,P.value,u.value?G.value:null)),We=computed(()=>{let $=getDataGridStatusBarConfig(o.value.statusBar,n.value.length,x.selectedRowIds.value.size);return $?{...$,aggregation:et.value??void 0}:null}),ft=computed(()=>n.value.length===0&&!!o.value.emptyState&&!o.value.isLoading),pt=computed(()=>G.value!=null||Z.value!=null),Le=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})),vt=computed(()=>({editingCell:F.value,activeCell:u.value?Z.value:null,selectionRange:u.value?G.value:null,cutRange:u.value?Ce.value:null,copyRange:u.value?be.value:null,colOffset:D.value,itemsLength:n.value.length,getRowId:i,editable:a.value,onCellValueChanged:d.value,isDragging:u.value?k.value:false,getFormulaValue:o.value.getFormulaValue,hasFormula:o.value.hasFormula,getFormula:o.value.getFormula,formulaVersion:o.value.formulaVersion})),gt=ref(null),$e=$=>{gt.value=$;},yt=($,Y,ae,de,pe,xe,ce)=>{let Ie=P.value.find(Ue=>Ue.columnId===Y);if(Ie){let Ue=parseValue(de,ae,$,Ie);if(!Ue.valid){S(null),$e(null),Q(void 0);return}de=Ue.value;}if(d.value?.({item:$,columnId:Y,oldValue:ae,newValue:de,rowIndex:pe}),S(null),$e(null),Q(void 0),!ce?.skipAdvance&&pe<n.value.length-1){let Ue=pe+1,tt=xe-D.value;R({rowIndex:Ue,columnIndex:xe}),O({startRow:Ue,startCol:tt,endRow:Ue,endCol:tt});}},he=()=>{S(null),$e(null),Q(void 0);},Ct=computed(()=>({flatColumns:C.value,visibleCols:P.value,visibleColumnCount:I.value,totalColCount:E.value,colOffset:D.value,hasCheckboxCol:w.value,hasRowNumbersCol:g.value,rowIndexByRowId:y.value,containerWidth:ut.value,minTableWidth:Ze.value,desiredTableWidth:dt.value,columnSizingOverrides:Fe.value,setColumnSizingOverrides:ct,onColumnResized:o.value.onColumnResized,measuredColumnWidths:_e.value,stickyHeader:o.value.stickyHeader??true})),wt=computed(()=>({selectedRowIds:x.selectedRowIds.value,updateSelection:x.updateSelection,handleRowCheckboxChange:x.handleRowCheckboxChange,handleSelectAll:x.handleSelectAll,allSelected:x.allSelected.value,someSelected:x.someSelected.value})),qe=computed(()=>({editingCell:F.value,setEditingCell:S,pendingEditorValue:X.value,setPendingEditorValue:Q,commitCellEdit:yt,cancelPopoverEdit:he,popoverAnchorEl:gt.value,setPopoverAnchorEl:$e})),ht=computed(()=>({activeCell:u.value?Z.value:null,setActiveCell:u.value?R:je,selectionRange:u.value?G.value:null,setSelectionRange:u.value?O:je,handleCellMouseDown:u.value?Ae:Or,handleSelectAllCells:u.value?A:je,hasCellSelection:u.value?pt.value:false,handleGridKeyDown:u.value?st:Mr,handleFillHandleMouseDown:u.value?Ne:je,handleCopy:u.value?B:je,handleCut:u.value?ee:je,handlePaste:u.value?te:Ur,cutRange:u.value?Ce.value:null,copyRange:u.value?be.value:null,clearClipboardRanges:u.value?Ee:je,canUndo:p.canUndo.value,canRedo:p.canRedo.value,onUndo:p.undo,onRedo:p.redo,isDragging:u.value?k.value:false})),xt=computed(()=>({menuPosition:u.value?L.value:null,setMenuPosition:u.value?z:je,handleCellContextMenu:u.value?le:kr,closeContextMenu:u.value?ne:je})),It=computed(()=>({headerFilterInput:Le.value,cellDescriptorInput:vt.value,statusBarConfig:We.value,showEmptyInGrid:ft.value,onCellError:o.value.onCellError})),Tt=computed(()=>({pinnedColumns:we.pinnedColumns.value,pinColumn:we.pinColumn,unpinColumn:we.unpinColumn,isPinned:we.isPinned,leftOffsets:De.value,rightOffsets:Qe.value,headerMenu:{isOpen:re.isOpen.value,openForColumn:re.openForColumn.value,anchorElement:re.anchorElement.value,open:re.open,close:re.close,handlePinLeft:re.handlePinLeft,handlePinRight:re.handlePinRight,handleUnpin:re.handleUnpin,handleSortAsc:re.handleSortAsc,handleSortDesc:re.handleSortDesc,handleClearSort:re.handleClearSort,handleAutosizeThis:re.handleAutosizeThis,handleAutosizeAll:re.handleAutosizeAll,canPinLeft:re.canPinLeft.value,canPinRight:re.canPinRight.value,canUnpin:re.canUnpin.value,currentSort:re.currentSort.value,isSortable:re.isSortable.value,isResizable:re.isResizable.value}}));return {layout:Ct,rowSelection:wt,editing:qe,interaction:ht,contextMenu:xt,viewModels:It,pinning:Tt}}function rn(e){let{columnSizingOverrides:o,setColumnSizingOverrides:t,minWidth:n=80,defaultWidth:i=120,onColumnResized:m}=e,s=0,a=null;return onUnmounted(()=>{a?.(),a=null;}),{handleResizeStart:(d,c)=>{d.preventDefault(),d.stopPropagation();let C=d.clientX,r=c.columnId,v=d.currentTarget.parentElement,h=v?v.getBoundingClientRect().width:o.value[r]?.widthPx??c.idealWidth??c.defaultWidth??i,P=h,I=document.body.style.cursor,w=document.body.style.userSelect;document.body.style.cursor="col-resize",document.body.style.userSelect="none";let g=()=>{t({...o.value,[r]:{widthPx:P}});},b=r===ROW_NUMBER_COLUMN_ID?ROW_NUMBER_COLUMN_MIN_WIDTH:n,E=x=>{let F=x.clientX-C;P=Math.max(b,h+F),s||(s=requestAnimationFrame(()=>{s=0,g();}));},D=()=>{document.removeEventListener("pointermove",E),document.removeEventListener("pointerup",y),a=null,document.body.style.cursor=I,document.body.style.userSelect=w,s&&(cancelAnimationFrame(s),s=0);},y=()=>{D(),g(),m?.(r,P);};document.addEventListener("pointermove",E),document.addEventListener("pointerup",y),a=D;},handleResizeDoubleClick:(d,c)=>{d.preventDefault(),d.stopPropagation();let C=c.columnId,v=(d.currentTarget.closest("th")??d.currentTarget.parentElement)?.closest("table")?.parentElement??void 0,h=measureColumnContentWidth(C,n,v);t({...o.value,[C]:{widthPx:h}}),m?.(C,h);},getColumnWidth:d=>o.value[d.columnId]?.widthPx??d.idealWidth??d.defaultWidth??i}}function an(e,o){let t=ref(e.value),n;return watch(e,i=>{n!==void 0&&clearTimeout(n),n=setTimeout(()=>{t.value=i;},o);}),onUnmounted(()=>{n!==void 0&&clearTimeout(n);}),t}function Fo(e,o){let t,n=e,i,m=((...s)=>{n=e,i=s,t!==void 0&&clearTimeout(t),t=setTimeout(()=>{n(...s),i=void 0,t=void 0;},o);});return m.cancel=()=>{t!==void 0&&clearTimeout(t),t=void 0,i=void 0;},m.flush=()=>{if(t!==void 0&&i!==void 0){clearTimeout(t),t=void 0;let s=i;i=void 0,n(...s);}},onUnmounted(()=>{t!==void 0&&clearTimeout(t);}),m}function sn(e){let{textValue:o="",onTextChange:t}=e,n=ref(o);return watch(e.isFilterOpen,a=>{a&&(n.value=e.textValue??"");}),{tempTextValue:n,setTempTextValue:a=>{n.value=a;},handleTextApply:()=>{t?.(n.value.trim());},handleTextClear:()=>{n.value="";}}}var Kr=150,Xn=[];function un(e){let{onFilterChange:o}=e,t=ref(new Set(e.selectedValues??Xn)),n=ref(""),i=an(n,Kr);watch(e.isFilterOpen,c=>{c&&(t.value=new Set(e.selectedValues??Xn),n.value="");});let m=computed(()=>{let c=e.options??Xn;if(!i.value.trim())return c;let C=i.value.toLowerCase().trim();return c.filter(r=>r.toLowerCase().includes(C))});return {tempSelected:t,setTempSelected:c=>{t.value=c;},searchText:n,setSearchText:c=>{n.value=c;},debouncedSearchText:i,filteredOptions:m,handleCheckboxChange:(c,C)=>{let r=new Set(t.value);C?r.add(c):r.delete(c),t.value=r;},handleSelectAll:()=>{t.value=new Set(m.value);},handleClearSelection:()=>{t.value=new Set;},handleApplyMultiSelect:()=>{o?.(Array.from(t.value));}}}var qr=300;function cn(e){let{onUserChange:o,filterType:t}=e,n=ref(null),i,m=ref([]),s=ref(false),a=ref(""),u=d=>{a.value=d;};return watch(e.isFilterOpen,d=>{d&&(a.value="",m.value=[],t==="people"&&setTimeout(()=>n.value?.focus(),50));}),watch([a,()=>e.peopleSearch,e.isFilterOpen],([d,c,C])=>{if(i&&clearTimeout(i),!(!c||!C||t!=="people")){if(!d.trim()){m.value=[];return}s.value=true,i=setTimeout(async()=>{try{let r=await c(d);m.value=r.slice(0,10);}catch{m.value=[];}finally{s.value=false;}},qr);}}),onUnmounted(()=>{i&&clearTimeout(i);}),{peopleSuggestions:m,isPeopleLoading:s,peopleSearchText:a,setPeopleSearchText:u,peopleInputRef:n,handleUserSelect:d=>{o?.(d);},handleClearUser:()=>{o?.(void 0);}}}function mn(e){let{onDateChange:o}=e,t=ref(e.dateValue?.from??""),n=ref(e.dateValue?.to??"");return watch(e.isFilterOpen,u=>{u&&(t.value=e.dateValue?.from??"",n.value=e.dateValue?.to??"");}),{tempDateFrom:t,setTempDateFrom:u=>{t.value=u;},tempDateTo:n,setTempDateTo:u=>{n.value=u;},handleDateApply:()=>{let u=t.value||void 0,f=n.value||void 0;o?.(u||f?{from:u,to:f}:void 0);},handleDateClear:()=>{t.value="",n.value="";}}}var Zr=[];function Ao(e){let{filterType:o,onSort:t}=e,n=()=>e.selectedValues??Zr,i=ref(null),m=ref(null),s=ref(false),a=ref(null),u=R=>{s.value=R;},f=sn({textValue:e.textValue,onTextChange:e.onTextChange,isFilterOpen:s}),p=un({selectedValues:e.selectedValues,onFilterChange:e.onFilterChange,options:e.options,isFilterOpen:s}),d=cn({selectedUser:e.selectedUser,onUserChange:e.onUserChange,peopleSearch:e.peopleSearch,isFilterOpen:s,filterType:o}),c=mn({dateValue:e.dateValue,onDateChange:e.onDateChange,isFilterOpen:s});watch(s,R=>{R||(a.value=null);});let C=null,r=null,v,h=()=>{P(),C=R=>{let T=R.target;m.value&&!m.value.contains(T)&&i.value&&!i.value.contains(T)&&(s.value=false);},r=R=>{(R.key==="Escape"||R.key==="Esc")&&(R.preventDefault(),R.stopPropagation(),s.value=false);},v=setTimeout(()=>{C&&document.addEventListener("mousedown",C);},0),document.addEventListener("keydown",r,true);},P=()=>{v&&clearTimeout(v),C&&document.removeEventListener("mousedown",C),r&&document.removeEventListener("keydown",r,true),C=null,r=null;};watch(s,R=>{R?h():P();}),onUnmounted(()=>P());let I=R=>{if(R.stopPropagation(),R.preventDefault(),!s.value&&i.value){let T=i.value.getBoundingClientRect();a.value={top:T.bottom+4,left:T.left};}s.value=!s.value;},w=R=>{R.stopPropagation(),t?.();},g=()=>{p.handleApplyMultiSelect(),s.value=false;},b=()=>{f.handleTextApply(),s.value=false;},E=R=>{d.handleUserSelect(R),s.value=false;},D=()=>{d.handleClearUser(),s.value=false;},y=()=>{c.handleDateApply(),s.value=false;},x=R=>R.stopPropagation(),F=R=>R.stopPropagation(),S=R=>R.stopPropagation(),X=R=>R.stopPropagation(),Q=R=>{R.key!=="Escape"&&R.key!=="Esc"&&R.stopPropagation();},Z=computed(()=>o==="multiSelect"?n().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:d.peopleInputRef,isFilterOpen:s,setFilterOpen:u,tempSelected:p.tempSelected,setTempSelected:p.setTempSelected,tempTextValue:f.tempTextValue,setTempTextValue:f.setTempTextValue,searchText:p.searchText,setSearchText:p.setSearchText,debouncedSearchText:p.debouncedSearchText,filteredOptions:p.filteredOptions,peopleSuggestions:d.peopleSuggestions,isPeopleLoading:d.isPeopleLoading,peopleSearchText:d.peopleSearchText,setPeopleSearchText:d.setPeopleSearchText,tempDateFrom:c.tempDateFrom,setTempDateFrom:c.setTempDateFrom,tempDateTo:c.tempDateTo,setTempDateTo:c.setTempDateTo,hasActiveFilter:Z,popoverPosition:a,handlers:{handleFilterIconClick:I,handleApplyMultiSelect:g,handleTextApply:b,handleTextClear:f.handleTextClear,handleUserSelect:E,handleClearUser:D,handleCheckboxChange:p.handleCheckboxChange,handleSelectAll:p.handleSelectAll,handleClearSelection:p.handleClearSelection,handlePopoverClick:x,handleInputFocus:F,handleInputMouseDown:S,handleInputClick:X,handleInputKeyDown:Q,handleDateApply:y,handleDateClear:c.handleDateClear,handleSortClick:w}}}function Bo(e){let{columns:o,visibleColumns:t,onVisibilityChange:n}=e,i=ref(false),m=null,s=()=>{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?s():a();}),onUnmounted(()=>a());let u=h=>{i.value=h;},f=()=>{i.value=!i.value;},p=()=>{i.value=false;},d=h=>P=>{n(h,P);},c=()=>{o.value.forEach(h=>{t.value.has(h.columnId)||n(h.columnId,true);});},C=()=>{o.value.forEach(h=>{!h.required&&t.value.has(h.columnId)&&n(h.columnId,false);});},r=computed(()=>t.value.size),v=computed(()=>o.value.length);return {open:i,setOpen:u,handleToggle:f,handleClose:p,handleCheckboxChange:d,handleSelectAll:c,handleClearAll:C,visibleCount:r,totalCount:v}}function Ho(e){let{value:o,editorType:t,onCommit:n,onCancel:i,dateFormat:m,dateEditorType:s}=e,a=m??DEFAULT_DATE_FORMAT,u=ref((()=>{if(o==null)return "";if(t==="date"){if(s==="native"){let v=String(o);return v.match(/^\d{4}-\d{2}-\d{2}/)?v.substring(0,10):v}return formatDateForDisplay(o,a)??""}return String(o)})()),f=v=>{u.value=v;},p=v=>{if(t==="date"&&s!=="native"){if(!v||!v.trim()){n(null);return}let h=parseUserInputDate(v,a);if(h!==null){let P=h.getUTCFullYear().toString().padStart(4,"0"),I=(h.getUTCMonth()+1).toString().padStart(2,"0"),w=h.getUTCDate().toString().padStart(2,"0");n(`${P}-${I}-${w}`);}else n(null);}else n(v);},d=v=>{n(v);},c=()=>{i();};return {localValue:u,setLocalValue:f,handleKeyDown:v=>{v.key==="Escape"&&(v.preventDefault(),v.stopPropagation(),c()),v.key==="Enter"&&(t==="text"||t==="date")&&(v.preventDefault(),v.stopPropagation(),p(u.value));},handleBlur:()=>{(t==="text"||t==="date")&&p(u.value);},commit:d,cancel:c}}function Go(e){let{values:o,formatValue:t,initialValue:n,onCommit:i,onCancel:m}=e,s=ref(""),a=o.findIndex(r=>String(r)===String(n)),u=ref(Math.max(a,0)),f=r=>{s.value=r;},p=r=>t?t(r):r!=null?String(r):"",d=computed(()=>{if(!s.value.trim())return o;let r=s.value.toLowerCase();return o.filter(v=>p(v).toLowerCase().includes(r))}),c=r=>{i(r);};return {searchText:s,setSearchText:f,filteredValues:d,highlightedIndex:u,handleKeyDown:r=>{switch(r.key){case "ArrowDown":r.preventDefault(),u.value=Math.min(u.value+1,d.value.length-1);break;case "ArrowUp":r.preventDefault(),u.value=Math.max(u.value-1,0);break;case "Enter":r.preventDefault(),r.stopPropagation(),d.value.length>0&&u.value<d.value.length&&c(d.value[u.value]);break;case "Escape":r.preventDefault(),r.stopPropagation(),m();break}},selectValue:c,getDisplayText:p}}var da=8,ca=5;function pn(e){let{columnOrder:o,onColumnOrderChange:t,tableRef:n,pinnedColumns:i}=e,m=ref(false),s=ref(null),a=null,u="unpinned",f=0,p=null;return onUnmounted(()=>{p?.(),p=null;}),{isDragging:m,dropIndicatorX:s,handleHeaderMouseDown:(c,C)=>{if(C.button!==0)return;let r=C.target.closest("th");if(r){let x=r.getBoundingClientRect();if(C.clientX>x.right-da)return}if(C.preventDefault(),!n.value||!t.value)return;a=c,u=getPinStateForColumn(c,i?.value),s.value=null;let h=C.clientX,P=false,I=C.clientX,w=-1,g=document.body.style.cursor,b=document.body.style.userSelect;document.body.style.cursor="grabbing",document.body.style.userSelect="none";let E=x=>{!P&&Math.abs(x.clientX-h)<ca||(P||(P=true,m.value=true),I=x.clientX,f||(f=requestAnimationFrame(()=>{f=0;let F=n.value;if(!F||!a)return;let S=calculateDropTarget({mouseX:I,columnOrder:o.value,draggedColumnId:a,draggedPinState:u,tableElement:F,pinnedColumns:i?.value});S?(w=S.targetIndex,s.value=S.indicatorX):s.value=null;})));},D=()=>{window.removeEventListener("pointermove",E,true),window.removeEventListener("pointerup",y,true),p=null,document.body.style.cursor=g,document.body.style.userSelect=b,f&&(cancelAnimationFrame(f),f=0);},y=()=>{if(D(),P&&a&&w>=0&&t.value){let x=reorderColumnArray(o.value,a,w);t.value(x);}a=null,m.value=false,s.value=null,w=-1;};window.addEventListener("pointermove",E,true),window.addEventListener("pointerup",y,true),p=D;}}}var ba=100;function gn(e){let{totalRows:o,rowHeight:t,enabled:n,overscan:i=5,threshold:m=ba,columnsEnabled:s,columnWidths:a,columnOverscan:u=2}=e;onMounted(()=>{validateVirtualScrollConfig({enabled:n.value,rowHeight:t});});let f=ref(null),p=ref(0),d=ref(0),c=ref(0),C=ref(0),r=0,v,h=null,P=computed(()=>n.value&&o.value>=m),I=computed(()=>P.value?computeVisibleRange(p.value,t,c.value,o.value,i):{startIndex:0,endIndex:Math.max(0,o.value-1),offsetTop:0,offsetBottom:0}),w=computed(()=>n.value?computeTotalHeight(o.value,t):0),g=computed(()=>{if(!s?.value)return null;let y=a?.value;return !y||y.length===0?null:computeVisibleColumnRange(d.value,y,C.value,u)}),b=()=>{r||(r=requestAnimationFrame(()=>{r=0;let y=f.value;y&&(p.value=y.scrollTop,d.value=y.scrollLeft);}));},E=()=>{let y=f.value;y&&(c.value=y.clientHeight,C.value=y.clientWidth);};return watch(f,y=>{y!==h&&(h&&h.removeEventListener("scroll",b),v&&(v.disconnect(),v=void 0),h=y,y&&(y.addEventListener("scroll",b,{passive:true}),typeof ResizeObserver<"u"&&(v=new ResizeObserver(E),v.observe(y)),E(),p.value=y.scrollTop,d.value=y.scrollLeft));}),onUnmounted(()=>{let y=f.value;y&&y.removeEventListener("scroll",b),v?.disconnect(),r&&(cancelAnimationFrame(r),r=0);}),{containerRef:f,visibleRange:I,totalHeight:w,scrollToRow:(y,x="start")=>{let F=f.value;F&&(F.scrollTop=getScrollTopForRow(y,t,c.value,x));},columnRange:g,scrollLeft:d}}function hn(e){let{props:o}=e,t=ref(null),n=ref(null),i=ref(null),m=ref(false),s=ln({props:o,wrapperRef:t}),a=computed(()=>{let E=o.value;return E.columnOrder?E.columnOrder:flattenColumns(E.columns).filter(D=>E.visibleColumns?.has(D.columnId)??true).map(D=>D.columnId)}),u=computed(()=>o.value.onColumnOrderChange),f=pn({columnOrder:a,onColumnOrderChange:u,tableRef:i}),p=computed(()=>o.value.virtualScroll?.enabled??false),d=computed(()=>o.value.items.length),c=o.value.virtualScroll?.rowHeight??36,C=o.value.virtualScroll?.overscan??5,r=computed(()=>o.value.virtualScroll?.columns===true),v=o.value.virtualScroll?.columnOverscan??2,h=computed(()=>{let E=s.layout.value,{visibleCols:D,columnSizingOverrides:y}=E,x=o.value.pinnedColumns??{},F=[];for(let S of D){if(x[S.columnId]||S.pinned)continue;let X=y[S.columnId];F.push(X?X.widthPx:S.defaultWidth??S.minWidth??DEFAULT_MIN_COLUMN_WIDTH);}return F}),P=gn({totalRows:d,rowHeight:c,enabled:p,overscan:C,columnsEnabled:r,columnWidths:h,columnOverscan:v}),I=computed(()=>{if(!r.value)return null;let D=s.layout.value.visibleCols,y=P.columnRange.value,x=o.value.pinnedColumns;return partitionColumnsForVirtualization(D,y,x)}),w=computed(()=>{let D=s.layout.value.visibleCols,y=new Map;for(let x=0;x<D.length;x++)y.set(D[x].columnId,x);return y}),g=computed(()=>s.layout.value.columnSizingOverrides),b=rn({columnSizingOverrides:g,setColumnSizingOverrides:E=>s.layout.value.setColumnSizingOverrides(E)});return {wrapperRef:t,tableContainerRef:n,tableRef:i,lastMouseShift:m,state:s,columnReorder:f,virtualScroll:P,virtualScrollEnabled:p,columnResize:b,columnPartition:I,globalColIndexMap:w}}function Rn(e,o,t){let n={"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=>{t.setEditingCell(null),t.handleCellMouseDown(i,e.rowIndex,e.globalColIndex);},onClick:()=>t.setActiveCell({rowIndex:e.rowIndex,columnIndex:e.globalColIndex}),onContextmenu:i=>t.handleCellContextMenu(i)};return e.canEditAny&&(n.role="button",n.onDblclick=()=>t.setEditingCell({rowId:e.rowId,columnId:o})),n}var No=()=>{};function Oa(e){return defineComponent({name:"DataGridTable",props:{gridProps:{type:Object,required:true}},setup(o){let t=computed(()=>o.gridProps),{wrapperRef:n,tableContainerRef:i,tableRef:m,lastMouseShift:s,state:a,columnReorder:{isDragging:u,dropIndicatorX:f,handleHeaderMouseDown:p},virtualScroll:{containerRef:d,visibleRange:c,totalHeight:C,scrollToRow:r},virtualScrollEnabled:v,columnResize:{handleResizeStart:h$1,handleResizeDoubleClick:P,getColumnWidth:I},columnPartition:w,globalColIndexMap:g}=hn({props:t}),b=computed(()=>{let S=t.value;return S.showRowNumbers||S.showColumnLetters?((S.currentPage??1)-1)*(S.pageSize??25):0});watch([()=>a.interaction.value.activeCell,b],([S,X])=>{let Q=t.value.onActiveCellChange;Q&&Q(S?formatCellReference(S.columnIndex-a.layout.value.colOffset,X+S.rowIndex+1):null);},{immediate:true});let E=S=>{s.value=S.shiftKey;},D=S=>S.preventDefault(),y=S=>S.stopPropagation(),x=computed(()=>buildHeaderRows(t.value.columns,t.value.visibleColumns)),F=computed(()=>{let S=a.layout.value,X=a.pinning.value,{visibleCols:Q,columnSizingOverrides:Z,measuredColumnWidths:R}=S,{leftOffsets:T,rightOffsets:U}=X,G={},O={},V={},A={};for(let k=0;k<Q.length;k++){let L=Q[k],z=L.pinned==="left",le=L.pinned==="right",ne=I(L),B=!!Z[L.columnId],ee=R[L.columnId],te=L.minWidth??estimateHeaderMinWidth(L.name),Ce=B?ne:Math.max(te,ee??0),be={minWidth:`${Ce}px`,width:`${ne}px`,maxWidth:`${ne}px`},Ee={minWidth:`${Ce}px`,width:`${ne}px`,maxWidth:`${ne}px`},Ae=["ogrid-data-cell"],Ne=["ogrid-header-cell"];z?(Ae.push("ogrid-data-cell--pinned-left"),be.left=`${T[L.columnId]??0}px`,Ne.push("ogrid-header-cell--pinned-left"),Ee.left=`${T[L.columnId]??0}px`):le&&(Ae.push("ogrid-data-cell--pinned-right"),be.right=`${U[L.columnId]??0}px`,Ne.push("ogrid-header-cell--pinned-right"),Ee.right=`${U[L.columnId]??0}px`),G[L.columnId]=be,O[L.columnId]=Ae.join(" "),V[L.columnId]=Ee,A[L.columnId]=Ne.join(" ");}return {cellStyles:G,cellClasses:O,hdrStyles:V,hdrClasses:A}});return ()=>{let S=o.gridProps,X=a.layout.value,Q=a.rowSelection.value,Z=a.editing.value,R=a.interaction.value,T=a.contextMenu.value,U=a.viewModels.value,G=a.pinning.value,{headerMenu:O}=G,{visibleCols:V,hasCheckboxCol:A,hasRowNumbersCol:k,colOffset:L,containerWidth:z,minTableWidth:le,desiredTableWidth:ne}=X,B=S.currentPage??1,ee=S.pageSize??25,te=k?(B-1)*ee:0,{selectedRowIds:Ce,handleRowCheckboxChange:be,handleSelectAll:Ee,allSelected:Ae,someSelected:Ne}=Q,{editingCell:St,setEditingCell:st,pendingEditorValue:ut,setPendingEditorValue:Ze,commitCellEdit:dt,cancelPopoverEdit:Fe,popoverAnchorEl:ct,setPopoverAnchorEl:we}=Z,{setActiveCell:Ke,setSelectionRange:re,handleCellMouseDown:_e,handleSelectAllCells:Je,selectionRange:De,hasCellSelection:Qe,handleGridKeyDown:et,handleFillHandleMouseDown:We,handleCopy:ft,handleCut:pt,handlePaste:Le,cutRange:vt,copyRange:gt,canUndo:$e,canRedo:yt,onUndo:he,onRedo:Ct,isDragging:wt}=R,{menuPosition:qe,handleCellContextMenu:ht,closeContextMenu:xt}=T,{headerFilterInput:It,cellDescriptorInput:Tt,statusBarConfig:$,showEmptyInGrid:Y,onCellError:ae}=U,de=S.items,pe=S.getRowId,xe=S.layoutMode??"fill",ce=S.rowSelection??"none",Ie=S.suppressHorizontalScroll,Ue=S.stickyHeader??true,tt=S.isLoading??false,Pn=S.loadingMessage??"Loading\u2026",Be=S["aria-label"],At=S["aria-labelledby"],En=xe==="content",Pt=!Ie&&z>0&&(le>z||ne>z),He=x.value,Et={commitCellEdit:dt,setEditingCell:st,setPendingEditorValue:Ze,cancelPopoverEdit:Fe},Dn={handleCellMouseDown:_e,setActiveCell:Ke,setEditingCell:st,handleCellContextMenu:ht},l=N=>{if(ce!=="single")return;let ie=N.currentTarget.dataset.rowId;ie&&Q.updateSelection(Ce.has(ie)?new Set:new Set([ie]));},M=(N,W,ie,Me)=>{try{return oe(N,W,ie,Me)}catch(_){return ae&&ae(_ instanceof Error?_:new Error(String(_)),void 0),""}},oe=(N,W,ie,Me)=>{let _=getCellRenderDescriptor(N,W,ie,Me,Tt);if(_.mode==="editing-inline"){let se=buildInlineEditorProps(N,W,_,Et);return h("div",{class:"ogrid-editing-cell"},h(e.InlineCellEditor,{value:se.value,item:se.item,column:se.column,rowIndex:se.rowIndex,editorType:se.editorType,onCommit:se.onCommit,onCancel:se.onCancel}))}if(_.mode==="editing-popover"&&typeof W.cellEditor=="function"){let se=buildPopoverEditorProps(N,W,_,ut,Et),J=W.cellEditor,Lt=resolveCellDisplayContent(W,N,_.displayValue),Jn=resolveCellStyle(W,N,_.displayValue);return h("div",[h("div",{ref:Qn=>{Qn&&we(Qn);},class:"ogrid-popover-anchor"},[Jn?h("span",{style:Jn},[Lt]):Lt]),ct?h(J,se):null])}let ke=Rn(_,W.columnId,Dn),Pe=["ogrid-cell-content"];W.type==="numeric"?Pe.push("ogrid-cell-content--numeric"):W.type==="boolean"&&Pe.push("ogrid-cell-content--boolean"),_.canEditAny&&Pe.push("ogrid-cell-content--editable"),_.isActive&&Pe.push("ogrid-cell-content--active"),_.isActive&&_.isInRange&&Pe.push("ogrid-cell-content--active-in-range"),_.isInRange&&!_.isActive&&Pe.push("ogrid-cell-in-range"),_.isInCutRange&&Pe.push("ogrid-cell-cut");let Xe;if(_.columnType==="boolean"){let se=!!_.displayValue;Xe=h("input",{type:"checkbox",checked:se,disabled:!_.canEditAny,onChange:_.canEditAny?()=>{let J=_.rowIndex,Lt=_.globalColIndex;Et.commitCellEdit(N,W.columnId,se,!se,J,Lt,{skipAdvance:true});}:void 0,onPointerdown:J=>handleBooleanCellPointerDown(J,_.rowIndex,_.globalColIndex,L,{setActiveCell:Ke,setSelectionRange:re}),onClick:J=>J.stopPropagation(),style:`margin:0;cursor:${_.canEditAny?"pointer":"default"};outline:none`,"aria-label":se?"Checked":"Unchecked"});}else {let se=resolveCellDisplayContent(W,N,_.displayValue),J=resolveCellStyle(W,N,_.displayValue);Xe=J?h("span",{style:J},se):se;}return h("div",{...ke,class:Pe.join(" ")},[Xe,..._.canEditAny&&_.isSelectionEndCell?[h("div",{onPointerdown:We,"aria-label":"Fill handle",class:"ogrid-fill-handle"})]:[]])},{cellStyles:Se,cellClasses:nt,hdrStyles:ot,hdrClasses:lt}=F.value,Te=V.map(N=>({col:N,tdClasses:nt[N.columnId]||"ogrid-data-cell",tdDynamicStyle:Se[N.columnId]||{}})),Ve=w.value,Rt=Te,Re=0,me=0;if(Ve){let N=new Set;for(let W of Ve.pinnedLeft)N.add(W.columnId);for(let W of Ve.virtualizedUnpinned)N.add(W.columnId);for(let W of Ve.pinnedRight)N.add(W.columnId);Rt=Te.filter(W=>N.has(W.col.columnId)),Re=Ve.leftSpacerWidth,me=Ve.rightSpacerWidth;}let Ge=g.value,ve=N=>{let W=ot[N.columnId]||{};return {classes:lt[N.columnId]||"ogrid-header-cell",style:{...W,cursor:u.value?"grabbing":"grab"}}},Oe=v.value,fe={position:"relative",width:En?"fit-content":"100%",maxWidth:"100%",overflowX:Ie?"hidden":Pt?"auto":"hidden",overflowY:"auto",backgroundColor:"#fff",willChange:"scroll-position",...Oe?{flex:"1",minHeight:"0"}:{minHeight:tt&&de.length===0?"200px":"auto"}};return S.rowHeight&&(fe["--ogrid-row-height"]=`${S.rowHeight}px`),h("div",{class:"ogrid-outer-container"},[h("div",{ref:N=>{n.value=N,d.value=N;},tabindex:0,role:"region","aria-label":Be??(At?void 0:"Data grid"),"aria-labelledby":At,onPointerdown:E,onKeydown:et,onContextmenu:D,"data-overflow-x":Pt?"true":"false","data-ogrid-scroll-container":"",style:fe},[h("div",{class:"ogrid-scroll-wrapper"},[h("div",{style:{minWidth:Pt?`${le}px`:void 0,overflowX:"clip"}},[h("div",{ref:N=>{i.value=N;},class:["ogrid-table-container",tt&&de.length>0?"ogrid-table-container--loading":""]},[...u.value&&f.value!==null?[h("div",{class:"ogrid-drop-indicator",style:{left:`${f.value}px`}})]:[],h("table",{ref:N=>{m.value=N;},class:"ogrid-table",role:"grid",style:{minWidth:`${le}px`},...v.value?{"data-virtual-scroll":""}:{}},[h("thead",{class:Ue?"ogrid-thead ogrid-sticky-header":"ogrid-thead"},[...S.showColumnLetters?[h("tr",{class:"ogrid-column-letter-row"},[...A?[h("th",{class:"ogrid-column-letter-cell"})]:[],...k?[h("th",{class:"ogrid-column-letter-cell"})]:[],...V.map((N,W)=>{let{classes:ie,style:Me}=ve(N);return h("th",{key:N.columnId,class:`ogrid-column-letter-cell ${ie}`,style:Me},indexToColumnLetter(W))})])]:[],...He.map((N,W)=>h("tr",{key:W,class:"ogrid-header-row"},[...W===He.length-1&&A?[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:Ae,indeterminate:Ne&&!Ae,ariaLabel:"Select all rows",onChange:ie=>Ee(!!ie)}))]:[],...W===0&&W<He.length-1&&A?[h("th",{rowSpan:He.length-1,class:"ogrid-checkbox-spacer",style:{width:`${CHECKBOX_COLUMN_WIDTH}px`,minWidth:`${CHECKBOX_COLUMN_WIDTH}px`}})]:[],...W===He.length-1&&k?[(()=>{let ie=X.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:A?`${CHECKBOX_COLUMN_WIDTH}px`:"0",zIndex:3}},["#",h("div",{onPointerdown:Me=>{Ke(null),re(null),n.value?.focus({preventScroll:true}),Me.stopPropagation(),h$1(Me,{columnId:ROW_NUMBER_COLUMN_ID,name:"#"});},class:"ogrid-resize-handle"})])})()]:[],...W===0&&W<He.length-1&&k?[(()=>{let ie=X.columnSizingOverrides[ROW_NUMBER_COLUMN_ID]?.widthPx??ROW_NUMBER_COLUMN_WIDTH;return h("th",{rowSpan:He.length-1,class:"ogrid-row-number-spacer",style:{width:`${ie}px`,position:"sticky",left:A?`${CHECKBOX_COLUMN_WIDTH}px`:"0",zIndex:3}})})()]:[],...N.map((ie,Me)=>{if(ie.isGroup)return h("th",{key:Me,colSpan:ie.colSpan,scope:"colgroup",class:"ogrid-column-group-header"},ie.label);if(!ie.columnDef)return null;let _=ie.columnDef,{classes:ke,style:Pe}=ve(_),se=S.sortBy===_.columnId?S.sortDirection==="asc"?"ascending":"descending":void 0;return h("th",{key:_.columnId,scope:"col","data-column-id":_.columnId,rowSpan:He.length>1?He.length-W:void 0,class:ke,style:Pe,"aria-sort":se,onPointerdown:J=>p(_.columnId,J)},[h("div",{class:"ogrid-header-content"},[h(e.ColumnHeaderFilter,getHeaderFilterConfig(_,It)),h("button",{onClick:J=>{J.stopPropagation(),O.isOpen&&O.openForColumn===_.columnId?O.close():O.open(_.columnId,J.currentTarget);},"aria-label":"Column options",title:"Column options",class:"ogrid-column-menu-btn"},"\u22EE")]),h("div",{onPointerdown:J=>{Ke(null),re(null),n.value?.focus({preventScroll:true}),J.stopPropagation(),h$1(J,_);},onDblclick:J=>P(J,_),class:"ogrid-resize-handle"})])})]))]),...Y?[]:[h("tbody",{},(()=>{let N=v.value,W=c.value,ie=N?W.startIndex:0,Me=N?Math.min(W.endIndex,de.length-1):de.length-1,_=[];N&&W.offsetTop>0&&_.push(h("tr",{key:"__vs-top",style:{height:`${W.offsetTop}px`}}));for(let ke=ie;ke<=Me;ke++){let Pe=de[ke];if(!Pe)continue;let Xe=pe(Pe),se=Ce.has(Xe);_.push(h("tr",{key:Xe,"data-row-id":Xe,"aria-selected":se||void 0,onClick:l,style:{cursor:ce==="single"?"pointer":void 0}},[...A?[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":ke,"data-col-index":0,onClick:y,class:"ogrid-checkbox-wrapper"},e.renderCheckbox({modelValue:se,ariaLabel:`Select row ${ke+1}`,onChange:J=>be(Xe,J,ke,s.value)})))]:[],...k?[(()=>{let J=X.columnSizingOverrides[ROW_NUMBER_COLUMN_ID]?.widthPx??ROW_NUMBER_COLUMN_WIDTH;return h("td",{class:"ogrid-row-number-cell",style:{width:`${J}px`,minWidth:`${J}px`,maxWidth:`${J}px`,padding:"6px",position:"sticky",left:A?`${CHECKBOX_COLUMN_WIDTH}px`:"0",zIndex:2}},String(te+ke+1))})()]:[],...Re>0?[h("td",{key:"__col-spacer-left",style:{width:`${Re}px`,minWidth:`${Re}px`,maxWidth:`${Re}px`,padding:"0"}})]:[],...Rt.map(J=>h("td",{key:J.col.columnId,"data-column-id":J.col.columnId,class:J.tdClasses,style:J.tdDynamicStyle},[M(Pe,J.col,ke,Ge.get(J.col.columnId)??0)])),...me>0?[h("td",{key:"__col-spacer-right",style:{width:`${me}px`,minWidth:`${me}px`,maxWidth:`${me}px`,padding:"0"}})]:[]]));}return N&&W.offsetBottom>0&&_.push(h("tr",{key:"__vs-bottom",style:{height:`${W.offsetBottom}px`}})),_})())]]),...Y&&S.emptyState?[e.renderEmptyState(S.emptyState)]:[]])])])]),...qe?[h(Teleport,{to:"body"},h(e.GridContextMenu,{x:qe.x,y:qe.y,hasSelection:Qe,canUndo:$e,canRedo:yt,onUndo:he??No,onRedo:Ct??No,onCopy:ft,onCut:pt,onPaste:()=>{Le();},onSelectAll:Je,onClose:xt}))]:[],h(Un,{containerRef:i,selectionRange:De,copyRange:gt,cutRange:vt,colOffset:L,items:de,visibleColumns:S.visibleColumns instanceof Set?Array.from(S.visibleColumns):S.visibleColumns,columnSizingOverrides:X.columnSizingOverrides,columnOrder:S.columnOrder}),...S.formulaReferences&&S.formulaReferences.length>0?[h(Ln,{containerEl:i.value,references:S.formulaReferences,colOffset:L})]:[],h(e.ColumnHeaderMenu,{isOpen:O.isOpen,anchorElement:O.anchorElement,onClose:O.close,onPinLeft:O.handlePinLeft,onPinRight:O.handlePinRight,onUnpin:O.handleUnpin,onSortAsc:O.handleSortAsc,onSortDesc:O.handleSortDesc,onClearSort:O.handleClearSort,onAutosizeThis:O.handleAutosizeThis,onAutosizeAll:O.handleAutosizeAll,canPinLeft:O.canPinLeft,canPinRight:O.canPinRight,canUnpin:O.canUnpin,currentSort:O.currentSort,isSortable:O.isSortable,isResizable:O.isResizable}),...$?[h(On,{totalCount:$.totalCount,filteredCount:$.filteredCount,selectedCount:$.selectedCount??Ce.size,selectedCellCount:De?(Math.abs(De.endRow-De.startRow)+1)*(Math.abs(De.endCol-De.startCol)+1):void 0,aggregation:$.aggregation,suppressRowCount:$.suppressRowCount})]:[],...tt?[h("div",{class:"ogrid-loading-overlay"},e.renderSpinner(Pn))]:[]])}}})}var bt={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 Na(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(t){let n=ref(null),i=ref(null),m=ref(null),s=ref(t.value),a=ref(0),u=()=>{let g=i.value,b=m.value;if(!g||!b)return;let E=g.getBoundingClientRect(),D=200,y=window.innerHeight-E.bottom,x=y<D&&E.top>y;b.style.position="fixed",b.style.left=`${E.left}px`,b.style.width=`${E.width}px`,b.style.maxHeight=`${D}px`,b.style.zIndex="9999",b.style.right="auto",b.style.textAlign="left",x?(b.style.top="auto",b.style.bottom=`${window.innerHeight-E.top}px`):b.style.top=`${E.bottom}px`;},f=null;onMounted(()=>{nextTick(()=>{if(i.value){t.editorType==="richSelect"&&v.value?v.value.focus({preventScroll:true}):i.value.focus({preventScroll:true}),u();let g=i.value,b=g.closest("[data-ogrid-scroll-container]")??g.closest('[style*="overflow"]'),E=()=>{t.onCancel&&t.onCancel();},D=requestAnimationFrame(()=>{b&&b.addEventListener("scroll",E,{passive:true}),window.addEventListener("scroll",E,{passive:true});});f=()=>{cancelAnimationFrame(D),b&&b.removeEventListener("scroll",E),window.removeEventListener("scroll",E);};return}n.value?.focus({preventScroll:true}),n.value?.select();});}),onUnmounted(()=>{f?.();}),watch(()=>t.value,g=>{s.value=g;}),(()=>{let b=(t.column.cellEditorParams?.values??[]).findIndex(E=>String(E)===String(t.value));a.value=Math.max(b,0);})();let d=()=>{nextTick(()=>{let g=m.value;if(!g)return;g.children[a.value]?.scrollIntoView({block:"nearest"});});},c=g=>{let b=t.column.cellEditorParams?.formatValue;return b?b(g):g!=null?String(g):""},C=g=>{let b=t.column.cellEditorParams?.values??[];switch(g.key){case "ArrowDown":g.preventDefault(),a.value=Math.min(a.value+1,b.length-1),d();break;case "ArrowUp":g.preventDefault(),a.value=Math.max(a.value-1,0),d();break;case "Enter":g.preventDefault(),g.stopPropagation(),b.length>0&&a.value<b.length&&t.onCommit(b[a.value]);break;case "Tab":g.preventDefault(),b.length>0&&a.value<b.length&&t.onCommit(b[a.value]);break;case "Escape":g.preventDefault(),g.stopPropagation(),t.onCancel();break}},r=ref(""),v=ref(null),h$1=ref(null),P=computed(()=>{let g=t.column.cellEditorParams?.values??[],b=r.value.trim().toLowerCase();return b?g.filter(E=>c(E).toLowerCase().includes(b)):g}),I=()=>{nextTick(()=>{let g=h$1.value;if(!g)return;g.children[a.value]?.scrollIntoView({block:"nearest"});});},w=g=>{let b=P.value;switch(g.key){case "ArrowDown":g.preventDefault(),a.value=Math.min(a.value+1,b.length-1),I();break;case "ArrowUp":g.preventDefault(),a.value=Math.max(a.value-1,0),I();break;case "Enter":g.preventDefault(),g.stopPropagation(),b.length>0&&a.value<b.length&&t.onCommit(b[a.value]);break;case "Escape":g.preventDefault(),g.stopPropagation(),t.onCancel();break}};return ()=>{if(t.editorType==="checkbox"){let g=!!t.value;return h("div",{style:{...bt,justifyContent:"center"}},o({checked:g,onChange:b=>t.onCommit(b),onCancel:t.onCancel}))}if(t.editorType==="select"){let g=t.column.cellEditorParams?.values??[];return h("div",{ref:b=>{i.value=b;},tabindex:0,style:{...bt,position:"relative"},onKeydown:C},[h("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",width:"100%",cursor:"pointer",fontSize:"13px",color:"inherit"}},[h("span",c(t.value)),h("span",{style:{marginLeft:"4px",fontSize:"10px",opacity:"0.5"}},"\u25BE")]),h("div",{ref:b=>{m.value=b;},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"}},[...g.map((b,E)=>h("div",{key:String(b),role:"option","aria-selected":E===a.value,onClick:()=>t.onCommit(b),style:{padding:"6px 8px",cursor:"pointer",color:"var(--ogrid-fg, #242424)",fontSize:"13px",...E===a.value?{background:"var(--ogrid-bg-hover, #e8f0fe)"}:{}}},c(b)))])])}if(t.editorType==="richSelect"){let g=P.value;return h("div",{ref:b=>{i.value=b;},style:{...bt,position:"relative"}},[h("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",width:"100%",cursor:"pointer",fontSize:"13px",color:"inherit"}},[h("span",c(t.value)),h("span",{style:{marginLeft:"4px",fontSize:"10px",opacity:"0.5"}},"\u25BE")]),h("div",{ref:b=>{m.value=b;},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:b=>{v.value=b;},type:"text",value:r.value,placeholder:"Search...",onInput:b=>{r.value=b.target.value,a.value=0;},onKeydown:w,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:b=>{h$1.value=b;}},g.map((b,E)=>h("div",{key:String(b),role:"option","aria-selected":E===a.value,onClick:()=>t.onCommit(b),style:{padding:"6px 8px",cursor:"pointer",color:"var(--ogrid-fg, #242424)",fontSize:"13px",...E===a.value?{background:"var(--ogrid-bg-hover, #e8f0fe)"}:{}}},c(b)))),...g.length===0?[h("div",{style:{padding:"6px 8px",color:"var(--ogrid-muted, #999)",fontSize:"13px"}},"No matches")]:[]])])}if(t.editorType==="date"){let g=t.column.cellEditorParams?.dateFormat??t.column.dateFormat??DEFAULT_DATE_FORMAT,b=t.column.cellEditorParams?.editorType??"text",E=F=>{if(b!=="native"){let S=parseUserInputDate(F,g);if(S!==null){let X=S.getUTCFullYear().toString().padStart(4,"0"),Q=(S.getUTCMonth()+1).toString().padStart(2,"0"),Z=S.getUTCDate().toString().padStart(2,"0");t.onCommit(`${X}-${Q}-${Z}`);}else t.onCommit(F||null);}else t.onCommit(F);},D=F=>{F.key==="Enter"&&(F.preventDefault(),E(String(s.value??""))),F.key==="Escape"&&(F.preventDefault(),t.onCancel()),F.key==="Tab"&&(F.preventDefault(),E(String(s.value??"")));};if(b==="native"){let F=(()=>{if(s.value==null)return "";let S=String(s.value);return S.match(/^\d{4}-\d{2}-\d{2}/)?S.substring(0,10):S})();return h("div",{style:bt},h("input",{ref:S=>{n.value=S;},type:"date",value:F,style:{width:"100%",height:"100%",border:"none",outline:"none",padding:"0 4px",fontSize:"inherit",boxSizing:"border-box"},onInput:S=>{s.value=S.target.value;},onKeydown:D,onBlur:()=>E(String(s.value??""))}))}let y=formatDateForDisplay(t.value,g)??"";(s.value==null||s.value==="")&&(s.value=y);let x=getDateInputPlaceholder(g);return h("div",{style:bt},h("input",{ref:F=>{n.value=F;},type:"text",value:s.value,placeholder:x,style:{width:"100%",height:"100%",border:"none",outline:"none",padding:"0 4px",fontSize:"inherit",boxSizing:"border-box"},onInput:F=>{s.value=F.target.value;},onKeydown:D,onBlur:()=>E(String(s.value??""))}))}return h("div",{style:bt},h("input",{ref:g=>{n.value=g;},type:"text",value:s.value!=null?String(s.value):"",style:{width:"100%",height:"100%",border:"none",outline:"none",padding:"0 4px",fontSize:"inherit",boxSizing:"border-box"},onInput:g=>{s.value=g.target.value;},onKeydown:g=>{g.key==="Enter"&&(g.preventDefault(),t.onCommit(s.value)),g.key==="Escape"&&(g.preventDefault(),t.onCancel()),g.key==="Tab"&&(g.preventDefault(),t.onCommit(s.value));},onBlur:()=>t.onCommit(s.value)}))}}})}var Xa=240,Zn=36,Tn={columns:"Columns",filters:"Filters"},ja={columns:"\u2261",filters:"\u2A65"};function _o(e){let o=e.activePanel!==null,t=e.position??"right",n={display:"flex",flexDirection:"column",width:`${Zn}px`,background:"var(--ogrid-header-bg, #f5f5f5)",...t==="right"?{borderLeft:"1px solid var(--ogrid-border, #e0e0e0)"}:{borderRight:"1px solid var(--ogrid-border, #e0e0e0)"}},i=h("div",{style:n,role:"tablist","aria-label":"Side bar tabs"},e.panels.map(a=>h("button",{key:a,role:"tab","aria-selected":e.activePanel===a,"aria-label":Tn[a],title:Tn[a],onClick:()=>e.onPanelChange(e.activePanel===a?null:a),style:{width:`${Zn}px`,height:`${Zn}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"}},ja[a]))),m=null;if(o&&e.activePanel){let a={width:`${Xa}px`,display:"flex",flexDirection:"column",overflow:"hidden",background:"var(--ogrid-bg, #fff)",color:"var(--ogrid-fg, #242424)",...t==="right"?{borderLeft:"1px solid var(--ogrid-border, #e0e0e0)"}:{borderRight:"1px solid var(--ogrid-border, #e0e0e0)"}},u=[];if(e.activePanel==="columns"){let f=e.columns.every(p=>e.visibleColumns.has(p.columnId));u.push(h("div",{style:{display:"flex",gap:"8px",marginBottom:"8px"}},[h("button",{disabled:f,onClick:()=>{let p=new Set(e.visibleColumns);e.columns.forEach(d=>p.add(d.columnId)),e.onSetVisibleColumns(p);},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 p=new Set;e.columns.forEach(d=>{d.required&&e.visibleColumns.has(d.columnId)&&p.add(d.columnId);}),e.onSetVisibleColumns(p);},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(p=>{u.push(h("label",{key:p.columnId,style:{display:"flex",alignItems:"center",gap:"6px",padding:"2px 0",cursor:"pointer"}},[h("input",{type:"checkbox",checked:e.visibleColumns.has(p.columnId),disabled:p.required,onChange:d=>e.onVisibilityChange(p.columnId,d.target.checked)}),h("span",null,p.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(f=>{let p=f.filterField,d=[h("div",{style:{fontWeight:"500",marginBottom:"4px",fontSize:"13px"}},f.name)];if(f.filterType==="text"){let c=e.filters[p],C=c?.type==="text"?c.value:"";d.push(h("input",{type:"text",value:C,onInput:r=>{let v=r.target.value;e.onFilterChange(p,v?{type:"text",value:v}: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 C=(e.filterOptions[p]??[]).map(r=>{let v=e.filters[p],h$1=v?.type==="multiSelect"?v.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:P=>{let I=e.filters[p],w=I?.type==="multiSelect"?I.value:[],g=P.target.checked?[...w,r]:w.filter(b=>b!==r);e.onFilterChange(p,g.length>0?{type:"multiSelect",value:g}:void 0);}}),h("span",null,r)])});d.push(h("div",{style:{maxHeight:"120px",overflowY:"auto"},role:"group","aria-label":`${f.name} options`},C));}if(f.filterType==="date"){let c=e.filters[p],C=c?.type==="date"?c.value:{from:void 0,to:void 0};d.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:r=>{let v=r.target.value||void 0,h=C.to;e.onFilterChange(p,v||h?{type:"date",value:{from:v,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:C.to??"",onInput:r=>{let v=r.target.value||void 0,h=C.from;e.onFilterChange(p,h||v?{type:"date",value:{from:h,to:v}}: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"}})])]));}u.push(h("div",{key:f.columnId,style:{marginBottom:"12px"}},d));})),m=h("div",{role:"tabpanel","aria-label":Tn[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,Tn[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 s=[];return t==="left"?(s.push(i),m&&s.push(m)):(m&&s.push(m),s.push(i)),h("div",{style:{display:"flex",flexDirection:"row",flexShrink:"0"},role:"complementary","aria-label":"Side bar"},s)}function Ya(e){return defineComponent({name:"OGrid",props:{gridProps:{type:Object,required:true}},setup(o,{expose:t}){let n=computed(()=>o.gridProps),{dataGridProps:i,pagination:m,columnChooser:s,layout:a,api:u}=_t(n);t({api:u});let f=ref(false),p=()=>{f.value=!f.value;},d=c=>{c.key==="Escape"&&f.value&&(f.value=false);};return onMounted(()=>{document.addEventListener("keydown",d);}),onUnmounted(()=>{document.removeEventListener("keydown",d);}),()=>{let c=a.value.sideBarProps,C=c!=null,r=c?.position??"right",v=[];a.value.toolbar&&v.push(a.value.toolbar);let P=a.value.fullScreen===true?h("button",{type:"button",title:f.value?"Exit fullscreen":"Fullscreen","aria-label":f.value?"Exit fullscreen":"Fullscreen",onClick:p,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=s.value.placement==="toolbar"?h(e.ColumnChooser,{columns:s.value.columns,visibleColumns:s.value.visibleColumns,onVisibilityChange:s.value.onVisibilityChange}):null,w=h(e.PaginationControls,{currentPage:m.value.page,pageSize:m.value.pageSize,totalCount:m.value.displayTotalCount,onPageChange:m.value.setPage,onPageSizeChange:x=>{m.value.setPageSize(x);},pageSizeOptions:m.value.pageSizeOptions,entityLabelPlural:m.value.entityLabelPlural}),g=h("div",{style:{flex:"1",minWidth:"0",minHeight:"0",display:"flex",flexDirection:"column"}},[h(e.DataGridTable,{gridProps:i.value})]),b=[];C&&r==="left"&&b.push(_o(c)),b.push(g),C&&r!=="left"&&b.push(_o(c));let E=v.length>0||I!=null||P!=null,D=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"},y=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:D},[h("div",{style:y??{}},[...E?[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"}},v),h("div",{style:{display:"flex",alignItems:"center",gap:"8px"}},[...I?[I]:[],...P?[P]:[]])])]:[],...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"}},b),...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))"}},[w])])])}}})}export{Mn as FormulaBar,Ln as FormulaRefOverlay,Un as MarchingAntsOverlay,An as SheetTabs,On as StatusBar,Oa as createDataGridTable,Na as createInlineCellEditor,Ya as createOGrid,Rn as getCellInteractionProps,$t as useActiveCell,Kt as useCellEditing,qt as useCellSelection,jt as useClipboard,Bo as useColumnChooserState,Ao as useColumnHeaderFilterState,on as useColumnHeaderMenuState,tn as useColumnPinning,pn as useColumnReorder,rn as useColumnResize,Xt as useContextMenu,ln as useDataGridState,hn as useDataGridTableSetup,mn as useDateFilterState,an as useDebounce,Fo as useDebouncedCallback,Jt as useFillHandle,Gt as useFilterOptions,zt as useFormulaBar,Ho as useInlineCellEditorState,Yt as useKeyboardNavigation,un as useMultiSelectFilterState,_t as useOGrid,cn as usePeopleFilterState,Go as useRichSelectState,Wt as useRowSelection,Ft as useSideBarState,en as useTableLayout,sn as useTextFilterState,Qt as useUndoRedo,gn 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,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,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 On=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 Mn=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 kn=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 ol={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"},ll={background:"none",border:"none",cursor:"pointer",padding:"4px 10px",fontSize:"16px",lineHeight:"22px",color:"var(--ogrid-fg-secondary, #666)",flexShrink:0},io={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"},rl={...io,fontWeight:600,borderBottomColor:"var(--ogrid-primary, #217346)",background:"var(--ogrid-bg, #fff)"},Ln=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:ol,role:"tablist","aria-label":"Sheet tabs"},[e.showAddButton?h("button",{type:"button",style:ll,onClick:()=>o("sheetAdd"),title:"Add sheet","aria-label":"Add sheet"},"+"):null,...e.sheets.map(n=>{let l=n.id===e.activeSheet,i=l?rl:io,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 ul(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 Bn=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=ul(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 Bt(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 et(e){let o=unref(e);return customRef((n,l)=>({get(){return isRef(e)&&(o=e.value),o},set(i){o=i,l();}}))}function mo(e){let{formulas:o,items:n,flatColumns:l,initialFormulas:i,onFormulaRecalc:m,formulaFunctions:d,namedRanges:a,sheets:s}=e,f=et(n),v=et(l),c=et(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[P,k]of Object.entries(s))u.value.registerSheet(P,k);if(i&&!g){g=true;let P=p(),k=u.value.loadFormulas(i,P);k.updatedCells.length>0&&c.value?.(k);}}else !x&&u.value&&(u.value=null);},{immediate:true});function h(x,P){return u.value?.getValue(x,P)}function E(x,P){return u.value?.hasFormula(x,P)??false}function T(x,P){return u.value?.getFormula(x,P)}function S(x,P,k){if(!u.value)return;let y=p(),R=u.value.setFormula(x,P,k,y);R.updatedCells.length>0&&c.value?.(R);}function A(x,P){if(!u.value)return;let k=p(),y=u.value.onCellChanged(x,P,k);y.updatedCells.length>0&&c.value?.(y);}function _(x,P){return u.value?.getPrecedents(x,P)??[]}function q(x,P){return u.value?.getDependents(x,P)??[]}function D(x,P){return u.value?.getAuditTrail(x,P)??null}return {enabled:r,getFormulaValue:h,hasFormula:E,getFormula:T,setFormula:S,onCellChanged:A,getPrecedents:_,getDependents:q,getAuditTrail:D}}function Ht(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=T=>{f.value=T;},r=()=>{let T=o.value,S=n.value;T==null||S==null||!d||(processFormulaBarCommit(f.value,T,S,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),E=computed(()=>extractFormulaReferences(h.value));return {cellRef:l,formulaText:h,isEditing:s,onInputChange:g,onCommit:r,onCancel:p,startEditing:u,referencedCells:E,isFormulaBarEditing:v}}var fo=["columns","filters"];function Tt(e){let{config:o}=e,n=o!=null&&o!==false,l=(()=>{if(!n||o===true)return {panels:fo,position:"right",defaultPanel:null};let f=o;return {panels:f.panels??fo,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 Vl=25,zl={};function zt(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,U="data"in t?t.data:void 0,te="dataSource"in t?t.dataSource:void 0;return U&&te&&console.warn("[OGrid] Both data and dataSource provided. dataSource takes precedence."),{getRowId:t.getRowId,data:U,dataSource:te}}),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??Vl,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),E=ref({field:r.value,direction:m.value.defaultSortDirection}),T=ref({}),S=ref(void 0),A=ref((()=>{let t=a.value.filter(U=>U.defaultVisible!==false).map(U=>U.columnId);return new Set(t.length>0?t:a.value.map(U=>U.columnId))})()),_=ref({}),q={};for(let t of flattenColumns(e.value.columns))t.pinned&&(q[t.columnId]=t.pinned);let D=ref(q),x=computed(()=>l.value.page??p.value),P=computed(()=>l.value.pageSize??h$1.value),k=computed(()=>l.value.sort??E.value),y=computed(()=>l.value.filters??T.value),R=computed(()=>o.value.columnOrder??S.value),b=computed(()=>l.value.visibleColumns??A.value),L=t=>{l.value.page===void 0&&(p.value=t),i.value.onPageChange?.(t);},C=t=>{l.value.pageSize===void 0&&(h$1.value=t),i.value.onPageSizeChange?.(t),L(1);},w=ref(0),I=t=>{l.value.sort===void 0&&(E.value=t),i.value.onSortChange?.(t),L(1),w.value++;},O=t=>{l.value.filters===void 0&&(T.value=t),i.value.onFiltersChange?.(t),L(1);},F=t=>{l.value.visibleColumns===void 0&&(A.value=t),i.value.onVisibleColumnsChange?.(t);},B=(t,U)=>{I(computeNextSortState(k.value,t,U));},z=(t,U)=>{O(mergeFilter(y.value,t,U));},G=(t,U)=>{let te=new Set(b.value);U?te.add(t):te.delete(t),F(te);},H=ref(new Set),N=computed(()=>e.value.selectedRows),re=computed(()=>N.value??H.value),ae=t=>{N.value===void 0&&(H.value=new Set(t.selectedRowIds)),e.value.onSelectionChange?.(t);},W=computed(()=>getMultiSelectFilterFields(a.value)),ne=computed(()=>n.value.dataSource??{fetchFilterOptions:void 0}),{filterOptions:le,loadingOptions:ve}=Bt(ne,W),Te=computed(()=>n.value.dataSource?.fetchFilterOptions!=null),Le=computed(()=>Te.value?le.value:deriveFilterOptionsFromData(u.value,a.value)),Ee=computed(()=>shouldUseWorkerSort(e.value.workerSort,u.value.length,{columns:a.value,filters:y.value,sortBy:k.value.field})),De=null,yt=-1,nt=null,st=null,ut=-1,ot=computed(()=>{if(!f.value||Ee.value)return null;let t=u.value,U=a.value,te=y.value,he=w.value,Ue=k.value.field,Ne=k.value.direction,ke=he!==yt||te!==nt||U!==st||t.length!==ut,Re;if(ke||De===null){yt=he,nt=te,st=U,ut=t.length;let be=processClientSideData(t,U,te,Ue,Ne),K=new Map;for(let M=0;M<t.length;M++)K.set(t[M],M);De=be.map(M=>{let Q=K.get(M);return Q!==void 0?Q:-1}).filter(M=>M!==-1),Re=be;}else Re=De.map(be=>t[be]).filter(be=>be!==void 0);let Rt=Re.length,bt=(x.value-1)*P.value;return {items:Re.slice(bt,bt+P.value),totalCount:Rt}}),qe=ref(null),lt=0,Me=null,Ve=-1,Se=null,dt=null,se=-1;watch([f,Ee,u,a,y,w,x,P],()=>{if(!f.value||!Ee.value)return;let t=u.value,U=a.value,te=y.value,he=w.value,Ue=k.value.field,Ne=k.value.direction,ke=x.value,Re=P.value,Rt=++lt;if(he!==Ve||te!==Se||U!==dt||t.length!==se||Me===null)Ve=he,Se=te,dt=U,se=t.length,Me=null,processClientSideDataAsync(t,U,te,Ue,Ne).then(Oe=>{if(Rt!==lt||ze)return;let be=new Map;for(let oe=0;oe<t.length;oe++)be.set(t[oe],oe);Me=Oe.map(oe=>{let V=be.get(oe);return V!==void 0?V:-1}).filter(oe=>oe!==-1);let K=Oe.length,M=(ke-1)*Re,Q=Oe.slice(M,M+Re);qe.value={items:Q,totalCount:K};}).catch(()=>{if(Rt!==lt||ze)return;let Oe=processClientSideData(t,U,te,Ue,Ne),be=new Map;for(let oe=0;oe<t.length;oe++)be.set(t[oe],oe);Me=Oe.map(oe=>{let V=be.get(oe);return V!==void 0?V:-1}).filter(oe=>oe!==-1);let K=Oe.length,M=(ke-1)*Re,Q=Oe.slice(M,M+Re);qe.value={items:Q,totalCount:K};});else {let Oe=Me.map(Q=>t[Q]).filter(Q=>Q!==void 0),be=Oe.length,K=(ke-1)*Re,M=Oe.slice(K,K+Re);qe.value={items:M,totalCount:be};}},{immediate:true});let xe=computed(()=>{let t=ot.value;return t||qe.value}),Xe=ref([]),je=ref(0),Ye=ref(false),Ze=0,Je=null,ze=false,ct=ref(0),mt=()=>{if(!s.value||!n.value.dataSource){s.value||(Ye.value=false);return}let t=++Ze;Je?.abort();let U=new AbortController;Je=U,Ye.value=true,n.value.dataSource.fetchPage({page:x.value,pageSize:P.value,sort:{field:k.value.field,direction:k.value.direction},filters:y.value,signal:U.signal}).then(te=>{t!==Ze||ze||U.signal.aborted||(Xe.value=te.items,je.value=te.totalCount);}).catch(te=>{t!==Ze||ze||U.signal.aborted||(i.value.onError?.(te),Xe.value=[],je.value=0);}).finally(()=>{t===Ze&&!ze&&!U.signal.aborted&&(Ye.value=false);});};onMounted(()=>{validateColumns(a.value),mt();}),watch([()=>n.value.dataSource,x,P,()=>k.value.field,()=>k.value.direction,y,ct],()=>{mt();}),onUnmounted(()=>{ze=true,Je?.abort(),Je=null;});let Be=computed(()=>f.value&&xe.value?xe.value.items:Xe.value),rt=computed(()=>f.value&&xe.value?xe.value.totalCount:je.value),Qe=computed(()=>!!e.value.formulas),ft=ref(0),Ut=t=>{ft.value+=1,e.value.onFormulaRecalc?.(t);},fe=mo({formulas:Qe,items:Be,flatColumns:a,initialFormulas:e.value.initialFormulas,onFormulaRecalc:Ut,formulaFunctions:e.value.formulaFunctions,namedRanges:e.value.namedRanges,sheets:e.value.sheets}),pt=false,vt=false;watch(Be,t=>{!pt&&t.length>0&&(pt=true,i.value.onFirstDataRendered?.()),!vt&&t.length>0&&(vt=true,validateRowIds(t,n.value.getRowId));});let at=computed(()=>Object.values(y.value).some(t=>t!==void 0)),gt=computed(()=>a.value.map(t=>({columnId:t.columnId,name:t.name,required:t.required===true}))),Ge=computed(()=>{let t=e.value.statusBar;if(!t)return;if(typeof t=="object")return t;let U=f.value?n.value.data?.length??0:je.value,te=rt.value;return {totalCount:U,filteredCount:at.value?te:void 0,selectedCount:re.value.size,suppressRowCount:true}}),Ct=(t,U)=>{_.value={..._.value,[t]:U},o.value.onColumnResized?.(t,U);},J=(t,U)=>{_.value={..._.value,[t]:U},(o.value.onAutosizeColumn??o.value.onColumnResized)?.(t,U);},Y=(t,U)=>{if(U===null){let{[t]:te,...he}=D.value;D.value=he;}else D.value={...D.value,[t]:U};o.value.onColumnPinned?.(t,U);},ie=shallowRef(Tt({config:e.value.sideBar}));watch(()=>e.value.sideBar,t=>{ie.value=Tt({config:t});});let ge=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}))),ce=computed(()=>{let t=ie.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:gt.value,visibleColumns:b.value,onVisibilityChange:G,onSetVisibleColumns:F,filterableColumns:ge.value,filters:y.value,onFilterChange:z,filterOptions:Le.value}}),Fe=()=>O({}),Ie=computed(()=>s.value&&Ye.value||g.value),Ce=ref(null),ye=ref(null),ht=t=>{if(Ce.value=t,t){let U=t.match(/^([A-Z]+)(\d+)$/);U?ye.value={col:columnLetterToIndex(U[1]),row:parseInt(U[2],10)-1}:ye.value=null;}else ye.value=null;},Ot=computed(()=>ye.value?.col??null),In=computed(()=>ye.value?.row??null),wt=(t,U)=>{let te=Be.value,he=a.value;if(!(U<0||U>=te.length||t<0||t>=he.length))return getCellValue(te[U],he[t])},pe=Ht({activeCol:Ot,activeRow:In,activeCellRef:Ce,getFormula:fe.enabled.value?fe.getFormula:void 0,getRawValue:wt,setFormula:fe.enabled.value?fe.setFormula:void 0}),xt=computed(()=>{let t=e.value,U=n.value.dataSource;return {items:Be.value,columns:o.value.columns,getRowId:n.value.getRowId,sortBy:k.value.field,sortDirection:k.value.direction,onColumnSort:B,visibleColumns:b.value,columnOrder:R.value,onColumnOrderChange:o.value.onColumnOrderChange,onColumnResized:Ct,onAutosizeColumn:J,onColumnPinned:Y,pinnedColumns:D.value,initialColumnWidths:_.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:re.value,onSelectionChange:ae,showRowNumbers:t.showRowNumbers||t.cellReferences||t.formulas,showColumnLetters:!!(t.cellReferences||t.formulas),showNameBox:!!(t.cellReferences&&!t.formulas),onActiveCellChange:t.cellReferences||t.formulas?ht:void 0,currentPage:x.value,pageSize:P.value,statusBar:Ge.value,isLoading:Ie.value,filters:y.value,onFilterChange:z,filterOptions:Le.value,loadingFilterOptions:U?.fetchFilterOptions?ve.value:zl,peopleSearch:U?.searchPeople,getUserByEmail:U?.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:at.value,onClearAll:Fe,message:t.emptyState?.message,render:t.emptyState?.render},formulas:t.formulas,formulaVersion:ft.value,...fe.enabled.value?{getFormulaValue:fe.getFormulaValue,hasFormula:fe.hasFormula,getFormula:fe.getFormula,setFormula:fe.setFormula,onFormulaCellChanged:fe.onCellChanged,getPrecedents:fe.getPrecedents,getDependents:fe.getDependents,getAuditTrail:fe.getAuditTrail}:{},formulaReferences:pe.referencedCells.value.length>0?pe.referencedCells.value:void 0}}),Tn=computed(()=>({page:x.value,pageSize:P.value,displayTotalCount:rt.value,setPage:L,setPageSize:C,pageSizeOptions:e.value.pageSizeOptions,entityLabelPlural:m.value.entityLabelPlural})),Pn=computed(()=>({columns:gt.value,visibleColumns:b.value,onVisibilityChange:G,placement:d.value})),En=computed(()=>{let t=e.value,U=!!t.formulas,te=!!t.cellReferences&&!U,he=t.toolbar;te&&(he=[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"},Ce.value??"\u2014"),he]);let Ue=U?h(kn,{cellRef:pe.cellRef.value,formulaText:pe.formulaText.value,isEditing:pe.isEditing.value,onInputChange:pe.onInputChange,onCommit:pe.onCommit,onCancel:pe.onCancel,onStartEditing:pe.startEditing}):void 0,Ne=t.sheetDefs&&t.sheetDefs.length>0&&t.activeSheet&&t.onSheetChange?h(Ln,{sheets:t.sheetDefs,activeSheet:t.activeSheet,showAddButton:!!t.onSheetAdd,onSheetChange:t.onSheetChange,onSheetAdd:t.onSheetAdd??(()=>{})}):void 0;return {toolbar:he,toolbarBelow:t.toolbarBelow,className:t.className,emptyState:t.emptyState,sideBarProps:ce.value,fullScreen:t.fullScreen,formulaBar:Ue,sheetTabs:Ne}}),Dn=computed(()=>({hasActiveFilters:at.value,setFilters:O})),Fn=computed(()=>({setRowData:t=>{s.value||(v.value=t);},setLoading:t=>{c.value=t;},getColumnState:()=>({visibleColumns:Array.from(b.value),sort:k.value,columnOrder:R.value??void 0,columnWidths:Object.keys(_.value).length>0?_.value:void 0,filters:Object.keys(y.value).length>0?y.value:void 0,pinnedColumns:Object.keys(D.value).length>0?D.value:void 0}),applyColumnState:t=>{t.visibleColumns&&F(new Set(t.visibleColumns)),t.sort&&I(t.sort),t.columnOrder&&(o.value.columnOrder===void 0&&(S.value=t.columnOrder),o.value.onColumnOrderChange?.(t.columnOrder)),t.columnWidths&&(_.value=t.columnWidths),t.filters&&O(t.filters),t.pinnedColumns&&(D.value=t.pinnedColumns);},setFilterModel:O,getSelectedRows:()=>Array.from(re.value),setSelectedRows:t=>{N.value===void 0&&(H.value=new Set(t));},selectAll:()=>{let t=new Set(Be.value.map(U=>n.value.getRowId(U)));N.value===void 0&&(H.value=t),e.value.onSelectionChange?.({selectedRowIds:Array.from(t),selectedItems:Be.value});},deselectAll:()=>{N.value===void 0&&(H.value=new Set),e.value.onSelectionChange?.({selectedRowIds:[],selectedItems:[]});},clearFilters:()=>O({}),clearSort:()=>I({field:r.value,direction:m.value.defaultSortDirection}),resetGridState:t=>{O({}),I({field:r.value,direction:m.value.defaultSortDirection}),t?.keepSelection||(N.value===void 0&&(H.value=new Set),e.value.onSelectionChange?.({selectedRowIds:[],selectedItems:[]}));},getDisplayedRows:()=>Be.value,refreshData:()=>{s.value&&ct.value++;},scrollToRow:()=>{},getColumnOrder:()=>R.value??a.value.map(t=>t.columnId),setColumnOrder:t=>{o.value.columnOrder===void 0&&(S.value=t),o.value.onColumnOrderChange?.(t);}}));return {dataGridProps:xt,pagination:Tn,columnChooser:Pn,layout:En,filters:Dn,api:Fn}}function Gt(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,E)=>{if(l.value==="single"){f(p?new Set([r]):new Set),a=h;return}let T=o.value,S;E&&a>=0&&a!==h?S=applyRangeRowSelection(a,h,p,T,n,s.value):(S=new Set(s.value),p?S.add(r):S.delete(r)),a=h,f(S);},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 Nt(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 Wt(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 _n="data-drag-range",Pt="data-drag-anchor",we=40,er=16;function _t(e){let o=et(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,w,I)=>{if(C.button!==0)return;let O=i();if(I<O)return;C.preventDefault();let F=I-O,B=m.value;if(C.shiftKey&&B!=null)p(normalizeSelectionRange({startRow:B.startRow,startCol:B.startCol,endRow:w,endCol:F})),l({rowIndex:w,columnIndex:I});else {v={row:w,col:F},f=false;let z={startRow:w,startCol:F,endRow:w,endCol:F};p(z),u=z,l({rowIndex:w,columnIndex:I}),a.value=true,q(z);}},E=()=>{let{rowCount:C,visibleColCount:w}=o.value;C.value===0||w.value===0||(p({startRow:0,startCol:0,endRow:C.value-1,endCol:w.value-1}),l({rowIndex:0,columnIndex:i()}));},T=new Set,S=null,A=(C,w,I,O,F,B,z,G)=>{C.hasAttribute(_n)||C.setAttribute(_n,""),G&&w===G.row&&I===G.col?C.hasAttribute(Pt)||C.setAttribute(Pt,""):C.hasAttribute(Pt)&&C.removeAttribute(Pt);let N=[];w===O&&N.push("inset 0 2px 0 0 var(--ogrid-selection, #217346)"),w===F&&N.push("inset 0 -2px 0 0 var(--ogrid-selection, #217346)"),I===B&&N.push("inset 2px 0 0 0 var(--ogrid-selection, #217346)"),I===z&&N.push("inset -2px 0 0 0 var(--ogrid-selection, #217346)"),C.style.boxShadow=N.length>0?N.join(", "):"",T.add(C);},_=C=>{C.removeAttribute(_n),C.removeAttribute(Pt),C.style.boxShadow="";},q=C=>{if(!n.value)return;let I=Math.min(C.startRow,C.endRow),O=Math.max(C.startRow,C.endRow),F=Math.min(C.startCol,C.endCol),B=Math.max(C.startCol,C.endCol),z=v,G=i();for(let N of T){let re=parseInt(N.getAttribute("data-row-index")??"",10),ae=parseInt(N.getAttribute("data-col-index")??"",10)-G;re>=I&&re<=O&&ae>=F&&ae<=B||(_(N),T.delete(N));}S||(S=buildCellIndex(n.value));let H=false;for(let N=I;N<=O;N++)for(let re=F;re<=B;re++){let ae=`${N},${re+G}`,W=S?.get(ae);W&&!W.isConnected&&!H&&(H=true,S=buildCellIndex(n.value),W=S?.get(ae)),W&&W.isConnected&&A(W,N,re,I,O,F,B,z);}},D=()=>{for(let C of T)_(C);T.clear(),S=null;},x=(C,w)=>{if(!v)return null;let O=document.elementFromPoint(C,w)?.closest?.("[data-row-index][data-col-index]");if(!O)return null;let F=parseInt(O.getAttribute("data-row-index")??"",10),B=parseInt(O.getAttribute("data-col-index")??"",10),z=i();if(Number.isNaN(F)||Number.isNaN(B)||B<z)return null;let G=B-z;return normalizeSelectionRange({startRow:v.row,startCol:v.col,endRow:F,endCol:G})},P=()=>{g&&(clearInterval(g),g=null);},k=()=>{let C=n.value;if(!C||!r||!a.value){P();return}let w=C.getBoundingClientRect(),I=0,O=0;if(r.cy<w.top+we?O=-computeAutoScrollSpeed(w.top+we-r.cy):r.cy>w.bottom-we&&(O=computeAutoScrollSpeed(r.cy-(w.bottom-we))),r.cx<w.left+we?I=-computeAutoScrollSpeed(w.left+we-r.cx):r.cx>w.right-we&&(I=computeAutoScrollSpeed(r.cx-(w.right-we))),I===0&&O===0){P();return}g||(g=setInterval(()=>{let F=n.value,B=r;if(!F||!B||!a.value){P();return}let z=F.getBoundingClientRect(),G=0,H=0;if(B.cy<z.top+we?H=-computeAutoScrollSpeed(z.top+we-B.cy):B.cy>z.bottom-we&&(H=computeAutoScrollSpeed(B.cy-(z.bottom-we))),B.cx<z.left+we?G=-computeAutoScrollSpeed(z.left+we-B.cx):B.cx>z.right-we&&(G=computeAutoScrollSpeed(B.cx-(z.right-we))),G===0&&H===0){P();return}F.scrollTop+=H,F.scrollLeft+=G;let N=x(B.cx,B.cy);N&&(u=N,q(N));},er));},y=C=>{!a.value||!v||(f||(f=true,d.value=true,S=buildCellIndex(n.value)),r={cx:C.clientX,cy:C.clientY},k(),c&&cancelAnimationFrame(c),c=requestAnimationFrame(()=>{if(c=0,!r)return;let w=x(r.cx,r.cy);if(!w)return;let I=u;I&&I.startRow===w.startRow&&I.startCol===w.startCol&&I.endRow===w.endRow&&I.endCol===w.endCol||(u=w,q(w));}));},R=()=>{if(!a.value)return;P(),c&&(cancelAnimationFrame(c),c=0),a.value=false;let C=f;if(C){if(r){let I=x(r.cx,r.cy);I&&(u=I);}let w=u;if(w){p(w);let I=v;I&&l({rowIndex:I.row,columnIndex:I.col+i()});}}D(),u=null,r=null,v=null,C&&(d.value=false);},b=C=>{s.value||y(C);},L=()=>{s.value||R();};return onMounted(()=>{window.addEventListener("pointermove",b,true),window.addEventListener("pointerup",L,true);}),onUnmounted(()=>{s.value=true,window.removeEventListener("pointermove",b,true),window.removeEventListener("pointerup",L,true),c&&cancelAnimationFrame(c),P();}),{selectionRange:m,setSelectionRange:p,handleCellMouseDown:h,handleSelectAllCells:E,isDragging:d}}function Kt(){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 $t(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 T=l.value,S=i.value,A=f();return T??(S!=null?{startRow:S.rowIndex,startCol:S.columnIndex-A,endRow:S.rowIndex,endCol:S.columnIndex-A}:null)},r=()=>{let T=g();if(T==null)return;let S=normalizeSelectionRange(T),A=formatSelectionAsTsv(o.value,n.value,S);u.value=A,c.value=S,navigator.clipboard.writeText(A).catch(_=>{typeof console<"u"&&console.warn("[OGrid] Clipboard write failed:",_);});};return {handleCopy:r,handleCut:()=>{if(m.value===false)return;let T=g();if(T==null||d.value==null)return;let S=normalizeSelectionRange(T);v.value=S,c.value=null,r(),c.value=null;},handlePaste:async()=>{if(m.value===false)return;let T=d.value;if(T==null)return;let S;try{S=await navigator.clipboard.readText();}catch{S="";}if(!S.trim()&&u.value!=null&&(S=u.value),!S.trim())return;let A=g(),_=A?A.startRow:0,q=A?A.startCol:0,D=o.value,x=n.value,P=parseTsvClipboard(S);a?.();let k=applyPastedValues(P,_,q,D,x);for(let y of k)T(y);if(v.value){let y=applyCutClear(v.value,D,x);for(let R of y)T(R);v.value=null;}s?.(),c.value=null;},cutRange:v,copyRange:c,clearClipboardRanges:()=>{c.value=null,v.value=null;}}}function qt(e){let o=et(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,E=m.selectedRowIds.value,{setActiveCell:T,setSelectionRange:S,setEditingCell:A,handleRowCheckboxChange:_,handleCopy:q,handleCut:D,handlePaste:x,setContextMenu:P,onUndo:k,onRedo:y,clearClipboardRanges:R}=d,b=a.editable.value,L=a.onCellValueChanged.value,C=a.rowSelection.value,w=a.wrapperRef,I=a.scrollToRow,{fillDown:O}=a,F=a.onKeyDown?.value;if(F&&(F(l),l.defaultPrevented))return;let B=s.length-1,z=g-1+c;if(s.length===0)return;if(r===null){["ArrowDown","ArrowUp","ArrowLeft","ArrowRight","Tab","Enter","Home","End","PageDown","PageUp"].includes(l.key)&&(T({rowIndex:0,columnIndex:c}),l.preventDefault());return}let{rowIndex:G,columnIndex:H}=r,N=H-c,re=l.shiftKey,ae=(W,ne)=>{if(W<0||W>=s.length||ne<0||ne>=f.length)return true;let le=getCellValue(s[W],f[ne]);return le==null||le===""};switch(l.key){case "c":if(l.ctrlKey||l.metaKey){if(h!=null)break;l.preventDefault(),q();}break;case "x":if(l.ctrlKey||l.metaKey){if(h!=null)break;l.preventDefault(),D();}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;b!==false&&O&&(l.preventDefault(),O());}break;case "ArrowDown":case "ArrowUp":case "ArrowRight":case "ArrowLeft":{if(h!=null)break;l.preventDefault();let{newRowIndex:W,newColumnIndex:ne,newRange:le}=computeArrowNavigation({direction:l.key,rowIndex:G,columnIndex:H,dataColIndex:N,colOffset:c,maxRowIndex:B,maxColIndex:z,visibleColCount:f.length,isCtrl:l.ctrlKey||l.metaKey,isShift:re,selectionRange:p,isEmptyAt:ae});S(le),T({rowIndex:W,columnIndex:ne}),(l.key==="ArrowDown"||l.key==="ArrowUp")&&I?.(W,"center");break}case "Tab":{l.preventDefault();let{rowIndex:W,columnIndex:ne}=computeTabNavigation(G,H,B,z,c,l.shiftKey),le=ne-c;S({startRow:W,startCol:le,endRow:W,endCol:le}),T({rowIndex:W,columnIndex:ne});break}case "Home":{l.preventDefault();let W=l.ctrlKey?0:G;S({startRow:W,startCol:0,endRow:W,endCol:0}),T({rowIndex:W,columnIndex:c});break}case "End":{l.preventDefault();let W=l.ctrlKey?B:G;S({startRow:W,startCol:g-1,endRow:W,endCol:g-1}),T({rowIndex:W,columnIndex:z});break}case "PageDown":case "PageUp":{l.preventDefault();let W=w.value,ne=10;if(W){let Te=W.querySelector("tbody tr");Te&&Te.offsetHeight>0&&(ne=Math.max(1,Math.floor(W.clientHeight/Te.offsetHeight)));}let le=l.key==="PageDown"?1:-1,ve=Math.max(0,Math.min(G+le*ne,B));S(re?{startRow:p?.startRow??G,startCol:p?.startCol??N,endRow:ve,endCol:p?.endCol??N}:{startRow:ve,startCol:N,endRow:ve,endCol:N}),T({rowIndex:ve,columnIndex:H}),I?.(ve,"center");break}case "Enter":case "F2":{if(l.preventDefault(),N>=0&&N<f.length){let W=f[N],ne=s[G];if(ne&&W){let le=W.editable===true||typeof W.editable=="function"&&W.editable(ne);b!==false&&le&&L!=null&&A({rowId:v(ne),columnId:W.columnId});}}break}case "Escape":l.preventDefault(),h!=null?A(null):(R?.(),T(null),S(null));break;case " ":if(C!=="none"&&H===0&&u){l.preventDefault();let W=s[G];if(W){let ne=v(W),le=E.has(ne);_(ne,!le,G,l.shiftKey);}}break;case "z":(l.ctrlKey||l.metaKey)&&h==null&&(l.shiftKey&&y?(l.preventDefault(),y()):!l.shiftKey&&k&&(l.preventDefault(),k()));break;case "y":(l.ctrlKey||l.metaKey)&&h==null&&y&&(l.preventDefault(),y());break;case "a":if(l.ctrlKey||l.metaKey){if(h!=null)break;l.preventDefault(),s.length>0&&g>0&&(S({startRow:0,startCol:0,endRow:s.length-1,endCol:g-1}),T({rowIndex:0,columnIndex:c}));}break;case "Delete":case "Backspace":{if(h!=null||b===false||L==null)break;let W=p??(r!=null?{startRow:r.rowIndex,startCol:r.columnIndex-c,endRow:r.rowIndex,endCol:r.columnIndex-c}:null);if(W==null)break;l.preventDefault();let ne=applyCellDeletion(W,s,f);for(let le of ne)L(le);break}case "F10":if(l.shiftKey)if(l.preventDefault(),r!=null&&w.value){let W=`[data-row-index="${r.rowIndex}"][data-col-index="${r.columnIndex}"]`,ne=w.value.querySelector(W);if(ne){let le=ne.getBoundingClientRect();P({x:le.left+le.width/2,y:le.top+le.height/2});}else P({x:100,y:100});}else P({x:100,y:100});break;}}}}var Xt="data-drag-range";function jt(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,E=null,T=null,S=D=>{g.value=D;},A=()=>{E&&(window.removeEventListener("pointermove",E,true),E=null),T&&(window.removeEventListener("pointerup",T,true),T=null),p&&(cancelAnimationFrame(p),p=0);};return watch(g,(D,x,P)=>{if(!D||l.value===false||!i.value||!s.value){A();return}r={endRow:D.startRow,endCol:D.startCol},h=null;let k=new Set,y=buildCellIndex(s.value),R=w=>{if(!s.value)return;let O=Math.min(w.startRow,w.endRow),F=Math.max(w.startRow,w.endRow),B=Math.min(w.startCol,w.endCol),z=Math.max(w.startCol,w.endCol),G=u();for(let H of k){let N=parseInt(H.getAttribute("data-row-index")??"",10),re=parseInt(H.getAttribute("data-col-index")??"",10)-G;N>=O&&N<=F&&re>=B&&re<=z||(H.removeAttribute(Xt),k.delete(H));}for(let H=O;H<=F;H++)for(let N=B;N<=z;N++){let re=`${H},${N+G}`,ae=y?.get(re);ae&&!ae.isConnected&&(y=buildCellIndex(s.value),ae=y.get(re)),ae&&(ae.hasAttribute(Xt)||ae.setAttribute(Xt,""),k.add(ae));}},b=()=>{for(let w of k)w.removeAttribute(Xt);k.clear();},L=null,C=(w,I)=>{let F=document.elementFromPoint(w,I)?.closest?.("[data-row-index][data-col-index]");if(!F||!s.value?.contains(F))return null;let B=parseInt(F.getAttribute("data-row-index")??"",10),z=parseInt(F.getAttribute("data-col-index")??"",10),G=u();if(Number.isNaN(B)||Number.isNaN(z)||z<G)return null;let H=z-G;return normalizeSelectionRange({startRow:D.startRow,startCol:D.startCol,endRow:B,endCol:H})};E=w=>{L={cx:w.clientX,cy:w.clientY},p&&cancelAnimationFrame(p),p=requestAnimationFrame(()=>{if(p=0,!L)return;let I=C(L.cx,L.cy);if(!I)return;let O=h;O&&O.startRow===I.startRow&&O.startCol===I.startCol&&O.endRow===I.endRow&&O.endCol===I.endCol||(h=I,r={endRow:I.endRow,endCol:I.endCol},R(I));});},T=()=>{if(p&&(cancelAnimationFrame(p),p=0),L){let G=C(L.cx,L.cy);G&&(h=G,r={endRow:G.endRow,endCol:G.endCol});}b();let w=r,I=normalizeSelectionRange({startRow:D.startRow,startCol:D.startCol,endRow:w.endRow,endCol:w.endCol}),O=c?.value;O&&(I.startRow=Math.max(I.startRow,O.startIndex),I.endRow=Math.min(I.endRow,O.endIndex)),d(I),a({rowIndex:D.startRow,columnIndex:D.startCol+u()});let F=o.value,B=n.value,z=i.value;if(z){let G=applyFillValues(I,D.startRow,D.startCol,F,B);if(G.length>0){f?.();for(let H of G)z(H);v?.();}}g.value=null,h=null,A();},window.addEventListener("pointermove",E,true),window.addEventListener("pointerup",T,true),P(()=>{A();});}),onUnmounted(()=>A()),{fillDrag:g,setFillDrag:S,handleFillHandleMouseDown:D=>{D.preventDefault(),D.stopPropagation();let x=m.value;x&&(g.value={startRow:x.startRow,startCol:x.startCol});},fillDown:()=>{let D=m.value;if(!D||l.value===false||!i.value)return;let x=normalizeSelectionRange(D),P=o.value,k=n.value,y=i.value,R=applyFillValues(x,x.startRow,x.startCol,P,k);if(R.length>0){f?.();for(let b of R)y(b);v?.();}}}}function Yt(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 Zt(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),E=(parseFloat(h.borderLeftWidth||"0")||0)+(parseFloat(h.borderRightWidth||"0")||0);a.value=Math.max(0,p.width-E);};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(S=>S.columnId)),h=v.value,E=Object.keys(h),T=E.filter(S=>p.has(S));if(T.length<E.length){let S={};for(let A of T)S[A]=h[A];v.value=S;}});let g=computed(()=>{let r=i.value?CHECKBOX_COLUMN_WIDTH:0;return n.value.reduce((p,h)=>{let E=v.value[h.columnId],T=h.minWidth??estimateHeaderMinWidth(h.name),S=E?E.widthPx:h.idealWidth??h.defaultWidth??T;return p+Math.max(T,S)+CELL_PADDING},r)});return {containerWidth:a,minTableWidth:u,desiredTableWidth:g,columnSizingOverrides:v,setColumnSizingOverrides:c,onColumnResized:d}}function Jt(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 E={},T=p?h:0;for(let S of u)d.value[S.columnId]==="left"&&(E[S.columnId]=T,T+=g[S.columnId]??r);return E},computeRightOffsets:(u,g,r)=>{let p={},h=0;for(let E=u.length-1;E>=0;E--){let T=u[E];d.value[T.columnId]==="right"&&(p[T.columnId]=h,h+=g[T.columnId]??r);}return p}}}function en(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=(C,w)=>{c.value=C,u.value=w,v.value=true;},r=()=>{v.value=false,c.value=null,u.value=null;},p=computed(()=>c.value?o.value.find(C=>C.columnId===c.value):void 0),h=computed(()=>c.value?n.value[c.value]:void 0),E=computed(()=>h.value!=="left"),T=computed(()=>h.value!=="right"),S=computed(()=>!!h.value),A=computed(()=>!c.value||!s?.value||s.value!==c.value?null:f?.value??null),_=computed(()=>p.value?.sortable!==false),q=ref(true);return {isOpen:v,openForColumn:c,anchorElement:u,open:g,close:r,handlePinLeft:()=>{c.value&&E.value&&(l(c.value,"left"),r());},handlePinRight:()=>{c.value&&T.value&&(l(c.value,"right"),r());},handleUnpin:()=>{c.value&&S.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 C=a??d;if(!c.value||!C||!q.value)return;let w=p.value;C(c.value,measureColumnContentWidth(c.value,w?.minWidth)),r();},handleAutosizeAll:()=>{let C=a??d;C&&(o.value.forEach(w=>{C(w.columnId,measureColumnContentWidth(w.columnId,w.minWidth));}),r());},canPinLeft:E,canPinRight:T,canUnpin:S,currentSort:A,isSortable:_,isResizable:q}}var _e=()=>{},Mr=async()=>{},kr=(e,o,n)=>{},Ar=e=>{},Lr=e=>{};function nn(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=Yt({onCellValueChanged:o.value.onCellValueChanged,afterChange:c}),g=computed(()=>u.onCellValueChanged),r=computed(()=>flattenColumns(o.value.columns)),p=computed(()=>{let J=f.value;return !J||Object.keys(J).length===0?r.value:r.value.map(Y=>{let ie=J[Y.columnId];return ie&&Y.pinned!==ie?{...Y,pinned:ie}:Y})}),h=computed(()=>resolveResponsiveConfig(o.value.responsiveColumns)),E=computed(()=>{let J=o.value.visibleColumns,Y=o.value.columnOrder,ie=J?p.value.filter(ce=>J.has(ce.columnId)):p.value;if(!Y?.length)return ie;let ge=new Map;for(let ce=0;ce<Y.length;ce++)ge.set(Y[ce],ce);return [...ie].sort((ce,Fe)=>{let Ie=ge.get(ce.columnId)??-1,Ce=ge.get(Fe.columnId)??-1;return Ie===-1&&Ce===-1?0:Ie===-1?1:Ce===-1?-1:Ie-Ce})}),T=ref(0),S=computed(()=>applyResponsiveHiding(E.value,T.value,h.value)),A=computed(()=>S.value.length),_=computed(()=>m.value==="multiple"),q=computed(()=>!!o.value.showRowNumbers),D=computed(()=>(_.value?1:0)+(q.value?1:0)),x=computed(()=>A.value+D.value),P=D,k=shallowRef(new Map);watch(l,J=>{let Y=k.value;Y.clear(),J.forEach((ie,ge)=>Y.set(i(ie),ge)),triggerRef(k);},{immediate:true});let y=Gt({items:l,getRowId:i,rowSelection:m,controlledSelectedRows:d,onSelectionChange:o.value.onSelectionChange}),{editingCell:R,setEditingCell:b,pendingEditorValue:L,setPendingEditorValue:C}=Nt(),{activeCell:w,setActiveCell:I}=Wt(n,R),O=computed(()=>l.value.length),F=computed(()=>S.value.length),{selectionRange:B,setSelectionRange:z,handleCellMouseDown:G,handleSelectAllCells:H,isDragging:N}=_t({colOffset:P,rowCount:O,visibleColCount:F,setActiveCell:I,wrapperRef:n}),{contextMenuPosition:re,setContextMenuPosition:ae,handleCellContextMenu:W,closeContextMenu:ne}=Kt(),{handleCopy:le,handleCut:ve,handlePaste:Te,cutRange:Le,copyRange:Ee,clearClipboardRanges:De}=$t({items:l,visibleCols:S,colOffset:P,selectionRange:B,activeCell:w,editable:a,onCellValueChanged:g,beginBatch:u.beginBatch,endBatch:u.endBatch}),yt=(J,Y,ie)=>{J.button===0&&(n.value?.focus({preventScroll:true}),De(),G(J,Y,ie));},{handleFillHandleMouseDown:nt,fillDown:st}=jt({items:l,visibleCols:S,editable:a,onCellValueChanged:g,selectionRange:B,setSelectionRange:z,setActiveCell:I,colOffset:P,wrapperRef:n,beginBatch:u.beginBatch,endBatch:u.endBatch}),{handleGridKeyDown:ut}=qt({data:{items:l,visibleCols:S,colOffset:P,hasCheckboxCol:_,visibleColumnCount:A,getRowId:i},state:{activeCell:w,selectionRange:B,editingCell:R,selectedRowIds:y.selectedRowIds},handlers:{setActiveCell:I,setSelectionRange:z,setEditingCell:b,handleRowCheckboxChange:y.handleRowCheckboxChange,handleCopy:le,handleCut:ve,handlePaste:Te,setContextMenu:ae,onUndo:u.undo,onRedo:u.redo,clearClipboardRanges:De},features:{editable:a,onCellValueChanged:g,rowSelection:m,wrapperRef:n,fillDown:st,onKeyDown:computed(()=>o.value.onKeyDown)}}),{containerWidth:ot,minTableWidth:qe,desiredTableWidth:lt,columnSizingOverrides:Me,setColumnSizingOverrides:Ve}=Zt({wrapperRef:n,visibleCols:E,flatColumns:p,hasCheckboxCol:_,initialColumnWidths:o.value.initialColumnWidths,onColumnResized:(J,Y)=>o.value.onColumnResized?.(J,Y)});watch(ot,J=>{T.value=J;},{immediate:true});let Se=Jt({columns:p,pinnedColumns:f,onColumnPinned:o.value.onColumnPinned}),dt=(J,Y)=>{Ve({...Me.value,[J]:{widthPx:Y}}),o.value.onColumnResized?.(J,Y);},se=en({columns:p,pinnedColumns:Se.pinnedColumns,onPinColumn:Se.pinColumn,onUnpinColumn:Se.unpinColumn,onSort:o.value.onColumnSort,onColumnResized:o.value.onColumnResized,onAutosizeColumn:dt,sortBy:computed(()=>o.value.sortBy),sortDirection:computed(()=>o.value.sortDirection)}),xe=ref({});watch([S,ot,Me],()=>{nextTick(()=>{let J=n.value;if(!J)return;let Y=J.querySelectorAll("th[data-column-id]");if(Y.length===0)return;let ie={};Y.forEach(Ie=>{let Ce=Ie.getAttribute("data-column-id");Ce&&(ie[Ce]=Ie.offsetWidth);});let ge=xe.value,ce=Object.keys(ie),Fe=ce.length!==Object.keys(ge).length;if(!Fe){for(let Ie of ce)if(ge[Ie]!==ie[Ie]){Fe=true;break}}Fe&&(xe.value=ie);});},{flush:"post"});let Xe=computed(()=>{let J={};for(let Y of S.value){let ie=Me.value[Y.columnId];J[Y.columnId]=ie?ie.widthPx:Y.idealWidth??Y.defaultWidth??Y.minWidth??DEFAULT_MIN_COLUMN_WIDTH;}return J}),je=computed(()=>Se.computeLeftOffsets(S.value,Xe.value,DEFAULT_MIN_COLUMN_WIDTH,_.value,CHECKBOX_COLUMN_WIDTH)),Ye=computed(()=>Se.computeRightOffsets(S.value,Xe.value,DEFAULT_MIN_COLUMN_WIDTH)),Ze=computed(()=>computeAggregations(l.value,S.value,s.value?B.value:null)),Je=computed(()=>{let J=getDataGridStatusBarConfig(o.value.statusBar,l.value.length,y.selectedRowIds.value.size);return J?{...J,aggregation:Ze.value??void 0}:null}),ze=computed(()=>l.value.length===0&&!!o.value.emptyState&&!o.value.isLoading),ct=computed(()=>B.value!=null||w.value!=null),mt=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})),Be=computed(()=>({editingCell:R.value,activeCell:s.value?w.value:null,selectionRange:s.value?B.value:null,cutRange:s.value?Le.value:null,copyRange:s.value?Ee.value:null,colOffset:P.value,itemsLength:l.value.length,getRowId:i,editable:a.value,onCellValueChanged:g.value,isDragging:s.value?N.value:false,getFormulaValue:o.value.getFormulaValue,hasFormula:o.value.hasFormula,getFormula:o.value.getFormula,formulaVersion:o.value.formulaVersion})),rt=ref(null),Qe=J=>{rt.value=J;},ft=(J,Y,ie,ge,ce,Fe,Ie)=>{let Ce=S.value.find(ye=>ye.columnId===Y);if(Ce){let ye=parseValue(ge,ie,J,Ce);if(!ye.valid){b(null),Qe(null),C(void 0);return}ge=ye.value;}if(b(null),Qe(null),C(void 0),Object.is(ge,ie)||g.value?.({item:J,columnId:Y,oldValue:ie,newValue:ge,rowIndex:ce}),!Ie?.skipAdvance&&ce<l.value.length-1){let ye=ce+1,ht=Fe-P.value;I({rowIndex:ye,columnIndex:Fe}),z({startRow:ye,startCol:ht,endRow:ye,endCol:ht});}},Ut=()=>{b(null),Qe(null),C(void 0);},fe=computed(()=>({flatColumns:p.value,visibleCols:S.value,visibleColumnCount:A.value,totalColCount:x.value,colOffset:P.value,hasCheckboxCol:_.value,hasRowNumbersCol:q.value,rowIndexByRowId:k.value,containerWidth:ot.value,minTableWidth:qe.value,desiredTableWidth:lt.value,columnSizingOverrides:Me.value,setColumnSizingOverrides:Ve,onColumnResized:o.value.onColumnResized,measuredColumnWidths:xe.value,stickyHeader:o.value.stickyHeader??true})),pt=computed(()=>({selectedRowIds:y.selectedRowIds.value,updateSelection:y.updateSelection,handleRowCheckboxChange:y.handleRowCheckboxChange,handleSelectAll:y.handleSelectAll,allSelected:y.allSelected.value,someSelected:y.someSelected.value})),vt=computed(()=>({editingCell:R.value,setEditingCell:b,pendingEditorValue:L.value,setPendingEditorValue:C,commitCellEdit:ft,cancelPopoverEdit:Ut,popoverAnchorEl:rt.value,setPopoverAnchorEl:Qe})),at=computed(()=>(v.value,{activeCell:s.value?w.value:null,setActiveCell:s.value?I:_e,selectionRange:s.value?B.value:null,setSelectionRange:s.value?z:_e,handleCellMouseDown:s.value?yt:kr,handleSelectAllCells:s.value?H:_e,hasCellSelection:s.value?ct.value:false,handleGridKeyDown:s.value?ut:Ar,handleFillHandleMouseDown:s.value?nt:_e,handleCopy:s.value?le:_e,handleCut:s.value?ve:_e,handlePaste:s.value?Te:Mr,cutRange:s.value?Le.value:null,copyRange:s.value?Ee.value:null,clearClipboardRanges:s.value?De:_e,canUndo:u.canUndo.value,canRedo:u.canRedo.value,onUndo:u.undo,onRedo:u.redo,isDragging:s.value?N.value:false})),gt=computed(()=>({menuPosition:s.value?re.value:null,setMenuPosition:s.value?ae:_e,handleCellContextMenu:s.value?W:Lr,closeContextMenu:s.value?ne:_e})),Ge=computed(()=>({headerFilterInput:mt.value,cellDescriptorInput:Be.value,statusBarConfig:Je.value,showEmptyInGrid:ze.value,onCellError:o.value.onCellError})),Ct=computed(()=>({pinnedColumns:Se.pinnedColumns.value,pinColumn:Se.pinColumn,unpinColumn:Se.unpinColumn,isPinned:Se.isPinned,leftOffsets:je.value,rightOffsets:Ye.value,headerMenu:{isOpen:se.isOpen.value,openForColumn:se.openForColumn.value,anchorElement:se.anchorElement.value,open:se.open,close:se.close,handlePinLeft:se.handlePinLeft,handlePinRight:se.handlePinRight,handleUnpin:se.handleUnpin,handleSortAsc:se.handleSortAsc,handleSortDesc:se.handleSortDesc,handleClearSort:se.handleClearSort,handleAutosizeThis:se.handleAutosizeThis,handleAutosizeAll:se.handleAutosizeAll,canPinLeft:se.canPinLeft.value,canPinRight:se.canPinRight.value,canUnpin:se.canUnpin.value,currentSort:se.currentSort.value,isSortable:se.isSortable.value,isResizable:se.isResizable.value}}));return {layout:fe,rowSelection:pt,editing:vt,interaction:at,contextMenu:gt,viewModels:Ge,pinning:Ct}}function on(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,E=h,T=document.body.style.cursor,S=document.body.style.userSelect;document.body.style.cursor="col-resize",document.body.style.userSelect="none";let A=()=>{n({...o.value,[r]:{widthPx:E}});},_=r===ROW_NUMBER_COLUMN_ID?ROW_NUMBER_COLUMN_MIN_WIDTH:l,q=P=>{let k=P.clientX-g;E=Math.max(_,h+k),d||(d=requestAnimationFrame(()=>{d=0,A();}));},D=()=>{document.removeEventListener("pointermove",q),document.removeEventListener("pointerup",x),a=null,document.body.style.cursor=T,document.body.style.userSelect=S,d&&(cancelAnimationFrame(d),d=0);},x=()=>{D(),A(),m?.(r,E);};document.addEventListener("pointermove",q),document.addEventListener("pointerup",x),a=D;},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 ln(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 Fo(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 rn(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 qr=150,Xn=[];function an(e){let{onFilterChange:o}=e,n=ref(new Set(e.selectedValues??Xn)),l=ref(""),i=ln(l,qr);watch(e.isFilterOpen,u=>{u&&(n.value=new Set(e.selectedValues??Xn),l.value="");});let m=computed(()=>{let u=e.options??Xn;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 jr=300;function un(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;}},jr);}}),onUnmounted(()=>{i&&clearTimeout(i);}),{peopleSuggestions:m,isPeopleLoading:d,peopleSearchText:a,setPeopleSearchText:s,peopleInputRef:l,handleUserSelect:c=>{o?.(c);},handleClearUser:()=>{o?.(void 0);}}}function dn(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 Qr=[];function Ao(e){let{filterType:o,onSort:n}=e,l=()=>e.selectedValues??Qr,i=ref(null),m=ref(null),d=ref(false),a=ref(null),s=C=>{d.value=C;},f=rn({textValue:e.textValue,onTextChange:e.onTextChange,isFilterOpen:d}),v=an({selectedValues:e.selectedValues,onFilterChange:e.onFilterChange,options:e.options,isFilterOpen:d}),c=un({selectedUser:e.selectedUser,onUserChange:e.onUserChange,peopleSearch:e.peopleSearch,isFilterOpen:d,filterType:o}),u=dn({dateValue:e.dateValue,onDateChange:e.onDateChange,isFilterOpen:d});watch(d,C=>{C||(a.value=null);});let g=null,r=null,p,h=()=>{E(),g=C=>{let w=C.target;m.value&&!m.value.contains(w)&&i.value&&!i.value.contains(w)&&(d.value=false);},r=C=>{(C.key==="Escape"||C.key==="Esc")&&(C.preventDefault(),C.stopPropagation(),d.value=false);},p=setTimeout(()=>{g&&document.addEventListener("mousedown",g);},0),document.addEventListener("keydown",r,true);},E=()=>{p&&clearTimeout(p),g&&document.removeEventListener("mousedown",g),r&&document.removeEventListener("keydown",r,true),g=null,r=null;};watch(d,C=>{C?h():E();}),onUnmounted(()=>E());let T=C=>{if(C.stopPropagation(),C.preventDefault(),!d.value&&i.value){let w=i.value.getBoundingClientRect();a.value={top:w.bottom+4,left:w.left};}d.value=!d.value;},S=C=>{C.stopPropagation(),n?.();},A=()=>{v.handleApplyMultiSelect(),d.value=false;},_=()=>{f.handleTextApply(),d.value=false;},q=C=>{c.handleUserSelect(C),d.value=false;},D=()=>{c.handleClearUser(),d.value=false;},x=()=>{u.handleDateApply(),d.value=false;},P=C=>C.stopPropagation(),k=C=>C.stopPropagation(),y=C=>C.stopPropagation(),R=C=>C.stopPropagation(),b=C=>{C.key!=="Escape"&&C.key!=="Esc"&&C.stopPropagation();},L=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:L,popoverPosition:a,handlers:{handleFilterIconClick:T,handleApplyMultiSelect:A,handleTextApply:_,handleTextClear:f.handleTextClear,handleUserSelect:q,handleClearUser:D,handleCheckboxChange:v.handleCheckboxChange,handleSelectAll:v.handleSelectAll,handleClearSelection:v.handleClearSelection,handlePopoverClick:P,handleInputFocus:k,handleInputMouseDown:y,handleInputClick:R,handleInputKeyDown:b,handleDateApply:x,handleDateClear:u.handleDateClear,handleSortClick:S}}}function Bo(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=>E=>{l(h,E);},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 Ho(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 E=h.getUTCFullYear().toString().padStart(4,"0"),T=(h.getUTCMonth()+1).toString().padStart(2,"0"),S=h.getUTCDate().toString().padStart(2,"0");l(`${E}-${T}-${S}`);}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 zo(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 ma=8,fa=5;function mn(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 P=r.getBoundingClientRect();if(g.clientX>P.right-ma)return}if(g.preventDefault(),!l.value||!n.value)return;a=u,s=getPinStateForColumn(u,i?.value),d.value=null;let h=g.clientX,E=false,T=g.clientX,S=-1,A=document.body.style.cursor,_=document.body.style.userSelect;document.body.style.cursor="grabbing",document.body.style.userSelect="none";let q=P=>{!E&&Math.abs(P.clientX-h)<fa||(E||(E=true,m.value=true),T=P.clientX,f||(f=requestAnimationFrame(()=>{f=0;let k=l.value;if(!k||!a)return;let y=calculateDropTarget({mouseX:T,columnOrder:o.value,draggedColumnId:a,draggedPinState:s,tableElement:k,pinnedColumns:i?.value});y?(S=y.targetIndex,d.value=y.indicatorX):d.value=null;})));},D=()=>{window.removeEventListener("pointermove",q,true),window.removeEventListener("pointerup",x,true),v=null,document.body.style.cursor=A,document.body.style.userSelect=_,f&&(cancelAnimationFrame(f),f=0);},x=()=>{if(D(),E&&a&&S>=0&&n.value){let P=reorderColumnArray(o.value,a,S);n.value(P);}a=null,m.value=false,d.value=null,S=-1;};window.addEventListener("pointermove",q,true),window.addEventListener("pointerup",x,true),v=D;}}}var ya=100;function pn(e){let{totalRows:o,rowHeight:n,enabled:l,overscan:i=5,threshold:m=ya,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,E=computed(()=>l.value&&o.value>=m),T=computed(()=>E.value?computeVisibleRange(v.value,n,u.value,o.value,i):{startIndex:0,endIndex:Math.max(0,o.value-1),offsetTop:0,offsetBottom:0}),S=computed(()=>l.value?computeTotalHeight(o.value,n):0),A=computed(()=>{if(!d?.value)return null;let x=a?.value;return !x||x.length===0?null:computeVisibleColumnRange(c.value,x,g.value,s)}),_=()=>{r||(r=requestAnimationFrame(()=>{r=0;let x=f.value;x&&(v.value=x.scrollTop,c.value=x.scrollLeft);}));},q=()=>{let x=f.value;x&&(u.value=x.clientHeight,g.value=x.clientWidth);};return watch(f,x=>{x!==h&&(h&&h.removeEventListener("scroll",_),p&&(p.disconnect(),p=void 0),h=x,x&&(x.addEventListener("scroll",_,{passive:true}),typeof ResizeObserver<"u"&&(p=new ResizeObserver(q),p.observe(x)),q(),v.value=x.scrollTop,c.value=x.scrollLeft));}),onUnmounted(()=>{let x=f.value;x&&x.removeEventListener("scroll",_),p?.disconnect(),r&&(cancelAnimationFrame(r),r=0);}),{containerRef:f,visibleRange:T,totalHeight:S,scrollToRow:(x,P="start")=>{let k=f.value;k&&(k.scrollTop=getScrollTopForRow(x,n,u.value,P));},columnRange:A,scrollLeft:c}}function gn(e){let{props:o}=e,n=ref(null),l=ref(null),i=ref(null),m=ref(false),d=nn({props:o,wrapperRef:n}),a=computed(()=>{let q=o.value;return q.columnOrder?q.columnOrder:flattenColumns(q.columns).filter(D=>q.visibleColumns?.has(D.columnId)??true).map(D=>D.columnId)}),s=computed(()=>o.value.onColumnOrderChange),f=mn({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 q=d.layout.value,{visibleCols:D,columnSizingOverrides:x}=q,P=o.value.pinnedColumns??{},k=[];for(let y of D){if(P[y.columnId]||y.pinned)continue;let R=x[y.columnId];k.push(R?R.widthPx:y.defaultWidth??y.minWidth??DEFAULT_MIN_COLUMN_WIDTH);}return k}),E=pn({totalRows:c,rowHeight:u,enabled:v,overscan:g,columnsEnabled:r,columnWidths:h,columnOverscan:p}),T=computed(()=>{if(!r.value)return null;let D=d.layout.value.visibleCols,x=E.columnRange.value,P=o.value.pinnedColumns;return partitionColumnsForVirtualization(D,x,P)}),S=computed(()=>{let D=d.layout.value.visibleCols,x=new Map;for(let P=0;P<D.length;P++)x.set(D[P].columnId,P);return x}),A=computed(()=>d.layout.value.columnSizingOverrides),_=on({columnSizingOverrides:A,setColumnSizingOverrides:q=>d.layout.value.setColumnSizingOverrides(q)});return {wrapperRef:n,tableContainerRef:l,tableRef:i,lastMouseShift:m,state:d,columnReorder:f,virtualScroll:E,virtualScrollEnabled:v,columnResize:_,columnPartition:T,globalColIndexMap:S}}function Cn(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 No=()=>{};function ka(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:E,getColumnWidth:T},columnPartition:S,globalColIndexMap:A}=gn({props:n}),_=computed(()=>{let y=n.value;return y.showRowNumbers||y.showColumnLetters?((y.currentPage??1)-1)*(y.pageSize??25):0});watch([()=>a.interaction.value.activeCell,_],([y,R])=>{let b=n.value.onActiveCellChange;b&&b(y?formatCellReference(y.columnIndex-a.layout.value.colOffset,R+y.rowIndex+1):null);},{immediate:true});let q=y=>{d.value=y.shiftKey;},D=y=>y.preventDefault(),x=y=>y.stopPropagation(),P=computed(()=>buildHeaderRows(n.value.columns,n.value.visibleColumns)),k=computed(()=>{let y=a.layout.value,R=a.pinning.value,{visibleCols:b,columnSizingOverrides:L,measuredColumnWidths:C}=y,{leftOffsets:w,rightOffsets:I}=R,O={},F={},B={},z={};for(let G=0;G<b.length;G++){let H=b[G],N=H.pinned==="left",re=H.pinned==="right",ae=T(H),W=!!L[H.columnId],ne=C[H.columnId],le=H.minWidth??estimateHeaderMinWidth(H.name),ve=W?ae:Math.max(le,ne??0),Te={minWidth:`${ve}px`,width:`${ae}px`,maxWidth:`${ae}px`},Le={minWidth:`${ve}px`,width:`${ae}px`,maxWidth:`${ae}px`},Ee=["ogrid-data-cell"],De=["ogrid-header-cell"];N?(Ee.push("ogrid-data-cell--pinned-left"),Te.left=`${w[H.columnId]??0}px`,De.push("ogrid-header-cell--pinned-left"),Le.left=`${w[H.columnId]??0}px`):re&&(Ee.push("ogrid-data-cell--pinned-right"),Te.right=`${I[H.columnId]??0}px`,De.push("ogrid-header-cell--pinned-right"),Le.right=`${I[H.columnId]??0}px`),O[H.columnId]=Te,F[H.columnId]=Ee.join(" "),B[H.columnId]=Le,z[H.columnId]=De.join(" ");}return {cellStyles:O,cellClasses:F,hdrStyles:B,hdrClasses:z}});return ()=>{let y=o.gridProps,R=a.layout.value,b=a.rowSelection.value,L=a.editing.value,C=a.interaction.value,w=a.contextMenu.value,I=a.viewModels.value,O=a.pinning.value,{headerMenu:F}=O,{visibleCols:B,hasCheckboxCol:z,hasRowNumbersCol:G,colOffset:H,containerWidth:N,minTableWidth:re,desiredTableWidth:ae}=R,W=y.currentPage??1,ne=y.pageSize??25,le=G?(W-1)*ne:0,{selectedRowIds:ve,handleRowCheckboxChange:Te,handleSelectAll:Le,allSelected:Ee,someSelected:De}=b,{editingCell:yt,setEditingCell:nt,pendingEditorValue:st,setPendingEditorValue:ut,commitCellEdit:ot,cancelPopoverEdit:qe,popoverAnchorEl:lt,setPopoverAnchorEl:Me}=L,{setActiveCell:Ve,setSelectionRange:Se,handleCellMouseDown:dt,handleSelectAllCells:se,selectionRange:xe,hasCellSelection:Xe,handleGridKeyDown:je,handleFillHandleMouseDown:Ye,handleCopy:Ze,handleCut:Je,handlePaste:ze,cutRange:ct,copyRange:mt,canUndo:Be,canRedo:rt,onUndo:Qe,onRedo:ft,isDragging:Ut}=C,{menuPosition:fe,handleCellContextMenu:pt,closeContextMenu:vt}=w,{headerFilterInput:at,cellDescriptorInput:gt,statusBarConfig:Ge,showEmptyInGrid:Ct,onCellError:J}=I,Y=y.items,ie=y.getRowId,ge=y.layoutMode??"fill",ce=y.rowSelection??"none",Fe=y.suppressHorizontalScroll,Ie=y.stickyHeader??true,Ce=y.isLoading??false,ye=y.loadingMessage??"Loading\u2026",ht=y["aria-label"],Ot=y["aria-labelledby"],In=ge==="content",wt=!Fe&&N>0&&(re>N||ae>N),pe=P.value,xt={commitCellEdit:ot,setEditingCell:nt,setPendingEditorValue:ut,cancelPopoverEdit:qe},Tn={handleCellMouseDown:dt,setActiveCell:Ve,setEditingCell:nt,handleCellContextMenu:pt},Pn=K=>{if(ce!=="single")return;let Q=K.currentTarget.dataset.rowId;Q&&b.updateSelection(ve.has(Q)?new Set:new Set([Q]));},En=(K,M,Q,oe)=>{try{return Dn(K,M,Q,oe)}catch(V){return J&&J(V instanceof Error?V:new Error(String(V)),void 0),""}},Dn=(K,M,Q,oe)=>{let V=getCellRenderDescriptor(K,M,Q,oe,gt);if(V.mode==="editing-inline"){let ue=buildInlineEditorProps(K,M,V,xt);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(V.mode==="editing-popover"&&typeof M.cellEditor=="function"){let ue=buildPopoverEditorProps(K,M,V,st,xt),ee=M.cellEditor,Mt=resolveCellDisplayContent(M,K,V.displayValue),Jn=resolveCellStyle(M,K,V.displayValue);return h("div",[h("div",{ref:Qn=>{Qn&&Me(Qn);},class:"ogrid-popover-anchor"},[Jn?h("span",{style:Jn},[Mt]):Mt]),lt?h(ee,ue):null])}let Ae=Cn(V,M.columnId,Tn),Pe=["ogrid-cell-content"];M.type==="numeric"?Pe.push("ogrid-cell-content--numeric"):M.type==="boolean"&&Pe.push("ogrid-cell-content--boolean"),V.canEditAny&&Pe.push("ogrid-cell-content--editable"),V.isActive&&Pe.push("ogrid-cell-content--active"),V.isActive&&V.isInRange&&Pe.push("ogrid-cell-content--active-in-range"),V.isInRange&&!V.isActive&&Pe.push("ogrid-cell-in-range"),V.isInCutRange&&Pe.push("ogrid-cell-cut");let We;if(V.columnType==="boolean"){let ue=!!V.displayValue;We=h("input",{type:"checkbox",checked:ue,disabled:!V.canEditAny,onChange:V.canEditAny?()=>{let ee=V.rowIndex,Mt=V.globalColIndex;xt.commitCellEdit(K,M.columnId,ue,!ue,ee,Mt,{skipAdvance:true});}:void 0,onPointerdown:ee=>handleBooleanCellPointerDown(ee,V.rowIndex,V.globalColIndex,H,{setActiveCell:Ve,setSelectionRange:Se}),onClick:ee=>ee.stopPropagation(),style:`margin:0;cursor:${V.canEditAny?"pointer":"default"};outline:none`,"aria-label":ue?"Checked":"Unchecked"});}else {let ue=resolveCellDisplayContent(M,K,V.displayValue),ee=resolveCellStyle(M,K,V.displayValue);We=ee?h("span",{style:ee},ue):ue;}return h("div",{...Ae,class:Pe.join(" ")},[We,...V.canEditAny&&V.isSelectionEndCell?[h("div",{onPointerdown:Ye,"aria-label":"Fill handle",class:"ogrid-fill-handle"})]:[]])},{cellStyles:Fn,cellClasses:t,hdrStyles:U,hdrClasses:te}=k.value,he=B.map(K=>({col:K,tdClasses:t[K.columnId]||"ogrid-data-cell",tdDynamicStyle:Fn[K.columnId]||{}})),Ue=S.value,Ne=he,ke=0,Re=0;if(Ue){let K=new Set;for(let M of Ue.pinnedLeft)K.add(M.columnId);for(let M of Ue.virtualizedUnpinned)K.add(M.columnId);for(let M of Ue.pinnedRight)K.add(M.columnId);Ne=he.filter(M=>K.has(M.col.columnId)),ke=Ue.leftSpacerWidth,Re=Ue.rightSpacerWidth;}let Rt=A.value,bt=K=>{let M=U[K.columnId]||{};return {classes:te[K.columnId]||"ogrid-header-cell",style:{...M,cursor:s.value?"grabbing":"grab"}}},Oe=p.value,be={position:"relative",width:In?"fit-content":"100%",maxWidth:"100%",overflowX:Fe?"hidden":wt?"auto":"hidden",overflowY:"auto",backgroundColor:"#fff",willChange:"scroll-position",...Oe?{flex:"1",minHeight:"0"}:{minHeight:Ce&&Y.length===0?"200px":"auto"}};return y.rowHeight&&(be["--ogrid-row-height"]=`${y.rowHeight}px`),h("div",{class:"ogrid-outer-container"},[h("div",{ref:K=>{l.value=K,c.value=K;},tabindex:0,role:"region","aria-label":ht??(Ot?void 0:"Data grid"),"aria-labelledby":Ot,onPointerdown:q,onKeydown:je,onContextmenu:D,"data-overflow-x":wt?"true":"false","data-ogrid-scroll-container":"",style:be},[h("div",{class:"ogrid-scroll-wrapper"},[h("div",{style:{minWidth:wt?`${re}px`:void 0,overflowX:"clip"}},[h("div",{ref:K=>{i.value=K;},class:["ogrid-table-container",Ce&&Y.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:K=>{m.value=K;},class:"ogrid-table",role:"grid",style:{minWidth:`${re}px`},...p.value?{"data-virtual-scroll":""}:{}},[h("thead",{class:Ie?"ogrid-thead ogrid-sticky-header":"ogrid-thead"},[...y.showColumnLetters?[h("tr",{class:"ogrid-column-letter-row"},[...z?[h("th",{class:"ogrid-column-letter-cell"})]:[],...G?[h("th",{class:"ogrid-column-letter-cell"})]:[],...B.map((K,M)=>{let{classes:Q,style:oe}=bt(K);return h("th",{key:K.columnId,class:`ogrid-column-letter-cell ${Q}`,style:oe},indexToColumnLetter(M))})])]:[],...pe.map((K,M)=>h("tr",{key:M,class:"ogrid-header-row"},[...M===pe.length-1&&z?[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:Ee,indeterminate:De&&!Ee,ariaLabel:"Select all rows",onChange:Q=>Le(!!Q)}))]:[],...M===0&&M<pe.length-1&&z?[h("th",{rowSpan:pe.length-1,class:"ogrid-checkbox-spacer",style:{width:`${CHECKBOX_COLUMN_WIDTH}px`,minWidth:`${CHECKBOX_COLUMN_WIDTH}px`}})]:[],...M===pe.length-1&&G?[(()=>{let Q=R.columnSizingOverrides[ROW_NUMBER_COLUMN_ID]?.widthPx??ROW_NUMBER_COLUMN_WIDTH;return h("th",{class:"ogrid-row-number-header",style:{width:`${Q}px`,minWidth:`${Q}px`,maxWidth:`${Q}px`,position:"sticky",left:z?`${CHECKBOX_COLUMN_WIDTH}px`:"0",zIndex:3}},["#",h("div",{onPointerdown:oe=>{Ve(null),Se(null),l.value?.focus({preventScroll:true}),oe.stopPropagation(),h$1(oe,{columnId:ROW_NUMBER_COLUMN_ID,name:"#"});},class:"ogrid-resize-handle",role:"separator","aria-label":"Resize row numbers"})])})()]:[],...M===0&&M<pe.length-1&&G?[(()=>{let Q=R.columnSizingOverrides[ROW_NUMBER_COLUMN_ID]?.widthPx??ROW_NUMBER_COLUMN_WIDTH;return h("th",{rowSpan:pe.length-1,class:"ogrid-row-number-spacer",style:{width:`${Q}px`,position:"sticky",left:z?`${CHECKBOX_COLUMN_WIDTH}px`:"0",zIndex:3}})})()]:[],...K.map((Q,oe)=>{if(Q.isGroup)return h("th",{key:oe,colSpan:Q.colSpan,scope:"colgroup",class:"ogrid-column-group-header"},Q.label);if(!Q.columnDef)return null;let V=Q.columnDef,{classes:Ae,style:Pe}=bt(V),ue=y.sortBy===V.columnId?y.sortDirection==="asc"?"ascending":"descending":void 0;return h("th",{key:V.columnId,scope:"col","data-column-id":V.columnId,rowSpan:pe.length>1?pe.length-M:void 0,class:Ae,style:Pe,"aria-sort":ue,onPointerdown:ee=>v(V.columnId,ee)},[h("div",{class:"ogrid-header-content"},[h(e.ColumnHeaderFilter,getHeaderFilterConfig(V,at)),h("button",{onClick:ee=>{ee.stopPropagation(),F.isOpen&&F.openForColumn===V.columnId?F.close():F.open(V.columnId,ee.currentTarget);},"aria-label":"Column options",title:"Column options",class:"ogrid-column-menu-btn"},"\u22EE")]),h("div",{onPointerdown:ee=>{Ve(null),Se(null),l.value?.focus({preventScroll:true}),ee.stopPropagation(),h$1(ee,V);},onDblclick:ee=>E(ee,V),class:"ogrid-resize-handle",role:"separator","aria-label":`Resize ${V.name??V.columnId}`})])})]))]),...Ct?[]:[h("tbody",{},(()=>{let K=p.value,M=u.value,Q=K?M.startIndex:0,oe=K?Math.min(M.endIndex,Y.length-1):Y.length-1,V=[];K&&M.offsetTop>0&&V.push(h("tr",{key:"__vs-top",style:{height:`${M.offsetTop}px`}}));for(let Ae=Q;Ae<=oe;Ae++){let Pe=Y[Ae];if(!Pe)continue;let We=ie(Pe),ue=ve.has(We);V.push(h("tr",{key:We,"data-row-id":We,"aria-selected":ue||void 0,onClick:Pn,style:{cursor:ce==="single"?"pointer":void 0}},[...z?[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":Ae,"data-col-index":0,onClick:x,class:"ogrid-checkbox-wrapper"},e.renderCheckbox({modelValue:ue,ariaLabel:`Select row ${Ae+1}`,onChange:ee=>Te(We,ee,Ae,d.value)})))]:[],...G?[(()=>{let ee=R.columnSizingOverrides[ROW_NUMBER_COLUMN_ID]?.widthPx??ROW_NUMBER_COLUMN_WIDTH;return h("td",{class:"ogrid-row-number-cell",style:{width:`${ee}px`,minWidth:`${ee}px`,maxWidth:`${ee}px`,padding:"6px",position:"sticky",left:z?`${CHECKBOX_COLUMN_WIDTH}px`:"0",zIndex:2}},String(le+Ae+1))})()]:[],...ke>0?[h("td",{key:"__col-spacer-left",style:{width:`${ke}px`,minWidth:`${ke}px`,maxWidth:`${ke}px`,padding:"0"}})]:[],...Ne.map(ee=>h("td",{key:ee.col.columnId,"data-column-id":ee.col.columnId,class:ee.tdClasses,style:ee.tdDynamicStyle},[En(Pe,ee.col,Ae,Rt.get(ee.col.columnId)??0)])),...Re>0?[h("td",{key:"__col-spacer-right",style:{width:`${Re}px`,minWidth:`${Re}px`,maxWidth:`${Re}px`,padding:"0"}})]:[]]));}return K&&M.offsetBottom>0&&V.push(h("tr",{key:"__vs-bottom",style:{height:`${M.offsetBottom}px`}})),V})())]]),...Ct&&y.emptyState?[e.renderEmptyState(y.emptyState)]:[]])])])]),...fe?[h(Teleport,{to:"body"},h(e.GridContextMenu,{x:fe.x,y:fe.y,hasSelection:Xe,canUndo:Be,canRedo:rt,onUndo:Qe??No,onRedo:ft??No,onCopy:Ze,onCut:Je,onPaste:()=>{ze();},onSelectAll:se,onClose:vt}))]:[],h(On,{containerRef:i,selectionRange:xe,copyRange:mt,cutRange:ct,colOffset:H,items:Y,visibleColumns:y.visibleColumns instanceof Set?Array.from(y.visibleColumns):y.visibleColumns,columnSizingOverrides:R.columnSizingOverrides,columnOrder:y.columnOrder}),...y.formulaReferences&&y.formulaReferences.length>0?[h(Bn,{containerEl:i.value,references:y.formulaReferences,colOffset:H})]:[],h(e.ColumnHeaderMenu,{isOpen:F.isOpen,anchorElement:F.anchorElement,onClose:F.close,onPinLeft:F.handlePinLeft,onPinRight:F.handlePinRight,onUnpin:F.handleUnpin,onSortAsc:F.handleSortAsc,onSortDesc:F.handleSortDesc,onClearSort:F.handleClearSort,onAutosizeThis:F.handleAutosizeThis,onAutosizeAll:F.handleAutosizeAll,canPinLeft:F.canPinLeft,canPinRight:F.canPinRight,canUnpin:F.canUnpin,currentSort:F.currentSort,isSortable:F.isSortable,isResizable:F.isResizable}),...Ge?[h(Mn,{totalCount:Ge.totalCount,filteredCount:Ge.filteredCount,selectedCount:Ge.selectedCount??ve.size,selectedCellCount:xe?(Math.abs(xe.endRow-xe.startRow)+1)*(Math.abs(xe.endCol-xe.startCol)+1):void 0,aggregation:Ge.aggregation,suppressRowCount:Ge.suppressRowCount})]:[],...Ce?[h("div",{class:"ogrid-loading-overlay"},e.renderSpinner(ye))]:[]])}}})}var St={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 Wa(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=R=>{d.value=R.target.value;},v=R=>R?.target?.value??String(d.value??""),c=R=>{if(n.editorType==="date"){let b=n.column.cellEditorParams?.dateFormat??n.column.dateFormat??DEFAULT_DATE_FORMAT;if((n.column.cellEditorParams?.editorType??"text")==="native"){if(R==null){d.value="";return}let C=String(R);d.value=C.match(/^\d{4}-\d{2}-\d{2}/)?C.substring(0,10):C;return}d.value=formatDateForDisplay(R,b)??"";return}d.value=R;};c(n.value);let u=R=>{s.value=true,n.onCommit(R);},g=()=>{s.value=true,n.onCancel();},r=()=>s.value?(s.value=false,true):false,p=()=>{let R=i.value,b=m.value;if(!R||!b)return;let L=R.getBoundingClientRect(),C=200,w=window.innerHeight-L.bottom,I=w<C&&L.top>w;b.style.position="fixed",b.style.left=`${L.left}px`,b.style.width=`${L.width}px`,b.style.maxHeight=`${C}px`,b.style.zIndex="9999",b.style.right="auto",b.style.textAlign="left",I?(b.style.top="auto",b.style.bottom=`${window.innerHeight-L.top}px`):b.style.top=`${L.bottom}px`;},h$1=null,E=null;onMounted(()=>{let R=b=>{b.key==="Escape"&&(b.preventDefault(),b.stopPropagation(),g());};document.addEventListener("keydown",R,true),E=()=>{document.removeEventListener("keydown",R,true);},nextTick(()=>{if(i.value){n.editorType==="richSelect"&&D.value?D.value.focus({preventScroll:true}):i.value.focus({preventScroll:true}),p();let b=i.value,L=b.closest("[data-ogrid-scroll-container]")??b.closest('[style*="overflow"]'),C=()=>{n.onCancel&&n.onCancel();},w=requestAnimationFrame(()=>{L&&L.addEventListener("scroll",C,{passive:true}),window.addEventListener("scroll",C,{passive:true});});h$1=()=>{cancelAnimationFrame(w),L&&L.removeEventListener("scroll",C),window.removeEventListener("scroll",C);};return}l.value?.focus({preventScroll:true}),l.value?.select();});}),onUnmounted(()=>{h$1?.(),E?.();}),watch(()=>n.value,c),(()=>{let b=(n.column.cellEditorParams?.values??[]).findIndex(L=>String(L)===String(n.value));a.value=Math.max(b,0);})();let S=()=>{nextTick(()=>{let R=m.value;if(!R)return;R.children[a.value]?.scrollIntoView({block:"nearest"});});},A=R=>{let b=n.column.cellEditorParams?.formatValue;return b?b(R):R!=null?String(R):""},_=R=>{let b=n.column.cellEditorParams?.values??[];switch(R.key){case "ArrowDown":R.preventDefault(),a.value=Math.min(a.value+1,b.length-1),S();break;case "ArrowUp":R.preventDefault(),a.value=Math.max(a.value-1,0),S();break;case "Enter":R.preventDefault(),R.stopPropagation(),b.length>0&&a.value<b.length&&u(b[a.value]);break;case "Tab":R.preventDefault(),b.length>0&&a.value<b.length&&u(b[a.value]);break;case "Escape":R.preventDefault(),R.stopPropagation(),g();break}},q=ref(""),D=ref(null),x=ref(null),P=computed(()=>{let R=n.column.cellEditorParams?.values??[],b=q.value.trim().toLowerCase();return b?R.filter(L=>A(L).toLowerCase().includes(b)):R}),k=()=>{nextTick(()=>{let R=x.value;if(!R)return;R.children[a.value]?.scrollIntoView({block:"nearest"});});},y=R=>{let b=P.value;switch(R.key){case "ArrowDown":R.preventDefault(),a.value=Math.min(a.value+1,b.length-1),k();break;case "ArrowUp":R.preventDefault(),a.value=Math.max(a.value-1,0),k();break;case "Enter":R.preventDefault(),R.stopPropagation(),b.length>0&&a.value<b.length&&u(b[a.value]);break;case "Escape":R.preventDefault(),R.stopPropagation(),g();break}};return ()=>{if(n.editorType==="checkbox"){let R=!!n.value;return h("div",{style:{...St,justifyContent:"center"}},o({checked:R,onChange:b=>u(b),onCancel:g}))}if(n.editorType==="select"){let R=n.column.cellEditorParams?.values??[];return h("div",{ref:b=>{i.value=b;},tabindex:0,style:{...St,position:"relative"},onKeydown:_},[h("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",width:"100%",cursor:"pointer",fontSize:"13px",color:"inherit"}},[h("span",A(n.value)),h("span",{style:{marginLeft:"4px",fontSize:"10px",opacity:"0.5"}},"\u25BE")]),h("div",{ref:b=>{m.value=b;},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"}},[...R.map((b,L)=>h("div",{key:String(b),role:"option","aria-selected":L===a.value,onClick:()=>u(b),style:{padding:"6px 8px",cursor:"pointer",color:"var(--ogrid-fg, #242424)",fontSize:"13px",...L===a.value?{background:"var(--ogrid-bg-hover, #e8f0fe)"}:{}}},A(b)))])])}if(n.editorType==="richSelect"){let R=P.value;return h("div",{ref:b=>{i.value=b;},style:{...St,position:"relative"}},[h("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",width:"100%",cursor:"pointer",fontSize:"13px",color:"inherit"}},[h("span",A(n.value)),h("span",{style:{marginLeft:"4px",fontSize:"10px",opacity:"0.5"}},"\u25BE")]),h("div",{ref:b=>{m.value=b;},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:b=>{D.value=b;},type:"text",value:q.value,placeholder:"Search...",onInput:b=>{q.value=b.target.value,a.value=0;},onKeydown:y,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:b=>{x.value=b;}},R.map((b,L)=>h("div",{key:String(b),role:"option","aria-selected":L===a.value,onClick:()=>u(b),style:{padding:"6px 8px",cursor:"pointer",color:"var(--ogrid-fg, #242424)",fontSize:"13px",...L===a.value?{background:"var(--ogrid-bg-hover, #e8f0fe)"}:{}}},A(b)))),...R.length===0?[h("div",{style:{padding:"6px 8px",color:"var(--ogrid-muted, #999)",fontSize:"13px"}},"No matches")]:[]])])}if(n.editorType==="date"){let R=n.column.cellEditorParams?.dateFormat??n.column.dateFormat??DEFAULT_DATE_FORMAT,b=n.column.cellEditorParams?.editorType??"text",L=I=>{if(b!=="native"){let O=parseUserInputDate(I,R);if(O!==null){let F=O.getUTCFullYear().toString().padStart(4,"0"),B=(O.getUTCMonth()+1).toString().padStart(2,"0"),z=O.getUTCDate().toString().padStart(2,"0");u(`${F}-${B}-${z}`);}else u(I||null);}else u(I);},C=I=>{I.stopPropagation(),I.key==="Enter"&&(I.preventDefault(),L(v(I))),I.key==="Escape"&&(I.preventDefault(),g()),I.key==="Tab"&&(I.preventDefault(),L(v(I)));};if(b==="native"){let I=(()=>{if(d.value==null)return "";let O=String(d.value);return O.match(/^\d{4}-\d{2}-\d{2}/)?O.substring(0,10):O})();return h("div",{style:St},h("input",{ref:O=>{l.value=O;},type:"date",value:I,style:{width:"100%",height:"100%",border:"none",outline:"none",padding:"0 4px",fontSize:"inherit",boxSizing:"border-box"},onInput:f,onChange:f,onKeyup:f,onKeydown:C,onBlur:O=>{r()||L(v(O));}}))}let w=getDateInputPlaceholder(R);return h("div",{style:St},h("input",{ref:I=>{l.value=I;},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:f,onChange:f,onKeyup:f,onKeydown:C,onBlur:I=>{r()||L(v(I));}}))}return h("div",{style:St},h("input",{ref:R=>{l.value=R;},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:R=>{R.stopPropagation(),R.key==="Enter"&&(R.preventDefault(),u(v(R))),R.key==="Escape"&&(R.preventDefault(),g()),R.key==="Tab"&&(R.preventDefault(),u(v(R)));},onBlur:R=>{r()||u(v(R));}}))}}})}var ja=240,Zn=36,xn={columns:"Columns",filters:"Filters"},Ya={columns:"\u2261",filters:"\u2A65"};function _o(e){let o=e.activePanel!==null,n=e.position??"right",l={display:"flex",flexDirection:"column",width:`${Zn}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":xn[a],title:xn[a],onClick:()=>e.onPanelChange(e.activePanel===a?null:a),style:{width:`${Zn}px`,height:`${Zn}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"}},Ya[a]))),m=null;if(o&&e.activePanel){let a={width:`${ja}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:E=>{let T=e.filters[v],S=T?.type==="multiSelect"?T.value:[],A=E.target.checked?[...S,r]:S.filter(_=>_!==r);e.onFilterChange(v,A.length>0?{type:"multiSelect",value:A}: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":xn[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,xn[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 Za(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}=zt(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 E=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,T=d.value.placement==="toolbar"?h(e.ColumnChooser,{columns:d.value.columns,visibleColumns:d.value.visibleColumns,onVisibilityChange:d.value.onVisibilityChange}):null,S=h(e.PaginationControls,{currentPage:m.value.page,pageSize:m.value.pageSize,totalCount:m.value.displayTotalCount,onPageChange:m.value.setPage,onPageSizeChange:P=>{m.value.setPageSize(P);},pageSizeOptions:m.value.pageSizeOptions,entityLabelPlural:m.value.entityLabelPlural}),A=h("div",{style:{flex:"1",minWidth:"0",minHeight:"0",display:"flex",flexDirection:"column"}},[h(e.DataGridTable,{gridProps:i.value})]),_=[];g&&r==="left"&&_.push(_o(u)),_.push(A),g&&r!=="left"&&_.push(_o(u));let q=p.length>0||T!=null||E!=null,D=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:D},[h("div",{style:x??{}},[...q?[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"}},[...T?[T]:[],...E?[E]:[]])])]:[],...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"}},_),...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))"}},[S])])])}}})}export{kn as FormulaBar,Bn as FormulaRefOverlay,On as MarchingAntsOverlay,Ln as SheetTabs,Mn as StatusBar,ka as createDataGridTable,Wa as createInlineCellEditor,Za as createOGrid,Cn as getCellInteractionProps,Wt as useActiveCell,Nt as useCellEditing,_t as useCellSelection,$t as useClipboard,Bo as useColumnChooserState,Ao as useColumnHeaderFilterState,en as useColumnHeaderMenuState,Jt as useColumnPinning,mn as useColumnReorder,on as useColumnResize,Kt as useContextMenu,nn as useDataGridState,gn as useDataGridTableSetup,dn as useDateFilterState,ln as useDebounce,Fo as useDebouncedCallback,jt as useFillHandle,Bt as useFilterOptions,Ht as useFormulaBar,Ho as useInlineCellEditorState,qt as useKeyboardNavigation,an as useMultiSelectFilterState,zt as useOGrid,un as usePeopleFilterState,zo as useRichSelectState,Gt as useRowSelection,Tt as useSideBarState,Zt as useTableLayout,rn as useTextFilterState,Yt as useUndoRedo,pn as useVirtualScroll};
@@ -3,6 +3,7 @@ import type { ICellValueChangedEvent } from '../types';
3
3
  export interface UseUndoRedoParams<T> {
4
4
  onCellValueChanged: ((event: ICellValueChangedEvent<T>) => void) | undefined;
5
5
  maxUndoDepth?: number;
6
+ afterChange?: () => void;
6
7
  }
7
8
  export interface UseUndoRedoResult<T> {
8
9
  onCellValueChanged: ((event: ICellValueChangedEvent<T>) => void) | undefined;
@@ -27,6 +27,8 @@ interface IOGridBaseProps<T> {
27
27
  onColumnOrderChange?: (order: string[]) => void;
28
28
  /** Called when a column is resized by the user. */
29
29
  onColumnResized?: (columnId: string, width: number) => void;
30
+ /** Called when user requests autosize for a single column (with measured width). */
31
+ onAutosizeColumn?: (columnId: string, width: number) => void;
30
32
  /** Called when a column is pinned or unpinned. */
31
33
  onColumnPinned?: (columnId: string, pinned: 'left' | 'right' | null) => void;
32
34
  editable?: boolean;
@@ -90,8 +92,14 @@ interface IOGridBaseProps<T> {
90
92
  responsiveColumns?: boolean | IResponsiveColumnsConfig;
91
93
  /** Virtual scrolling configuration. Set `enabled: true` with a fixed `rowHeight` to virtualize large datasets. */
92
94
  virtualScroll?: IVirtualScrollConfig;
93
- /** Offload sort/filter to a Web Worker for large datasets. Falls back to sync when sort column has a custom compare. */
94
- workerSort?: boolean;
95
+ /**
96
+ * Offload sort/filter to a Web Worker for large datasets.
97
+ * - `true`: always use worker sort
98
+ * - `'auto'`: use worker sort when data.length > 5000
99
+ * - `false` (default): use synchronous sort
100
+ * Falls back to sync when the sort column has a custom compare.
101
+ */
102
+ workerSort?: boolean | 'auto';
95
103
  /** Fixed row height in pixels. Overrides default row height (36px). */
96
104
  rowHeight?: number;
97
105
  /** Cell spacing/density preset. Controls cell padding throughout the grid. Default: 'normal'. */
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alaarab/ogrid-vue",
3
- "version": "2.5.9",
3
+ "version": "2.6.1",
4
4
  "description": "OGrid Vue – Vue 3 composables, headless components, and utilities for OGrid data grids.",
5
5
  "main": "dist/esm/index.js",
6
6
  "module": "dist/esm/index.js",
@@ -36,7 +36,7 @@
36
36
  "node": ">=18"
37
37
  },
38
38
  "dependencies": {
39
- "@alaarab/ogrid-core": "2.5.9"
39
+ "@alaarab/ogrid-core": "2.6.1"
40
40
  },
41
41
  "peerDependencies": {
42
42
  "vue": "^3.3.0"