@progress/kendo-react-grid 10.2.0-develop.1 → 10.2.0-develop.3

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.
@@ -6,4 +6,4 @@
6
6
  *-------------------------------------------------------------------------------------------
7
7
  */
8
8
  "use client";
9
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const xt=require("react"),b=require("@progress/kendo-react-common"),l=require("@progress/kendo-react-data-tools"),St=require("./drag/ColumnResize.js"),Dt=require("./drag/CommonDragLogic.js"),kt=require("./constants/index.js"),w=require("./utils/index.js"),Me=require("./VirtualScrollFixed.js"),Kt=require("./VirtualScroll.js"),Mt=require("./contextMenu/GridContextMenu.js"),Te=require("./contextMenu/enums.js"),Ae=require("./sortCommon.js");function Tt(t){const v=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(t){for(const m in t)if(m!=="default"){const H=Object.getOwnPropertyDescriptor(t,m);Object.defineProperty(v,m,H.get?H:{enumerable:!0,get:()=>t[m]})}}return v.default=t,Object.freeze(v)}const i=Tt(xt),He=i.createContext(void 0),At=t=>{var ke,Ke;const v=t.gridProps.isClient,[m,H]=i.useState({}),Fe=e=>{e.event.preventDefault(),H({...m,show:!0,offset:{left:e.event.pageX,top:e.event.pageY},dataItem:e.dataItem,field:e.field})},be=()=>{H({})},h=i.useMemo(()=>t.columnsRef.find(e=>e.field===m.field),[t.columnsRef,m]),he=i.useMemo(()=>{const e=t.gridProps.sortable&&(h==null?void 0:h.sortable);return w.getDefaultHeadContextMenuItems({sortable:!!e,selectable:l.getSelectionOptions(t.gridProps.selectable).enabled,clipboard:!!t.gridProps.clipboard})},[h,t.gridProps.sortable,t.gridProps.selectable,t.gridProps.clipboard]),Ie=i.useMemo(()=>{const e=t.gridProps.sortable&&(h==null?void 0:h.sortable);return w.getDefaultBodyContextMenuItems({sortable:!!e,selectable:l.getSelectionOptions(t.gridProps.selectable).enabled,clipboard:!!t.gridProps.clipboard,rowReorderable:w.isRowReorderEnabled(t.gridProps.rowReorderable)})},[h,t.gridProps.sortable,t.gridProps.selectable,t.gridProps.clipboard]),Ge=i.useMemo(()=>{const e=(h==null?void 0:h.contextMenu)||t.gridProps.contextMenu,n=typeof e=="function"?e(m):e;if(n&&m.offset){const r=m.dataItem?Te.GridContextMenuAnchorPart.body:Te.GridContextMenuAnchorPart.head,a=n[r],o=m.dataItem?Ie:he;return a===!1?void 0:a===!0||a===void 0?o:a}},[t.gridProps.contextMenu,m,Ie,he,h]),Le=e=>{var s,g,f,P,y,ee,C,U,V;const n=e.event.item,r={target:E.current,syntheticEvent:e.event.syntheticEvent,nativeEvent:e.event.nativeEvent,menuItem:n,...e};t.gridProps.onContextMenuItemClick&&u(t.gridProps.onContextMenuItemClick,r);const a=X(),o={selectedField:t.gridProps.selectedField||"",componentId:t.id,dataItems:a,dataItem:e.dataItem,startRowIndex:-1,endRowIndex:-1,startColIndex:-1,endColIndex:-1,ctrlKey:!1,altKey:!1,metaKey:!1,shiftKey:!1,isDrag:!1,...l.getSelectionOptions(t.gridProps.selectable),...r},c=a.findIndex(_=>_===e.dataItem);switch((s=n.data)==null?void 0:s.action){case"SortCommand":if(h){const _=(g=n.name)==null?void 0:g.toLowerCase().includes("asc"),Et=((f=n.name)==null?void 0:f.toLowerCase().includes("desc"))?"desc":void 0,yt=_?"asc":Et,wt=n.name?yt:void 0;Re(e.event.syntheticEvent,h,wt)}break;case"SelectRowCommand":pe(o);break;case"SelectAllRowsCommand":Ze(o);break;case"ClearSelectionCommand":et(o);break;case"ReorderRowCommand":q.current=e.dataItem,(P=n.name)!=null&&P.toLowerCase().includes("rowup")&&c>0&&G(e.event.syntheticEvent,c-1,"before"),(y=n.name)!=null&&y.toLowerCase().includes("rowdown")&&c<a.length-1&&G(e.event.syntheticEvent,c+1,"after"),(ee=n.name)!=null&&ee.toLowerCase().includes("rowtop")&&G(e.event.syntheticEvent,0,"before"),(C=n.name)!=null&&C.toLowerCase().includes("rowbottom")&&G(e.event.syntheticEvent,a.length-1,"after");break;case"CopySelectionCommand":$(l.ClipboardActionType.copy,e.event.nativeEvent,{copyHeaders:!((U=n.name)!=null&&U.toLowerCase().includes("noheaders"))},e.dataItem,e.field);break;case"PasteCommand":$(l.ClipboardActionType.paste,e.event.nativeEvent,{copyHeaders:!((V=n.name)!=null&&V.toLowerCase().includes("noheaders"))},e.dataItem,e.field);break}be()},B=()=>{const e=t.columnsRef.filter(n=>n.declarationIndex>=0&&n.parentIndex===-1);return w.sanitizeColumns(e)},Oe=(e,n,r)=>{if(t.gridProps.onContextMenu&&v){const a={target:E.current,syntheticEvent:e,nativeEvent:e.nativeEvent,dataItem:n,field:r};u(t.gridProps.onContextMenu,a)}t.gridProps.contextMenu&&Fe({event:e,dataItem:n,field:r})},ze=e=>{if(e.target!==e.currentTarget)return;clearTimeout(fe.current),d.current&&(d.current.table=k.current);const n=e.currentTarget.scrollLeft,r=e.currentTarget.scrollTop,a=t.gridProps.scrollable==="virtual";t.gridProps.columnVirtualization&&(!a||r===ge.current)&&(fe.current=window.setTimeout(()=>{ie()},0)),t.gridProps.scrollLeftRef&&(t.gridProps.scrollLeftRef.current=n),N.current&&N.current.setScrollLeft(n),z.current&&z.current.setScrollLeft(n),d.current&&r!==ge.current&&d.current.scrollHandler(e),t.gridProps.onScroll&&v&&u(t.gridProps.onScroll,{...I(e)}),ge.current=r},Ne=e=>{l.tableKeyboardNavigation.onKeyDown(e,{navigatable:t.gridProps.navigatable||!1,contextStateRef:D,navigationStateRef:M,onNavigationAction:Ue,columns:B()}),l.tableKeyboardNavigation.onGetSnapshotBeforeUpdate({document:x(),contextStateRef:D,navigationStateRef:M});const n={dataItems:L(),mode:R.mode,cell:R.cell,componentId:t.id,selectedField:t.gridProps.selectedField,...I(e)};t.gridProps.onKeyDown&&v&&u(t.gridProps.onKeyDown,n)},qe=e=>{l.tableKeyboardNavigation.onFocus(e,{navigatable:!!t.gridProps.navigatable,contextStateRef:D})},Ue=e=>{if(e.action==="moveToNextPage"&&nt(e.event),e.action==="moveToPrevPage"&&rt(e.event),e.focusElement&&e.action==="reorderToRight"){const n=parseInt(e.focusElement.ariaColIndex,10)-1;n<t.columnsRef.length-1&&re(n,n+1,e.event)}if(e.focusElement&&e.action==="reorderToLeft"){const n=parseInt(e.focusElement.ariaColIndex,10)-1;n>0&&re(n,n-1,e.event)}if(e.action==="select"&&Je(e.event),t.gridProps.onNavigationAction&&v){const n={focusElement:e.focusElement,...I(e.event)};u(t.gridProps.onNavigationAction,n)}},Ve=(e,n)=>{t.gridProps.onRowClick&&e.target.nodeName==="TD"&&u(t.gridProps.onRowClick,{dataItem:n,...I(e)})},_e=(e,n)=>{t.gridProps.onRowDoubleClick&&e.target.nodeName==="TD"&&u(t.gridProps.onRowDoubleClick,{dataItem:n,...I(e)})},Be=(e,n,r)=>{if(Se.enabled&&Se.mode==="incell"&&t.gridProps.dataItemKey){const a=l.editReducer(t.gridProps.edit,{type:l.EDIT_ACTION.ENTER_FIELD_EDIT,payload:{id:n[t.gridProps.dataItemKey],field:r}});t.gridProps.onEditChange&&u(t.gridProps.onEditChange,{edit:a,...I(e)})}},je=(e,n)=>{var a;if(l.getDetailExpandableOptions(t.detailExpandable).enabled){const o=l.detailExpandReducer((a=t.gridProps.detailExpand)!=null?a:{},e);t.gridProps.onDetailExpandChange&&u(t.gridProps.onDetailExpandChange,{...I(n),detailExpand:o})}},We=(e,n)=>{var a;const r=l.getGroupExpandableOptions(typeof t.gridProps.groupable=="object"?t.gridProps.groupable.expandable!==!1:t.gridProps.groupable);if(r.enabled){const o=l.groupExpandReducer((a=t.gridProps.groupExpand)!=null?a:[],e,r);t.gridProps.onGroupExpandChange&&u(t.gridProps.onGroupExpandChange,{...I(n),groupExpand:o})}},Re=(e,n,r)=>{const{allowUnsort:a,mode:o}=Ae.normalizeSortable(t.gridProps.sortable||!1,n.sortable||!1),c=(t.gridProps.sort||[]).filter(f=>f.field===n.field)[0],s=r||Ae.firstLevelSortSeqMap[a][c&&c.dir||""],g=o==="single"?[]:(t.gridProps.sort||[]).filter(f=>f.field!==n.field);s!==""&&n.field&&g.push({field:n.field,dir:s}),Ce(g,e)},$e=e=>{var n;if(e.field===t.gridProps.expandField||e._expand||t.gridProps.group&&e.field===void 0){if(t.gridProps.onExpandChange){const r=t.gridProps.dataItemKey?l.detailExpandReducer((n=t.gridProps.detailExpand)!=null?n:{},{type:l.DETAIL_EXPAND_ACTION.SET,id:e.dataItem[t.gridProps.dataItemKey],payload:e.value}):t.gridProps.detailExpand;u(t.gridProps.onExpandChange,{...I(e.syntheticEvent),expand:r,dataItem:e.dataItem,dataIndex:e.dataIndex,value:e.value})}return}t.gridProps.onItemChange&&u(t.gridProps.onItemChange,{...I(e.syntheticEvent),dataItem:e.dataItem,dataIndex:e.dataIndex,field:e.field,value:e.value})},Xe=e=>{var n;if(t.gridProps.onSelectionChange&&R.enabled){const{event:r,dataItem:a,dataIndex:o,columnIndex:c}=e,s={...I(r.syntheticEvent),dataItem:a,startColIndex:c,endColIndex:c,startRowIndex:o,endRowIndex:o,dataItems:L(),altKey:!1,ctrlKey:!1,shiftKey:!1,metaKey:!1,mode:R.mode,cell:R.cell,isDrag:!1,componentId:t.id,selectedField:t.gridProps.selectedField||""};u(t.gridProps.onSelectionChange,{...s,select:t.gridProps.dataItemKey?l.getSelectedState({event:s,selectedState:(n=t.gridProps.select)!=null?n:{},dataItemKey:t.gridProps.dataItemKey}):{}})}},Je=e=>{var f,P;if(t.gridProps.selectedField||!R.enabled||!t.gridProps.dataItemKey)return;const n={dataItems:L(),mode:R.mode,cell:R.cell,componentId:t.id,selectedField:t.gridProps.selectedField,...I(e)},r=l.getSelectedStateFromKeyDown({event:n,selectedState:(f=t.gridProps.select)!=null?f:{},dataItemKey:t.gridProps.dataItemKey});if(r===t.gridProps.select)return;const a=e.target,o=l.closestTagName(a,"TD"),c=l.closestTagName(a,"TR"),s=l.getColumnIndex(o),g=l.getRowIndex(c);if(s!==void 0&&g!==void 0){const y=(P=w.getDataAsArray(t.gridProps.data))==null?void 0:P[g];t.gridProps.onSelectionChange&&u(t.gridProps.onSelectionChange,{...n,select:r,dataItem:y,startRowIndex:g,startColIndex:s,startDataItem:y,endDataItem:y,endRowIndex:g,endColIndex:s,ctrlKey:e.ctrlKey,altKey:e.altKey,metaKey:e.metaKey,shiftKey:e.shiftKey,isDrag:!1})}},Ye=e=>{var n;if(t.gridProps.onHeaderSelectionChange&&R.enabled){const r=L();u(t.gridProps.onHeaderSelectionChange,{select:e.syntheticEvent.target.checked?r.reduce((a,o)=>(t.gridProps.dataItemKey&&b.getter(t.gridProps.dataItemKey)(o)!==void 0&&(a[b.getter(t.gridProps.dataItemKey)(o)]=!0),a),{}):{},field:e.field,nativeEvent:e.syntheticEvent&&e.syntheticEvent.nativeEvent,syntheticEvent:e.syntheticEvent,target:E.current,dataItems:r,selectedField:(n=t.gridProps.selectedField)!=null?n:""})}},j=(e,n)=>{t.gridProps.onSelectionChange&&R.enabled&&u(t.gridProps.onSelectionChange,{...e,select:n})},Qe=e=>{var n;if(t.gridProps.onSelectionChange&&R.enabled){const r=X()[e.startRowIndex],a=X()[e.endRowIndex],o={syntheticEvent:void 0,target:E.current,selectedField:t.gridProps.selectedField||"",componentId:t.id,dataItems:L(),dataItem:null,startDataItem:r,endDataItem:a,...e},c=l.getSelectedState({event:o,selectedState:(n=t.gridProps.select)!=null?n:{},dataItemKey:t.gridProps.dataItemKey});j(o,c)}},Ze=e=>{if(t.gridProps.onSelectionChange&&R.enabled){const n=e.dataItems[0],r=e.dataItems[e.dataItems.length-1],a={},o={...e,startDataItem:n,endDataItem:r,startRowIndex:0,endRowIndex:e.dataItems.length-1,startColIndex:0,endColIndex:t.columnsRef.length-1};e.dataItems.forEach(c=>{const g=b.getter(t.gridProps.dataItemKey)(c);a[g]=e.cell?[...Array(t.columnsRef.length).keys()]:!0}),j(o,a)}},pe=e=>{if(t.gridProps.onSelectionChange&&R.enabled){const r=b.getter(t.gridProps.dataItemKey)(e.dataItem),a=0,o=t.columnsRef.length-1,c=e.dataItems.findIndex(y=>y[t.gridProps.dataItemKey]===e.dataItem[t.gridProps.dataItemKey]),f={...e,startDataItem:c,endDataItem:c,startRowIndex:c,endRowIndex:c,startColIndex:a,endColIndex:o},P=e.mode==="multiple"?t.gridProps.select||{}:{};P[r]===!0||Array.isArray(P[r])&&P[r].length===t.columnsRef.length?delete P[r]:P[r]=e.cell?[...Array(t.columnsRef.length).keys()]:!0,j(f,P)}},et=e=>{t.gridProps.onSelectionChange&&R.enabled&&j(e,{})},F=(e,n,r,a,o)=>{const c=t.gridProps.onDataStateChange;if(e){const s={...I(a),...n,targetEvent:o};u(e,s)}else c&&u(c,{...I(a),targetEvent:o||{},dataState:{...ut(),...r}})},W=(e,n,r)=>{F(t.gridProps.onPageChange,{page:e},{skip:e.skip,take:e.take},n,r)},tt=()=>{let e=t.gridProps.total||0;return Array.isArray(t.gridProps.data)?e=e||t.gridProps.data.length:t.gridProps.data&&(e=e||t.gridProps.data.total),e},nt=e=>{var o,c;const n=(c=(o=t.gridProps.take)!=null?o:t.gridProps.pageSize)!=null?c:0,r=(t.gridProps.skip||0)+n,a=tt();r<a&&W({skip:r,take:n},e)},rt=e=>{var a,o;const n=(o=(a=t.gridProps.take)!=null?a:t.gridProps.pageSize)!=null?o:0,r=(t.gridProps.skip||0)-n;r>=0&&W({skip:r,take:n},e)},at=e=>{W({skip:e.skip,take:e.take},e.syntheticEvent,e.targetEvent)},Ce=(e,n)=>{F(t.gridProps.onSortChange,{sort:e},{sort:e,...t.gridProps.scrollable==="virtual"?{skip:0}:{}},n)},ot=(e,n)=>{F(t.gridProps.onFilterChange,{filter:e},{filter:e||void 0,skip:0},n)},it=e=>{const n=t.gridProps.searchFields||t.columnsRef.map(o=>o.field)||[],r=e.nativeEvent.target.value,a={logic:"or",filters:n.filter(o=>o!==void 0).map(o=>{var c;return typeof o=="string"?{field:o,value:r,operator:"contains"}:{value:r,operator:(c=o.operator)!=null?c:"contains",field:o.field,ignoreCase:o.ignoreCase}})};F(t.gridProps.onSearchChange,{search:a},{},e.syntheticEvent)},te=(e,n)=>{const r=n.nativeEvent?n:{nativeEvent:n.nativeEvent||n.originalEvent};e.length===0&&t.gridProps.navigatable&&(le.current=!0),F(t.gridProps.onGroupChange,{group:e},{group:e,skip:0},r)},ne=e=>{if(t.gridProps.onColumnsStateChange){const n={target:E.current,columnsState:e};u(t.gridProps.onColumnsStateChange,n)}},re=(e,n,r)=>{const{columnsRef:a,columnsState:o}=t,c=a[e],s=w.getFlatColumnsState(o),g=c.depth,f=C=>{do C++;while(C<a.length&&a[C].depth>g);return C},P=a.splice(e,f(e)-e);a.splice(e<n?f(n-P.length):n,0,...P),a.filter(C=>C.declarationIndex>=0).forEach((C,U)=>{C.orderIndex=U;const V=s.find(_=>_.id===C.id);V&&(V.orderIndex=U)});const y=a[e].locked&&a[n].locked;l.updateLeft(t.columnsMapRef,a,y||p.current),l.updateRight(t.columnsMapRef,a,y||p.current),de.current&&(p.current=!1,de.current=!1);const ee=B();if(ie(),t.gridProps.onColumnReorder){const C={target:E.current,columns:ee,columnId:c.id,nativeEvent:r};u(t.gridProps.onColumnReorder,C)}ne(o)},G=(e,n,r)=>{const a=typeof t.gridProps.rowReorderable=="object"?t.gridProps.rowReorderable.enabled:t.gridProps.rowReorderable;if(r==="forbidden"||!a||!q.current)return;const{slicedData:o,dataRef:c}=t,s=(o||c)[n];t.gridProps.onRowReorder&&u(t.gridProps.onRowReorder,{draggedDataItems:[q.current],droppedDataItem:s==null?void 0:s.dataItem,dropPosition:r,nativeEvent:e.originalEvent,dragEvent:e,target:E.current}),q.current=null},ct=(e,n,r)=>{if(t.gridProps.group===void 0)return;const a=t.gridProps.group.slice();a.splice(n,0,...a.splice(e,1)),te(a,r)},ve=(e,n,r)=>{const a=t.columnsRef[e].field;if(!a)return;const o=(t.gridProps.group||[]).slice();o.splice(n,0,{field:a}),te(o,r)},dt=(e,n)=>{const r=K.current.getCurrentGroupsLength;ve(e,r,n)},ae=()=>{let e=0;if(!S.current.colGroupMain)return;const n=S.current.colGroupMain.children;for(let r=0;r<n.length;r++){const a=n[r].width;if(!a){e=0;break}e+=parseFloat(a.toString())}e=Math.round(e),N.current&&N.current.setWidth(e),z.current&&z.current.setWidth(e),k.current&&(k.current.style.width=e?e+"px":"")},$=i.useCallback((e,n,r,a,o)=>{var f;if(!lt()&&!r||!e)return;const c={type:e,nativeEvent:n,columns:t.columnsRef,dataItemKey:t.gridProps.dataItemKey||"",dataItem:a,field:o,...typeof t.gridProps.clipboard!="boolean"?t.gridProps.clipboard:{},...r},s=X(),g=l.populateClipboardData({event:c,data:s,selectedState:(f=t.gridProps.select)!=null?f:{},previousCopiedItems:we.current});e!==l.ClipboardActionType.paste&&(we.current=g.copiedItems),t.gridProps.onClipboard&&v&&u(t.gridProps.onClipboard,{...c,...g})},[t.gridProps.select,t.gridProps.dataItemKey,t.gridProps.data,t.gridProps.clipboard,t.gridProps.onClipboard]),lt=()=>{var o,c,s;if(!b.canUseDOM)return!1;const e=b.getActiveElement(x()),n=e?e.matches(".k-table-td")?e:(o=x())==null?void 0:o.body:(c=x())==null?void 0:c.body,r=n.closest(".k-grid-container"),a=n&&((s=A.current)==null?void 0:s.contains(n));return!!(n&&a&&r)},st=(e,n,r,a,o,c,s)=>{ae(),p.current=!0,de.current=!0,t.gridProps.onColumnResize&&v&&u(t.gridProps.onColumnResize,{columns:B(),nativeEvent:a,targetColumnId:s,index:e,newWidth:n,oldWidth:r,end:o,target:E.current}),o&&ne(c)},ut=()=>{var e;return{filter:t.gridProps.filter,sort:t.gridProps.sort,skip:t.gridProps.skip,take:(e=t.gridProps.take)!=null?e:t.gridProps.pageSize,group:t.gridProps.group}},I=e=>({nativeEvent:e&&e.nativeEvent,syntheticEvent:e,target:E.current}),gt=e=>({...e,nativeEvent:void 0,syntheticEvent:void 0,target:void 0,targetEvent:void 0,focusElement:void 0}),u=(e,n)=>{if(t.gridProps.isClient){e(n);return}e(gt(n))},ft=()=>{var e,n,r;if(O.current&&((e=O.current)==null?void 0:e.getElementsByClassName("k-grid-edit-row").length)>0){ue.current=!1,(n=document.activeElement)!=null&&n.closest(".k-grid-edit-row")?se.current=document.activeElement:se.current=void 0;const a=Array.from((r=O.current)==null?void 0:r.getElementsByClassName("k-grid-edit-row"));a.length>Pe.current.length?Z.current=a.filter(o=>!Pe.current.includes(o))[0]:a.length===1&&(Z.current=a[0],ue.current=!0),Pe.current=a}},L=()=>t.dataRef.filter(e=>e.rowType==="data").map(e=>e.dataItem),X=()=>(t.slicedData||t.dataRef).filter(e=>e.rowType==="data").map(e=>e.dataItem),x=()=>{var e;if(b.canUseDOM)return((e=J())==null?void 0:e.ownerDocument)||document},J=()=>A.current,oe=i.useCallback(e=>{var a;if(!d.current||!((a=d.current)!=null&&a.container)||t.gridProps.scrollable==="none")return;T.current&&T.current.disconnect();const{rowIndex:n}=e,r=J();if(t.gridProps.scrollable==="virtual")d.current.askedSkip=n,d.current.container.scroll(0,Math.round(d.current.askedSkip/d.current.total*d.current.container.scrollHeight));else if(r){const o=n<1?r.querySelector("tbody > tr:nth-child(1)"):r.querySelector(`tbody > tr:nth-child(${n+1})`);o&&Q.current&&(Q.current.scrollTop=o.offsetTop)}},[t.gridProps.scrollable]),Ee=e=>JSON.stringify(e.map(n=>({id:n.id,field:n.field,title:n.title,children:n.children}))),mt=()=>Ee(vt)===Ee(t.columnsRef),Pt=()=>{mt()||ie()},bt=(e,n)=>{var r,a;if(d.current){if(d.current.fixedScroll=t.gridProps.fixedScroll||!1,d.current.PageChange=W,d.current.realSkip=t.gridProps.skip||0,d.current.pageSize=(a=(r=t.gridProps.take)!=null?r:t.gridProps.pageSize)!=null?a:0,d.current.scrollableVirtual=t.gridProps.scrollable==="virtual",d.current.total=e,d.current.propsSkip=(t.gridProps.skip||0)+(t.gridProps.scrollable==="virtual"?d.current.topCacheCount+(d.current.attendedSkip-(t.gridProps.skip||0)):0),t.gridProps.rowHeight!==void 0&&t.gridProps.rowHeight>0&&!n){const o=t.gridProps.rowHeight*e;d.current.containerHeight=w.firefox?Math.min(w.firefoxMaxHeight,o):o}else d.current.containerHeight=1533915;if(d.current.containerRef=Q,d.current.tableBodyRef=O,d.current.table=k.current,d.current instanceof Me.VirtualScrollFixed){const{rowHeight:o=0,detail:c,expandField:s}=t.gridProps;let{detailRowHeight:g=0}=t.gridProps;g=c&&s?g:o,t.isAllData?(d.current.total=t.dataRef.length,d.current.rowHeightService=new b.RowHeightService(t.dataRef.length,o,g,t.dataRef)):d.current.rowHeightService=new b.RowHeightService(e,o,g);const f=d.current.rowHeightService.totalHeight();d.current.containerHeight=w.firefox?Math.min(w.firefoxMaxHeight,f):f}}},ye=i.useCallback(e=>{const n={rowIndex:me.current};e.forEach(r=>{r.isIntersecting||oe(n)})},[oe]),ie=()=>{t.gridProps.forceUpdate&&t.gridProps.forceUpdate()},ht=e=>e.left!==void 0?xe!=="rtl"?{left:e.left,right:e.right}:{left:e.right,right:e.left}:{},E=i.useRef(null),d=i.useRef(),S=i.useRef(),K=i.useRef(),D=i.useRef(),M=i.useRef(),Y=i.useRef(),T=i.useRef(null),O=i.useRef(null),It=i.useRef(null),Q=i.useRef(null),k=i.useRef(null),ce=i.useRef(null),A=i.useRef(null),z=i.useRef(null),N=i.useRef(null),de=i.useRef(!1),le=i.useRef(!1),Z=i.useRef(),se=i.useRef(),ue=i.useRef(!1),p=i.useRef(!0),ge=i.useRef(0),fe=i.useRef(),me=i.useRef(),Pe=i.useRef([]),we=i.useRef([]),q=i.useRef(null),Rt=i.useRef(null),Ct=i.useRef(null),xe=b.useDir(A),vt=i.useMemo(()=>i.Children.toArray(t.gridProps.children),[t.gridProps.children]),R=l.getSelectionOptions((ke=t.gridProps.selectable)!=null?ke:!!t.gridProps.selectedField),Se=l.getEditableOptions((Ke=t.gridProps.editable)!=null?Ke:!!t.gridProps.editField);i.useMemo(()=>{l.tableKeyboardNavigation.onConstructor({navigatable:!!t.gridProps.navigatable,contextStateRef:D,navigationStateRef:M,idPrefix:t.id})},[]),i.useMemo(()=>{var r;(r=d.current)==null||r.reset();const e=t.gridProps.groupable===!0||typeof t.gridProps.groupable=="object"&&t.gridProps.groupable.enabled!==!1,n=t.isFixedVirtualScroll?Me.VirtualScrollFixed:Kt.VirtualScroll;d.current=new n(e||t.gridProps.rowHeight===void 0||t.gridProps.rowHeight===0)},[t.gridProps.scrollable,t.gridProps.total,t.gridProps.filter,t.gridProps.group,t.gridProps.groupable,t.gridProps.sort,t.gridProps.rowHeight]),i.useEffect(()=>(t.gridProps.clipboard&&(Y.current=new l.ClipboardService($),Y.current.addEventListeners(x())),()=>{Y.current&&Y.current.removeEventListeners(x())}),[t.gridProps.onClipboard,t.gridProps.clipboard,$,x]),i.useEffect(()=>(t.gridProps.columnVirtualization&&!window.navigator.userAgent.match(kt.SAFARI_REGEX)&&(ce.current&&(ce.current.style.display="block"),k.current&&(k.current.style.display="block")),ae(),b.setScrollbarWidth(),l.tableKeyboardNavigation.onComponentDidMount({scope:A.current||void 0,contextStateRef:D,navigationStateRef:M}),()=>{clearTimeout(fe.current)}),[]),i.useEffect(()=>{var e;ae(),b.setScrollbarWidth(),(e=d.current)!=null&&e.tableTransform&&d.current.table&&(d.current.table.style.transform=d.current.tableTransform,d.current.tableTransform=""),ft(),l.tableKeyboardNavigation.onComponentDidUpdate({scope:A.current||void 0,contextStateRef:D,navigationStateRef:M,focusFirst:le.current,newEditableRow:Z.current,singleEditRow:ue.current,lastActiveElement:se.current,navigatable:t.gridProps.navigatable}),le.current=!1,Z.current=void 0}),i.useEffect(()=>{if(b.canUseDOM){const e={rootMargin:"0px",threshold:.9};T.current=window.IntersectionObserver&&new window.IntersectionObserver(ye,e)||null}},[ye]),i.useEffect(()=>{var n;let e;return b.canUseDOM&&window.ResizeObserver&&(e=new window.ResizeObserver(Pt),e.observe((n=x())==null?void 0:n.body)),()=>{e==null||e.disconnect()}},[]),i.useImperativeHandle(E,()=>({get element(){return J()},props:t.gridProps,get columns(){return B()},scrollIntoView:e=>{var a;if(!((a=d.current)!=null&&a.container)||t.gridProps.scrollable==="none")return;const{rowIndex:n}=e;me.current=n;const r=J();if(T.current&&r){T.current.disconnect();const o=r.querySelector(`[absolute-row-index="${me.current}"]`);o?T.current.observe(o):oe(e)}},fitColumns:e=>{S.current.dblClickHandler(null,e)}})),i.useImperativeHandle(t.gridRef,()=>E.current),i.useMemo(()=>{S.current=new St.ColumnResize(st)},[t.gridProps.onColumnResize,t.columnsRef]),i.useMemo(()=>{K.current=new Dt.CommonDragLogic(re,ct,ve)},[t.gridProps.onColumnReorder,t.gridProps.onGroupChange,t.gridProps.group,t.columnsRef,t.gridProps.groupable]),S.current.resizable=t.gridProps.resizable||!1,S.current.columns=t.columnsRef,S.current.columnsState=b.cloneArray(t.columnsState);const De=t.gridProps.groupable===!0||typeof t.gridProps.groupable=="object"&&t.gridProps.groupable.enabled!==!1;return K.current.reorderable=t.gridProps.reorderable||!1,K.current.groupable=De,K.current.columns=t.columnsRef,bt(t.total,De),i.createElement(He.Provider,{value:{isClient:v,rowReorder:G,activeDragRowDataItemRef:q,reorderRowDragTargetRef:Rt,reorderRowDropTargetRef:Ct,dir:xe,getCellPositionStyle:ht,dataItemKey:t.gridProps.dataItemKey,columnsState:t.columnsState,onColumnsStateChange:ne,groupChange:te,selectionRelease:Qe,pagerPageChange:at,onContextMenu:Oe,rowClick:Ve,rowDblClick:_e,cellClick:Be,headerCellClick:Re,itemChange:$e,sortChange:Ce,filterChange:ot,searchChange:it,onHeaderSelectionChange:Ye,columnGroupChange:dt,onKeyDown:Ne,onFocus:qe,scrollHandler:ze,selectionChange:Xe,dispatchDetailExpand:je,dispatchGroupExpand:We,columnResizeRef:S,dragLogicRef:K,navigationStateRef:M,tableElementRef:k,tableBodyElementRef:O,headerElementRef:It,containerElementRef:Q,headTableElementRef:ce,elementRef:A,footerRef:z,headerRef:N,vsRef:d}},i.createElement(l.TableKeyboardNavigationContext.Provider,{value:D.current},t.children),i.createElement(Mt.GridContextMenu,{show:m.show,dataItem:m.dataItem,field:m.field,items:Ge,offset:m.offset,onClose:be,onSelect:Le}))};exports.GridClientWrapper=At;exports.GridContext=He;
9
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const xt=require("react"),h=require("@progress/kendo-react-common"),s=require("@progress/kendo-react-data-tools"),St=require("./drag/ColumnResize.js"),Dt=require("./drag/CommonDragLogic.js"),kt=require("./constants/index.js"),w=require("./utils/index.js"),Me=require("./VirtualScrollFixed.js"),Kt=require("./VirtualScroll.js"),Mt=require("./contextMenu/GridContextMenu.js"),Te=require("./contextMenu/enums.js"),Ae=require("./sortCommon.js");function Tt(t){const v=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(t){for(const f in t)if(f!=="default"){const H=Object.getOwnPropertyDescriptor(t,f);Object.defineProperty(v,f,H.get?H:{enumerable:!0,get:()=>t[f]})}}return v.default=t,Object.freeze(v)}const i=Tt(xt),He=i.createContext(void 0),At=t=>{var ke,Ke;const v=t.gridProps.isClient,[f,H]=i.useState({}),Fe=e=>{e.event.preventDefault(),H({...f,show:!0,offset:{left:e.event.pageX,top:e.event.pageY},dataItem:e.dataItem,field:e.field})},be=()=>{H({})},b=i.useMemo(()=>t.columnsRef.find(e=>e.field===f.field),[t.columnsRef,f]),Ie=i.useMemo(()=>{const e=t.gridProps.sortable&&(b==null?void 0:b.sortable);return w.getDefaultHeadContextMenuItems({sortable:!!e,selectable:s.getSelectionOptions(t.gridProps.selectable).enabled,clipboard:!!t.gridProps.clipboard})},[b,t.gridProps.sortable,t.gridProps.selectable,t.gridProps.clipboard]),Re=i.useMemo(()=>{const e=t.gridProps.sortable&&(b==null?void 0:b.sortable);return w.getDefaultBodyContextMenuItems({sortable:!!e,selectable:s.getSelectionOptions(t.gridProps.selectable).enabled,clipboard:!!t.gridProps.clipboard,rowReorderable:w.isRowReorderEnabled(t.gridProps.rowReorderable)})},[b,t.gridProps.sortable,t.gridProps.selectable,t.gridProps.clipboard]),Ge=i.useMemo(()=>{const e=(b==null?void 0:b.contextMenu)||t.gridProps.contextMenu,n=typeof e=="function"?e(f):e;if(n&&f.offset){const o=f.dataItem?Te.GridContextMenuAnchorPart.body:Te.GridContextMenuAnchorPart.head,r=n[o],a=f.dataItem?Re:Ie;return r===!1?void 0:r===!0||r===void 0?a:r}},[t.gridProps.contextMenu,f,Re,Ie,b]),Le=e=>{var l,g,m,P,y,te,C,U,V;const n=e.event.item,o={target:E.current,syntheticEvent:e.event.syntheticEvent,nativeEvent:e.event.nativeEvent,menuItem:n,...e};t.gridProps.onContextMenuItemClick&&u(t.gridProps.onContextMenuItemClick,o);const r=X(),a={selectedField:t.gridProps.selectedField||"",componentId:t.id,dataItems:r,dataItem:e.dataItem,startRowIndex:-1,endRowIndex:-1,startColIndex:-1,endColIndex:-1,ctrlKey:!1,altKey:!1,metaKey:!1,shiftKey:!1,isDrag:!1,...s.getSelectionOptions(t.gridProps.selectable),...o},d=r.findIndex(B=>B===e.dataItem);switch((l=n.data)==null?void 0:l.action){case"SortCommand":if(b){const B=(g=n.name)==null?void 0:g.toLowerCase().includes("asc"),Et=((m=n.name)==null?void 0:m.toLowerCase().includes("desc"))?"desc":void 0,yt=B?"asc":Et,wt=n.name?yt:void 0;Ce(e.event.syntheticEvent,b,wt)}break;case"SelectRowCommand":pe(a);break;case"SelectAllRowsCommand":Ze(a);break;case"ClearSelectionCommand":et(a);break;case"ReorderRowCommand":q.current=e.dataItem,(P=n.name)!=null&&P.toLowerCase().includes("rowup")&&d>0&&G(e.event.syntheticEvent,d-1,"before"),(y=n.name)!=null&&y.toLowerCase().includes("rowdown")&&d<r.length-1&&G(e.event.syntheticEvent,d+1,"after"),(te=n.name)!=null&&te.toLowerCase().includes("rowtop")&&G(e.event.syntheticEvent,0,"before"),(C=n.name)!=null&&C.toLowerCase().includes("rowbottom")&&G(e.event.syntheticEvent,r.length-1,"after");break;case"CopySelectionCommand":$(s.ClipboardActionType.copy,e.event.nativeEvent,{copyHeaders:!((U=n.name)!=null&&U.toLowerCase().includes("noheaders"))},e.dataItem,e.field);break;case"PasteCommand":$(s.ClipboardActionType.paste,e.event.nativeEvent,{copyHeaders:!((V=n.name)!=null&&V.toLowerCase().includes("noheaders"))},e.dataItem,e.field);break}be()},_=()=>{const e=t.columnsRef.filter(n=>n.declarationIndex>=0&&n.parentIndex===-1);return w.sanitizeColumns(e)},Oe=(e,n,o)=>{if(t.gridProps.onContextMenu&&v){const r={target:E.current,syntheticEvent:e,nativeEvent:e.nativeEvent,dataItem:n,field:o};u(t.gridProps.onContextMenu,r)}t.gridProps.contextMenu&&Fe({event:e,dataItem:n,field:o})},ze=e=>{if(e.target!==e.currentTarget)return;clearTimeout(me.current),c.current&&(c.current.table=k.current);const n=e.currentTarget.scrollLeft,o=e.currentTarget.scrollTop,r=t.gridProps.scrollable==="virtual";t.gridProps.columnVirtualization&&(!r||o===fe.current)&&(me.current=window.setTimeout(()=>{de()},0)),t.gridProps.scrollLeftRef&&(t.gridProps.scrollLeftRef.current=n),N.current&&N.current.setScrollLeft(n),z.current&&z.current.setScrollLeft(n),c.current&&o!==fe.current&&c.current.scrollHandler(e),t.gridProps.onScroll&&v&&u(t.gridProps.onScroll,{...I(e)}),fe.current=o},Ne=e=>{s.tableKeyboardNavigation.onKeyDown(e,{navigatable:t.gridProps.navigatable||!1,contextStateRef:D,navigationStateRef:M,onNavigationAction:Ue,columns:_()}),s.tableKeyboardNavigation.onGetSnapshotBeforeUpdate({document:x(),contextStateRef:D,navigationStateRef:M});const n={dataItems:L(),mode:R.mode,cell:R.cell,componentId:t.id,selectedField:t.gridProps.selectedField,...I(e)};t.gridProps.onKeyDown&&v&&u(t.gridProps.onKeyDown,n)},qe=e=>{s.tableKeyboardNavigation.onFocus(e,{navigatable:!!t.gridProps.navigatable,contextStateRef:D})},Ue=e=>{if(e.action==="moveToNextPage"&&nt(e.event),e.action==="moveToPrevPage"&&rt(e.event),e.focusElement&&e.action==="reorderToRight"){const n=parseInt(e.focusElement.ariaColIndex,10)-1;n<t.columnsRef.length-1&&oe(n,n+1,e.event)}if(e.focusElement&&e.action==="reorderToLeft"){const n=parseInt(e.focusElement.ariaColIndex,10)-1;n>0&&oe(n,n-1,e.event)}if(e.action==="select"&&Je(e.event),t.gridProps.onNavigationAction&&v){const n={focusElement:e.focusElement,...I(e.event)};u(t.gridProps.onNavigationAction,n)}},Ve=(e,n)=>{t.gridProps.onRowClick&&e.target.nodeName==="TD"&&u(t.gridProps.onRowClick,{dataItem:n,...I(e)})},Be=(e,n)=>{t.gridProps.onRowDoubleClick&&e.target.nodeName==="TD"&&u(t.gridProps.onRowDoubleClick,{dataItem:n,...I(e)})},_e=(e,n,o)=>{if(De.enabled&&De.mode==="incell"&&t.gridProps.dataItemKey){const r=s.editReducer(t.gridProps.edit,{type:s.EDIT_ACTION.ENTER_FIELD_EDIT,payload:{id:n[t.gridProps.dataItemKey],field:o}});t.gridProps.onEditChange&&u(t.gridProps.onEditChange,{edit:r,...I(e)})}},je=(e,n)=>{var r;if(s.getDetailExpandableOptions(t.detailExpandable).enabled){const a=s.detailExpandReducer((r=t.gridProps.detailExpand)!=null?r:{},e);t.gridProps.onDetailExpandChange&&u(t.gridProps.onDetailExpandChange,{...I(n),detailExpand:a})}},We=(e,n)=>{var r;const o=s.getGroupExpandableOptions(typeof t.gridProps.groupable=="object"?t.gridProps.groupable.expandable!==!1:t.gridProps.groupable);if(o.enabled){const a=s.groupExpandReducer((r=t.gridProps.groupExpand)!=null?r:[],e,o);t.gridProps.onGroupExpandChange&&u(t.gridProps.onGroupExpandChange,{...I(n),groupExpand:a})}},Ce=(e,n,o)=>{const{allowUnsort:r,mode:a}=Ae.normalizeSortable(t.gridProps.sortable||!1,n.sortable||!1),d=(t.gridProps.sort||[]).filter(m=>m.field===n.field)[0],l=o||Ae.firstLevelSortSeqMap[r][d&&d.dir||""],g=a==="single"?[]:(t.gridProps.sort||[]).filter(m=>m.field!==n.field);l!==""&&n.field&&g.push({field:n.field,dir:l}),ve(g,e)},$e=e=>{var n;if(e.field===t.gridProps.expandField||e._expand||t.gridProps.group&&e.field===void 0){if(t.gridProps.onExpandChange){const o=t.gridProps.dataItemKey?s.detailExpandReducer((n=t.gridProps.detailExpand)!=null?n:{},{type:s.DETAIL_EXPAND_ACTION.SET,id:e.dataItem[t.gridProps.dataItemKey],payload:e.value}):t.gridProps.detailExpand;u(t.gridProps.onExpandChange,{...I(e.syntheticEvent),expand:o,dataItem:e.dataItem,dataIndex:e.dataIndex,value:e.value})}return}t.gridProps.onItemChange&&u(t.gridProps.onItemChange,{...I(e.syntheticEvent),dataItem:e.dataItem,dataIndex:e.dataIndex,field:e.field,value:e.value})},Xe=e=>{var n;if(t.gridProps.onSelectionChange&&R.enabled){const{event:o,dataItem:r,dataIndex:a,columnIndex:d}=e,l={...I(o.syntheticEvent),dataItem:r,startColIndex:d,endColIndex:d,startRowIndex:a,endRowIndex:a,dataItems:L(),altKey:!1,ctrlKey:!1,shiftKey:!1,metaKey:!1,mode:R.mode,cell:R.cell,isDrag:!1,componentId:t.id,selectedField:t.gridProps.selectedField||""};u(t.gridProps.onSelectionChange,{...l,select:t.gridProps.dataItemKey?s.getSelectedState({event:l,selectedState:(n=t.gridProps.select)!=null?n:{},dataItemKey:t.gridProps.dataItemKey}):{}})}},Je=e=>{var m,P;if(t.gridProps.selectedField||!R.enabled||!t.gridProps.dataItemKey)return;const n={dataItems:L(),mode:R.mode,cell:R.cell,componentId:t.id,selectedField:t.gridProps.selectedField,...I(e)},o=s.getSelectedStateFromKeyDown({event:n,selectedState:(m=t.gridProps.select)!=null?m:{},dataItemKey:t.gridProps.dataItemKey});if(o===t.gridProps.select)return;const r=e.target,a=s.closestTagName(r,"TD"),d=s.closestTagName(r,"TR"),l=s.getColumnIndex(a),g=s.getRowIndex(d);if(l!==void 0&&g!==void 0){const y=(P=w.getDataAsArray(t.gridProps.data))==null?void 0:P[g];t.gridProps.onSelectionChange&&u(t.gridProps.onSelectionChange,{...n,select:o,dataItem:y,startRowIndex:g,startColIndex:l,startDataItem:y,endDataItem:y,endRowIndex:g,endColIndex:l,ctrlKey:e.ctrlKey,altKey:e.altKey,metaKey:e.metaKey,shiftKey:e.shiftKey,isDrag:!1})}},Ye=e=>{var n;if(t.gridProps.onHeaderSelectionChange&&R.enabled){const o=L();u(t.gridProps.onHeaderSelectionChange,{select:e.syntheticEvent.target.checked?o.reduce((r,a)=>(t.gridProps.dataItemKey&&h.getter(t.gridProps.dataItemKey)(a)!==void 0&&(r[h.getter(t.gridProps.dataItemKey)(a)]=!0),r),{}):{},field:e.field,nativeEvent:e.syntheticEvent&&e.syntheticEvent.nativeEvent,syntheticEvent:e.syntheticEvent,target:E.current,dataItems:o,selectedField:(n=t.gridProps.selectedField)!=null?n:""})}},j=(e,n)=>{t.gridProps.onSelectionChange&&R.enabled&&u(t.gridProps.onSelectionChange,{...e,select:n})},Qe=e=>{var n;if(t.gridProps.onSelectionChange&&R.enabled){const o=X()[e.startRowIndex],r=X()[e.endRowIndex],a={syntheticEvent:void 0,target:E.current,selectedField:t.gridProps.selectedField||"",componentId:t.id,dataItems:L(),dataItem:null,startDataItem:o,endDataItem:r,...e},d=s.getSelectedState({event:a,selectedState:(n=t.gridProps.select)!=null?n:{},dataItemKey:t.gridProps.dataItemKey});j(a,d)}},Ze=e=>{if(t.gridProps.onSelectionChange&&R.enabled){const n=e.dataItems[0],o=e.dataItems[e.dataItems.length-1],r={},a={...e,startDataItem:n,endDataItem:o,startRowIndex:0,endRowIndex:e.dataItems.length-1,startColIndex:0,endColIndex:t.columnsRef.length-1};e.dataItems.forEach(d=>{const g=h.getter(t.gridProps.dataItemKey)(d);r[g]=e.cell?[...Array(t.columnsRef.length).keys()]:!0}),j(a,r)}},pe=e=>{if(t.gridProps.onSelectionChange&&R.enabled){const o=h.getter(t.gridProps.dataItemKey)(e.dataItem),r=0,a=t.columnsRef.length-1,d=e.dataItems.findIndex(y=>y[t.gridProps.dataItemKey]===e.dataItem[t.gridProps.dataItemKey]),m={...e,startDataItem:d,endDataItem:d,startRowIndex:d,endRowIndex:d,startColIndex:r,endColIndex:a},P=e.mode==="multiple"?t.gridProps.select||{}:{};P[o]===!0||Array.isArray(P[o])&&P[o].length===t.columnsRef.length?delete P[o]:P[o]=e.cell?[...Array(t.columnsRef.length).keys()]:!0,j(m,P)}},et=e=>{t.gridProps.onSelectionChange&&R.enabled&&j(e,{})},F=(e,n,o,r,a)=>{const d=t.gridProps.onDataStateChange;if(e){const l={...I(r),...n,targetEvent:a};u(e,l)}else d&&u(d,{...I(r),targetEvent:a||{},dataState:{...ut(),...o}})},W=(e,n,o)=>{F(t.gridProps.onPageChange,{page:e},{skip:e.skip,take:e.take},n,o)},tt=()=>{let e=t.gridProps.total||0;return Array.isArray(t.gridProps.data)?e=e||t.gridProps.data.length:t.gridProps.data&&(e=e||t.gridProps.data.total),e},nt=e=>{var a,d;const n=(d=(a=t.gridProps.take)!=null?a:t.gridProps.pageSize)!=null?d:0,o=(t.gridProps.skip||0)+n,r=tt();o<r&&W({skip:o,take:n},e)},rt=e=>{var r,a;const n=(a=(r=t.gridProps.take)!=null?r:t.gridProps.pageSize)!=null?a:0,o=(t.gridProps.skip||0)-n;o>=0&&W({skip:o,take:n},e)},ot=e=>{W({skip:e.skip,take:e.take},e.syntheticEvent,e.targetEvent)},ve=(e,n)=>{F(t.gridProps.onSortChange,{sort:e},{sort:e,...t.gridProps.scrollable==="virtual"?{skip:0}:{}},n)},at=(e,n)=>{F(t.gridProps.onFilterChange,{filter:e},{filter:e||void 0,skip:0},n)},it=e=>{const n=t.gridProps.searchFields||t.columnsRef.map(a=>a.field)||[],o=e.nativeEvent.target.value,r={logic:"or",filters:n.filter(a=>a!==void 0).map(a=>{var d;return typeof a=="string"?{field:a,value:o,operator:"contains"}:{value:o,operator:(d=a.operator)!=null?d:"contains",field:a.field,ignoreCase:a.ignoreCase}})};F(t.gridProps.onSearchChange,{search:r},{},e.syntheticEvent)},ne=(e,n)=>{const o=n.nativeEvent?n:{nativeEvent:n.nativeEvent||n.originalEvent};e.length===0&&t.gridProps.navigatable&&(se.current=!0),F(t.gridProps.onGroupChange,{group:e},{group:e,skip:0},o)},re=e=>{if(t.gridProps.onColumnsStateChange){const n={target:E.current,columnsState:e};u(t.gridProps.onColumnsStateChange,n)}},oe=(e,n,o)=>{const{columnsRef:r,columnsState:a}=t,d=r[e],l=w.getFlatColumnsState(a),g=d.depth,m=C=>{do C++;while(C<r.length&&r[C].depth>g);return C},P=r.splice(e,m(e)-e);r.splice(e<n?m(n-P.length):n,0,...P),r.filter(C=>C.declarationIndex>=0).forEach((C,U)=>{C.orderIndex=U;const V=l.find(B=>B.id===C.id);V&&(V.orderIndex=U)});const y=r[e].locked&&r[n].locked;s.updateLeft(t.columnsMapRef,r,y||p.current),s.updateRight(t.columnsMapRef,r,y||p.current),le.current&&(p.current=!1,le.current=!1);const te=_();if(de(),t.gridProps.onColumnReorder){const C={target:E.current,columns:te,columnId:d.id,nativeEvent:o};u(t.gridProps.onColumnReorder,C)}re(a)},G=(e,n,o)=>{const r=typeof t.gridProps.rowReorderable=="object"?t.gridProps.rowReorderable.enabled:t.gridProps.rowReorderable;if(o==="forbidden"||!r||!q.current)return;const{slicedData:a,dataRef:d}=t,l=(a||d)[n];t.gridProps.onRowReorder&&u(t.gridProps.onRowReorder,{draggedDataItems:[q.current],droppedDataItem:l==null?void 0:l.dataItem,dropPosition:o,nativeEvent:e.originalEvent,dragEvent:e,target:E.current}),q.current=null},dt=(e,n,o)=>{if(t.gridProps.group===void 0)return;const r=t.gridProps.group.slice();r.splice(n,0,...r.splice(e,1)),ne(r,o)},Ee=(e,n,o)=>{const r=t.columnsRef[e].field;if(!r)return;const a=(t.gridProps.group||[]).slice();a.splice(n,0,{field:r}),ne(a,o)},ct=(e,n)=>{const o=K.current.getCurrentGroupsLength;Ee(e,o,n)},ae=()=>{let e=0;if(!S.current.colGroupMain)return;const n=S.current.colGroupMain.children;for(let o=0;o<n.length;o++){const r=n[o].width;if(!r){e=0;break}e+=parseFloat(r.toString())}e=Math.round(e),N.current&&N.current.setWidth(e),z.current&&z.current.setWidth(e),k.current&&(k.current.style.width=e?e+"px":"")},$=i.useCallback((e,n,o,r,a)=>{var m;if(!lt()&&!o||!e)return;const d={type:e,nativeEvent:n,columns:t.columnsRef,dataItemKey:t.gridProps.dataItemKey||"",dataItem:r,field:a,...typeof t.gridProps.clipboard!="boolean"?t.gridProps.clipboard:{},...o},l=X(),g=s.populateClipboardData({event:d,data:l,selectedState:(m=t.gridProps.select)!=null?m:{},previousCopiedItems:xe.current});e!==s.ClipboardActionType.paste&&(xe.current=g.copiedItems),t.gridProps.onClipboard&&v&&u(t.gridProps.onClipboard,{...d,...g})},[t.gridProps.select,t.gridProps.dataItemKey,t.gridProps.data,t.gridProps.clipboard,t.gridProps.onClipboard]),lt=()=>{var a,d,l;if(!h.canUseDOM)return!1;const e=h.getActiveElement(x()),n=e?e.matches(".k-table-td")?e:(a=x())==null?void 0:a.body:(d=x())==null?void 0:d.body,o=n.closest(".k-grid-container"),r=n&&((l=A.current)==null?void 0:l.contains(n));return!!(n&&r&&o)},st=(e,n,o,r,a,d,l)=>{ae(),p.current=!0,le.current=!0,t.gridProps.onColumnResize&&v&&u(t.gridProps.onColumnResize,{columns:_(),nativeEvent:r,targetColumnId:l,index:e,newWidth:n,oldWidth:o,end:a,target:E.current}),a&&re(d)},ut=()=>{var e;return{filter:t.gridProps.filter,sort:t.gridProps.sort,skip:t.gridProps.skip,take:(e=t.gridProps.take)!=null?e:t.gridProps.pageSize,group:t.gridProps.group}},I=e=>({nativeEvent:e&&e.nativeEvent,syntheticEvent:e,target:E.current}),gt=e=>({...e,nativeEvent:void 0,syntheticEvent:void 0,target:void 0,targetEvent:void 0,focusElement:void 0}),u=(e,n)=>{if(t.gridProps.isClient){e(n);return}e(gt(n))},ft=()=>{var e,n,o;if(O.current&&((e=O.current)==null?void 0:e.getElementsByClassName("k-grid-edit-row").length)>0){ge.current=!1,(n=document.activeElement)!=null&&n.closest(".k-grid-edit-row")?ue.current=document.activeElement:ue.current=void 0;const r=Array.from((o=O.current)==null?void 0:o.getElementsByClassName("k-grid-edit-row"));r.length>he.current.length?Z.current=r.filter(a=>!he.current.includes(a))[0]:r.length===1&&(Z.current=r[0],ge.current=!0),he.current=r}},L=()=>t.dataRef.filter(e=>e.rowType==="data").map(e=>e.dataItem),X=()=>(t.slicedData||t.dataRef).filter(e=>e.rowType==="data").map(e=>e.dataItem),x=()=>{var e;if(h.canUseDOM)return((e=J())==null?void 0:e.ownerDocument)||document},J=()=>A.current,ie=i.useCallback(e=>{var r;if(!c.current||!((r=c.current)!=null&&r.container)||t.gridProps.scrollable==="none")return;T.current&&T.current.disconnect();const{rowIndex:n}=e,o=J();if(t.gridProps.scrollable==="virtual")c.current.askedSkip=n,c.current.container.scroll(0,Math.round(c.current.askedSkip/c.current.total*c.current.container.scrollHeight));else if(o){const a=n<1?o.querySelector("tbody > tr:nth-child(1)"):o.querySelector(`tbody > tr:nth-child(${n+1})`);a&&Q.current&&(Q.current.scrollTop=a.offsetTop)}},[t.gridProps.scrollable]),ye=e=>JSON.stringify(e.map(n=>({id:n.id,field:n.field,title:n.title,children:n.children}))),mt=()=>ye(vt)===ye(t.columnsRef),Pt=()=>{mt()||de()},ht=e=>{var n,o;if(c.current){if(c.current.fixedScroll=t.gridProps.fixedScroll||!1,c.current.PageChange=W,c.current.realSkip=t.gridProps.skip||0,c.current.pageSize=(o=(n=t.gridProps.take)!=null?n:t.gridProps.pageSize)!=null?o:0,c.current.scrollableVirtual=t.gridProps.scrollable==="virtual",c.current.total=e,c.current.propsSkip=(t.gridProps.skip||0)+(t.gridProps.scrollable==="virtual"?c.current.topCacheCount+(c.current.attendedSkip-(t.gridProps.skip||0)):0),t.gridProps.rowHeight!==void 0&&t.gridProps.rowHeight>0&&!ee){const r=t.gridProps.rowHeight*e;c.current.containerHeight=w.firefox?Math.min(w.firefoxMaxHeight,r):r}else c.current.containerHeight=1533915;if(c.current.containerRef=Q,c.current.tableBodyRef=O,c.current.table=k.current,c.current instanceof Me.VirtualScrollFixed){const{rowHeight:r=0,detail:a,expandField:d}=t.gridProps;let{detailRowHeight:l=0}=t.gridProps;l=a&&d?l:r,t.isAllData?(c.current.total=t.dataRef.length,c.current.rowHeightService=new h.RowHeightService(t.dataRef.length,r,l,t.dataRef)):c.current.rowHeightService=new h.RowHeightService(e,r,l);const g=c.current.rowHeightService.totalHeight();c.current.containerHeight=w.firefox?Math.min(w.firefoxMaxHeight,g):g}}},we=i.useCallback(e=>{const n={rowIndex:Pe.current};e.forEach(o=>{o.isIntersecting||ie(n)})},[ie]),de=()=>{t.gridProps.forceUpdate&&t.gridProps.forceUpdate()},bt=e=>e.left!==void 0?Se!=="rtl"?{left:e.left,right:e.right}:{left:e.right,right:e.left}:{},E=i.useRef(null),c=i.useRef(void 0),S=i.useRef(void 0),K=i.useRef(void 0),D=i.useRef(void 0),M=i.useRef(void 0),Y=i.useRef(void 0),T=i.useRef(null),O=i.useRef(null),It=i.useRef(null),Q=i.useRef(null),k=i.useRef(null),ce=i.useRef(null),A=i.useRef(null),z=i.useRef(null),N=i.useRef(null),le=i.useRef(!1),se=i.useRef(!1),Z=i.useRef(void 0),ue=i.useRef(void 0),ge=i.useRef(!1),p=i.useRef(!0),fe=i.useRef(0),me=i.useRef(void 0),Pe=i.useRef(void 0),he=i.useRef([]),xe=i.useRef([]),q=i.useRef(null),Rt=i.useRef(null),Ct=i.useRef(null),Se=h.useDir(A),vt=i.useMemo(()=>i.Children.toArray(t.gridProps.children),[t.gridProps.children]),ee=t.gridProps.groupable===!0||typeof t.gridProps.groupable=="object"&&t.gridProps.groupable.enabled!==!1,R=s.getSelectionOptions((ke=t.gridProps.selectable)!=null?ke:!!t.gridProps.selectedField),De=s.getEditableOptions((Ke=t.gridProps.editable)!=null?Ke:!!t.gridProps.editField);return i.useMemo(()=>{s.tableKeyboardNavigation.onConstructor({navigatable:!!t.gridProps.navigatable,contextStateRef:D,navigationStateRef:M,idPrefix:t.id})},[]),i.useMemo(()=>{var n;(n=c.current)==null||n.reset();const e=t.isFixedVirtualScroll?Me.VirtualScrollFixed:Kt.VirtualScroll;c.current=new e(ee||t.gridProps.rowHeight===void 0||t.gridProps.rowHeight===0)},[t.gridProps.scrollable,t.gridProps.total,t.gridProps.filter,t.gridProps.group,ee,t.gridProps.sort,t.gridProps.rowHeight]),i.useEffect(()=>(t.gridProps.clipboard&&(Y.current=new s.ClipboardService($),Y.current.addEventListeners(x())),()=>{Y.current&&Y.current.removeEventListeners(x())}),[t.gridProps.onClipboard,t.gridProps.clipboard,$,x]),i.useEffect(()=>(t.gridProps.columnVirtualization&&!window.navigator.userAgent.match(kt.SAFARI_REGEX)&&(ce.current&&(ce.current.style.display="block"),k.current&&(k.current.style.display="block")),ae(),h.setScrollbarWidth(),s.tableKeyboardNavigation.onComponentDidMount({scope:A.current||void 0,contextStateRef:D,navigationStateRef:M}),()=>{clearTimeout(me.current)}),[]),i.useEffect(()=>{var e;ae(),h.setScrollbarWidth(),(e=c.current)!=null&&e.tableTransform&&c.current.table&&(c.current.table.style.transform=c.current.tableTransform,c.current.tableTransform=""),ft(),s.tableKeyboardNavigation.onComponentDidUpdate({scope:A.current||void 0,contextStateRef:D,navigationStateRef:M,focusFirst:se.current,newEditableRow:Z.current,singleEditRow:ge.current,lastActiveElement:ue.current,navigatable:t.gridProps.navigatable}),se.current=!1,Z.current=void 0}),i.useEffect(()=>{if(h.canUseDOM){const e={rootMargin:"0px",threshold:.9};T.current=window.IntersectionObserver&&new window.IntersectionObserver(we,e)||null}},[we]),i.useEffect(()=>{var n;let e;return h.canUseDOM&&window.ResizeObserver&&(e=new window.ResizeObserver(Pt),e.observe((n=x())==null?void 0:n.body)),()=>{e==null||e.disconnect()}},[]),i.useImperativeHandle(E,()=>({get element(){return J()},props:t.gridProps,get columns(){return _()},scrollIntoView:e=>{var r;if(!((r=c.current)!=null&&r.container)||t.gridProps.scrollable==="none")return;const{rowIndex:n}=e;Pe.current=n;const o=J();if(T.current&&o){T.current.disconnect();const a=o.querySelector(`[absolute-row-index="${Pe.current}"]`);a?T.current.observe(a):ie(e)}},fitColumns:e=>{S.current.dblClickHandler(null,e)}})),i.useImperativeHandle(t.gridRef,()=>E.current),i.useMemo(()=>{S.current=new St.ColumnResize(st)},[t.gridProps.onColumnResize,t.columnsRef]),i.useMemo(()=>{K.current=new Dt.CommonDragLogic(oe,dt,Ee)},[t.gridProps.onColumnReorder,t.gridProps.onGroupChange,t.gridProps.group,t.columnsRef,t.gridProps.groupable]),S.current.resizable=t.gridProps.resizable||!1,S.current.columns=t.columnsRef,S.current.columnsState=h.cloneArray(t.columnsState),K.current.reorderable=t.gridProps.reorderable||!1,K.current.groupable=ee,K.current.columns=t.columnsRef,ht(t.total),i.createElement(He.Provider,{value:{isClient:v,rowReorder:G,activeDragRowDataItemRef:q,reorderRowDragTargetRef:Rt,reorderRowDropTargetRef:Ct,dir:Se,getCellPositionStyle:bt,dataItemKey:t.gridProps.dataItemKey,columnsState:t.columnsState,onColumnsStateChange:re,groupChange:ne,selectionRelease:Qe,pagerPageChange:ot,onContextMenu:Oe,rowClick:Ve,rowDblClick:Be,cellClick:_e,headerCellClick:Ce,itemChange:$e,sortChange:ve,filterChange:at,searchChange:it,onHeaderSelectionChange:Ye,columnGroupChange:ct,onKeyDown:Ne,onFocus:qe,scrollHandler:ze,selectionChange:Xe,dispatchDetailExpand:je,dispatchGroupExpand:We,columnResizeRef:S,dragLogicRef:K,navigationStateRef:M,tableElementRef:k,tableBodyElementRef:O,headerElementRef:It,containerElementRef:Q,headTableElementRef:ce,elementRef:A,footerRef:z,headerRef:N,vsRef:c}},i.createElement(s.TableKeyboardNavigationContext.Provider,{value:D.current},t.children),i.createElement(Mt.GridContextMenu,{show:f.show,dataItem:f.dataItem,field:f.field,items:Ge,offset:f.offset,onClose:be,onSelect:Le}))};exports.GridClientWrapper=At;exports.GridContext=He;