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