@progress/kendo-vue-grid 7.1.0-develop.6 → 7.1.0-develop.7

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/GridToolbar.js CHANGED
@@ -5,4 +5,4 @@
5
5
  * Licensed under commercial license. See LICENSE.md in the package root for more information
6
6
  *-------------------------------------------------------------------------------------------
7
7
  */
8
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("vue"),r=require("@progress/kendo-vue-common"),t=o.defineComponent({name:"GridToolbar",props:{size:{type:String,default:"medium",validator:function(e){return["small","medium"].includes(e)}}},computed:{wrapperClass(){const{size:e}=this.$props;return{"k-toolbar":!0,"k-grid-toolbar":!0,"k-toolbar-solid":!0,[`k-toolbar-${r.kendoThemeMaps.sizeMap[e]||e}`]:e}}},render(){const e=r.getDefaultSlots(this);return o.createVNode("div",{class:this.wrapperClass,role:"toolbar"},[e])}});exports.GridToolbar=t;
8
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("vue"),r=require("@progress/kendo-vue-common"),t=o.defineComponent({name:"GridToolbar",props:{size:{type:String,validator:function(e){return["none","small","medium"].includes(e)}}},computed:{wrapperClass(){const{size:e}=this.$props;return{"k-toolbar":!0,"k-grid-toolbar":!0,"k-toolbar-solid":!0,[`k-toolbar-${r.kendoThemeMaps.sizeMap[e]||e}`]:e}}},render(){const e=r.getDefaultSlots(this);return o.createVNode("div",{class:this.wrapperClass,role:"toolbar"},[e])}});exports.GridToolbar=t;
package/GridToolbar.mjs CHANGED
@@ -5,38 +5,37 @@
5
5
  * Licensed under commercial license. See LICENSE.md in the package root for more information
6
6
  *-------------------------------------------------------------------------------------------
7
7
  */
8
- import { defineComponent as o, createVNode as e } from "vue";
9
- import { getDefaultSlots as t, kendoThemeMaps as a } from "@progress/kendo-vue-common";
10
- const i = /* @__PURE__ */ o({
8
+ import { defineComponent as r, createVNode as e } from "vue";
9
+ import { getDefaultSlots as t, kendoThemeMaps as s } from "@progress/kendo-vue-common";
10
+ const i = /* @__PURE__ */ r({
11
11
  name: "GridToolbar",
12
12
  props: {
13
13
  size: {
14
14
  type: String,
15
- default: "medium",
16
- validator: function(r) {
17
- return ["small", "medium"].includes(r);
15
+ validator: function(o) {
16
+ return ["none", "small", "medium"].includes(o);
18
17
  }
19
18
  }
20
19
  },
21
20
  computed: {
22
21
  wrapperClass() {
23
22
  const {
24
- size: r
23
+ size: o
25
24
  } = this.$props;
26
25
  return {
27
26
  "k-toolbar": !0,
28
27
  "k-grid-toolbar": !0,
29
28
  "k-toolbar-solid": !0,
30
- [`k-toolbar-${a.sizeMap[r] || r}`]: r
29
+ [`k-toolbar-${s.sizeMap[o] || o}`]: o
31
30
  };
32
31
  }
33
32
  },
34
33
  render() {
35
- const r = t(this);
34
+ const o = t(this);
36
35
  return e("div", {
37
36
  class: this.wrapperClass,
38
37
  role: "toolbar"
39
- }, [r]);
38
+ }, [o]);
40
39
  }
41
40
  });
42
41
  export {
@@ -12,4 +12,4 @@
12
12
  * Licensed under commercial license. See LICENSE.md in the package root for more information
13
13
  *-------------------------------------------------------------------------------------------
14
14
  */
15
- !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("vue"),require("@progress/kendo-vue-common"),require("@progress/kendo-vue-data-tools"),require("@progress/kendo-vue-indicators"),require("@progress/kendo-vue-intl"),require("@progress/kendo-svg-icons"),require("@progress/kendo-vue-inputs"),require("@progress/kendo-vue-dateinputs"),require("@progress/kendo-vue-popup"),require("@progress/kendo-data-query"),require("@progress/kendo-vue-animation"),require("@progress/kendo-vue-buttons"),require("@progress/kendo-vue-dropdowns")):"function"==typeof define&&define.amd?define(["exports","vue","@progress/kendo-vue-common","@progress/kendo-vue-data-tools","@progress/kendo-vue-indicators","@progress/kendo-vue-intl","@progress/kendo-svg-icons","@progress/kendo-vue-inputs","@progress/kendo-vue-dateinputs","@progress/kendo-vue-popup","@progress/kendo-data-query","@progress/kendo-vue-animation","@progress/kendo-vue-buttons","@progress/kendo-vue-dropdowns"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).KendoVueGrid={},e.Vue,e.KendoVueCommon,e.KendoVueDatatools,e.KendoVueIndicators,e.KendoVueIntl,e.KendoSVGIcons,e.KendoVueInputs,e.KendoVueDateinputs,e.KendoVuePopup,e.KendoDataQuery,e.KendoVueAnimation,e.KendoVueButtons,e.KendoVueDropdowns)}(this,(function(e,t,i,r,o,l,n,a,s,d,c,h,p,u){"use strict";const g=t.defineComponent({name:"KendoGridNav",props:{currentData:Array,id:String},inject:{onNavKeyDown:{default:i.noop},onNavFocus:{default:i.noop},onNavMount:{default:i.noop},handleDispatchFocus:{default:i.noop},kbContext:{default:null},navigation:{default:null}},mounted(){this.onNavMount({scope:this.$el||void 0})},updated(){this.onNavMount({scope:this.$el||void 0})},methods:{onKeyDown(e){this.onNavKeyDown(e,{navigation:this.navigation,kbContext:this.kbContext,onNavigationAction:this.onNavigationAction}),this.$emit("keydown",{dataItems:this.getLeafDataItems(),componentId:this._gridId,selectedField:this.$props.selectedField,event:e})},onFocus(e){this.onNavFocus(e,{kbContext:this.kbContext})},onNavigationAction(e){this.$emit("navigationaction",{focusElement:e.focusElement,event:e.event})},getLeafDataItems(){return this.$props.currentData.filter((e=>"data"===e.rowType)).map((e=>e.dataItem))}},render(){const e=i.getDefaultSlots(this);return t.createVNode("div",{onKeydown:this.onKeyDown,onFocusin:this.onFocus,id:this.$props.id,"data-keyboardnavscope":!0},[e])}}),f={filterable:!0,editable:!0,sortable:!0,resizable:!0,reorderable:!0,groupable:!0},m="string";function v(e,t){const i=e.split(".");let r=t;return i.forEach((e=>{r=r?r[e]:void 0})),r}function b(e,t,o,l,n,a,s,d,c,h,p=0,u){let g=p;for(let f=0;f<t.length;f++){let m;if(!n||void 0===t[f].value||void 0===t[f].items){const r=!!c&&!(null==a||!a[i.getter(c)(t[f])]);e[e.length]={dataIndex:l.index,dataItem:t[f],rowType:"data",level:p,group:u,expanded:void 0!==h?v(h,t[f]):null!=r&&r},l.index++;continue}{let e;e=null!=u&&u.parents?[{field:u.field,value:u.value},...u.parents]:u?[u]:[],m={field:t[f].field,value:t[f].value,parents:e}}g=Math.max(g,p+1);let C=!1;const x=r.findGroupExpand(s||[],m);C=h?void 0===h||void 0===v(h,t[f])||v(h,t[f]):x?!1!==x.expanded:!1!==d,e[e.length]={dataIndex:-1,dataItem:t[f],level:p,group:m,rowType:"groupHeader",expanded:C},C&&(m.expanded=C,g=Math.max(b(e,t[f].items,o,l,n,a,s,d,c,h,p+1,m),g)),("always"===o||C&&"visible"===o)&&(e[e.length]={dataIndex:-1,dataItem:t[f],rowType:"groupFooter",level:p,expanded:C})}return g}function C(e){return e&&"rtl"===getComputedStyle(e).direction||!1}function x(e,t){if(!(t&&e&&e.originalEvent&&i.canUseDOM))return-1;let r=document.elementFromPoint(e.clientX,e.originalEvent.clientY);for(;r&&r.parentElement!==t;)r=r.parentElement;const o=t.children;for(let e=0;e<o.length;e++)if(o[e]===r)return e;return-1}const $=["sortChange","filterChange","groupChange","pageChange","expandChange","selectionChange","headerSelectionChange","rowClick","itemChange","dataStateChange","columnResize","columnReorder"],k=(e,t)=>`The ${e} event handler property is deprecated, use https://www.telerik.com/kendo-vue-ui/components/grid/api/GridProps/#toc-${t} instead`;function S(e,t){const i=[[]];let o=0;for(let t=e.length-1;t>=0;t--)o=Math.max(o,e[t].depth),e[t].headerColSpan=e[t].headerColSpan||1,e[t].children.length>0&&(e[t].headerColSpan=e[t].children.reduce(((e,t)=>t.hidden?e:e+t.headerColSpan),0));const l=[];let n=1;return e.forEach(((e,t)=>{i[e.depth]=i[e.depth]||[];let r=!1;0===i[e.depth].length&&(n<=1?n=1+(e.children.length>0?0:o-e.depth):(n--,r=!0)),e.rowSpan=1+(e.children.length>0?0:o-e.depth),e.kFirst=r,e.index=i[e.depth].length,i[e.depth].push(t),e.ariaColumnIndex=l[e.depth]?l[e.depth]+1:1;for(let t=e.depth;t<e.depth+e.rowSpan;t++)l[t]=(l[t]||0)+e.headerColSpan})),r.updateLeft(i,e,t),r.updateRight(i,e,t),i}function I(e,t,o,l=0,n=!1){const a=[];if(!e)return[];e&&void 0===e.length&&(e=[e]),e.forEach(((e,s)=>{const d=e.id?e.id:r.tableKeyboardNavigationTools.generateNavigatableId(""+o.prevId++,o.idPrefix,"column"),c=!!(i.canUseDOM&&e.media&&window.matchMedia)&&!window.matchMedia(e.media).matches,h=n||c||e.hidden,p=null==t?void 0:t.find((e=>e.id===d)),u=I(e.children,(null==p?void 0:p.children)||[],o,l+1,h);a.push({depth:l,...f,...u.length?{cell:()=>null,filterCell:()=>null}:{},...e,id:d,declarationIndex:a.length,children:u,headerColSpan:0,rowSpan:0,columnType:e.columnType||"data",colSpan:e.colSpan||1,isAccessible:!0,hidden:h,left:null,right:null,rowSpannable:e.rowSpannable,...p?{width:p.width,orderIndex:p.orderIndex}:{}})}));if(a.sort(((e,t)=>e.orderIndex===t.orderIndex?e.declarationIndex-t.declarationIndex:(e.orderIndex||0)-(t.orderIndex||0))),0===l){const e=[],t=(i,r)=>i.forEach((i=>{i.parentIndex=r,t(i.children,e.push(i)-1)}));return t(a,-1),e}return a}const y=e=>Array.isArray(e)?e:e?e.data:[];function w(e,t,i,o){const l=y(e),n=[];if(l.length>0){let e=l[0];if(t)for(let i=0;i<t.length;i++)e=e.items&&e.items[0];Object.getOwnPropertyNames(e).forEach((e=>{e!==i.column&&n.push({id:r.tableKeyboardNavigationTools.generateNavigatableId(""+o.prevId++,o.idPrefix,"column"),declarationIndex:-1,parentIndex:-1,depth:0,colSpan:0,headerColSpan:0,rowSpan:0,index:0,columnType:"data",left:0,right:0,rightBorder:!1,children:[],ariaColumnIndex:0,isAccessible:!0,...f,field:e})}))}return n}const N=e=>e.filter((t=>!((e,t)=>{let i=e[t.parentIndex];for(;i;){if(i.footerCell)return!0;i=e[i.parentIndex]}return!1})(e,t)&&(!!t.footerCell||!(t.children&&t.children.length>0)))),R={number:function(e,t,i){return typeof e===m&&"null"===e.toLowerCase()?null:t.parseNumber(e,i)},date:function(e,t,i){return typeof e===m&&"null"===e.toLowerCase()?null:t.parseDate(e,i)},boolean:function(e){return typeof e===m?"null"===e.toLowerCase()?null:"true"===e.toLowerCase():null!=e?!!e:e},string:function(e){return typeof e===m&&"null"===e.toLowerCase()?null:null!=e?e+"":e},default:function(e){return e}};function V(e,t,i,r){return e.forEach((e=>{e.expanded=t[r]&&!t[r].includes(E(e,i)),e.items&&e.items.length&&(e.items=V(e.items,t,i,r+1))})),e}function F(e,t,i){return t&&t.length&&e.data.forEach((e=>{e.expanded=void 0!==e.expanded?e.expanded:t[0]&&!t[0].includes(E(e,i)),e.items&&e.items.length&&(e.items=V(e.items,t,i,1))})),e}function E(e,t){let i=e;for(;i.items&&i.items.length;)i=i.items[0];return t?i[t]:e.value}const A=e=>{const t=[],i=e=>null==e?void 0:e.forEach((e=>{t.push(e),i(e.children)}));return i(e),t},D="undefined"!=typeof window&&/Firefox/.test(window.navigator.userAgent),L=17895697,O=e=>(e.sort(((e,t)=>e.declarationIndex-t.declarationIndex)),e.map((e=>{const{declarationIndex:t,parentIndex:i,depth:r,headerColSpan:o,rowSpan:l,index:n,kFirst:a,children:s,...d}=e;return s.length?{children:O(s),...d}:d}))),H=(e,t)=>"function"==typeof e.colSpan?e.colSpan({dataItem:t,column:e}):e.colSpan||1,T=e=>{var t,r;const o="object"==typeof e?null==(t=e.enabled)||t:null!=e&&e,l="object"==typeof e&&null!=(r=e.valueGetter)?r:(e,t)=>i.getter(t)(e);return{enabled:o,valueGetter:l}},G=e=>{let t=0;if(e){const i=e.insertRow(0);i.insertCell(0).textContent="&nbsp;",t=i.getBoundingClientRect().height,e.deleteRow(0)}return t},_=t.defineComponent({name:"KendoGridSelectionCell",inheritAttrs:!1,props:{id:String,field:String,dataItem:Object,format:String,type:String,className:String,colSpan:Number,columnIndex:Number,columnsCount:Number,rowType:String,level:Number,expanded:Boolean,render:[String,Function,Object],isSelected:Boolean,ariaColumnIndex:Number,editor:String,isRtl:Boolean},emits:{selectionchange:null,cellkeydown:null},inject:{kendoIntlService:{default:null},getKeyboardNavigationAttributes:{default:i.noop}},data:()=>({inputId:i.guid()}),computed:{tdClass(){const{className:e}=this.$props;return{"k-table-td":!0,[e]:e}}},methods:{triggerKeydown(e){this.$emit("cellkeydown",{event:e,dataItem:this.$props.dataItem,field:this.$props.field})},handleOnChange(e){this.$emit("selectionchange",{event:e,dataItem:this.$props.dataItem})}},render(){const e=v(this.$props.field,this.$props.dataItem),o=this.$props.render,l=this.getKeyboardNavigationAttributes(this.$props.id),n="groupHeader"!==this.$props.rowType?t.createVNode("td",{style:this.$attrs.style,onKeydown:this.triggerKeydown,colspan:this.$props.colSpan,class:this.tdClass,"aria-colindex":this.$props.ariaColumnIndex,role:"gridcell",tabindex:l.tabIndex,"data-keyboardnavlevel":l[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":l[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode("span",{class:"k-checkbox-wrap"},[t.createVNode("input",{checked:e,id:this.inputId,type:"checkbox",class:"k-checkbox k-checkbox-md k-rounded-md",onChange:this.handleOnChange},null)]),t.createVNode("label",{class:"k-checkbox-label",for:this.inputId},null)]):null;return i.getTemplate.call(this,{h:t.h,template:o,defaultRendering:n,additionalProps:this.$props,additionalListeners:{keydown:this.triggerKeydown,change:this.handleOnChange}})}}),z="grid.noRecords",B="grid.selectAllRows",j="grid.pagerInfo",M="grid.pagerFirstPage",K="grid.pagerPreviousPage",P="grid.pagerNextPage",W="grid.pagerLastPage",q="grid.pagerItemsPerPage",U="grid.pagerPage",Y="grid.pagerPageSelection",X="grid.pagerOf",J="grid.pagerTotalPages",Q="grid.groupPanelEmpty",Z="grid.groupColumn",ee="grid.ungroupColumn",te="grid.columnMenu",ie="grid.filterApplyButton",re="grid.filterClearButton",oe="grid.filterClearAllButton",le="grid.filterResetButton",ne="grid.filterSubmitButton",ae="grid.filterTitle",se="grid.sortAscending",de="grid.sortDescending",ce="grid.sortClearButton",he="grid.sortApplyButton",pe="grid.searchPlaceholder",ue="grid.searchboxPlaceholder",ge="grid.exportPDF",fe="grid.filterCheckAll",me="grid.filterChooseOperator",ve="grid.filterSelectAll",be="grid.filterSelectedItems",Ce="grid.sortAriaLabel",xe="grid.sortableColumnAriaLabel",$e="grid.sortableColumnAscendingAriaLabel",ke="grid.sortableColumnDescendingAriaLabel",Se="grid.editDialogTitle",Ie="grid.editDialogSaveButtonTitle",ye="grid.editDialogCancelButtonTitle",we="grid.filterAriaLabel",Ne="grid.numericFilterAriaLabel",Re="grid.groupPanelAriaLabel",Ve="grid.groupExpand",Fe="grid.groupCollapse",Ee="grid.groupClearButton",Ae="grid.groupApplyButton",De="grid.detailExpand",Le="grid.detailCollapse",Oe="grid.selectRow",He="grid.gridAriaLabel",Te="grid.gridRowReorderAriaLabel",Ge="grid.gridAdaptiveColumnMenuFilterTitle",_e="grid.columnMenuColumnChooserTitle",ze="grid.columnMenuColumnChooserSelectedItems",Be="grid.adaptiveColumnMenuChooserTitle",je="grid.adaptiveColumnMenuChooserSubTitle",Me="grid.columnChooserApplyButton",Ke="grid.columnChooserResetButton",Pe="grid.adaptiveColumnMenuCheckboxFilterTitle",We="grid.adaptiveToolbarSortTitle",qe="grid.adaptiveToolbarGroupTitle",Ue="grid.toolbarSort",Ye="grid.dateFilterAriaLabel",Xe="grid.textFilterAriaLabel",Je="grid.booleanFilterAriaLabel",Qe="grid.groupHeaderAriaLabel",Ze="grid.groupCaretAriaLabelCollapse",et="grid.groupCaretAriaLabelExpand",tt="grid.expandDetailTemplateAriaLabel",it="grid.collapseDetailTemplateAriaLabel",rt="grid.toolbarAI",ot="grid.aIResponseData",lt="grid.generatedWithAI",nt="grid.toolbarAIApply",at="grid.toolbarGroup",st="grid.toolbarFilter",dt="grid.toolbarColumnsChooser",ct="grid.toolbarCheckboxFilter",ht={[De]:"Expand detail row",[Le]:"Collapse detail row",[Ve]:"Expand group",[Fe]:"Collapse Group",[Ee]:"Clear grouping",[Ae]:"Done",[z]:"No records available",[B]:"Select all rows",[Q]:"Drag a column header and drop it here to group by that column",[ie]:"Apply",[re]:"Clear",[oe]:"Clear all filters",[le]:"Reset",[ne]:"Filter",[ae]:"Filter",[se]:"Sort Ascending",[de]:"Sort Descending",[ce]:"Clear sorting",[he]:"Done",[Ce]:"Sortable",[We]:"Sort by",[qe]:"Group by",[Ue]:"Sort",[rt]:"AI Assistant",[nt]:"Apply",[ot]:"Operation is successful. Data is: \n",[lt]:"Generated with AI",[at]:"Group",[st]:"Filter",[dt]:"Columns",[ct]:"Filter",[Z]:"Group Column",[ee]:"Ungroup Column",[te]:"Column menu",[q]:"items per page",[j]:"{0} - {1} of {2} items",[M]:"Go to the first page",[K]:"Go to the previous page",[P]:"Go to the next page",[W]:"Go to the last page",[U]:"Page",[Y]:"Page size",[X]:"of",[J]:"{0}",[pe]:"Search",[ue]:"Search...",[ge]:"Export PDF",[fe]:"Check All",[Se]:"Edit Dialog",[Ie]:"Save",[ye]:"Cancel",[me]:"Choose Operator",[be]:"selected items",[ve]:"Select All",[xe]:"Sortable Column",[$e]:"Sorted in ascending order",[ke]:"Sorted in descending order",[we]:"Filter",[Ne]:"Numeric Filter",[Ye]:"Date Filter",[Xe]:"Text Filter",[Je]:"Boolean Filter",[Qe]:"Group Header",[Ze]:"Collapse Group",[et]:"Expand Group",[tt]:"Expand Details",[it]:"Collapse Details",[Re]:"Group panel",[He]:"Table",[Te]:"Drag row",[Oe]:"Select Row",[_e]:"Columns Chooser",[Ge]:"Filter by",[Be]:"Columns Chooser",[je]:"Selected fields are visible",[Pe]:"Filter by",[ze]:"Selected items",[Me]:"Apply",[Ke]:"Reset","grid.filterEqOperator":"Is equal to","grid.filterNotEqOperator":"Is not equal to","grid.filterIsNullOperator":"Is null","grid.filterIsNotNullOperator":"Is not null","grid.filterIsEmptyOperator":"Is empty","grid.filterIsNotEmptyOperator":"Is not empty","grid.filterStartsWithOperator":"Starts with","grid.filterContainsOperator":"Contains","grid.filterNotContainsOperator":"Does not contain","grid.filterEndsWithOperator":"Ends with","grid.filterGteOperator":"Is greater than or equal to","grid.filterGtOperator":"Is greater than","grid.filterLteOperator":"Is less than or equal to","grid.filterLtOperator":"Is less than","grid.filterIsTrue":"Is true","grid.filterIsFalse":"Is false","grid.filterBooleanAll":"(All)","grid.filterAfterOrEqualOperator":"Is after or equal to","grid.filterAfterOperator":"Is after","grid.filterBeforeOperator":"Is before","grid.filterBeforeOrEqualOperator":"Is before or equal to","grid.filterAndLogic":"And","grid.filterOrLogic":"Or"},pt=t.defineComponent({name:"KendoGridHierarchyCell",inheritAttrs:!1,props:{id:String,field:String,dataItem:Object,format:String,type:String,className:String,colSpan:Number,columnIndex:Number,columnsCount:Number,rowType:String,level:Number,expanded:Boolean,editor:String,isSelected:Boolean,dataIndex:Number,ariaColumnIndex:Number,render:[String,Function,Object],isRtl:Boolean},emits:{change:null,cellkeydown:null},inject:{kendo:{default:null},kendoIntlService:{default:null},kendoLocalizationService:{default:null},getKeyboardNavigationAttributes:{default:i.noop}},methods:{triggerStateChange(){const e=this.kendo;e.dataItemKey&&void 0!==this.$props.dataItem[e.dataItemKey]&&(null==e||e.dispatchDetailExpand({type:r.DETAIL_EXPAND_ACTION.TOGGLE,id:this.$props.dataItem[e.dataItemKey]}))},triggerKeydown(e,t){this.$emit("cellkeydown",{event:e,dataItem:this.$props.dataItem,field:this.$props.field,expanded:t}),!e.defaultPrevented&&e.keyCode===i.Keys.enter&&(e.preventDefault(),this.$emit("change",{dataItem:this.$props.dataItem,dataIndex:this.$props.dataIndex,event:e,field:this.$props.field,value:!t}),this.triggerStateChange())},clickHandler(e,t,i){e.preventDefault(),this.$emit("change",{dataItem:t,event:e,field:void 0,value:!i}),this.triggerStateChange()}},computed:{wrapperClass(){return{"k-table-td":!0,"k-hierarchy-cell":!0,[this.className||""]:this.className}}},render(){let e=null;const o=this.getKeyboardNavigationAttributes(this.$props.id),a=l.provideLocalizationService(this),s=a.toLanguageString(it,ht[it]),d=a.toLanguageString(tt,ht[tt]);if("groupFooter"===this.$props.rowType)e=t.createVNode("td",{class:this.wrapperClass},null);else if("groupHeader"!==this.$props.rowType){const l=this.$props.expanded;e=t.createVNode("td",{style:this.$attrs.style,onKeydown:e=>{this.triggerKeydown(e,l)},class:this.wrapperClass,"aria-expanded":l?"true":"false",role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,tabindex:o.tabIndex,"data-keyboardnavlevel":o[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":o[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode("a",{onClick:e=>{this.clickHandler(e,this.$props.dataItem,l)},href:"#",tabindex:-1,title:l?s:d,"aria-label":l?s:d},[t.createVNode(i.Icon,{name:l?"minus":"plus",icon:l?n.minusIcon:n.plusIcon},null)])])}return i.getTemplate.call(this,{h:t.h,template:this.$props.render,defaultRendering:e,additionalProps:this.$props,additionalListeners:{keydown:this.triggerKeydown,click:this.clickHandler}})}}),ut=t.defineComponent({props:{id:String},inject:{getKeyboardNavigationAttributes:{default:i.noop}},setup:()=>({kendoIntlService:t.inject("kendoIntlService",{})}),render(){const e=this.getKeyboardNavigationAttributes(this.$props.id);return t.createVNode("td",{class:"k-table-td k-hierarchy-cell",tabindex:e.tabIndex,"data-keyboardnavlevel":e[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":e[r.KEYBOARD_NAV_DATA_ID]},null)}}),gt=t.defineComponent({props:{colSpan:Number,ariaColIndex:Number,dataItem:[Object,String,Number],dataIndex:Number,detail:[String,Function,Object],id:String},inject:{getKeyboardNavigationAttributes:{default:i.noop}},setup:()=>({kendoIntlService:t.inject("kendoIntlService",{})}),render(){const{colSpan:e,ariaColIndex:o,dataItem:l,dataIndex:n,id:a}=this.$props,s=this.getKeyboardNavigationAttributes(a);return t.createVNode("td",{class:"k-table-td k-detail-cell",colspan:e,"aria-colindex":o,role:"gridcell",tabindex:s.tabIndex,"data-keyboardnavlevel":s[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":s[r.KEYBOARD_NAV_DATA_ID]},[function(e){return i.getTemplate.call(this,{h:t.h,template:this.$props.detail,additionalProps:e})}.call(this,{dataItem:l,dataIndex:n})])}}),ft=t.defineComponent({name:"GridEditCell",inheritAttrs:!1,props:{id:String,field:String,dataItem:Object,format:String,type:String,className:String,colSpan:Number,columnIndex:Number,columnsCount:Number,rowType:String,level:Number,expanded:Boolean,editor:String,isSelected:Boolean,ariaColumnIndex:Number,render:[String,Function,Object],isRtl:Boolean,readFormat:String,dataIndex:Number},emits:{change:null,cellkeydown:null,edit:null,add:null,cancel:null,save:null,remove:null},inject:{kendoIntlService:{default:null},getKeyboardNavigationAttributes:{default:i.noop}},computed:{tdClass(){const{className:e}=this.$props;return{"k-table-td":!0,[e]:e}}},data:()=>({inputId:i.guid()}),methods:{triggerKeydown(e){this.$emit("cellkeydown",{event:e,dataItem:this.$props.dataItem,field:this.$props.field})},triggerEdit(e){this.$emit("edit",e)},triggerAdd(e){this.$emit("add",e)},triggerCancel(e){this.$emit("cancel",e)},triggerSave(e){this.$emit("save",e)},triggerRemove(e){this.$emit("remove",e)},changeHandler(e,t){t||(t="checkbox"===e.target.type?e.target.checked:e.target.valueAsDate?e.target.valueAsDate:e.target.value),this.$emit("change",{dataItem:this.$props.dataItem,field:this.$props.field,event:e,value:t})}},setup:()=>({kendoIntlService:t.inject("kendoIntlService",{})}),render(){const e=v(this.$props.field,this.$props.dataItem),o=this.getKeyboardNavigationAttributes(this.$props.id);let l=null;switch(this.$props.editor){case"numeric":l=t.createVNode("td",{style:this.$attrs.style,onKeydown:this.triggerKeydown,colspan:this.$props.colSpan,class:this.tdClass,role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,"aria-selected":this.$props.isSelected,"data-grid-col-index":this.$props.columnIndex,tabindex:o.tabIndex,"data-keyboardnavlevel":o[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":o[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode(a.NumericTextBox,{style:{width:"100%"},value:void 0===e?null:e,onChange:this.changeHandler},null)]);break;case"date":l=t.createVNode("td",{style:this.$attrs.style,onKeydown:this.triggerKeydown,colspan:this.$props.colSpan,class:this.tdClass,role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,"aria-selected":this.$props.isSelected,"data-grid-col-index":this.$props.columnIndex,tabindex:o.tabIndex,"data-keyboardnavlevel":o[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":o[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode(s.DatePicker,{style:{width:"100%"},value:e,onChange:this.changeHandler},null)]);break;case"boolean":l=t.createVNode("td",{style:this.$attrs.style,onKeydown:this.triggerKeydown,colspan:this.$props.colSpan,class:this.tdClass,role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,"aria-selected":this.$props.isSelected,"data-grid-col-index":this.$props.columnIndex,tabindex:o.tabIndex,"data-keyboardnavlevel":o[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":o[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode("input",{checked:e||!1,id:this.inputId,type:"checkbox",class:"k-checkbox k-checkbox-md k-rounded-md",onChange:this.changeHandler},null),t.createVNode("label",{class:"k-checkbox-label",for:this.inputId},null)]);break;default:l=t.createVNode("td",{style:this.$attrs.style,onKeydown:this.triggerKeydown,colspan:this.$props.colSpan,class:this.tdClass,role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,"aria-selected":this.$props.isSelected,"data-grid-col-index":this.$props.columnIndex,tabindex:o.tabIndex,"data-keyboardnavlevel":o[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":o[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode("span",{class:"k-textbox k-input k-input-md k-rounded-md k-input-solid"},[t.createVNode("input",{style:{width:"100%"},class:"k-input-inner",value:null!=e?e:"",onChange:this.changeHandler},null)])])}return i.getTemplate.call(this,{h:t.h,template:this.$props.render,defaultRendering:l,additionalProps:this.$props,additionalListeners:{change:this.changeHandler,keydown:this.triggerKeydown,edit:this.triggerEdit,add:this.triggerAdd,cancel:this.triggerCancel,save:this.triggerSave,remove:this.triggerRemove}})}}),mt=t.defineComponent({props:{staticHeaders:Boolean,headerRow:Object,columnResize:Object,cols:Array,size:String,draggable:Boolean},data:()=>({divStyle:{},element:null,headerWrap:null,table:null}),computed:{wrapperClass(){return{"k-grid-header":!0,"k-grid-draggable-header":this.$props.draggable}},tableClass(){const{size:e}=this.$props;return{"k-table":!0,"k-grid-header-table":!0,[`k-table-${i.kendoThemeMaps.sizeMap[e]||e}`]:e}}},mounted(){this.headerWrap=i.getRef(this,"headerWrap"),this.table=i.getRef(this,"table"),this.$props.columnResize.colGroupHeader=i.getRef(this,"colGroupHeader");const e=C(this.$el);this.$props.columnResize&&this.$props.columnResize.setIsRtl(e)},methods:{setScrollLeft(e){this.headerWrap&&(this.headerWrap.scrollLeft=e)},setWidth(e){this.table&&(this.table.style.width=e+"px")}},setup:()=>({headerWrapRef:t.ref(null),tableRef:t.ref(null),colGroupHeaderRef:t.ref(null)}),render(){return this.$props.staticHeaders?t.createVNode("div",{class:this.wrapperClass},[t.createVNode("div",{ref:i.setRef(this,"headerWrap"),class:"k-grid-header-wrap"},[t.createVNode("table",{class:this.tableClass,ref:i.setRef(this,"table"),role:"none"},[t.createVNode("colgroup",{ref:i.setRef(this,"colGroupHeader")},[this.$props.cols]),this.$props.headerRow])])]):this.$props.headerRow}}),vt=(...e)=>Object.assign({allowUnsort:!0,mode:"single"},...e),bt=t.defineComponent({props:{onResize:Function},mounted(){this.$el&&(this.draggable=this.$refs.draggable)},methods:{drag(e){const t=this.draggable&&this.draggable.element;t&&this.$emit("resize",e,t,!1)},release(e){const t=this.draggable&&this.draggable.element;t&&this.$emit("resize",e,t,!0)}},render(){const e={cursor:"col-resize",display:"block",height:"1000%",position:"absolute",top:0,width:".5em"};return t.createVNode(i.Draggable,{onDrag:this.drag,onRelease:this.release,ref:"draggable"},{default:()=>[t.createVNode("span",{class:"k-column-resizer",draggable:!1,style:e},null)]})}}),Ct=t.defineComponent({props:{onPressHandler:Function,onDragHandler:Function,onReleaseHandler:Function},mounted(){this.$el&&(this.draggable=this.$refs.draggable)},methods:{onPress(e){const t=this.draggable&&this.draggable.element;t&&this.$emit("pressHandler",e,t)},onDrag(e){const t=this.draggable&&this.draggable.element;t&&this.$emit("dragHandler",e,t)},onRelease(e){const t=this.draggable&&this.draggable.element;t&&this.$emit("releaseHandler",e,t)}},render(){const e=i.getDefaultSlots(this);return t.createVNode(i.Draggable,{onPress:this.onPress,onDrag:this.onDrag,onRelease:this.onRelease,ref:"draggable"},{default:()=>[t.createVNode("tr",{class:"k-table-row",role:"row"},[e])]})}}),xt=t.defineComponent({props:{field:String,title:String,sortable:[Boolean,Object],render:[Object,Function,String],selectionValue:[Boolean,String,Number],onHeadercellclick:Function},computed:{linkClass(){return{"k-link":!0,"!k-cursor-default":!this.sortable}}},methods:{clickHandler(e){this.sortable&&this.$emit("headercellclick",e)}},render(){const e=i.getDefaultSlots(this),r=this.$props.render,o=this.$props.title||this.$props.field||" ",l=i.getTemplate.call(this,{h:t.h,template:r,defaultRendering:o,additionalProps:this.$props,additionalListeners:{click:this.clickHandler}});return t.createVNode("span",{class:this.linkClass,onClick:this.clickHandler},[t.createVNode("span",{class:"k-column-title"},[l]),e])}}),$t=t.defineComponent({props:{title:String,iconClass:String,icon:String,svgIcon:Object,selected:Boolean,onMenuitemclick:Function},methods:{onClick(e){this.$emit("menuitemclick",e)},onKeyDown(e){e.keyCode===i.Keys.enter&&this.$emit("menuitemclick",e)}},render(){const{title:e,iconClass:r,selected:o,icon:l,svgIcon:n}=this.$props;return t.createVNode("div",{tabindex:0,onKeydown:this.onKeyDown,onClick:this.onClick,class:"k-columnmenu-item "+(o?"k-selected":"")},[r&&t.createVNode(i.Icon,{class:r},null),(l||n)&&t.createVNode(i.Icon,{name:l,icon:n},null),e])}}),kt=t.defineComponent({render(){const e=i.getDefaultSlots(this);return t.createVNode("div",{class:"k-columnmenu-item-wrapper"},[e])}}),St="desc",It={true:{asc:{asc:"",desc:"desc"},desc:{asc:"asc",desc:""},"":{asc:"asc",desc:"desc"}},false:{asc:{asc:"asc",desc:"desc"},desc:{asc:"asc",desc:"desc"},"":{asc:"asc",desc:"desc"}}},yt=(e,t)=>t?t.findIndex((t=>t.field===e)):-1,wt=(e,t)=>!!(t&&e>-1&&"asc"===t[e].dir),Nt=(e,t)=>!!(t&&e>-1&&t[e].dir===St),Rt=t.defineComponent({props:{sortable:[Boolean,Object],sort:{type:Array},column:Object,onSortchange:Function,onClosemenu:Function},inject:{kendoLocalizationService:{default:null}},methods:{onAscClick(e){this.onSort(e,"asc"),this.$emit("closemenu")},onDescClick(e){this.onSort(e,St),this.$emit("closemenu")},onSort(e,t){if(e.preventDefault(),!i.hasListener.call(this,"sortchange"))return;const{column:r,sortable:o,sort:l}=this.$props,{allowUnsort:n,mode:a}=vt(o||!1,!1),s=(l||[]).filter((e=>e.field===r.field))[0],d=It[n][s&&s.dir||""][t],c="single"===a?[]:(this.$props.sort||[]).filter((e=>e.field!==r.field));""!==d&&r.field&&c.push({field:r.field,dir:d}),this.$emit("sortchange",c,{event:e,field:this.$props.column.field})}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const{sort:e,column:i}=this.$props,r=yt(i.field,e),o=l.provideLocalizationService(this);return t.createVNode(kt,null,{default:()=>[t.createVNode($t,{title:o.toLanguageString(se,ht[se]),icon:"sort-asc-small",svgIcon:n.sortAscSmallIcon,selected:wt(r,e),onMenuitemclick:this.onAscClick},null),t.createVNode($t,{title:o.toLanguageString(de,ht[de]),icon:"sort-desc-small",svgIcon:n.sortDescSmallIcon,selected:Nt(r,e),onMenuitemclick:this.onDescClick},null)]})}}),Vt=t.defineComponent({props:{show:Boolean},render(){const e=i.getDefaultSlots(this);return t.createVNode("div",{class:"k-columnmenu-item-content"},[t.createVNode(h.Reveal,{appear:this.$props.show,style:{position:"relative",display:"block"}},{default:()=>[this.$props.show?e:null]})])}}),Ft=[{text:"grid.filterAndLogic",operator:"and"},{text:"grid.filterOrLogic",operator:"or"}],Et={text:[{text:"grid.filterContainsOperator",operator:"contains"},{text:"grid.filterNotContainsOperator",operator:"doesnotcontain"},{text:"grid.filterEqOperator",operator:"eq"},{text:"grid.filterNotEqOperator",operator:"neq"},{text:"grid.filterStartsWithOperator",operator:"startswith"},{text:"grid.filterEndsWithOperator",operator:"endswith"},{text:"grid.filterIsNullOperator",operator:"isnull"},{text:"grid.filterIsNotNullOperator",operator:"isnotnull"},{text:"grid.filterIsEmptyOperator",operator:"isempty"},{text:"grid.filterIsNotEmptyOperator",operator:"isnotempty"}],numeric:[{text:"grid.filterEqOperator",operator:"eq"},{text:"grid.filterNotEqOperator",operator:"neq"},{text:"grid.filterGteOperator",operator:"gte"},{text:"grid.filterGtOperator",operator:"gt"},{text:"grid.filterLteOperator",operator:"lte"},{text:"grid.filterLtOperator",operator:"lt"},{text:"grid.filterIsNullOperator",operator:"isnull"},{text:"grid.filterIsNotNullOperator",operator:"isnotnull"}],date:[{text:"grid.filterEqOperator",operator:"eq"},{text:"grid.filterNotEqOperator",operator:"neq"},{text:"grid.filterAfterOrEqualOperator",operator:"gte"},{text:"grid.filterAfterOperator",operator:"gt"},{text:"grid.filterBeforeOperator",operator:"lt"},{text:"grid.filterBeforeOrEqualOperator",operator:"lte"},{text:"grid.filterIsNullOperator",operator:"isnull"},{text:"grid.filterIsNotNullOperator",operator:"isnotnull"}],boolean:[{text:"grid.filterEqOperator",operator:"eq"}]},At=e=>"isnull"===e||"isnotnull"===e||"isempty"===e||"isnotempty"===e,Dt=(e,t)=>e.map((e=>({text:t.toLanguageString(e.text,ht[e.text]),operator:e.operator}))),Lt=[{text:"grid.filterBooleanAll",operator:""},{text:"grid.filterIsTrue",operator:!0},{text:"grid.filterIsFalse",operator:!1}],Ot=(e,t,i)=>{const r=Ht(i.operators);let o=i.operator;switch(i.filterType){case"numeric":case"date":(!o||At(o))&&(o=r),null===e&&o===r&&(o="");break;case"text":(!o||At(o))&&(o=r),!e&&o===r&&(o="");break;default:return}return{value:e,operator:o,event:t}},Ht=(e,t)=>t?e[t][0].operator:e[0].operator,Tt=e=>e||"text",Gt=(e,t)=>({value:e,operator:""===e?"":"eq",event:t}),_t=(e,t,i)=>(At(e)&&(i=null),{value:i,operator:e,event:t}),zt=t.defineComponent({props:{field:String,filterType:String,value:[Object,String,Number,Date,Boolean],operator:String,operators:Array,booleanValues:Array},emits:{change:null,filtercellfocus:null},methods:{handleFocus(e){this.$emit("filtercellfocus",e)},triggerChange(e){this.$emit("change",e)},inputChange(e,t){const i=Ot(e,t,this.$props);this.triggerChange(i)},boolDropdownChange(e,t){const i=Gt(e.value.operator,t);this.triggerChange(i)}},render(){const{filterType:e,value:i,booleanValues:r}=this.$props;let o;switch(e){case"numeric":return t.createVNode(a.NumericTextBox,{value:i,onChange:e=>{this.inputChange(e.value,e.event)}},null);case"date":return t.createVNode(s.DatePicker,{value:i,onFocus:this.handleFocus,onChange:e=>{this.inputChange(e.value,e.event)}},null);case"boolean":return o=e=>null==e,t.createVNode(u.DropDownList,{onChange:this.boolDropdownChange,value:r.find((e=>e.operator===(o(i)?"":i))),"data-items":r,textField:"text"},null);default:return t.createVNode("span",{class:"k-textbox k-input k-input-md k-rounded-md k-input-solid"},[t.createVNode("input",{class:"k-input-inner",value:i||"",onInput:e=>{this.inputChange(e.target.value,e)}},null)])}}}),Bt=t.defineComponent({props:{filterType:String,operator:String,operators:Array},emits:{change:null},methods:{triggerChange(e){this.$emit("change",e)},operatorChange(e,t){const i=_t(e.value.operator,t,this.$props.value);this.triggerChange(i)}},render(){const e=this.$props.operators.find((e=>e.operator===this.$props.operator))||null;return"boolean"!==this.$props.filterType?t.createVNode(u.DropDownList,{onChange:this.operatorChange,value:e,"data-items":this.$props.operators,textField:"text"},null):null}});function jt(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}const Mt=e=>e||{filters:[],logic:"and"},Kt=(e,t)=>Mt(t).filters.filter((t=>!!c.isCompositeFilterDescriptor(t)&&(t.filters&&t.filters.length&&t.filters.length<=2&&!t.filters.find((t=>c.isCompositeFilterDescriptor(t)||t.field!==e)))))[0]||null,Pt=t.defineComponent({name:"KendoGridColumnMenuFilter",props:{column:Object,filter:Object,expanded:{type:Boolean,default:void 0},filterable:Boolean,filterOperators:{type:Object,default:function(){return Et}},hideSecondFilter:{type:[Boolean,Object],default:function(){}},filterUI:[String,Function,Object],onFilterfocus:Function,onFilterchange:Function,onExpandchange:Function,onClosemenu:Function},inject:{kendoLocalizationService:{default:null}},data:()=>({currentExpanded:!1,filterGroup:null}),created(){let e;if(this.$props.column&&this.$props.column.field){const t=Tt(this.$props.column.filter),i=Ht(this.$props.filterOperators,t);e=Kt(this.$props.column.field,this.$props.filter),e=e?{...e,filters:e.filters.map((e=>({...e})))}:{logic:"and",filters:[{field:this.$props.column.field,operator:i},{field:this.$props.column.field,operator:i}]},1===e.filters.filter((e=>e.field===this.$props.column.field)).length&&e.filters.splice(1,0,{field:this.$props.column.field,operator:i})}this.currentExpanded=this.$props.expanded||!1,this.filterGroup=e},methods:{removeGroup(e,t){const i=[...t.filters],r=i.findIndex((t=>t===e));return r>-1&&i.splice(r,1),{...t,filters:i}},insertGroup:(e,t)=>({...t,filters:[e,...t.filters]}),isControlled(){return void 0!==this.$props.expanded},onFilterExpand(){const e=this.isControlled(),t=!(e?this.$props.expanded:this.currentExpanded);this.$emit("expandchange",t),e||(this.currentExpanded=t)},filterChangeHandler(e,t){this.filterChange(t||0,e)},firstFilterChange(e){this.filterChange(0,e)},secondFilterChange(e){this.filterChange(1,e)},filterChange(e,t){const i=this.filterGroup.filters.map(((i,r)=>r===e?{...i,value:t.value,operator:t.operator}:i));this.filterGroup={...this.filterGroup,filters:i}},logicChange(e){this.filterGroup={...this.filterGroup,logic:e.target.value.operator}},clear(e){if(e.preventDefault(),!i.hasListener.call(this,"filterchange"))return;const t=this.$props.column.field,r=Mt(this.$props.filter),o=Kt(t,this.$props.filter),l=r.filters.filter((e=>e!==o));l.length?this.$emit("filterchange",{...r,filters:l},{event:e,field:this.$props.column.field}):this.$emit("filterchange",null,{event:e,field:this.$props.column.field}),this.$emit("closemenu")},currentFilterGroup(){return{...this.filterGroup,filters:this.filterGroup.filters.filter((e=>void 0!==e.value&&null!==e.value&&""!==e.value||null===e.value&&e.operator))}},submit(e){if(e.preventDefault(),!i.hasListener.call(this,"filterchange"))return;const t=this.$props.column.field,r=Mt(this.$props.filter),o=Kt(t,this.$props.filter),l=this.currentFilterGroup();let n=null;if(o&&l.filters.length>0){const e=r.filters.map((e=>e===o?l:e));n={...r,filters:e}}else if(0===l.filters.length){const e=r.filters.filter((e=>e!==o));e.length&&(n={...r,filters:e})}else n={...r,filters:[...r.filters,l]};this.$emit("filterchange",n,{event:e,field:this.$props.column.field}),this.$emit("closemenu")},handleFocus(e){this.$emit("filterfocus",e)}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){let e,r;const{column:o,filterUI:a,hideSecondFilter:s,filterOperators:d}=this.$props;if(!o||!o.field)return t.createVNode("div",null,null);const c=o.filter||"text",h=l.provideLocalizationService(this),g=this.filterGroup.filters,f=Dt(d[c],h),m=Dt(Lt,h),v={field:o.field,value:g[0].value,operator:g[0].operator,booleanValues:m,filterType:c},b={field:o.field,value:g[1].value,operator:g[1].operator,booleanValues:m,filterType:c},C=this.filterGroup.logic,x=Dt(Ft,h),$={value:x.find((e=>e.operator===(null===C?"":C))),data:x},k=0!==this.currentFilterGroup().filters.length,S=this.isControlled()?this.$props.expanded:this.currentExpanded,I=v.field,y=v.value,w=v.operator,N=v.booleanValues,R=v.filterType,V=b.field,F=b.value,E=b.operator,A=b.booleanValues,D=b.filterType,L=a&&i.templateRendering.call(this,a,i.getListeners.call(this)),O=i.getTemplate.call(this,{h:t.h,template:L,defaultRendering:void 0,additionalProps:this.$props,additionalListeners:{change:this.filterChangeHandler,logicchange:this.logicChange}});return t.createVNode(kt,null,{default:()=>[t.createVNode($t,{title:h.toLanguageString(ae,ht[ae]),icon:"filter",svgIcon:n.filterIcon,onMenuitemclick:this.onFilterExpand},null),t.createVNode(Vt,{show:!!S},{default:()=>[t.createVNode("div",{class:"kendo-grid-filter-menu-container"},[t.createVNode("form",{class:"k-filter-menu k-border-up",onSubmit:this.submit,onReset:this.clear},[t.createVNode("div",{class:"k-filter-menu-container"},[!a&&[t.createVNode(Bt,{operator:w,filterType:R,onChange:e=>{this.filterChangeHandler(e,0)},operators:f},null),t.createVNode(zt,{field:I,value:y,operator:w,booleanValues:N,filterType:R,onFiltercellfocus:this.handleFocus,onChange:e=>{this.filterChangeHandler(e,0)},operators:f},null)],!s&&!a&&[t.createVNode(u.DropDownList,{onChange:this.logicChange,class:"k-filter-and","data-items":$.data,value:$.value,textField:"text"},null),t.createVNode(Bt,{operator:E,filterType:D,onChange:e=>{this.filterChangeHandler(e,1)},operators:f},null),t.createVNode(zt,{field:V,value:F,operator:E,booleanValues:A,filterType:D,onFiltercellfocus:this.handleFocus,onChange:e=>{this.filterChangeHandler(e,1)},operators:f},null)],a&&O,t.createVNode("div",{class:"k-columnmenu-actions"},[t.createVNode(p.Button,{themeColor:"primary",disabled:!k},jt(e=h.toLanguageString(ne,ht[ne]))?e:{default:()=>[e]}),t.createVNode(p.Button,{type:"reset"},jt(r=h.toLanguageString(re,ht[re]))?r:{default:()=>[r]})])])])])]})]})}}),Wt=t.defineComponent({name:"KendoColumnMenuContent",inheritAttrs:!1,props:{column:Object,sortable:[Boolean,Object],sort:{type:Array},filter:Object,filterOperators:Object,filterable:Boolean,render:[Boolean,String,Function,Object],onContentfocus:Function,onClosemenu:Function,onSortchange:Function,onExpandchange:Function,onFilterchange:Function},methods:{handleFocus(e){this.$emit("contentfocus",e)},closeMenu(){this.$emit("closemenu")},expandChange(){this.$emit("expandchange")},sortChange(e,t){this.$emit("sortchange",e,t)},filterChange(e,t){this.$emit("filterchange",e,t)},contentKeyDown(e){e.keyCode===i.Keys.esc&&this.$emit("closemenu")}},render(){const e=this.$props.render,r=t.createVNode("div",{style:this.$attrs.style,onKeydown:this.contentKeyDown},[t.createVNode(Rt,{column:this.$props.column,sortable:this.$props.sortable,sort:this.$props.sort,onClosemenu:this.closeMenu,onSortchange:this.sortChange},null),t.createVNode(Pt,{column:this.$props.column,filterable:this.$props.filterable,filter:this.$props.filter,filterOperators:this.$props.filterOperators,onFilterfocus:this.handleFocus,onClosemenu:this.closeMenu,onExpandchange:this.expandChange,onFilterchange:this.filterChange},null)]);return i.getTemplate.call(this,{h:t.h,template:"boolean"!=typeof e&&e,defaultRendering:r,additionalProps:this.$props,additionalListeners:{closemenu:this.closeMenu,filterchange:this.filterChange,sortchange:this.sortChange,expandchange:this.expandChange,contentfocus:this.handleFocus}})}}),qt=t.defineComponent({name:"KendoColumnMenu",props:{animate:{type:[Boolean,Object],default:function(){return!0}},column:Object,sortable:[Boolean,Object],sort:{type:Array},opened:Boolean,filter:Object,filterable:Boolean,filterOperators:Object,render:[Boolean,String,Function,Object],columnMenuIcon:i.SvgIcon,onClose:Function,onSortchange:Function,onFilterchange:Function},inject:{kendoIntlService:{default:null},kendoLocalizationService:{default:null}},data:()=>({show:!1,blurTimeout:void 0}),created(){this._anchor=i.guid()},computed:{currentOpen(){return this.show||this.$props.opened}},watch:{currentOpen:function(e){this.$nextTick((function(){if(this._content=this.$refs.content,e&&this._content){const e=r.tableKeyboardNavigationTools.getFocusableElements(this._content,{focusable:!0});e.length?e[0].focus():this._content.focus()}}))}},methods:{blur(){clearTimeout(this.blurTimeout),this.blurTimeout=setTimeout((()=>{this.closeMenu()}),200)},focus(){clearTimeout(this.blurTimeout)},handleFocus(e){clearTimeout(this.blurTimeout)},anchorClick(e){e.preventDefault(),this.show=!this.show},closeMenu(){this.$emit("close"),this.show=!1},sortChange(e,t){this.$emit("sortchange",e,t)},filterChange(e,t){this.$emit("filterchange",e,t)}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const e=this.$props.render,r=l.provideLocalizationService(this),{columnMenuIcon:o}=this.$props;return t.createVNode("div",{style:{display:"inline"}},[t.createVNode("a",{class:"k-grid-header-menu k-grid-column-menu",title:`${this.$props.column.field} ${r.toLanguageString(te,ht[te])}`,ref:i.setRef(this,"kendoAnchor"),onClick:this.anchorClick,href:"#"},[o?t.createVNode(i.Icon,{name:o.name,icon:o},null):t.createVNode(i.Icon,{name:"more-vertical",icon:n.moreVerticalIcon},null)]),t.createVNode(d.Popup,{animate:this.$props.animate,anchor:this._anchor,show:this.currentOpen},{default:()=>[t.createVNode("div",{ref:"content",class:"k-column-menu k-grid-columnmenu-popup",tabindex:0,onFocusout:this.blur,onFocusin:this.focus,style:{outline:"none",width:"230px"}},[t.createVNode(Wt,{column:this.$props.column,sortable:this.$props.sortable,sort:this.$props.sort,filter:this.$props.filter,filterable:this.$props.filterable,filterOperators:this.$props.filterOperators,render:e,onContentfocus:this.handleFocus,onClosemenu:this.closeMenu,onSortchange:this.sortChange,onFilterchange:this.filterChange},null)])]})])}});function Ut(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}const Yt={none:"none",asc:"ascending",desc:"descending"},Xt={true:{asc:"desc",desc:"","":"asc"},false:{asc:"desc",desc:"asc","":"asc"}},Jt=t.defineComponent({name:"KendoHeaderRow",props:{grid:Object,cellRender:[String,Function,Object],groupable:[Boolean,Object],reorderable:Boolean,sortable:[Boolean,Object],sort:{type:Array},filter:Object,filterable:Boolean,filterOperators:Object,filterChange:Function,filterRow:Object,columns:Array,columnsMap:Array,columnResize:Object,columnMenu:[Boolean,String,Function,Object],columnMenuAnimate:{type:[Boolean,Object],default:function(){return!0}},columnMenuIcon:Object,isRtl:Boolean,isColCountDefined:Boolean,columnsInitial:Array,onSortChange:Function,onFilterChange:Function,onSelectionchange:Function,onPressHandler:Function,onDragHandler:Function,onReleaseHandler:Function},inject:{onNavFocus:{default:i.noop},kendoLocalizationService:{default:null}},data:()=>({columnMenuOpened:{}}),created(){this.serviceIndex=0,this.index=-1,this._element=null,this.cellClick=this.cellClick.bind(this)},methods:{pressHandler(e,t){this.$emit("pressHandler",e,t)},dragHandler(e,t){this.$emit("dragHandler",e,t)},releaseHandler(e){this.$emit("releaseHandler",e)},selectionChangeHandler(e){this.$emit("selectionchange",e)},cellClick(e,t){if(e.preventDefault(),!i.hasListener.call(this,"sortChange"))return;const{allowUnsort:r,mode:o}=vt(this.$props.sortable||!1,t.sortable||!1),l=(this.$props.sort||[]).filter((e=>e.field===t.field))[0],n=Xt[r][l&&l.dir||""],a="single"===o?[]:(this.$props.sort||[]).filter((e=>e.field!==t.field));""!==n&&t.field&&a.push({field:t.field,dir:n}),this.sortChangeHandler(a,{event:e,field:t.field})},sortChangeHandler(e,t){this.$emit("sortChange",e,t)},filterChangeHandler(e,t){this.$emit("filterChange",e,t)},cellClass(e,t,i){let r="k-header"+(i?" k-grid-header-sticky":"")+(t?" "+t:"");return this.$props.sort&&this.$props.sort.filter((t=>t.field===e)).length>0&&(r+=" k-sorted"),r},cellKeyDown(e,t){e.defaultPrevented||(e.keyCode===i.Keys.enter&&this.cellClick(e,t),e.altKey&&e.keyCode===i.Keys.down&&t.field&&(e.preventDefault(),this.columnMenuOpened={[t.field]:!0}))},getTemplate(e){return i.templateRendering.call(this.$props.grid,e,i.getListeners.call(this.$props.grid))},columnMenuClose(){this.onNavFocus({}),this.columnMenuOpened={}}},computed:{element(){return this._element},theadClasses:()=>({"k-table-thead":!0})},render(e){const o=l.provideLocalizationService(this),a=o.toLanguageString(xe,ht[xe]),s=o.toLanguageString($e,ht[$e]),d=o.toLanguageString(ke,ht[ke]);this.serviceIndex=0,this.index=-1;const c=function(e){return e.map((function(e){const o=this.$props.columns[e],l=this.$props.sortable&&o.sortable,c=this.$props.sort?this.$props.sort.findIndex((e=>e.field===o.field)):-1,h=c>=0&&this.$props.sort[c].dir||"none",p=function(e){if(!this.$props.sort)return null;const r=e>=0?this.$props.sort[e].dir:"";return e>=0&&[t.createVNode("span",{key:1,class:"k-sort-icon"},[t.createVNode(i.Icon,{name:"sort-"+r+"-small",icon:"asc"===r?n.sortAscSmallIcon:n.sortDescSmallIcon},null)]),this.$props.sort.length>1&&t.createVNode("span",{key:2,class:"k-sort-icon"},[t.createVNode("span",{class:"k-sort-order"},[e+1])])]}.call(this,c),u=o.columnMenu||!1===o.columnMenu?o.columnMenu:this.$props.columnMenu,g=o.menuIcon||this.$props.columnMenuIcon,f=(o.kFirst?"k-first ":"")+this.cellClass(o.field,o.headerClassName,o.locked)+(u?" k-filterable":""),m=u&&"boolean"!=typeof u?this.getTemplate(u):!!u,v=void 0!==o.left?this.$props.isRtl?{left:o.right+"px",right:o.left+"px"}:{left:o.left+"px",right:o.right+"px"}:{},b="none"===Yt[h]?a:"ascending"===Yt[h]?s:d;let C=o.isAccessible?{ariaSort:Yt[h],ariaLabel:b,role:"columnheader",ariaColumnIndex:this.$props.isColCountDefined?this.$props.columnsInitial.findIndex((e=>e.field===o.field))+1:void 0,ariaSelected:!1,ariaHaspopup:u?"menu":this.$props.filterable&&o.filterable?"dialog":void 0}:{role:"columnheader"};const x=o.declarationIndex>=0?++this.index:--this.serviceIndex,$=void 0!==o.columnMenuOpened?o.columnMenuOpened:this.columnMenuOpened[o.field];return t.createVNode(r.HeaderThElement,{ariaSort:l?C.ariaSort:void 0,ariaLabel:l?C.ariaLabel:void 0,role:C.role,ariaColumnIndex:C.ariaColumnIndex,ariaSelected:C.ariaSelected,ariaHaspopup:C.ariaHaspopup,key:x,colSpan:o.headerColSpan,rowSpan:o.rowSpan,class:f,style:v,columnId:o.id,navigatable:o.navigatable,onKeydown:e=>this.cellKeyDown(e,o)},{default:()=>[[0===o.children.length&&u&&t.createVNode(qt,{key:0,column:{field:o.field,filter:o.filter},opened:$,animate:this.$props.columnMenuAnimate,sortable:l,sort:this.$props.sort,onClose:this.columnMenuClose,onSortchange:this.sortChangeHandler,filter:this.$props.filter,filterable:this.$props.filterable&&o.filterable,filterOperators:this.$props.filterOperators,onFilterchange:this.filterChangeHandler,render:m,columnMenuIcon:g},null),o.internalHeaderCell&&t.createVNode("span",{class:"k-cell-inner"},[t.createVNode(o.internalHeaderCell,{key:1,field:o.field,sortable:l,onHeadercellclick:e=>this.cellClick(e,o),onSelectionchange:this.selectionChangeHandler,selectionValue:o.headerSelectionValue,title:o.title,render:(o.headerCell||this.$props.cellRender)&&this.getTemplate(o.headerCell||this.$props.cellRender)},Ut(p)?p:{default:()=>[p]})])||t.createVNode("span",{class:"k-cell-inner"},[t.createVNode(xt,{key:1,field:o.field,sortable:l,onHeadercellclick:e=>this.cellClick(e,o),selectionValue:o.headerSelectionValue,title:o.title,render:(o.headerCell||this.$props.cellRender)&&this.getTemplate(o.headerCell||this.$props.cellRender)},Ut(p)?p:{default:()=>[p]})]),this.$props.columnResize&&this.$props.columnResize.resizable&&o.resizable&&t.createVNode(bt,{key:2,onResize:(e,t,i)=>this.$props.columnResize&&this.$props.columnResize.dragHandler(e,o,t,i)},null)]]})}),this)};return t.createVNode("thead",{role:"rowgroup",class:this.theadClasses,"data-keyboardnavheader":!0},[this.$props.columnsMap.map((function(e,i){let r;return(this.$props.groupable||this.$props.reorderable)&&t.createVNode(Ct,{key:i,onPressHandler:this.pressHandler,onDragHandler:this.dragHandler,onReleaseHandler:this.releaseHandler},Ut(r=c.call(this,e))?r:{default:()=>[r]})||t.createVNode("tr",{class:"k-table-row",role:"row","aria-rowindex":this.columnsMap.length},[c.call(this,e)])}),this),this.$props.filterRow])}}),Qt=t.defineComponent({name:"KendoGridFilterCell",inheritAttrs:!1,props:{id:String,grid:Object,field:String,filterType:String,colSpan:Number,title:String,value:[String,Number,Boolean,Date],operator:[String,Function],operators:Array,booleanValues:Array,onChange:Function,render:[String,Function,Object],ariaLabel:String,size:String},inject:{kendoLocalizationService:{default:null},kendoIntlService:{default:null}},methods:{inputChange(e,t){const i=Ot(e,t,this.$props);this.triggerChange(i)},operatorChange(e,t){const i=_t(e.value.operator,t,this.$props.value);this.triggerChange(i)},boolDropdownChange(e,t){const i=Gt(e.value.operator,t);this.triggerChange(i)},clear(e){e.preventDefault(),this.triggerChange({value:"",operator:"",event:e})},triggerChange(e){e.field=this.$props.field,this.$emit("change",e)}},setup:()=>({kendoIntlService:t.inject("kendoIntlService",{}),kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const e=l.provideLocalizationService(this),{size:r}=this.$props,o=this.$props.operators.find((e=>e.operator===this.$props.operator))||null,d=t.createVNode("div",{class:"k-filtercell",style:this.$attrs.style},[t.createVNode("div",{class:"k-filtercell-wrapper"},[function(e,i){let o;switch(e){case"numeric":return t.createVNode(a.NumericTextBox,{size:r,value:i,onChange:e=>{this.inputChange(e.value,e.event)},title:this.$props.title,ariaLabel:this.ariaLabel},null);case"date":return t.createVNode(s.DatePicker,{size:r,value:i,onChange:e=>{this.inputChange(e.value,e)},title:this.$props.title,ariaLabel:this.ariaLabel},null);case"boolean":return o=this.$props.booleanValues,t.createVNode(u.DropDownList,{onChange:this.boolDropdownChange,size:r,value:o.find((e=>e.operator===(null!==i?i:""))),"data-items":o,textField:"text",title:this.$props.title,ariaLabel:this.ariaLabel},null);default:return t.createVNode(a.TextBox,{value:i||"",size:r,onInput:e=>{this.inputChange(e.target.value,e)},title:this.$props.title,"aria-label":this.ariaLabel},null)}}.call(this,this.$props.filterType,this.$props.value),t.createVNode("div",{class:"k-filtercell-operator"},[function(){if("boolean"!==this.$props.filterType)return t.createVNode(u.DropDownList,{onChange:this.operatorChange,value:o,size:r,class:"k-dropdown-operator",icon:"filter",svgIcon:n.filterIcon,iconClassName:"filter k-button-icon","data-items":this.$props.operators,textField:"text",title:e.toLanguageString(me,ht[me]),popupSettings:{width:"",anchor:""},ariaLabel:this.ariaLabel},null)}.call(this),t.createTextVNode(" "),t.createVNode(p.Button,{type:"button",size:r,icon:"filter-clear",svgIcon:n.filterClearIcon,class:{"k-disabled":!(null!==this.$props.value&&""!==this.$props.value||this.$props.operator)},title:e.toLanguageString(re,ht[re]),onClick:this.clear},null)])])]),c=this.$props.grid?i.getListeners.call(this.$props.grid):null,h=i.templateRendering.call(this.$props.grid,this.$props.render,c);return i.getTemplate.call(this,{h:t.h,template:h,defaultRendering:d,additionalProps:this.$props,additionalListeners:{change:this.triggerChange}})}});const Zt=t.defineComponent({name:"kendoFilterRow",props:{grid:Object,columns:Array,filter:Object,filterOperators:Object,sort:[Object,Array],cellRender:[String,Function,Object],isRtl:Boolean,ariaRowIndex:Number,size:String,onFilterchange:Function},inject:{kendoLocalizationService:{default:null}},methods:{headerCellClassName(e,t){let i=t?" k-grid-header-sticky":"";return this.$props.sort&&this.$props.sort.filter((t=>t.field===e)).length>0&&(i+=" k-sorted"),i},setFilter(e,t,i,r){const o=[];(""!==e&&null!==e||""!==t)&&o.push({field:i,operator:t,value:e}),this.$props.filter&&this.$props.filter.filters&&(this.$props.filter.filters||[]).forEach((e=>{const t=e;t&&t.field!==i&&o.push(t)}));const l=o.length>0?{logic:"and",filters:o}:null;this.$emit("filterchange",l,r)}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const e=l.provideLocalizationService(this),i=this.$props.filter&&this.$props.filter.filters||[],o=(e,t=null)=>{const r=i.filter((t=>t.field===e))[0];return r?r.value:t},n=e=>{const t=i.filter((t=>t.field===e))[0];return t?t.operator:null};let a=0,s=-1;const d=this.$props.columns.filter((e=>0===e.children.length)).map((function(i){const l=Tt(i.filter),d=(i.title||i.field)+" "+((e,t)=>{switch(e){case"text":return t.toLanguageString(Xe,ht[Xe]);case"numeric":return t.toLanguageString(Ne,ht[Ne]);case"boolean":return t.toLanguageString(Je,ht[Je]);case"date":return t.toLanguageString(Ye,ht[Ye]);default:return}})(l,e),c=t.createVNode(Qt,{grid:this.$props.grid,field:i.field,title:i.filterTitle,value:o(i.field,"text"===l?"":null),operator:n(i.field),operators:Dt(this.$props.filterOperators[l]||[],e),booleanValues:Dt(Lt,e),filterType:l,onChange:e=>{this.setFilter(e.value,e.operator,i.field,e)},render:i.filterCell||this.$props.cellRender,"aria-label":d,size:this.$props.size},null),h=i.declarationIndex>=0?++s:--a,p={ariaLabel:i.filterable?e.toLanguageString(we,ht[we]):void 0,ariaColumnIndex:i.ariaColumnIndex},u=void 0!==i.left?this.$props.isRtl?{left:i.right+"px",right:i.left+"px"}:{left:i.left+"px",right:i.right+"px"}:{},g=t.createVNode(r.HeaderTdElement,{key:h,role:"gridcell",columnId:r.tableKeyboardNavigationTools.getFilterColumnId(i.id),navigatable:i.navigatable,style:u,class:this.headerCellClassName(i.field,i.locked)||void 0,ariaColumnIndex:p.ariaColumnIndex,"aria-label":d},function(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}(c)?c:{default:()=>[c]});return i.filterable&&g||t.createVNode(r.HeaderTdElement,{key:h,role:"gridcell",columnId:r.tableKeyboardNavigationTools.getFilterColumnId(i.id),navigatable:i.navigatable,style:u,class:this.headerCellClassName(i.field,i.locked)||void 0,ariaColumnIndex:p.ariaColumnIndex,"aria-label":d},null)}),this);return t.createVNode("tr",{class:"k-table-row k-filter-row","aria-rowindex":this.ariaRowIndex,role:"row"},[d])}}),ei=t.defineComponent({props:{title:String,dir:String,onRemove:Function,onSortChange:Function,onPress:Function,onDrag:Function,onRelease:Function},mounted(){this.element=i.getRef(this,"indicatorContainer"),this.element&&(this.draggable=this.$refs.draggable)},methods:{press(e){this.element&&this.$emit("press",e,this.element)},drag(e){this.element&&this.$emit("drag",e,this.element)},release(e){this.element&&this.$emit("release",e,this.element)},sortChange(e){e.preventDefault();const t="asc"===this.$props.dir?"desc":"asc";this.$emit("sortChange",e,t)},groupRemove(e){e.preventDefault(),this.$emit("remove",e)}},setup:()=>({indicatorContainerRef:t.ref(null)}),render(){return t.createVNode(i.Draggable,{onPress:this.press,onDrag:this.drag,onRelease:this.release,ref:"draggable"},{default:()=>[t.createVNode("div",{class:"k-chip k-chip-md k-chip-solid k-chip-solid-base k-rounded-md",ref:i.setRef(this,"indicatorContainer")},[t.createVNode(i.Icon,{name:"sort-"+this.$props.dir+"-small",class:"k-chip-icon",icon:"asc"===this.$props.dir?n.sortAscSmallIcon:n.sortDescSmallIcon},null),t.createVNode("span",{class:"k-chip-content",tabindex:-1,onClick:this.sortChange},[this.$props.title]),t.createVNode("span",{class:"k-chip-actions"},[t.createVNode("span",{class:"k-chip-action k-chip-remove-action",tabindex:-1,onClick:this.groupRemove},[t.createVNode(i.Icon,{name:"x-circle",icon:n.xCircleIcon},null)])])])]})}}),ti=t.defineComponent({props:{group:Array,resolveTitle:Function,ariaControls:String,onPressHandler:Function,onDragHandler:Function,onReleaseHandler:Function,onGroupChange:Function},inject:{kendoLocalizationService:{default:null}},methods:{pressHandler(e,t){this.$emit("pressHandler",e,t)},dragHandler(e,t){this.$emit("dragHandler",e,t)},releaseHandler(e){this.$emit("releaseHandler",e)},onGroupRemove(e,t){const i=this.$props.group.slice();i.splice(t,1),this.$emit("groupChange",i,e)},onGroupSortChange(e,t,i,r){const o=Object.assign({},i,{dir:r}),l=this.$props.group.slice();l.splice(t,1,o),this.$emit("groupChange",l,e)}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const e=this.$props.group||[],i=this.$props.ariaControls,r=e.map((function(e,i){return t.createVNode(ei,{key:i,dir:e.dir||"asc",title:this.$props.resolveTitle(e.field),onRemove:e=>this.onGroupRemove(e,i),onSortChange:(t,r)=>{this.onGroupSortChange(t,i,e,r)},onPress:this.pressHandler,onDrag:this.dragHandler,onRelease:this.releaseHandler},null)}),this),o=l.provideLocalizationService(this).toLanguageString(Qe,ht[Qe]);return t.createVNode("div",{class:"k-grouping-header",role:"toolbar","aria-label":o,"aria-controls":i},[!!r.length&&t.createVNode("div",{class:"k-chip-list k-chip-list-md"},[r]),t.createVNode("div",{class:"k-grouping-drop-container"},[!r.length&&l.provideLocalizationService(this).toLanguageString(Q,ht[Q])])])}}),ii=t.defineComponent({name:"Footer",props:{staticHeaders:Boolean,row:Object,columnResize:Object,cols:Array,size:String},data:()=>({scrollbarWidth:0,rtl:!1,tableWidth:null}),computed:{tableClass(){const{size:e}=this.$props;return{"k-table":!0,"k-grid-footer-table":!0,[`k-table-${i.kendoThemeMaps.sizeMap[e]||e}`]:e}},tableStyle(){return this.tableWidth?{width:this.tableWidth}:null}},mounted(){this.rtl=C(this.$el),this.$props.columnResize.colGroupFooter=i.getRef(this,"colGroupHeader"),this._footerWrap=i.getRef(this,"footerWrap")},methods:{setScrollLeft(e){this._footerWrap&&(this._footerWrap.scrollLeft=e)},setWidth(e){this.$data.tableWidth=e+"px"}},setup(){const e=t.ref(null);return{colGroupHeaderRef:t.ref(null),footerWrapRef:e}},render(){return this.$props.staticHeaders?t.createVNode("div",{class:"k-grid-footer",role:"presentation"},[t.createVNode("div",{class:"k-grid-footer-wrap",ref:i.setRef(this,"footerWrap"),role:"presentation"},[t.createVNode("table",{class:this.tableClass,style:this.tableStyle,role:"presentation"},[t.createVNode("colgroup",{ref:i.setRef(this,"colGroupHeader")},[this.$props.cols]),t.createVNode("tfoot",{class:"k-table-tfoot",role:"rowgroup"},[this.$props.row])])])]):t.createVNode("tfoot",{class:"k-table-tfoot k-grid-footer",role:"rowgroup"},[this.$props.row])}}),ri=t.defineComponent({name:"FooterRow",props:{isRtl:Boolean,columns:Array,rowIndex:Number},methods:{columnStyles(e){return void 0!==e.left?this.$props.isRtl?{left:e.right+"px",right:e.left+"px"}:{left:e.left+"px",right:e.right+"px"}:{}}},render(){return t.createVNode("tr",{class:"k-table-row",role:"row","aria-rowIndex":this.$props.rowIndex},[N(this.$props.columns).map((function(e,r){let o=null;const l=e.locked&&void 0!==e.left?"k-grid-footer-sticky":"",n=e.footerClassName?`k-table-td ${e.footerClassName} ${l}`:"k-table-td "+l;return o=i.getTemplate.call(this,{h:t.h,template:e.footerCell,defaultRendering:null,additionalProps:{field:e.field,colSpan:1!==e.colSpan?e.colSpan:void 0,defaultStyle:this.columnStyles(e)}}),t.createVNode("td",{key:r,colspan:1!==e.colSpan?e.colSpan:void 0,style:this.columnStyles(e),class:n,role:"gridcell"},[o])}),this)])}});let oi=class{constructor(){this.table=null,this.tableBody=null,this.container=null,this.scrollHeightContainer=null,this.total=0,this.scrollableVirtual=!1,this.pageSize=0,this.fixedScroll=!1,this.tableTransform="",this.scrollSyncing=!1,this.firstToLoad=0,this.lastScrollTop=0,this.firstLoaded=0,this.lastLoaded=0,this.scrollHandler=this.scrollHandler.bind(this)}reset(){this.firstToLoad=0,this.firstLoaded=0,this.lastLoaded=0,this.rowHeightService=void 0,!this.fixedScroll&&this.container&&0!==this.container.scrollTop&&(this.scrollSyncing=!0,this.container.scrollTop=0,this.lastScrollTop=0,this.translate(0,!0))}scrollHandler(e){if(this.scrollSyncing)return void(this.scrollSyncing=!1);if(!(this.scrollableVirtual&&this.container&&this.table&&this.rowHeightService&&this.container))return;const t=this.container.scrollTop,i=this.lastScrollTop>=t,r=!i;this.lastScrollTop=t;const o=this.container.offsetHeight;let l=this.rowHeightService.index(t);const n=this.rowHeightService.index(t+o),a=Math.max(l+this.pageSize-this.total,0);if(l=Math.max(l-a,0),r&&n>=this.lastLoaded&&this.lastLoaded<this.total-1)this.firstToLoad=l,this.loadPage(e);else if(i&&l<this.firstToLoad){const t=Math.max(Math.floor(.3*this.pageSize)-a,0);this.firstToLoad=Math.max(l-t,0),this.loadPage(e)}}update(){var e;const t=this.getItemHeights();if(this.firstLoaded>this.firstToLoad){const e=Math.min(this.firstLoaded-this.firstToLoad,this.pageSize),i=this.getTotalHeight(e,t)-this.getExpectedTotalHeight(e);0!==i&&this.adjustScroll(i)}null==(e=this.rowHeightService)||e.update(this.firstToLoad,t),this.setScrollHeightContainerHeight(),this.firstLoaded=this.firstToLoad,this.lastLoaded=this.firstLoaded+t.length-1}loadPage(e){this.rowHeightService&&(this.translate(this.rowHeightService.offset(this.firstToLoad)),this.changePage(this.firstToLoad,e))}translate(e,t){this.scrollableVirtual&&this.table&&(t?this.table.style.transform="translateY("+e+"px)":this.tableTransform="translateY("+e+"px)")}changePage(e,t){this.PageChange&&this.PageChange({skip:Math.max(0,e),take:this.pageSize},t)}adjustScroll(e){this.scrollSyncing=!0,this.container&&(this.container.scrollTop+=e)}setScrollHeightContainerHeight(){var e;if(this.scrollableVirtual&&this.scrollHeightContainer){let t=(null==(e=this.rowHeightService)?void 0:e.totalHeight())||0;t=D?Math.min(L,t):t,this.scrollHeightContainer.style.height=t+"px"}}getItemHeights(){const e=[];return this.tableBody&&Array.from(this.tableBody.children).forEach((t=>{const i=t.getBoundingClientRect().height;t.classList.contains("k-detail-row")?e[e.length-1]+=i:e.push(i)})),e}getTotalHeight(e,t){return t.slice(0,e).reduce(((e,t)=>e+t),0)}getExpectedTotalHeight(e){const t=this.rowHeightService;if(!t)return 0;const i=this.firstToLoad+(e-1);return t.offset(i)+t.height(i)-t.offset(this.firstToLoad)}};class li{constructor(e){this.columns=[],this.columnsState=[],this.resizable=!1,this.isRtl=!1,this.setIsRtl=e=>{this.isRtl=e},this.initWidths=()=>{var e;const t=(null==(e=this.colGroupMain)?void 0:e.children)||[],i=A(this.columnsState),r=this.columns.filter((e=>{var t;return!(null!=(t=e.children)&&t.length)}));for(let e=0;e<t.length;e++){const o=t[e];let l="";const n=i.find((t=>t.id===r[e].id));n&&(l=n.width||""),o.width=l,this.colGroupHeader&&(this.colGroupHeader.children[e].width=l),this.colGroupFooter&&(this.colGroupFooter.children[e].width=l)}},this.dragHandler=(e,t,i,r)=>{const o=e.originalEvent;r||(o.preventDefault(),o.stopPropagation(),o.stopImmediatePropagation());const l=i.closest("th");if(!l)return;const n=l.clientWidth;let a=n;if(this.isRtl?a+=i.getBoundingClientRect().right-i.offsetWidth/2-e.clientX:a+=e.clientX-i.getBoundingClientRect().left-i.offsetWidth/2,!r&&Math.abs(a-n)<1)return;this.fixateInitialWidths(l.parentElement.clientWidth),this.setWidths(t,Math.floor(a)/n);const s=this.columns.filter((e=>!e.children.length)).findIndex((e=>e.id===t.id));this.onResize(s,n,a,o,r,this.columnsState,t.id)},this.dblClickHandler=(e,t)=>{const i=this.columns.filter((e=>t.indexOf(e.id)>-1)),r=A(this.columnsState);if(!this.colGroupMain||!i.length)return;const o={},l=i;for(;l.length>0;){const e=l.pop();if(!e)break;e.children.length?l.push(...e.children):o[e.id]=e}const n=this.columns.filter((e=>!e.children.length)),a=[];n.forEach(((e,t)=>{o[e.id]&&a.push(t)}));const s=[this.colGroupMain.parentElement],d=[this.colGroupMain];this.colGroupHeader&&(s.push(this.colGroupHeader.parentElement),d.push(this.colGroupHeader)),this.colGroupFooter&&(s.push(this.colGroupFooter.parentElement),d.push(this.colGroupFooter)),s.forEach((e=>e.classList.add("k-autofitting")));const c=[];d.forEach((e=>{a.forEach((t=>{e.children[t]&&(e.children[t].width="",c[t]=Math.max(c[t]||0,e.children[t].offsetWidth+1))}))})),d.forEach((e=>{a.forEach((t=>{if(e.children[t]){e.children[t].width=c[t]+"px";const i=r.find((e=>e.id===n[t].id));i&&(i.width=c[t])}}))})),s.forEach((e=>e.classList.remove("k-autofitting"))),this.onResize(a[0],0,0,e,!0,this.columnsState,t[0])},this.updateColElements=e=>{var t,i,r;const o=this.columns.filter((e=>!e.hidden&&!e.children.length));let l=1e-10;for(let n=0;n<e.length;n++){const a=e[n],s=o.findIndex((e=>e.id===a.id)),d=parseFloat((a.width||0).toString()),c=Math.floor(d);l+=d-c;const h=c+Math.floor(l);l-=Math.floor(l);const p=o.find((e=>e.id===a.id));if(!p)return;if(null!=(t=this.colGroupMain)&&t.children[s]){const e=parseInt(this.colGroupMain.children[s].width,10);this.colGroupMain.children[s].width=h+"px",this.updateNextLockedCol(this.colGroupMain.parentElement,p,e-h)}if(null!=(i=this.colGroupHeader)&&i.children[s]){const e=parseInt(this.colGroupHeader.children[s].width,10);this.colGroupHeader.children[s].width=h+"px",this.updateNextLockedCol(this.colGroupHeader.parentElement,p,e-h)}if(null!=(r=this.colGroupFooter)&&r.children[s]){const e=parseInt(this.colGroupFooter.children[s].width,10);this.colGroupFooter.children[s].width=h+"px",this.updateNextLockedCol(this.colGroupFooter.parentElement,p,e-h)}}},this.onResize=e}fixateInitialWidths(e){var t;let i=0;const r=(null==(t=this.colGroupMain)?void 0:t.children)||[];for(let t=0;t<r.length;t++)r[t].width?e-=r[t].clientWidth:i++;if(0===i)return;const o=Math.floor(e/i),l=A(this.columnsState),n=this.columns.filter((e=>!e.children.length));for(let e=0;e<r.length;e++){const t=r[e],i=t.width?t.clientWidth:o;t.width=i;const a=l.find((t=>t.id===n[e].id));a&&(a.width=i.toString()),this.colGroupHeader&&(this.colGroupHeader.children[e].width=i),this.colGroupFooter&&(this.colGroupFooter.children[e].width=i)}}setWidths(e,t){const i=A(this.columnsState),r=this.columns.findIndex((t=>t.id===e.id)),o=[];let l=e.children.filter((e=>!e.hidden)).length;for(let e=r+1;e<this.columns.length&&!(l<=0);e++){const t=this.columns[e];t.children.length?l+=t.children.filter((e=>!e.hidden)).length:o.push(t),l--}0===o.length&&o.push(e);const n=[];o.forEach((e=>{const r=i.find((t=>t.id===e.id));if(r){let i=r.width?parseFloat(r.width.toString())*t:0;const o=void 0===e.minResizableWidth?10:e.minResizableWidth;i<o&&(i=o),r.width=i,n.push(r)}})),this.updateColElements(n)}updateNextLockedCol(e,t,i){const r=t.index,o=this.colGroupMain.parentElement.closest(".k-grid"),l=null==o?void 0:o.clientWidth,n=this.columns.filter((e=>e.locked)).map((e=>parseInt(e.width+"",10))).reduce(((e,t)=>e+t),0);!t.locked||l<=n+20||this.columns.forEach((t=>{if(null!=t&&t.locked&&i){const o=null==e?void 0:e.querySelectorAll('[aria-colindex="'+t.ariaColumnIndex+'"]');null==o||o.forEach((e=>{const o=e.style;this.isRtl?(t.index>r&&null!=o&&o.right&&(o.right=parseInt(o.right,10)-i+"px"),t.index<r&&null!=o&&o.left&&(o.left=parseInt(o.left,10)-i+"px")):(t.index>r&&null!=o&&o.left&&(o.left=parseInt(o.left,10)-i+"px"),t.index<r&&null!=o&&o.right&&(o.right=parseInt(o.right,10)-i+"px"))}))}}))}}let ni=class{constructor(e,t,r){this.reorderable=!1,this.groupable=!1,this.dropElementClue=null,this.dragElementClue=null,this.startColumn=-1,this.startGroup=-1,this.currentColumn=-1,this.currentGroup=-1,this.groupPanelDivElement=null,this.refGroupPanelDiv=e=>{this.groupPanelDivElement=e.children?e.children[0]:e},this.refDropElementClue=e=>{this.dropElementClue=e,this.dropElementClue&&i.canUseDOM&&document.body.appendChild(this.dropElementClue.$el)},this.refDragElementClue=e=>{this.dragElementClue=e,this.dragElementClue&&i.canUseDOM&&document.body.appendChild(this.dragElementClue.$el)},this.pressHandler=(e,t)=>{e.isTouch||e.originalEvent.preventDefault();const i=this.getColumnIndex(e,t);if(this.startGroup=this.getGroupIndex(e),i>=0){const e=this.columns[i];(e.reorderable&&this.reorderable||e.groupable&&this.groupable)&&(this.startColumn=i)}},this.dragHandler=(e,t)=>{if(e.isTouch||e.originalEvent.preventDefault(),e.originalEvent.stopPropagation(),-1===this.startColumn&&-1===this.startGroup)return;this.currentColumn=this.getColumnIndex(e,t);const i=this.groupPanelDivElement&&this.groupPanelDivElement.children;this.currentGroup=this.isTargetGroupingContainer(e)?i&&i.length?i.length:0:this.getGroupIndex(e);const r=!this.isValid();r&&(this.currentColumn=-1,this.currentGroup=-1);const o=this.currentColumn>=0?t.children[this.columns[this.currentColumn].index]:this.isTargetGroupingContainer(e)?e.originalEvent.target:this.groupPanelDivElement&&this.groupPanelDivElement.children[this.currentGroup];this.updateDragElementClue(e,t,o,r),this.updateDropElementClue(e,t,o,r)},this.releaseHandler=e=>{const t=this.startColumn,i=this.currentColumn,r=this.startGroup,o=this.currentGroup;this.dropElementClue&&(this.dropElementClue.visible=!1),this.dragElementClue&&(this.dragElementClue.visible=!1);const l=this.isValid();this.startColumn=this.startGroup=this.currentColumn=this.currentGroup=-1,l&&(t>=0&&i>=0?this.columnReorder(t,i,e.originalEvent):r>=0&&o>=0?this.groupReorder(r,o,e.originalEvent):t>=0&&o>=0&&this.columnToGroup(t,o,e.originalEvent))},this.columnReorder=e,this.groupReorder=t,this.columnToGroup=r}getColumnIndex(e,t){if(!t||t.parentElement===this.groupPanelDivElement)return-1;const i=x(e,t);if(-1===i)return-1;for(let e=0;e<t.parentNode.children.length;e++)if(t.parentNode.children[e]===t)return this.columns.findIndex((t=>t.index===i&&t.depth===e));return-1}isTargetGroupingContainer(e){const t=e.originalEvent.target;return t.className.indexOf&&-1!==t.className.indexOf("k-grouping-drop-container")}getGroupIndex(e){return x(e,this.groupPanelDivElement)}isValid(){return this.startGroup>=0?this.currentGroup>=0&&this.currentGroup!==this.startGroup:-1!==this.startColumn&&(this.currentGroup>=0?!0===this.columns[this.startColumn].groupable&&!0===this.groupable:!0===this.reorderable&&this.currentColumn>=0&&this.currentColumn!==this.startColumn&&!0===this.columns[this.startColumn].reorderable&&this.columns[this.currentColumn].parentIndex===this.columns[this.startColumn].parentIndex)}updateDragElementClue(e,t,i,r){if(!this.dragElementClue)return;const o=this.startColumn>=0?t.children[this.columns[this.startColumn].index].innerText:t.innerText;this.dragElementClue.visible=!0,this.dragElementClue.top=e.pageY+10,this.dragElementClue.left=e.pageX,this.dragElementClue.innerText=o,this.dragElementClue.status=r||!i?"cancel":"plus"}updateDropElementClue(e,t,i,r){if(!this.dropElementClue)return;if(r||!i)return void(this.dropElementClue.visible=!1);const o=i.getBoundingClientRect(),l=(i.closest(".k-grouping-header")||i).getBoundingClientRect();let n=o.left+e.pageX-e.clientX-6;!this.isTargetGroupingContainer(e)&&(this.currentColumn>this.startColumn||this.currentGroup>this.startGroup&&-1!==this.startGroup)&&(n+=o.width);const a=l.top+e.pageY-e.clientY;this.dropElementClue.visible=!0,this.dropElementClue.top=a,this.dropElementClue.left=n,this.dropElementClue.height=this.currentColumn>=0?t.clientHeight:l.height}};const ai=t.defineComponent({data:()=>({visible:!1,top:0,left:0,innerText:"",status:"cancel"}),render(){return this.visible&&t.createVNode("div",{class:"k-header k-drag-clue",style:{display:"block",position:"absolute",zIndex:2e4,padding:"8px 12px",top:this.top+"px",left:this.left+"px"}},[t.createVNode(i.Icon,{name:this.status,class:"k-drag-status",icon:"cancel"===this.status?n.cancelIcon:n.plusIcon},null),this.innerText])}}),si=t.defineComponent({data:()=>({height:0,visible:!1,left:0,top:0}),render(){return this.visible&&t.createVNode("div",{class:"k-grouping-dropclue",style:{zIndex:1e4,display:"block",top:this.top+"px",left:this.left+"px",height:this.height+"px"}},null)}}),di=t.defineComponent({name:"GridCell",inheritAttrs:!1,emits:{cellclick:null,cellkeydown:null},props:{id:String,field:String,dataItem:Object,format:String,readFormat:String,className:String,colSpan:Number,columnIndex:Number,columnsCount:Number,dataIndex:Number,rowType:String,level:Number,expanded:Boolean,type:String,editor:String,rowSpan:[Number,Object],isSelected:Boolean,isHighlighted:Boolean,ariaColumnIndex:Number,render:[String,Function,Object],isRtl:Boolean,onEdit:Function,onSave:Function,onRemove:Function,onCancel:Function,onChange:Function,onSelectionchange:Function},inject:{kendoIntlService:{default:null},getKeyboardNavigationAttributes:{default:i.noop}},methods:{triggerClick(){this.$emit("cellclick",{dataItem:this.$props.dataItem,field:this.$props.field})},triggerKeydown(e){this.$emit("cellkeydown",{event:e,dataItem:this.$props.dataItem,field:this.$props.field})},triggerEdit(e){this.$emit("edit",e)},triggerAdd(e){this.$emit("add",e)},triggerCancel(e){this.$emit("cancel",e)},triggerSave(e){this.$emit("save",e)},triggerRemove(e){this.$emit("remove",e)}},created(){this._intl=l.provideIntlService(this)},computed:{tdClass(){const{className:e,isHighlighted:t}=this.$props;return{"k-table-td":!0,"k-highlighted":t,[e]:e}}},setup:()=>({kendoIntlService:t.inject("kendoIntlService",{})}),render(){var e,o,l;let n=null;const a=this.getKeyboardNavigationAttributes(this.$props.id);if(null===(null==(e=this.$props.rowSpan)?void 0:e.count))return null;if("groupFooter"===this.$props.rowType)n=t.createVNode("td",{class:this.tdClass},null);else if(void 0!==this.$props.field&&"groupHeader"!==this.$props.rowType){const e=v(this.$props.field,this.$props.dataItem);let i="";null!=e&&(i=this.$props.format?this.$props.type?this._intl.format(this.$props.format,R[this.$props.type](e,this._intl,this.$props.readFormat)):this._intl.format(this.$props.format,e):e.toString()),n=t.createVNode("td",{style:this.$attrs.style,colspan:this.$props.colSpan,rowspan:null!=(l=null==(o=this.$props.rowSpan)?void 0:o.count)?l:void 0,class:this.tdClass,onKeydown:this.triggerKeydown,onClick:this.triggerClick,role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,"aria-selected":this.$props.isSelected,"data-grid-col-index":this.$props.columnIndex,tabindex:a.tabIndex,"data-keyboardnavlevel":a[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":a[r.KEYBOARD_NAV_DATA_ID]},[i])}return i.getTemplate.call(this,{h:t.h,template:this.$props.render,defaultRendering:n,additionalProps:this.$props,additionalListeners:{click:this.triggerClick,keydown:this.triggerKeydown,edit:this.triggerEdit,add:this.triggerAdd,cancel:this.triggerCancel,save:this.triggerSave,remove:this.triggerRemove}})}}),ci=t.defineComponent({name:"KendoGridGroupCell",inheritAttrs:!1,props:{id:String,field:String,dataItem:Object,format:String,type:String,colSpan:Number,className:String,columnIndex:Number,columnsCount:Number,rowType:String,level:Number,expanded:Boolean,editor:String,dataIndex:Number,isSelected:Boolean,isRtl:Boolean,ariaColumnIndex:Number,group:Object,render:[String,Function,Object]},emits:{change:null,cellkeydown:null},inject:{kendo:{default:null},kendoIntlService:{default:null},kendoLocalizationService:{default:null},getKeyboardNavigationAttributes:{default:i.noop}},computed:{tdClass(){const{className:e}=this.$props;return{"k-table-td":!0,[e]:e}}},methods:{triggerStateChange(){var e;const t=this.kendo;null==(e=null==t?void 0:t.dispatchGroupExpand)||e.call(t,{type:r.GROUP_EXPAND_ACTION.TOGGLE,group:this.$props.group})},triggerKeydown(e,t){this.$emit("cellkeydown",{event:e,dataItem:this.$props.dataItem,dataIndex:this.$props.dataIndex,field:this.$props.field,expanded:this.$props.expanded}),!e.defaultPrevented&&e.keyCode===i.Keys.enter&&(e.preventDefault(),this.$emit("change",{dataItem:this.$props.dataItem,dataIndex:this.$props.dataIndex,event:e,level:this.$props.level,field:void 0,value:!t}),this.triggerStateChange())},clickHandler(e,t,i){e.preventDefault(),this.$emit("change",{dataItem:t,dataIndex:this.$props.dataIndex,event:e,level:this.$props.level,field:void 0,value:!i}),this.triggerStateChange()}},render(){let e=null;const{columnIndex:o,level:a,columnsCount:s,rowType:d,dataItem:c,field:h,expanded:p,render:u}=this.$props,g=this.getKeyboardNavigationAttributes(this.$props.id),f=l.provideLocalizationService(this).toLanguageString(Ze,ht[Ze]),m=l.provideLocalizationService(this).toLanguageString(et,ht[et]);return void 0===o||void 0===a||o<a||void 0===s||"groupHeader"!==d||void 0===c[h]?e=t.createVNode("td",{style:this.$attrs.style,key:"g"+o,class:"k-table-td k-group-cell"},null):o<=a&&(e=t.createVNode("td",{style:this.$attrs.style,onKeydown:e=>{this.triggerKeydown(e,p)},key:"g-colspan",class:this.tdClass,colspan:s-o,role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,"aria-selected":this.$props.isSelected,"aria-expanded":p,"data-grid-col-index":this.$props.columnIndex,tabindex:g.tabIndex,"data-keyboardnavlevel":g[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":g[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode("p",{class:"k-reset"},[t.createVNode("a",{onClick:e=>{this.clickHandler(e,c,p)},href:"#",tabindex:-1,title:p?f:m,"aria-label":p?f:m},[t.createVNode(i.Icon,{name:p?"caret-alt-down":this.isRtl?"caret-alt-left":"caret-alt-right",icon:p?n.caretAltDownIcon:this.isRtl?n.caretAltLeftIcon:n.caretAltRightIcon},null)]),c[h]?c[h].toString():""])])),i.getTemplate.call(this,{h:t.h,template:u,defaultRendering:e,additionalProps:this.$props,additionalListeners:{keydown:this.triggerKeydown,click:this.clickHandler}})}}),hi=t.defineComponent({name:"KendoGridRow",props:{rowType:String,item:Object,isAltRow:Boolean,isHidden:Boolean,isHighlighted:Boolean,onClick:Function,isInEdit:Boolean,isSelected:Boolean,selectedField:String,rowHeight:Number,ariaRowIndex:Number,absoluteRowIndex:Number,dataIndex:Number,render:[String,Function,Object],onRowclick:Function,onRowdblclick:Function},methods:{handleClick(e){this.$emit("rowclick",e)},handleDoubleClick(e){this.$emit("rowdblclick",e)}},computed:{trClass(){const{rowType:e,isAltRow:t,isInEdit:i,isHighlighted:r,isSelected:o}=this.$props;return{"k-table-row":!0,"k-selected":o,"k-highlighted":r,"k-table-group-row":"groupHeader"===e,"k-grouping-row":"groupHeader"===e,"k-group-footer":"groupFooter"===e,"k-master-row":"groupHeader"!==e&&"groupFooter"!==e,"k-table-alt-row":t,"k-edit-row":i}}},render(){const e=i.getDefaultSlots(this),r=t.createVNode("tr",{onClick:this.handleClick,onDblclick:this.handleDoubleClick,class:this.trClass,style:{height:this.$props.rowHeight?this.$props.rowHeight+"px":"",visibility:this.$props.isHidden?"hidden":""},role:"row","aria-rowindex":this.$props.ariaRowIndex,"absolute-row-index":this.$props.absoluteRowIndex,"data-grid-row-index":"data"===this.$props.rowType?this.$props.dataIndex:void 0},[e]);return i.getTemplate.call(this,{h:t.h,template:this.$props.render,defaultRendering:r,additionalProps:this.$props,additionalListeners:{click:this.handleClick},defaultSlots:e,swapDefaultSlots:!0})}}),pi={id:String,autoProcessData:[Boolean,Object],topCacheCount:{type:Number,default:0},collapsedGroups:{type:Array,default:function(){return[]}},uniqueField:String,totalGroupedHeight:Number,allGroupedItems:Object,alternatePerGroup:Boolean,columns:Array,columnsState:{type:Array,default:function(){}},defaultColumnsState:{type:Array,default:function(){}},columnVirtualization:Boolean,dataItems:[Array,Object],sortable:[Boolean,Object],defaultSort:Array,sort:Array,filterable:Boolean,filterOperators:Object,filterCellRender:[String,Function,Object],headerCellRender:[String,Function,Object],showLoader:{type:Boolean,default:void 0},loader:[String,Function,Object,Boolean],defaultFilter:Object,filter:Object,defaultSearch:Object,search:Object,searchFields:Array,highlight:Object,pageable:[Boolean,Object],pageSize:Number,total:Number,fixedScroll:Boolean,skip:Number,defaultSkip:Number,take:Number,defaultTake:Number,expandField:String,expandColumn:Object,selectedField:String,cellRender:[String,Function,Object],rowRender:[String,Function,Object],rowSpannable:[Boolean,Object],resizable:Boolean,reorderable:Boolean,group:Array,defaultGroup:Array,groupable:[Boolean,Object],groupExpand:Array,defaultGroupExpand:Array,detailExpand:Object,defaultDetailExpand:Object,editField:String,rowClass:Function,scrollable:{type:String,default:"scrollable"},size:{type:String,default:"medium",validator:function(e){return["small","medium"].includes(e)}},pager:[String,Function,Object],rowHeight:Number,detailRowHeight:Number,detail:[String,Function,Object],columnMenu:[Boolean,String,Function,Object],columnMenuAnimate:{type:[Boolean,Object],default:function(){return!0}},columnMenuIcon:i.SvgIcon,dataItemKey:String,navigatable:{type:Boolean,default:!1},onItemchange:Function,onExpandchange:Function,onDatastatechange:Function,onPagechange:Function,onSortchange:Function,onFilterchange:Function,onGroupchange:Function,onSearchchange:Function,onGroupexpandchange:Function,onDetailexpandchange:Function},ui=t.defineComponent({props:{field:String,title:String,selectionValue:Boolean,render:[Object,Function,String]},created(){this.inputId=i.guid()},inject:{kendoLocalizationService:{default:null}},methods:{changeHandle(e){this.$emit("selectionchange",{field:this.$props.field,event:e})}},render(){const e=this.$props.render,r=l.provideLocalizationService(this).toLanguageString(B,ht[B]),o=t.createVNode("input",{checked:this.$props.selectionValue,id:this.inputId,type:"checkbox",class:"k-checkbox k-checkbox-md k-rounded-md","aria-label":r,onChange:this.changeHandle},null),n=i.getTemplate.call(this,{h:t.h,template:e,defaultRendering:o,additionalProps:{...this.$props,selectAll:r},additionalListeners:{selectionchange:this.changeHandle}}),a=e?n:t.createVNode("span",{class:"k-checkbox-wrap"},[n]);return t.createVNode("span",{class:"k-link"},[t.createVNode("span",{class:"k-column-title"},[a])])}}),gi=t.defineComponent({name:"GridNoRecords",inject:{kendoLocalizationService:{default:null}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const e=i.getDefaultSlots(this),r=l.provideLocalizationService(this).toLanguageString(z,ht[z]);return e?t.createVNode("div",null,[e]):r}}),fi=t.defineComponent({name:"GridNoRecordsContainer",props:{id:String},render(){const e=i.getDefaultSlots(this),o=i.uGrid;return t.createVNode("div",{key:"no-records",class:i.classNames(o.noRecords({}))},[t.createVNode("div",t.mergeProps({class:i.classNames(o.noRecordsTemplate({}))},{[r.KEYBOARD_NAV_DATA_ID]:this.$props.id}),[e])])}}),mi={name:"@progress/kendo-vue-grid",productName:"Kendo UI for Vue",productCode:"KENDOUIVUE",productCodes:["KENDOUIVUE"],publishDate:0,version:"7.1.0-develop.6",licensingDocsUrl:"https://www.telerik.com/kendo-vue-ui/my-license/"};function vi(e){const t=e.replace(/^pager\.([a-z])/,((e,t)=>"grid.pager"+t.toUpperCase()));return{messageKey:t,defaultMessage:ht[t]}}const bi=Symbol("kendoKey");const Ci=t.defineComponent({name:"KendoGrid",inheritAttrs:!1,props:{...pi,toolbar:{type:Object},noRecords:{type:Object}},data:()=>({isRtl:!1,context:void 0,navigation:void 0,showLicenseWatermark:!1,licenseMessage:void 0,notHiddenColumns:[]}),watch:{rowHeight:function(e,t){var i;this.onRowHeightChanged(e,t),null==(i=this.vsRef)||i.reset()},scrollable:function(){var e;null==(e=this.vsRef)||e.reset()},filter:function(){var e;null==(e=this.vsRef)||e.reset()},group:function(){var e;null==(e=this.vsRef)||e.reset()},currentGroupable:function(){var e;null==(e=this.vsRef)||e.reset()},sort:function(){var e;null==(e=this.vsRef)||e.reset()}},created(){i.validatePackage(mi),this.showLicenseWatermark=i.shouldShowValidationUI(mi),this.licenseMessage=i.getLicenseMessage(mi),this.initialHeight=null,this._columns=[],this.vsRef=new oi,this.dragLogic=new ni(this.columnReorder.bind(this),this.groupReorder.bind(this),this.columnToGroup.bind(this)),this.columnResize=new li(this.onResize.bind(this)),this._columnsMap=[[]],this._header=null,this._footer=null,this.tableBodyRef=null,this.tableRef=null,this.scrollHeightContainerRef=null,this.forceUpdateTimeout=void 0,this._gridId=i.guid(),this._gridRoleElementId=i.guid(),this.slicedCurrentData=void 0,this._prevTotal=void 0,this._containerHeightRef=0,this._minRowHeightRef=0,this._virtualSkipRef=0,this.wrapperScrollTopRef=0,this.scrollLeftRef=0},mounted(){var e,t;this.setRefs();const r=i.isRtl(this._element);this._prevTotal=this.$props.total,this.isRtl=r,this.initialHeight=(null==(t=null==(e=this._element)?void 0:e.style)?void 0:t.height)||null,this.resizeObserver=i.canUseDOM&&(null==window?void 0:window.ResizeObserver)&&new ResizeObserver(this.calculateMedia),null!=document&&document.body&&this.resizeObserver&&this.resizeObserver.observe(document.body)},updated(){var e;this.setRefs();const t=i.isRtl(this._element);this.isRtl=t,this._prevTotal=this.$props.total,this.vsRef.tableTransform&&this.vsRef.table&&(this.vsRef.table.style.transform=this.vsRef.tableTransform,this.vsRef.tableTransform=""),this.isVirtualScroll&&(this.setContainerHeight(),this.setMinRowHeight(),null==(e=this.vsRef)||e.update())},unmounted(){this.gridUnmounted()},computed:{gridId(){return this.$props.id+"-role-element-id"},idPrefix(){return this.$props.navigatable?this.gridId:""},groupExpandable(){return r.getGroupExpandableOptions("object"==typeof this.$props.groupable&&!1!==this.$props.groupable.enabled?this.$props.groupable.expandable:this.$props.groupable)},hierarchClass:()=>i.uGrid.hierarchyCell({}),computedRowSpannable(){return T(this.$props.rowSpannable)},detailExpandable(){return r.getDetailExpandableOptions(!!this.$props.detail)},nonscrollableWrapperClass(){const{size:e}=this.$props,t=this.$attrs.class;return{"k-grid":!0,"k-grid-md":!e,[`k-grid-${i.kendoThemeMaps.sizeMap[e]||e}`]:e,[t]:!!t}},scrollableWrapperClass(){const{scrollable:e}=this.$props;return{...this.nonscrollableWrapperClass,"k-grid-virtual":"virtual"===e}},gridTableClass(){const{size:e}=this.$props;return{"k-table":!0,"k-grid-table":!0,"k-grid-md":!e,[`k-table-${i.kendoThemeMaps.sizeMap[e]||e}`]:e}},getCorrectHeight(){return"virtual"===this.$props.scrollable?this.initialHeight||"450px":null},currentGroupable(){var e;const t=null==(e=this.gridContext.group)?void 0:e.value;return!0===this.$props.groupable&&(null==t?void 0:t.length)||i.isObject(this.$props.groupable)&&!1!==this.$props.groupable.enabled},computedCollapsed(){let e=[];if(this.$props.group)for(let t=0;t<this.$props.group.length;t++)this.$props.collapsedGroups[t]?e.push(this.$props.collapsedGroups[t]):e.push([]);return e},getAriaRowCount(){const e=this.$props.dataItems,t=this.$props.total||(null==e?void 0:e.total)||(null==e?void 0:e.length)||0;return this.$props.detail?this._columnsMap.length+(this.$props.filterable?1:0)+2*t+(this._columns.some((e=>!!e.footerCell))?1:0):this.$props.pageable||"scrollable"!==this.$props.scrollable?this.$props.groupable?-1:this._columnsMap.length+(this.$props.filterable?1:0)+t+(this._columns.some((e=>!!e.footerCell))?1:0):void 0},getAriaColCount(){const e=this.$props.columns,t=this.$props.columnVirtualization,i=0!==(null==e?void 0:e.filter((e=>void 0!==e.hidden)).length);if(t||i)return 0!==(null==e?void 0:e.length)?null==e?void 0:e.length:-1},isVirtualScroll(){return"virtual"===this.$props.scrollable||void 0===this.$props.scrollable||!1}},methods:{readColumnElements(){return I(this.$props.columns,this.currentColumnsState,{prevId:0,idPrefix:this.idPrefix})},getResolvedFlatColumnsState(){const e=[],t=(i,r)=>null==i?void 0:i.forEach((i=>{const o=i.hidden||r;e.push({...i,hidden:o}),t(i.children,o)}));return t(this.currentColumnsState,!1),e},filterColumns(e){const t=this.getResolvedFlatColumnsState();return[e.filter((e=>{var i;return!(e.hidden||null!=(i=t.find((t=>t.id===e.id)))&&i.hidden)})),e.filter((e=>{var i;return e.hidden||(null==(i=t.find((t=>t.id===e.id)))?void 0:i.hidden)}))]},getFlatData(e,t,i,r,o,l,n){const a=[];return{flattedData:a,resolvedGroupsCount:b(a,e,t,{index:i},void 0!==r,o,l,this.groupExpandable.defaultExpand,n,this.$props.expandField)}},getColumnsEssentialProps:e=>e&&JSON.stringify(e.map((e=>({id:e.id,field:e.field,title:e.title,children:e.children})))),calculateMedia(){const e=this.filterHiddenColumns(this.$props.columns||[]);this.getColumnsEssentialProps(this.notHiddenColumns)!==this.getColumnsEssentialProps(e)&&this.$forceUpdate()},filterHiddenColumns(e){if(!e||0===e.length)return e;const t=e=>({...e,children:e.children&&e.children.length>0?this.filterHiddenColumns(e.children):e.children});return[...e].filter((e=>!e.hidden)).filter((e=>i.canUseDOM&&e&&e.media?window.matchMedia(e.media).matches:e)).map((e=>t(e)))},getColumns(){const e=this._columns.filter((e=>e.declarationIndex>=0&&-1===e.parentIndex)),t=e=>(e.sort(((e,t)=>e.declarationIndex-t.declarationIndex)),e.map((e=>{const{declarationIndex:i,parentIndex:r,depth:o,colSpan:l,rowSpan:n,index:a,kFirst:s,children:d,...c}=e;return d.length?{children:t(d),...c}:c})));return t(e)},setRefs(){const e=i.getRef(this,"gridNav");e&&(this._element=e.$el);const t=i.getRef(this,"groupPanelDiv");if(t){let e=t.$el||null;this.dragLogic.refGroupPanelDiv(e)}const r=i.getRef(this,"dropElementClue"),o=i.getRef(this,"dragElementClue");this.dragLogic.refDropElementClue(r),this.dragLogic.refDragElementClue(o),this.columnResize.colGroupMain=i.getRef(this,"colGroup"),this._header=i.getRef(this,"header"),this._footer=i.getRef(this,"footer"),this.resetTableWidth(),i.setScrollbarWidth()},gridUnmounted(){clearTimeout(this.forceUpdateTimeout),this.columnResize.columns=[],this.dragLogic.columns=[],this.dragLogic&&this.dragLogic.dragElementClue&&(this.dragLogic.dragElementClue.$el.remove(),this.dragLogic.dropElementClue.$el.remove()),this.currentData=[],this._columns=[],null!=document&&document.body&&this.resizeObserver&&this.resizeObserver.disconnect()},isAllData(){const{dataItems:e,total:t}=this.$props;return Array.isArray(e)?e.length===t:!!e&&t===e.total},resetVirtualSkip(){this.isVirtualScroll&&this._virtualSkipRef&&(this._virtualSkipRef=0)},virtualPageChange(e,t){var i;this.$props.pageable||null!=(i=this.$props.group)&&i.length?(this._virtualSkipRef=e.skip,this.$forceUpdate()):this.pageChangeHandler(e,t)},initializeVirtualization(){const e=this.vsRef,t=this.$props.rowHeight||this._minRowHeightRef||0;e&&(e.fixedScroll=this.$props.fixedScroll||!1,e.PageChange=this.virtualPageChange,e.pageSize=this._virtualPageSize,e.scrollableVirtual=this.isVirtualScroll,e.container=i.getRef(this,"scrollContainer"),e.tableBody=i.getRef(this,"tableBody"),e.scrollHeightContainer=i.getRef(this,"scrollHeightContainer"),e.table=i.getRef(this,"table"),(!e.rowHeightService||e.total!==this._virtualTotal)&&t&&(e.total=this._virtualTotal,e.rowHeightService=new i.RowHeightService(this._virtualTotal,t)))},setContainerHeight(){const e=i.getRef(this,"scrollContainer");this._containerHeightRef=(null==e?void 0:e.offsetHeight)||0},setMinRowHeight(){if(!this._minRowHeightRef&&!this.$props.rowHeight){const e=G(i.getRef(this,"tableBody"));e&&(this._minRowHeightRef=e,this.$forceUpdate())}},onRowHeightChanged(e,t){this.setRefs()},scrollHandler(e){clearTimeout(this.forceUpdateTimeout);const t=e.currentTarget.scrollLeft,i=e.currentTarget.scrollTop;this.$props.columnVirtualization&&(!this.isVirtualScroll||i===this.wrapperScrollTopRef)&&(this.forceUpdateTimeout=setTimeout((()=>{this.$forceUpdate()}),0)),this.scrollLeftRef=t,this._header&&this._header.setScrollLeft(e.currentTarget.scrollLeft),this._footer&&this._footer.setScrollLeft(e.currentTarget.scrollLeft),this.vsRef&&i!==this.wrapperScrollTopRef&&this.vsRef.scrollHandler(e),this.$emit("scroll",e),this.wrapperScrollTopRef=i},rowClick(e,t){"checkbox"!==e.target.type&&this.$emit("rowclick",{dataItem:t.dataItem,...this.getArguments(e)})},rowDoubleClick(e,t){"checkbox"!==e.target.type&&this.$emit("rowdblclick",{dataItem:t.dataItem,...this.getArguments(e)})},loopGroupedItems(e,t,i=0,r=null){return e.forEach((e=>{!r&&t(e,i)&&(r=e),e.items&&e.items.length&&!r&&(r=this.loopGroupedItems(e.items,t,i+1,r))})),r},updateGroupCollapsed(e){let t=this.computedCollapsed,i=t[e.level];const r=this.$props.uniqueField,o=this.allGroupedItems?this.loopGroupedItems(this.allGroupedItems.data,(function(t,i){return t.value===e.dataItem.value&&i===e.level}),0,null):e.dataItem,l=E(o||e.dataItem,r);if(e.value){if(i&&i.length){const e=i.indexOf(l);e>-1&&i.splice(e,1)}}else i?i.includes(l)||i.push(l):i=[l];return t},itemChange(e){var t;const r=i.hasListener.call(this,"itemchange"),o=null==(t=this.gridContext.group)?void 0:t.value;e.field===this.$props.expandField||(o||this.$props.detail)&&void 0===e.field?i.hasListener.call(this,"expandchange")&&e.dataItem&&this.$emit("expandchange",{...this.getArguments(e.event),collapsedGroups:this.updateGroupCollapsed(e),dataItem:e.dataItem,value:e.value}):r&&this.$emit("itemchange",{...this.getArguments(e.event),dataItem:e.dataItem,field:e.field,value:e.value})},cellClickHandler(e){this.$emit("cellclick",{dataItem:e.dataItem,field:e.field})},cellKeydownHandler(e){this.$emit("cellkeydown",e)},editHandler(e){this.$emit("edit",{dataItem:e})},removeHandler(e){this.$emit("remove",{dataItem:e})},saveHandler(e){this.$emit("save",{dataItem:e})},cancelHandler(e){this.$emit("cancel",{dataItem:e})},selectionChangeHandler(e){const{event:t,dataItem:i,dataIndex:r,columnIndex:o}=e;this.$emit("selectionchange",{...this.getArguments(t.event),dataItem:i,startColIndex:o,endColIndex:o,startRowIndex:r,endRowIndex:r,dataItems:this.getLeafDataItems(),altKey:!1,ctrlKey:!1,shiftKey:!1,metaKey:!1,isDrag:!1,componentId:this._gridId,selectedField:this.$props.selectedField||""})},onHeaderSelectionChangeHandler(e){this.$emit("headerselectionchange",{field:e.field,event:e.event,target:this})},pageChangeHandler(e,t){this.raiseDataEvent("pagechange",{page:e,event:t},{skip:e.skip,take:e.take},t)},sortChangeHandler(e,t){this.raiseDataEvent("sortchange",{sort:e},{sort:e},t)},filterChangeHandler(e,t){this.raiseDataEvent("filterchange",{filter:e},{filter:e,skip:0},t)},groupChangeHandler(e,t){this.raiseDataEvent("groupchange",{group:e},{group:e,skip:0},t)},handleDetailExpandAction(e,t){var i;if(this.detailExpandable.enabled){const o=null==(i=this.gridContext.detailExpand)?void 0:i.value,l=r.detailExpandReducer(null!=o?o:{},e);this.$emit("detailexpandchange",{...this.getArguments(t),detailExpand:l})}},handleGroupExpandAction(e,t){var i;if(this.groupExpandable.enabled){const o=null==(i=this.gridContext.groupExpand)?void 0:i.value,l=r.groupExpandReducer(null!=o?o:[],e,this.groupExpandable);this.$props.expandField||this.$emit("groupexpandchange",{...this.getArguments(t),groupExpand:l})}},raiseDataEvent(e,t,r,o){if(this.resetVirtualSkip(),this.$props.autoProcessData)this.gridContext[e]({...this.getArguments(o),...t});else if(i.hasListener.call(this,e))this.$emit(e,{...this.getArguments(o),...t});else if(i.hasListener.call(this,"datastatechange")){const e={...this.getDataState(),...r};this.gridContext.datastatechange({...this.getArguments(o),data:e,dataState:e})}},columnReorder(e,t,i){const o=this._columns[e],l=A(this.currentColumnsState),n=o.depth,a=e=>{do{e++}while(e<this._columns.length&&this._columns[e].depth>n);return e},s=this._columns.splice(e,a(e)-e);this._columns.splice(e<t?a(t-s.length):t,0,...s),this._columns.filter((e=>e.declarationIndex>=0)).forEach(((e,t)=>{e.orderIndex=t;const i=l.find((t=>t.id===e.id));i&&(i.orderIndex=t)}));const d=this._columns[e].locked&&this._columns[t].locked;r.updateLeft(this._columnsMap,this._columns,d||this.shouldUpdateLeftRightRef),r.updateRight(this._columnsMap,this._columns,d||this.shouldUpdateLeftRightRef),this.resizedRef&&(this.shouldUpdateLeftRightRef=!1,this.resizedRef=!1);const c=this.getColumns();this.$emit("columnreorder",{target:this,columns:c,event:i,prev:e,next:t}),this.gridContext.columnsstatechange({columnsState:this.currentColumnsState})},groupReorder(e,t,i){var r;const o=null==(r=this.gridContext.group)?void 0:r.value;void 0!==o&&(o.splice(t,0,...o.splice(e,1)),this.groupChangeHandler(o,i))},columnToGroup(e,t,i){var r;const o=this._columns[e].field;if(!o)return;const l=((null==(r=this.gridContext.group)?void 0:r.value)||[]).slice();l.splice(t,0,{field:o}),this.groupChangeHandler(l,i)},resetTableWidth(){var e;let t=0;if(!this.columnResize.colGroupMain)return;const r=null==(e=this.columnResize.colGroupMain)?void 0:e.children;for(let e=0;e<r.length;e++){const i=r[e].width;if(!i)return;t+=parseFloat(i.toString())}t=Math.round(t),this._header&&this._header.setWidth(t),this._footer&&this._footer.setWidth(t);const o=i.getRef(this,"table");o&&t&&(o.style.width=t+"px")},onResize(e,t,i,r,o,l,n){this.resetTableWidth(),this.shouldUpdateLeftRightRef=!0,this.resizedRef=!0,this.$emit("columnresize",{columns:this.getColumns(),index:e,targetColumnId:n,event:r,newWidth:t,oldWidth:i,end:o,target:this}),o&&this.gridContext.columnsstatechange({columnsState:l})},initColumnsState(e,t){const i=e=>{var r;const o=t.find((t=>t.id===e.id));if(o){const t={...o};return t.children=null==(r=e.children)?void 0:r.map(i),t}return e};this.currentColumnsState=e.filter((e=>-1===e.parentIndex)).map(i)},configureColumns(e,o){e.filter((e=>"checkbox"===e.columnType)).forEach((e=>{e.width=e.width||"50px",e.defaultCell=t.markRaw(_),e.defaultHeaderCell=t.markRaw(ui),e._type="edit"})),this.$props.selectedField&&this._columns.filter((e=>e.field===this.$props.selectedField)).forEach((e=>{e.width=e.width||"50px",e.internalCell=t.markRaw(_),e.internalHeaderCell=t.markRaw(ui)}));const l=A(this.currentColumnsState);this.initColumnsState(e,l);const n={id:"",resizable:!0,width:"32px",title:" ",declarationIndex:-1,orderIndex:-1,children:[],parentIndex:-1,depth:0,colSpan:0,headerColSpan:0,rowSpan:0,left:0,right:0,index:0,rightBorder:!1,ariaColumnIndex:0,isAccessible:!0};let a=0;if(this.detailExpandable.enabled&&this.$props.detail&&!this.$props.expandField){const i={...n,_type:"expand",id:r.tableKeyboardNavigationTools.generateNavigatableId(""+a++,"expand","column"),defaultCell:t.markRaw(pt),internalCell:t.markRaw(pt),field:this.detailExpandable.column,headerClassName:this.hierarchClass};e.unshift(i),this.currentColumnsState.unshift(l.find((e=>e.id===i.id))||i)}this.$props.expandField&&i.hasListener.call(this,"expandchange")&&this.$props.detail&&(e.unshift({...n,internalCell:t.markRaw(pt),field:this.$props.expandField,headerClassName:"k-hierarchy-cell k-header",id:r.tableKeyboardNavigationTools.generateNavigatableId(`${e.length}`,this.idPrefix,"column"),...this.expandColumn}),a++);for(let i=0;i<o;i++){const i={...n,isAccessible:!1,defaultCell:t.markRaw(ci),internalCell:t.markRaw(ci),id:r.tableKeyboardNavigationTools.generateNavigatableId(""+a++,"group","column"),field:"value",locked:this.$props.lockGroups};e.unshift(i),this.currentColumnsState.unshift(l.find((e=>e.id===i.id))||i)}e.slice(a).forEach((e=>{e.parentIndex>=0&&(e.parentIndex+=a),e.rowSpannable=void 0!==e.rowSpannable?T(e.rowSpannable):this.computedRowSpannable}))},initColumns(e,t){var i;this._columns=this.readColumnElements();const r=null==(i=this.gridContext.group)?void 0:i.value;0===this._columns.filter((e=>!e.hidden)).length&&(this._columns=w(e,r,{column:this.$props.expandField?this.$props.expandField:this.groupExpandable.column},{prevId:0,idPrefix:this.idPrefix})),this.configureColumns(this._columns,t);const[o,l]=this.filterColumns(this._columns);this._columns=o,this.hiddenColumnsRef=l,this._columnsMap=S(this._columns,!0)},resolveTitle(e){const t=this.findColumnByField(e),i=t&&(t.title||t.field);return void 0===i?e:i},findColumnByField(e){let t;return this.$props.columns.forEach((i=>{const r=this.searchColumn(i,e);r&&(t=r)})),t},searchColumn(e,t){if(e.field===t)return e;if(e.children){let i,r=null;for(i=0;null==r&&i<e.children.length;i++)r=this.searchColumn(e.children[i],t);return r}return null},getDataState(){var e,t,i,r,o;const l=null==(e=this.gridContext.sort)?void 0:e.value,n=null==(t=this.gridContext.filter)?void 0:t.value,a=null==(i=this.gridContext.skip)?void 0:i.value,s=null==(r=this.gridContext.take)?void 0:r.value,d=null==(o=this.gridContext.group)?void 0:o.value;return{filter:n,sort:l,skip:a,take:void 0!==s?s:this.$props.pageSize,group:d}},getArguments(e){return{event:e,target:this}},getLeafDataItems(){return this.currentData.filter((e=>"data"===e.rowType)).map((e=>e.dataItem))},totalGroupedRows(e){let t=0;return e&&(t=this.addSubItems(e,t)),t},addSubItems(e,t){return e.forEach((e=>{t++,!1!==e.expanded&&e.items&&(t=this.addSubItems(e.items,t)),this.group&&this.group.length&&("always"===this.$props.groupable.footer||!1!==e.expanded&&e.items&&"visible"===this.$props.groupable.footer)&&t++})),t},searchChange(e){const t=this.$props.searchFields||this._columns.map((e=>e.field))||[],i=e.event.target.value,r={logic:"or",filters:t.filter((e=>void 0!==e)).map((e=>{var t;return"string"==typeof e?{field:e,value:i,operator:"contains"}:{value:i,operator:null!=(t=e.operator)?t:"contains",field:e.field,ignoreCase:e.ignoreCase}}))};this.raiseDataEvent("searchchange",{search:r},{skip:0},e)},getCellsToRender(e,t){var i;const r=[];let o=null,l=0;if(t.forEach(((i,n)=>{const a=parseFloat((i.width||"").toString())||10;if(l)return l--,void(o&&(o.width+=a));const s=Math.min(H(i,e),t.length-n);l=s-1,o={width:a,colSpan:s,columnIndex:n},r.push(o)})),this.$props.columnVirtualization){const e=this.scrollLeftRef||0,o=this.tableWidth||parseFloat(((null==(i=this.$attrs.style)?void 0:i.width)||"").toString());return function(e){const{cellModels:t,columns:i=[],tableViewPortWidth:r,scrollLeft:o}=e;let l=0,n=t.length-1,a=0,s=0;for(let e=0;e<t.length;e++)if(!i[t[e].columnIndex].locked&&(a=s,s+=t[e].width||10,s>=o)){l=e;break}for(let e=l;e<t.length;e++)if(!i[t[e].columnIndex].locked){if(!(a<r+o))break;a+=t[e].width||10,n=e}l>0&&l--,n<t.length-1&&n++;let d=0,c=0;for(let e=0;e<l;e++)i[t[e].columnIndex].locked||(d+=t[e].colSpan);for(let e=n+1;e<t.length;e++)i[t[e].columnIndex].locked||(c+=t[e].colSpan);t[l].colSpan+=d,t[n].colSpan+=c;const h=t.slice(0,l).filter((e=>i[e.columnIndex].locked)),p=t.slice(n+1).filter((e=>i[e.columnIndex].locked));return[...h,...t.slice(l,n+1),...p]}({cellModels:r,columns:t,tableViewPortWidth:o,scrollLeft:e})}return r},calcVirtualPageSize(){const{pageable:e,take:t,pageSize:i}=this.$props;if(!this.isVirtualScroll)return 0;if(!e){if(t)return t;if(i)return i}const r=this.$props.rowHeight||this._minRowHeightRef,o=this._containerHeightRef;return o&&r?Math.ceil(o/r*1.5):0}},provide(){return{kendo:{dataItemKey:this.$props.dataItemKey,searchChange:this.searchChange,dispatchGroupExpand:this.handleGroupExpandAction,dispatchDetailExpand:this.handleDetailExpandAction}}},setup(e){const i=t.ref(null),r=t.ref(null),o=t.ref(null),l=t.ref(null),n=t.ref(null),a=t.ref(null),s=t.ref(null),d=t.ref(null),c=t.ref(null),h=t.ref(null),p=t.ref(!0),u=t.ref(!1);return{groupPanelDivRef:i,dropElementClueRef:r,dragElementClueRef:o,headerRef:l,footerRef:n,gridNavRef:a,colGroupRef:s,scrollContainerRef:d,scrollTableRef:c,scrollTableBodyRef:h,gridContext:t.inject(bi,{}),shouldUpdateLeftRightRef:p,resizedRef:u,currentColumnsState:e.columnsState}},render(){var e,l,n,a,s,d,h,p,u,f,m;const v=null==(e=this.gridContext.sort)?void 0:e.value,b=null==(l=this.gridContext.filter)?void 0:l.value,C=null==(n=this.gridContext.search)?void 0:n.value,x=null==(a=this.gridContext.skip)?void 0:a.value,$=null==(s=this.gridContext.take)?void 0:s.value,k=null==(d=this.gridContext.group)?void 0:d.value,S=null==(h=this.gridContext.groupExpand)?void 0:h.value,I=null==(p=this.gridContext.detailExpand)?void 0:p.value,y=!(null==k||!k.length);let w;this.currentColumnsState=null==(u=this.gridContext.columnsState)?void 0:u.value;const N=!0===this.$props.autoProcessData?{group:!0,sort:!0,filter:!0,search:!0,page:!0}:this.$props.autoProcessData;let R=this.$props.total||0;const V=r.tableKeyboardNavigationTools.getIdPrefix(this.navigation);let A=[];Array.isArray(this.$props.dataItems)?A=this.$props.dataItems:this.$props.dataItems&&(A=F(this.$props.dataItems,this.$props.collapsedGroups.length?this.computedCollapsed:[],this.$props.uniqueField).data,R=R||this.$props.dataItems.total);const D=!0===this.$props.groupable||i.isObject(this.$props.groupable)&&!1!==this.$props.groupable.enabled;this.dragLogic.reorderable=this.$props.reorderable||!1,this.dragLogic.groupable=D,this._virtualPageSize=this.calcVirtualPageSize();const L=A.length===R,O=i.isObject(this.$props.groupable)&&this.$props.groupable.footer||"none";if(this.currentData=[],N){const e=N.page&&!(this.isVirtualScroll&&!this.$props.pageable),{data:t,total:i}=c.process(A,{group:N.group?k:void 0,sort:N.sort?v:void 0,filter:r.combineFilters(N.filter?b:void 0,N.search?C:void 0),...e?{take:this.$props.pageable?$||10:$,skip:x||0}:{}});A=t,R=null!=(f=this.$props.total)?f:i}const{resolvedGroupsCount:H,flattedData:T}=this.getFlatData(A,O,L?0:this.$props.skip||0,k,I,S,this.$props.dataItemKey);this.currentData=T;const G=this._virtualSkipRef||0;if(this._virtualTotal=R,this.isVirtualScroll){let e=x||0;if((y||this.$props.pageable)&&(e=G,this._virtualTotal=this.currentData.length),L||y||this.$props.pageable)if(0===this._virtualPageSize){const t=Math.min($||this.$props.pageSize||20,this.currentData.length);w=this.currentData.slice(e,e+t)}else w=this.currentData.slice(e,e+this._virtualPageSize)}this.initializeVirtualization(),this.initColumns(this.$props.dataItems,H),this.columnResize.resizable=this.$props.resizable||!1,this.columnResize.columns=this._columns,this.columnResize.columnsState=i.cloneArray(this.currentColumnsState||[]),this.dragLogic.columns=this._columns;const _=this.$props.toolbar,z=this.$props.noRecords,B=this._columns.filter((e=>0===e.children.length)),j=D&&t.createVNode(ti,{ref:e=>{this.groupPanelDivRef=e},group:k||[],ariaControls:this._gridRoleElementId,onGroupChange:this.groupChangeHandler,onPressHandler:this.dragLogic.pressHandler,onDragHandler:this.dragLogic.dragHandler,onReleaseHandler:this.dragLogic.releaseHandler,resolveTitle:this.resolveTitle},null),M=(this.dragLogic.reorderable||this.dragLogic.groupable)&&i.canUseDOM&&document&&document.body,K=[M&&t.createVNode(si,{ref:e=>{this.dropElementClueRef=e}},null),M&&t.createVNode(ai,{ref:e=>{this.dragElementClueRef=e}},null)],P=t.createVNode(mt,{size:this.$props.size,columnResize:this.columnResize,staticHeaders:"none"!==this.$props.scrollable,ref:e=>{this.headerRef=e},headerRow:t.createVNode(Jt,{grid:this,sort:v,groupable:this.$props.groupable,reorderable:this.$props.reorderable,sortable:this.$props.sortable,onSortChange:this.sortChangeHandler,filter:b,filterable:this.$props.filterable,filterOperators:this.$props.filterOperators||Et,onFilterChange:this.filterChangeHandler,columnMenu:this.$props.columnMenu,columnMenuIcon:this.$props.columnMenuIcon,columnMenuAnimate:this.$props.columnMenuAnimate,onSelectionchange:this.onHeaderSelectionChangeHandler,columns:this._columns,columnsInitial:this.$props.columns,columnResize:this.columnResize,onPressHandler:this.dragLogic.pressHandler,onDragHandler:this.dragLogic.dragHandler,onReleaseHandler:this.dragLogic.releaseHandler,columnsMap:this._columnsMap,cellRender:this.$props.headerCellRender,isRtl:this.isRtl,isColCountDefined:void 0!==this.getAriaColCount,filterRow:this.$props.filterable&&t.createVNode(Zt,{grid:this,size:this.$props.size,columns:this._columns,filter:b,filterOperators:this.$props.filterOperators||Et,onFilterchange:this.filterChangeHandler,sort:this.$props.sort,cellRender:this.$props.filterCellRender,isRtl:this.isRtl,ariaRowIndex:this._columnsMap.length+1},null)||void 0},null),cols:B.map((function(e,i){return t.createVNode("col",{key:i.toString(),width:void 0!==e.width?Math.floor(parseFloat(e.width.toString())):void 0},null)}),this)},null),W=this._columns.some((e=>!!e.footerCell))?t.createVNode(ii,{size:this.$props.size,columnResize:this.columnResize,staticHeaders:"none"!==this.$props.scrollable,ref:e=>{this.footerRef=e},row:t.createVNode(ri,{isRtl:this.isRtl,rowIndex:this.getAriaRowCount+1,columns:this._columns},null),cols:B.map((function(e,i){return t.createVNode("col",{key:i.toString(),width:void 0!==e.width?Math.floor(parseFloat(e.width.toString())):void 0},null)}),this)},null):t.createVNode("span",null,null),q=this.showLicenseWatermark?t.createVNode(i.WatermarkOverlay,{message:this.licenseMessage},null):null,U=this.$attrs.style,Y=U&&i.isObject(U)&&U.width||"";this.tableWidth=parseFloat(Y.toString());const X=B.findIndex((e=>"function"==typeof e.colSpan))>-1;let J;X||(J=this.getCellsToRender(null,B));const Q=function(e,o,l,n,a){let s=!1;const d=this.$props.selectedField,c=d?i.getNestedValue(d,e.dataItem):void 0,h=this.$props.highlight&&this.$props.dataItemKey&&void 0!==i.getter(this.$props.dataItemKey)(e.dataItem)?this.$props.highlight[i.getter(this.$props.dataItemKey)(e.dataItem)]:void 0;return X&&(J=this.getCellsToRender(e.dataItem,B)),{row:J.map((function({columnIndex:n,colSpan:d}){var p,u,g,f;const m=B[n];let v;if(null!=(p=m.rowSpannable)&&p.enabled&&"data"===e.rowType&&m.field&&a){const t=m.field?null==(g=(u=m.rowSpannable).valueGetter)?void 0:g.call(u,e.dataItem,m.field):null;v={value:t,count:1},a[m.field]&&(null==(f=a[m.field])?void 0:f.value)===t&&null!==a[m.field]?(a[m.field].count++,v.count=null):a[m.field]=v}const b=`${m.className?m.className+" ":""}${m.locked?"k-grid-content-sticky":""}`,C=void 0!==m.left?this.isRtl?{left:m.right+"px",right:m.left+"px"}:{left:m.left+"px",right:m.right+"px"}:{};let x,$=!1;if(m.editable&&this.$props.editField){const t=i.getNestedValue(this.$props.editField,e.dataItem);(!0===t||t===m.field)&&(s=!0,$=!0)}m.cell&&(x=m.cell);const k=this.computedCollapsed&&this.computedCollapsed[e.level]&&this.computedCollapsed[e.level].some((t=>t===E(e.dataItem,this.$props.uniqueField))),S=m.id?m.id:n,I=k?!k:e.expanded||e.dataItem.expanded,y="expand"===m._type,w=r.tableKeyboardNavigationTools.generateNavigatableId(`${o}-${String(n)}`,V,y||"groupHeader"===e.rowType||"groupFooter"===e.rowType||"value"===m.field?"nodata":"cell");return m.internalCell?t.createVNode(m.internalCell,{key:S,id:w,colSpan:d,dataItem:e.dataItem,field:m.field||"",editor:m.editor,format:m.format,readFormat:m.readFormat,type:m.type,className:b,render:x||this.$props.cellRender,onChange:this.itemChange,onSelectionchange:t=>this.selectionChangeHandler({event:t,dataItem:e.dataItem,dataIndex:l,columnIndex:n}),columnIndex:n,columnsCount:this._columns.filter((e=>!e.children.length)).length,rowType:e.rowType,level:e.level,expanded:I,dataIndex:e.dataIndex,style:C,ariaColumnIndex:m.ariaColumnIndex,isRtl:this.isRtl,isSelected:Array.isArray(c)&&c.indexOf(n)>-1,isHighlighted:!("boolean"==typeof h||!h||!m.field||!0!==h[m.field]),group:e.group,rowSpan:v},null):$?t.createVNode(ft,{id:w,key:S,colSpan:d,dataItem:e.dataItem,field:m.field||"",editor:m.editor,format:m.format,readFormat:m.readFormat,type:m.type,className:b,render:x||this.$props.cellRender,onEdit:this.editHandler,onRemove:this.removeHandler,onSave:this.saveHandler,onCancel:this.cancelHandler,onChange:this.itemChange,columnIndex:n,columnsCount:this._columns.filter((e=>!e.children.length)).length,rowType:e.rowType,level:e.level,expanded:I,dataIndex:e.dataIndex,style:C},null):t.createVNode(di,{key:S,id:w,colSpan:d,dataItem:e.dataItem,field:m.field||"",editor:m.editor,format:m.format,readFormat:m.readFormat,type:m.type,className:b,render:x||this.$props.cellRender,onCellclick:this.cellClickHandler,onCellkeydown:this.cellKeydownHandler,onEdit:this.editHandler,onRemove:this.removeHandler,onSave:this.saveHandler,onCancel:this.cancelHandler,onChange:this.itemChange,onSelectionchange:t=>this.selectionChangeHandler({event:t,dataItem:e.dataItem,dataIndex:l,columnIndex:n}),columnIndex:n,columnsCount:this._columns.filter((e=>!e.children.length)).length,rowType:e.rowType,level:e.level,expanded:I,dataIndex:e.dataIndex,style:C,rowSpan:v,isSelected:Array.isArray(c)&&c.indexOf(n)>-1,isHighlighted:!("boolean"==typeof h||!h||!m.field||!0!==h[m.field])},null)}),this),isInEdit:s,isSelected:"boolean"==typeof c&&c,isHighlighted:"boolean"==typeof h&&h}};let Z=[];const ee=!this.currentData.length,te=e=>e>=this.currentData.length-0;let ie=0;if(this.currentData.length){const e=this._columnsMap.length+(this.$props.filterable?1:0)+1;let o=this.$props.skip||0,l=-1,n=0;const a=this.computedRowSpannable.enabled?{}:void 0;if(this.isVirtualScroll){if(G>0){const e=this.currentData.slice(0,G).filter((e=>"data"===e.rowType)).length;l+=e,o+=e}!this.$props.pageable&&L&&(l+=this.$props.skip||0)}Z=(w||this.currentData).map((function(s,d){"data"===s.rowType&&l++;const c=s.dataIndex%2!=0,h=this.$props.dataItemKey&&i.getter(this.$props.dataItemKey)(s.dataItem),p=d+o,u=h||"ai"+p,g=u+"_1",f=Q.call(this,s,u,l,c,a),m=B.length-(this.detailExpandable.enabled?1:0)-((null==k?void 0:k.length)||0)||1;return ie=p+e+n,[t.createVNode(hi,{key:u,item:s,dataIndex:l,ariaRowIndex:ie,absoluteRowIndex:p,isAltRow:c,isHidden:te(d),rowHeight:this.$props.rowHeight,isSelected:f.isSelected,isHighlighted:f.isHighlighted,isInEdit:f.isInEdit,rowType:s.rowType,onRowclick:e=>this.rowClick(e,s),onRowdblclick:e=>this.rowDoubleClick(e,s),render:this.$props.rowRender,class:this.$props.rowClass?this.$props.rowClass(s):""},{default:()=>[f.row]}),this.$props.detail&&"data"===s.rowType&&(s.expanded||s.dataItem.expanded)&&t.createVNode("tr",{key:g,class:c?"k-table-row k-table-alt-row k-detail-row":"k-table-row k-detail-row",style:{visibility:te(d)?"hidden":"",height:this.$props.detailRowHeight+"px"},role:"row","aria-rowindex":ie},[null==k?void 0:k.map((function(e){return t.createVNode(ci,{id:"",dataIndex:s.dataIndex,field:e.field,dataItem:s.dataItem,key:`group-${e.field}-${s.dataIndex}`,group:s.group},null)}),this),(this.$props.expandField||this.detailExpandable.enabled)&&t.createVNode(ut,{id:r.tableKeyboardNavigationTools.generateNavigatableId(`${g}-dhcell`,V)},null),t.createVNode(gt,{dataItem:s.dataItem,dataIndex:s.dataIndex,colSpan:m,ariaColIndex:2+(k?k.length:0),detail:this.$props.detail?this.$props.detail:void 0,id:r.tableKeyboardNavigationTools.generateNavigatableId(`${g}-dcell`,V)},null)])]}),this)}const re=this.$props.pageable&&t.createVNode(r.Pager,{class:"k-grid-pager",onPagesizechange:this.pageChangeHandler,onPagechange:this.pageChangeHandler,size:this.$props.size,total:R,skip:x||0,pageSize:(void 0!==$?$:this.$props.pageSize)||10,messagesMap:vi,settings:r.normalize(this.$props.pageable||{})},null),oe=i.getTemplate.call(this,{h:t.h,template:this.$props.pager,defaultRendering:re,additionalProps:{...this.$props,skip:this.$props.skip||0,messagesMap:vi},additionalListeners:{pagesizechange:this.pageChangeHandler,pagechange:this.pageChangeHandler}}),le=e=>v&&v.filter((t=>t.field===e)).length>0,ne=t.createVNode("colgroup",{ref:i.setRef(this,"colGroup")},[B.map((function(e,i){return t.createVNode("col",{key:i.toString(),class:le(e.field)?"k-sorted":void 0,width:void 0!==e.width?-1!==e.width.toString().indexOf("%")?e.width:Math.floor(parseFloat(e.width.toString()))+"px":void 0},null)}),this)]),ae={height:this.getCorrectHeight,...this.$attrs.style},se=this.$props.loader&&t.createVNode("div",{class:"k-loader-container k-loader-container-md k-loader-top"},[t.createVNode("div",{class:"k-loader-container-overlay k-overlay-light"},null),t.createVNode("div",{class:"k-loader-container-inner"},[t.createVNode(o.Loader,{size:"large",type:"infinite-spinner"},null)])]),de=(null!=(m=this.$props.showLoader)?m:!!this.$props.loader)&&i.getTemplate.call(this,{h:t.h,template:this.$props.loader,defaultRendering:se});return"none"===this.$props.scrollable?t.createVNode(r.TableKeyboardNavigationProvider,{ref:"navRef",id:this._gridId,navigatable:this.$props.navigatable},{default:()=>[t.createVNode(g,{ref:e=>{this.gridNavRef=e},currentData:this.currentData,id:this.$props.id,style:ae,class:this.nonscrollableWrapperClass},{default:()=>[_,j,t.createVNode("div",{role:"grid",class:"k-grid-aria-root",id:this._gridRoleElementId,"aria-colcount":this.getAriaColCount,"aria-rowcount":this.getAriaRowCount},[t.createVNode("table",{class:"k-table",style:{tableLayout:"fixed"},ref:i.setRef(this,"table"),role:"none"},[t.createTextVNode(" "),ne,P,t.createVNode("tbody",{class:"k-table-tbody","data-keyboardnavbody":!0},[Z,de]),W]),ee&&t.createVNode(fi,{id:r.tableKeyboardNavigationTools.generateNavigatableId("no-records",V)},{default:()=>[z.length?z:t.createVNode(gi,null,null)]})]),oe,K]})]}):t.createVNode(r.TableKeyboardNavigationProvider,{ref:"navRef",id:this._gridId,navigatable:this.$props.navigatable},{default:()=>[t.createVNode(g,{ref:e=>{this.gridNavRef=e},currentData:this.currentData,id:this.$props.id,style:ae,class:this.scrollableWrapperClass},{default:()=>[_,j,t.createVNode("div",{role:"grid",class:"k-grid-aria-root",id:this._gridRoleElementId,"aria-colcount":this.getAriaColCount,"aria-rowcount":this.getAriaRowCount},[P,t.createVNode("div",{class:"k-grid-container",role:"presentation"},[t.createVNode("div",{role:"presentation",ref:i.setRef(this,"scrollContainer"),class:"k-grid-content k-virtual-content",onScroll:this.scrollHandler},[t.createVNode("div",{class:"k-grid-table-wrap",role:"presentation"},[t.createVNode("table",{role:"none",class:this.gridTableClass,ref:i.setRef(this,"table")},[ne,t.createVNode("tbody",{class:"k-table-tbody",role:"rowgroup","data-keyboardnavbody":!0,ref:i.setRef(this,"tableBody")},[Z])]),ee&&t.createVNode(fi,{id:r.tableKeyboardNavigationTools.generateNavigatableId("no-records",V)},{default:()=>[z.length?z:t.createVNode(gi,null,null)]})]),!ee&&t.createVNode("div",{class:"k-height-container",role:"presentation"},[t.createVNode("div",{ref:i.setRef(this,"scrollHeightContainer"),style:"virtual"===this.$props.scrollable?{height:this._containerHeightRef+"px"}:{}},null)])]),de]),W,q]),oe,K]})]})}}),xi=t.defineComponent({name:"KendoVueGridStateProvider",inheritAttrs:!1,props:pi,setup(e,{emit:i}){var r,o,l,n,a,s,d,c,h;const p=t.ref({filter:null!=(r=e.defaultFilter)?r:e.filter,highlight:e.highlight,search:null!=(o=e.defaultSearch)?o:e.search,sort:null!=(l=e.defaultSort)?l:e.sort,take:null!=(n=e.defaultTake)?n:e.take,skip:null!=(a=e.defaultSkip)?a:e.skip,group:null!=(s=e.defaultGroup)?s:e.group,detailExpand:null!=(d=e.defaultDetailExpand)?d:e.detailExpand,groupExpand:null!=(c=e.defaultGroupExpand)?c:e.groupExpand,columnsState:null!=(h=e.defaultColumnsState)?h:e.columnsState}),u=t.computed((()=>e.filter||p.value.filter||null));t.watch((()=>e.filter),(e=>{p.value.filter=e}));const g=t.computed((()=>e.search||p.value.search||null));t.watch((()=>e.search),(e=>{p.value.search=e}));const f=t.computed((()=>e.sort||p.value.sort||[]));t.watch((()=>e.sort),(e=>{p.value.sort=e}));const m=t.computed((()=>e.skip||p.value.skip||0)),v=t.computed((()=>e.take||p.value.take||0));t.watch((()=>e.skip),(e=>{p.value.skip=e})),t.watch((()=>e.take),(e=>{p.value.take=e}));const b=t.computed((()=>e.group||p.value.group||[]));t.watch((()=>e.group),(e=>{p.value.group=e}));const C=t.computed((()=>e.detailExpand||p.value.detailExpand||{}));t.watch((()=>e.detailExpand),(e=>{p.value.detailExpand=e}));const x=t.computed((()=>e.groupExpand||p.value.groupExpand||[]));t.watch((()=>e.groupExpand),(e=>{p.value.groupExpand=e}));const $=t.computed((()=>e.columnsState||e.defaultColumnsState||[]));t.watch((()=>e.columnsState),(e=>{p.value.columnsState=e})),t.provide(bi,{sort:f,sortchange:e=>{p.value.sort=e.sort,i("sortchange",e)},filter:u,filterchange:e=>{p.value.filter=e.filter,i("filterchange",e)},search:g,searchchange:e=>{p.value.search=e.search,i("searchchange",e)},skip:m,take:v,pagechange:e=>{p.value.skip=e.page.skip,p.value.take=e.page.take,i("pagechange",e)},group:b,groupchange:e=>{p.value.group=e.group,i("groupchange",e)},detailExpand:C,detailexpandchange:e=>{p.value.detailExpand=e.detailExpand,i("detailexpandchange",e)},groupExpand:x,groupexpandchange:e=>{p.value.groupExpand=e.groupExpand,i("groupexpandchange",e)},columnsState:$,columnsstatechange:e=>{p.value.columnsState=e.columnsState,i("columnsstatechange",e)},datastatechange:e=>{p.value={...p.value,...e.data},i("datastatechange",e)}})},render(){return i.getDefaultSlots(this)}}),$i=t.defineComponent({name:"KendoVueGrid",props:pi,setup(e,{expose:i}){const r=t.ref(null);i({get element(){var e;return(null==(e=r.value)?void 0:e.element)||null},get props(){return e},get columns(){var e;return(null==(e=r.value)?void 0:e.columns)||[]},scrollIntoView:e=>{var t;null==(t=r.value)||t.scrollIntoView(e)},fitColumns:e=>{var t;null==(t=r.value)||t.fitColumns(e)},exportAsPdf:()=>{var e;null==(e=r.value)||e.exportAsPdf()}})},computed:{columnsWithTemplates(){const e=i.getListeners.call(this);return i.mapTree(this.$props.columns||[],"children",(t=>{const r={...t},o=i.templateRendering.call(this,r.cell,e),l=i.templateRendering.call(this,r.headerCell,e),n=i.templateRendering.call(this,r.filterCell,e),a=i.templateRendering.call(this,r.footerCell,e),s=i.templateRendering.call(this,r.columnMenu,e);return{...r,cell:o,headerCell:l,filterCell:n,footerCell:a,columnMenu:s}}))}},render(){const e=i.getDefaultSlots(this)||[],r=i.getListeners.call(this),o=e.filter((e=>{var t,i;return e.tag&&-1!==e.tag.toLowerCase().indexOf("toolbar")||e.componentOptions&&-1!==(null==(t=e.componentOptions.tag)?void 0:t.toLowerCase().indexOf("toolbar"))||-1!==(null==(i=null==e?void 0:e.type)?void 0:i.name.toLowerCase().indexOf("toolbar"))})),l=e.filter((e=>{var t,i;return e.tag&&-1!==e.tag.toLowerCase().indexOf("records")||e.componentOptions&&-1!==(null==(t=e.componentOptions.tag)?void 0:t.toLowerCase().indexOf("records"))||-1!==(null==(i=null==e?void 0:e.type)?void 0:i.name.toLowerCase().indexOf("records"))})),{cellRender:n,detail:a,columns:s,rowRender:d,pager:c,loader:h,...p}=this.$props,u=i.templateRendering.call(this,a,r),g=i.templateRendering.call(this,n,r),f=i.templateRendering.call(this,d,r),m=i.templateRendering.call(this,c,r),v=i.templateRendering.call(this,h,r),b=this.columnsWithTemplates;return t.createVNode(xi,p,{default:()=>[t.createVNode(Ci,t.mergeProps(p,r,{class:this.$attrs.class,style:this.$attrs.style,columns:b,cellRender:g,rowRender:f,pager:m,loader:v,detail:u,toolbar:o,noRecords:l}),null)]})}}),ki=t.defineComponent({name:"KendoGridColumnMenuFilterUI",inheritAttrs:!1,props:{firstFilterProps:Object,secondFilterProps:Object,logicValue:Object,logicData:Array,hideSecondFilter:Boolean,operators:Array,render:[String,Function,Object]},emits:{change:null,filteruifocus:null,logicChange:null},methods:{handleFocus(e){this.$emit("filteruifocus",e)},changeHandler(e,t){this.$emit("change",e,t)},logicChange(e){this.$emit("logicChange",e)}},render(){const{firstFilterProps:e,hideSecondFilter:r,secondFilterProps:o,logicData:l,logicValue:n,operators:a,render:s}=this.$props,d=e.field,c=e.value,h=e.operator,p=e.booleanValues,g=e.filterType,f=o.field,m=o.value,v=o.operator,b=o.booleanValues,C=o.filterType,x=t.createVNode("div",{style:this.$attrs.style,class:this.$attrs.class},[t.createVNode(zt,{field:d,value:c,operator:h,booleanValues:p,filterType:g,onFiltercellfocus:this.handleFocus,onChange:e=>{this.changeHandler(e,0)},operators:a},null),!r&&t.createVNode("div",null,[t.createVNode(u.DropDownList,{onChange:this.logicChange,class:"k-filter-and","data-items":l,value:n,textField:"text"},null),t.createVNode(zt,{field:f,value:m,operator:v,booleanValues:b,filterType:C,onFiltercellfocus:this.handleFocus,onChange:e=>{this.changeHandler(e,1)},operators:a},null)])]);return i.getTemplate.call(this,{h:t.h,template:s,defaultRendering:x,additionalProps:this.$props,additionalListeners:{change:this.changeHandler,logicchange:this.logicChange}})}});function Si(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}const Ii={name:"KendoGridColumnMenuCheckboxFilter",props:{column:Object,filter:Object,filterable:Boolean,filterOperators:Object,checkAllItem:[String,Object,Function],item:[String,Object,Function],expanded:{type:Boolean,default:void 0},dataItems:Array,searchBox:{type:Boolean,default:!0},uniqueData:{type:Boolean,default:!0}},data:()=>({currentExpanded:!1,currentValue:"",currentData:void 0,dataFromProps:void 0,currentFilter:void 0}),created(){this.compositeFilterIndex=this.getFilterIndex(),this.currentExpanded=this.$props.expanded,this.currentData=this.parseData(this.$props.dataItems,this.$props.uniqueData)||[],this.dataFromProps=this.parseData(this.$props.dataItems,!1)||[],this.currentFilter=this.defaultFilter()},updated(){const e=this.$props.column.field||"",t=this.$props.dataItems.map((t=>v(e,t)));((e,t)=>e.length===t.length&&e.every(((e,i)=>e===t[i])))(t,this.dataFromProps)||(this.currentData=t,this.dataFromProps=t)},inject:{kendoLocalizationService:{default:null}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){let e,r;const{column:o}=this.$props;if(!o||!o.field)return t.createVNode("div",null,null);const s=l.provideLocalizationService(this),d=void 0!==this.$props.expanded?this.$props.expanded:this.currentExpanded,c=[];if(this.currentFilter){const e=[...this.currentFilter.filters];this.compositeFilterIndex=e.findIndex((e=>!!(e.filters&&e.filters.length>0)&&e.filters[0].field===o.field)),-1!==this.compositeFilterIndex&&e[this.compositeFilterIndex].filters.length>0&&e[this.compositeFilterIndex].filters.forEach((e=>{e.field===this.$props.column.field&&c.push(e.value)}))}const h=function(){return this.$props.searchBox&&t.createVNode("span",{class:"k-list-filter"},[t.createVNode("span",{class:"k-textbox k-input k-input-md k-rounded-md k-input-solid"},[t.createVNode(i.Icon,{name:"search",icon:n.searchIcon,class:"k-input-icon"},null),t.createVNode("input",{ref:"searchBox",placeholder:s.toLanguageString(pe,ht[pe]),class:"k-input-inner",value:this.currentValue,onInput:this.handleSearchChange},null)])])},u=c.filter(((e,t)=>c.indexOf(e)===t)),g=i.templateRendering.call(this,this.$props.item,i.getListeners.call(this)),f=i.templateRendering.call(this,this.$props.checkAllItem,i.getListeners.call(this)),m=t.createVNode("li",{class:"k-item"},[t.createVNode(a.Checkbox,{label:s.toLanguageString(fe,ht[fe]),onChange:e=>this.handleCheckBoxChange(e,"all"),checked:this.isAllSelected()},null)]),v=i.getTemplate.call(this,{h:t.h,template:f,defaultRendering:m,additionalProps:{checked:this.isAllSelected()},additionalListeners:{change:e=>this.handleCheckBoxChange(e,"all")}});return t.createVNode(kt,null,{default:()=>[t.createVNode($t,{title:s.toLanguageString(ae,ht[ae]),icon:"filter",svgIcon:n.filterIcon,onMenuitemclick:this.onFilterExpand},null),t.createVNode(Vt,{show:!!d},{default:()=>[t.createVNode("div",{class:"kendo-grid-filter-menu-container"},[t.createVNode("form",{class:"k-filter-menu k-border-up",onSubmit:this.submit,onReset:this.clear},[t.createVNode("div",{class:"k-filter-menu-container"},[h.call(this),t.createVNode("ul",{class:"k-reset k-multicheck-wrap"},[v,this.currentData.map((function(e,r){const o=t.createVNode("li",{class:"k-item",key:r},[t.createVNode(a.Checkbox,{label:String(e),onChange:t=>this.handleCheckBoxChange(t,e),checked:u.includes(e)},null)]);return i.getTemplate.call(this,{h:t.h,template:g,defaultRendering:o,additionalProps:{item:e,index:r,checked:u.includes(e)},additionalListeners:{change:t=>this.handleCheckBoxChange(t,e)}})}),this)]),t.createVNode("div",{class:"k-columnmenu-actions"},[t.createVNode(p.Button,{themeColor:"primary"},Si(e=s.toLanguageString(ne,ht[ne]))?e:{default:()=>[e]}),t.createVNode(p.Button,{type:"reset"},Si(r=s.toLanguageString(re,ht[re]))?r:{default:()=>[r]})])])])])]})]})},methods:{defaultFilter(){return this.$props.filter?i.clone(this.$props.filter):{filters:[],logic:"and"}},parseData(e,t){const i=this.$props.column.field||"",r=e.map((e=>v(i,e)));return t?r.filter(((e,t)=>r.indexOf(e)===t)):r},getFilterIndex(){const e=this.$props.column.field;return this.defaultFilter().filters.findIndex((t=>t.filters&&t.filters.length>0&&t.filters[0].field===e))},onFilterExpand(){const e=void 0!==this.$props.expanded,t=!(e?this.$props.expanded:this.currentExpanded);this.$emit("expandchange",t),e||(this.currentExpanded=t)},handleSearchChange(e){const t={logic:"and",filters:[{field:this.$props.column.field,operator:"startswith",value:e.target.value,ignoreCase:!0}]};this.currentValue=e.target.value,this.currentData=this.parseData(c.filterBy(this.$props.dataItems||[],t),this.$props.uniqueData)},clear(e){e.preventDefault();const t=this.currentFilter||null;null!==t&&t.filters.length>0?(this.compositeFilterIndex>=0&&t.filters.splice(this.compositeFilterIndex,1),this.$emit("filterchange",t,e)):this.$emit("filterchange",null,e),this.$emit("closemenu")},submit(e){e.preventDefault();const t=this.currentFilter||null;this.$emit("filterchange",t,e),this.$emit("closemenu")},handleCheckBoxChange(e,t){const i=this.$props.column.field||"",r={...this.currentFilter},o=[...this.currentFilter.filters];let l=[];if(-1!==this.compositeFilterIndex&&r.filters[this.compositeFilterIndex].filters&&"all"!==t&&(l=r.filters[this.compositeFilterIndex].filters),e.value&&"all"===t)this.currentData.forEach((e=>{l.push({field:i,operator:"eq",value:e})}));else if(e.value)l.push({field:i,operator:"eq",value:t});else if(this.currentFilter){const e=l.findIndex((e=>e.value===t));l.splice(e,1)}r.logic="and",-1!==this.compositeFilterIndex?o[this.compositeFilterIndex]={logic:"or",filters:l}:o.push({logic:"or",filters:l}),(!e.value&&"all"===t||0===l.length)&&o.splice(this.compositeFilterIndex,1),r.filters=o,this.currentFilter=r},isAllSelected(){let e=!1;if(this.currentFilter){const t=[...this.currentFilter.filters];return-1!==this.compositeFilterIndex&&(e=this.currentData.every((e=>!(-1===this.compositeFilterIndex||!t[this.compositeFilterIndex].filters)&&t[this.compositeFilterIndex].filters.findIndex((t=>t.value===e))>=0)),e)}return e}}},yi=t.defineComponent({render:()=>null}),wi=t.defineComponent({name:"GridToolbar",props:{size:{type:String,default:"medium",validator:function(e){return["small","medium"].includes(e)}}},computed:{wrapperClass(){const{size:e}=this.$props;return{"k-toolbar":!0,"k-grid-toolbar":!0,"k-toolbar-solid":!0,[`k-toolbar-${i.kendoThemeMaps.sizeMap[e]||e}`]:e}}},render(){const e=i.getDefaultSlots(this);return t.createVNode("div",{class:this.wrapperClass,role:"toolbar"},[e])}}),Ni=t.defineComponent({name:"KendoVueGridSearchBox",inheritAttrs:!1,props:{onChange:Function,className:String,placeholder:String},setup(e,{emit:i}){const o=t.inject("kendoLocalizationService",{}),{searchChange:l}=t.inject("kendo",{}),{search:n}=t.inject(bi,{}),a=t.computed((()=>r.getStringFromSearch(n.value))),s=t.computed((()=>({"k-grid-search":!0,"k-searchbox":!0}))),d=t.computed((()=>{const t=o;return null!=t&&t.toLanguageString?t.toLanguageString("searchboxPlaceholder","Search..."):e.placeholder||"Search..."}));return{handleChange:t=>{l&&l(t),i("change",t),e.onChange&&e.onChange.call(void 0,t)},value:a,rootClassName:s,placeholder:d}},render(){return t.createVNode(a.TextBox,t.mergeProps({placeholder:this.placeholder,value:this.value,prefix:()=>t.createVNode(i.SvgIcon,{icon:n.searchIcon},null)},this.$attrs,{class:this.rootClassName,onInput:this.handleChange}),null)}});e.Footer=ii,e.FooterRow=ri,e.Grid=$i,e.GridCell=di,e.GridColumnMenuCheckboxFilter=Ii,e.GridColumnMenuFilter=Pt,e.GridColumnMenuFilterCell=zt,e.GridColumnMenuFilterUI=ki,e.GridColumnMenuItem=$t,e.GridColumnMenuItemContent=Vt,e.GridColumnMenuItemGroup=kt,e.GridColumnMenuSort=Rt,e.GridDetailRow=yi,e.GridEditCell=ft,e.GridFilterCell=Qt,e.GridGroupCell=ci,e.GridHeaderCell=xt,e.GridHierarchyCell=pt,e.GridNoRecords=gi,e.GridRow=hi,e.GridSearchBox=Ni,e.GridToolbar=wi,e.applyExpandedState=F,e.autoGenerateColumns=w,e.calcRowHeight=G,e.checkPropCompatibility=function(e){for(let t=0;t<$.length;t++){const i=$[t];if(void 0!==e[i]){const e="on"+i.charAt(0).toUpperCase()+i.slice(1);console.warn(k(i,e))}}},e.filterGroupByField=Kt,e.firefox=D,e.firefoxMaxHeight=L,e.flatData=b,e.footerColumns=N,e.getColSpan=H,e.getColumnWidth=e=>void 0!==e.width?Math.floor(parseFloat(e.width.toString()))+"px":void 0,e.getDataAsArray=y,e.getFlatColumnsState=A,e.getIndex=x,e.getNestedValue=v,e.getRowSpanOptions=T,e.groupedFirstItemValue=E,e.isRtl=C,e.isSorted=(e,t)=>t&&t.filter((t=>t.field===e)).length>0,e.mapColumns=S,e.parsers=R,e.readColumns=I,e.sanitizeColumns=O,e.sortGroupByField=(e,t)=>{const i=yt(e,t);return Nt(i,t)||wt(i,t)}}));
15
+ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("vue"),require("@progress/kendo-vue-common"),require("@progress/kendo-vue-data-tools"),require("@progress/kendo-vue-indicators"),require("@progress/kendo-vue-intl"),require("@progress/kendo-svg-icons"),require("@progress/kendo-vue-inputs"),require("@progress/kendo-vue-dateinputs"),require("@progress/kendo-vue-popup"),require("@progress/kendo-data-query"),require("@progress/kendo-vue-animation"),require("@progress/kendo-vue-buttons"),require("@progress/kendo-vue-dropdowns")):"function"==typeof define&&define.amd?define(["exports","vue","@progress/kendo-vue-common","@progress/kendo-vue-data-tools","@progress/kendo-vue-indicators","@progress/kendo-vue-intl","@progress/kendo-svg-icons","@progress/kendo-vue-inputs","@progress/kendo-vue-dateinputs","@progress/kendo-vue-popup","@progress/kendo-data-query","@progress/kendo-vue-animation","@progress/kendo-vue-buttons","@progress/kendo-vue-dropdowns"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).KendoVueGrid={},e.Vue,e.KendoVueCommon,e.KendoVueDatatools,e.KendoVueIndicators,e.KendoVueIntl,e.KendoSVGIcons,e.KendoVueInputs,e.KendoVueDateinputs,e.KendoVuePopup,e.KendoDataQuery,e.KendoVueAnimation,e.KendoVueButtons,e.KendoVueDropdowns)}(this,(function(e,t,i,r,o,l,n,a,s,d,c,h,p,u){"use strict";const g=t.defineComponent({name:"KendoGridNav",props:{currentData:Array,id:String},inject:{onNavKeyDown:{default:i.noop},onNavFocus:{default:i.noop},onNavMount:{default:i.noop},handleDispatchFocus:{default:i.noop},kbContext:{default:null},navigation:{default:null}},mounted(){this.onNavMount({scope:this.$el||void 0})},updated(){this.onNavMount({scope:this.$el||void 0})},methods:{onKeyDown(e){this.onNavKeyDown(e,{navigation:this.navigation,kbContext:this.kbContext,onNavigationAction:this.onNavigationAction}),this.$emit("keydown",{dataItems:this.getLeafDataItems(),componentId:this._gridId,selectedField:this.$props.selectedField,event:e})},onFocus(e){this.onNavFocus(e,{kbContext:this.kbContext})},onNavigationAction(e){this.$emit("navigationaction",{focusElement:e.focusElement,event:e.event})},getLeafDataItems(){return this.$props.currentData.filter((e=>"data"===e.rowType)).map((e=>e.dataItem))}},render(){const e=i.getDefaultSlots(this);return t.createVNode("div",{onKeydown:this.onKeyDown,onFocusin:this.onFocus,id:this.$props.id,"data-keyboardnavscope":!0},[e])}}),f={filterable:!0,editable:!0,sortable:!0,resizable:!0,reorderable:!0,groupable:!0},m="string";function v(e,t){const i=e.split(".");let r=t;return i.forEach((e=>{r=r?r[e]:void 0})),r}function b(e,t,o,l,n,a,s,d,c,h,p=0,u){let g=p;for(let f=0;f<t.length;f++){let m;if(!n||void 0===t[f].value||void 0===t[f].items){const r=!!c&&!(null==a||!a[i.getter(c)(t[f])]);e[e.length]={dataIndex:l.index,dataItem:t[f],rowType:"data",level:p,group:u,expanded:void 0!==h?v(h,t[f]):null!=r&&r},l.index++;continue}{let e;e=null!=u&&u.parents?[{field:u.field,value:u.value},...u.parents]:u?[u]:[],m={field:t[f].field,value:t[f].value,parents:e}}g=Math.max(g,p+1);let C=!1;const x=r.findGroupExpand(s||[],m);C=h?void 0===h||void 0===v(h,t[f])||v(h,t[f]):x?!1!==x.expanded:!1!==d,e[e.length]={dataIndex:-1,dataItem:t[f],level:p,group:m,rowType:"groupHeader",expanded:C},C&&(m.expanded=C,g=Math.max(b(e,t[f].items,o,l,n,a,s,d,c,h,p+1,m),g)),("always"===o||C&&"visible"===o)&&(e[e.length]={dataIndex:-1,dataItem:t[f],rowType:"groupFooter",level:p,expanded:C})}return g}function C(e){return e&&"rtl"===getComputedStyle(e).direction||!1}function x(e,t){if(!(t&&e&&e.originalEvent&&i.canUseDOM))return-1;let r=document.elementFromPoint(e.clientX,e.originalEvent.clientY);for(;r&&r.parentElement!==t;)r=r.parentElement;const o=t.children;for(let e=0;e<o.length;e++)if(o[e]===r)return e;return-1}const $=["sortChange","filterChange","groupChange","pageChange","expandChange","selectionChange","headerSelectionChange","rowClick","itemChange","dataStateChange","columnResize","columnReorder"],k=(e,t)=>`The ${e} event handler property is deprecated, use https://www.telerik.com/kendo-vue-ui/components/grid/api/GridProps/#toc-${t} instead`;function S(e,t){const i=[[]];let o=0;for(let t=e.length-1;t>=0;t--)o=Math.max(o,e[t].depth),e[t].headerColSpan=e[t].headerColSpan||1,e[t].children.length>0&&(e[t].headerColSpan=e[t].children.reduce(((e,t)=>t.hidden?e:e+t.headerColSpan),0));const l=[];let n=1;return e.forEach(((e,t)=>{i[e.depth]=i[e.depth]||[];let r=!1;0===i[e.depth].length&&(n<=1?n=1+(e.children.length>0?0:o-e.depth):(n--,r=!0)),e.rowSpan=1+(e.children.length>0?0:o-e.depth),e.kFirst=r,e.index=i[e.depth].length,i[e.depth].push(t),e.ariaColumnIndex=l[e.depth]?l[e.depth]+1:1;for(let t=e.depth;t<e.depth+e.rowSpan;t++)l[t]=(l[t]||0)+e.headerColSpan})),r.updateLeft(i,e,t),r.updateRight(i,e,t),i}function I(e,t,o,l=0,n=!1){const a=[];if(!e)return[];e&&void 0===e.length&&(e=[e]),e.forEach(((e,s)=>{const d=e.id?e.id:r.tableKeyboardNavigationTools.generateNavigatableId(""+o.prevId++,o.idPrefix,"column"),c=!!(i.canUseDOM&&e.media&&window.matchMedia)&&!window.matchMedia(e.media).matches,h=n||c||e.hidden,p=null==t?void 0:t.find((e=>e.id===d)),u=I(e.children,(null==p?void 0:p.children)||[],o,l+1,h);a.push({depth:l,...f,...u.length?{cell:()=>null,filterCell:()=>null}:{},...e,id:d,declarationIndex:a.length,children:u,headerColSpan:0,rowSpan:0,columnType:e.columnType||"data",colSpan:e.colSpan||1,isAccessible:!0,hidden:h,left:null,right:null,rowSpannable:e.rowSpannable,...p?{width:p.width,orderIndex:p.orderIndex}:{}})}));if(a.sort(((e,t)=>e.orderIndex===t.orderIndex?e.declarationIndex-t.declarationIndex:(e.orderIndex||0)-(t.orderIndex||0))),0===l){const e=[],t=(i,r)=>i.forEach((i=>{i.parentIndex=r,t(i.children,e.push(i)-1)}));return t(a,-1),e}return a}const y=e=>Array.isArray(e)?e:e?e.data:[];function w(e,t,i,o){const l=y(e),n=[];if(l.length>0){let e=l[0];if(t)for(let i=0;i<t.length;i++)e=e.items&&e.items[0];Object.getOwnPropertyNames(e).forEach((e=>{e!==i.column&&n.push({id:r.tableKeyboardNavigationTools.generateNavigatableId(""+o.prevId++,o.idPrefix,"column"),declarationIndex:-1,parentIndex:-1,depth:0,colSpan:0,headerColSpan:0,rowSpan:0,index:0,columnType:"data",left:0,right:0,rightBorder:!1,children:[],ariaColumnIndex:0,isAccessible:!0,...f,field:e})}))}return n}const N=e=>e.filter((t=>!((e,t)=>{let i=e[t.parentIndex];for(;i;){if(i.footerCell)return!0;i=e[i.parentIndex]}return!1})(e,t)&&(!!t.footerCell||!(t.children&&t.children.length>0)))),R={number:function(e,t,i){return typeof e===m&&"null"===e.toLowerCase()?null:t.parseNumber(e,i)},date:function(e,t,i){return typeof e===m&&"null"===e.toLowerCase()?null:t.parseDate(e,i)},boolean:function(e){return typeof e===m?"null"===e.toLowerCase()?null:"true"===e.toLowerCase():null!=e?!!e:e},string:function(e){return typeof e===m&&"null"===e.toLowerCase()?null:null!=e?e+"":e},default:function(e){return e}};function V(e,t,i,r){return e.forEach((e=>{e.expanded=t[r]&&!t[r].includes(E(e,i)),e.items&&e.items.length&&(e.items=V(e.items,t,i,r+1))})),e}function F(e,t,i){return t&&t.length&&e.data.forEach((e=>{e.expanded=void 0!==e.expanded?e.expanded:t[0]&&!t[0].includes(E(e,i)),e.items&&e.items.length&&(e.items=V(e.items,t,i,1))})),e}function E(e,t){let i=e;for(;i.items&&i.items.length;)i=i.items[0];return t?i[t]:e.value}const A=e=>{const t=[],i=e=>null==e?void 0:e.forEach((e=>{t.push(e),i(e.children)}));return i(e),t},D="undefined"!=typeof window&&/Firefox/.test(window.navigator.userAgent),L=17895697,O=e=>(e.sort(((e,t)=>e.declarationIndex-t.declarationIndex)),e.map((e=>{const{declarationIndex:t,parentIndex:i,depth:r,headerColSpan:o,rowSpan:l,index:n,kFirst:a,children:s,...d}=e;return s.length?{children:O(s),...d}:d}))),H=(e,t)=>"function"==typeof e.colSpan?e.colSpan({dataItem:t,column:e}):e.colSpan||1,T=e=>{var t,r;const o="object"==typeof e?null==(t=e.enabled)||t:null!=e&&e,l="object"==typeof e&&null!=(r=e.valueGetter)?r:(e,t)=>i.getter(t)(e);return{enabled:o,valueGetter:l}},G=e=>{let t=0;if(e){const i=e.insertRow(0);i.insertCell(0).textContent="&nbsp;",t=i.getBoundingClientRect().height,e.deleteRow(0)}return t},_=t.defineComponent({name:"KendoGridSelectionCell",inheritAttrs:!1,props:{id:String,field:String,dataItem:Object,format:String,type:String,className:String,colSpan:Number,columnIndex:Number,columnsCount:Number,rowType:String,level:Number,expanded:Boolean,render:[String,Function,Object],isSelected:Boolean,ariaColumnIndex:Number,editor:String,isRtl:Boolean},emits:{selectionchange:null,cellkeydown:null},inject:{kendoIntlService:{default:null},getKeyboardNavigationAttributes:{default:i.noop}},data:()=>({inputId:i.guid()}),computed:{tdClass(){const{className:e}=this.$props;return{"k-table-td":!0,[e]:e}}},methods:{triggerKeydown(e){this.$emit("cellkeydown",{event:e,dataItem:this.$props.dataItem,field:this.$props.field})},handleOnChange(e){this.$emit("selectionchange",{event:e,dataItem:this.$props.dataItem})}},render(){const e=v(this.$props.field,this.$props.dataItem),o=this.$props.render,l=this.getKeyboardNavigationAttributes(this.$props.id),n="groupHeader"!==this.$props.rowType?t.createVNode("td",{style:this.$attrs.style,onKeydown:this.triggerKeydown,colspan:this.$props.colSpan,class:this.tdClass,"aria-colindex":this.$props.ariaColumnIndex,role:"gridcell",tabindex:l.tabIndex,"data-keyboardnavlevel":l[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":l[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode("span",{class:"k-checkbox-wrap"},[t.createVNode("input",{checked:e,id:this.inputId,type:"checkbox",class:"k-checkbox k-checkbox-md k-rounded-md",onChange:this.handleOnChange},null)]),t.createVNode("label",{class:"k-checkbox-label",for:this.inputId},null)]):null;return i.getTemplate.call(this,{h:t.h,template:o,defaultRendering:n,additionalProps:this.$props,additionalListeners:{keydown:this.triggerKeydown,change:this.handleOnChange}})}}),z="grid.noRecords",B="grid.selectAllRows",j="grid.pagerInfo",M="grid.pagerFirstPage",K="grid.pagerPreviousPage",P="grid.pagerNextPage",W="grid.pagerLastPage",q="grid.pagerItemsPerPage",U="grid.pagerPage",Y="grid.pagerPageSelection",X="grid.pagerOf",J="grid.pagerTotalPages",Q="grid.groupPanelEmpty",Z="grid.groupColumn",ee="grid.ungroupColumn",te="grid.columnMenu",ie="grid.filterApplyButton",re="grid.filterClearButton",oe="grid.filterClearAllButton",le="grid.filterResetButton",ne="grid.filterSubmitButton",ae="grid.filterTitle",se="grid.sortAscending",de="grid.sortDescending",ce="grid.sortClearButton",he="grid.sortApplyButton",pe="grid.searchPlaceholder",ue="grid.searchboxPlaceholder",ge="grid.exportPDF",fe="grid.filterCheckAll",me="grid.filterChooseOperator",ve="grid.filterSelectAll",be="grid.filterSelectedItems",Ce="grid.sortAriaLabel",xe="grid.sortableColumnAriaLabel",$e="grid.sortableColumnAscendingAriaLabel",ke="grid.sortableColumnDescendingAriaLabel",Se="grid.editDialogTitle",Ie="grid.editDialogSaveButtonTitle",ye="grid.editDialogCancelButtonTitle",we="grid.filterAriaLabel",Ne="grid.numericFilterAriaLabel",Re="grid.groupPanelAriaLabel",Ve="grid.groupExpand",Fe="grid.groupCollapse",Ee="grid.groupClearButton",Ae="grid.groupApplyButton",De="grid.detailExpand",Le="grid.detailCollapse",Oe="grid.selectRow",He="grid.gridAriaLabel",Te="grid.gridRowReorderAriaLabel",Ge="grid.gridAdaptiveColumnMenuFilterTitle",_e="grid.columnMenuColumnChooserTitle",ze="grid.columnMenuColumnChooserSelectedItems",Be="grid.adaptiveColumnMenuChooserTitle",je="grid.adaptiveColumnMenuChooserSubTitle",Me="grid.columnChooserApplyButton",Ke="grid.columnChooserResetButton",Pe="grid.adaptiveColumnMenuCheckboxFilterTitle",We="grid.adaptiveToolbarSortTitle",qe="grid.adaptiveToolbarGroupTitle",Ue="grid.toolbarSort",Ye="grid.dateFilterAriaLabel",Xe="grid.textFilterAriaLabel",Je="grid.booleanFilterAriaLabel",Qe="grid.groupHeaderAriaLabel",Ze="grid.groupCaretAriaLabelCollapse",et="grid.groupCaretAriaLabelExpand",tt="grid.expandDetailTemplateAriaLabel",it="grid.collapseDetailTemplateAriaLabel",rt="grid.toolbarAI",ot="grid.aIResponseData",lt="grid.generatedWithAI",nt="grid.toolbarAIApply",at="grid.toolbarGroup",st="grid.toolbarFilter",dt="grid.toolbarColumnsChooser",ct="grid.toolbarCheckboxFilter",ht={[De]:"Expand detail row",[Le]:"Collapse detail row",[Ve]:"Expand group",[Fe]:"Collapse Group",[Ee]:"Clear grouping",[Ae]:"Done",[z]:"No records available",[B]:"Select all rows",[Q]:"Drag a column header and drop it here to group by that column",[ie]:"Apply",[re]:"Clear",[oe]:"Clear all filters",[le]:"Reset",[ne]:"Filter",[ae]:"Filter",[se]:"Sort Ascending",[de]:"Sort Descending",[ce]:"Clear sorting",[he]:"Done",[Ce]:"Sortable",[We]:"Sort by",[qe]:"Group by",[Ue]:"Sort",[rt]:"AI Assistant",[nt]:"Apply",[ot]:"Operation is successful. Data is: \n",[lt]:"Generated with AI",[at]:"Group",[st]:"Filter",[dt]:"Columns",[ct]:"Filter",[Z]:"Group Column",[ee]:"Ungroup Column",[te]:"Column menu",[q]:"items per page",[j]:"{0} - {1} of {2} items",[M]:"Go to the first page",[K]:"Go to the previous page",[P]:"Go to the next page",[W]:"Go to the last page",[U]:"Page",[Y]:"Page size",[X]:"of",[J]:"{0}",[pe]:"Search",[ue]:"Search...",[ge]:"Export PDF",[fe]:"Check All",[Se]:"Edit Dialog",[Ie]:"Save",[ye]:"Cancel",[me]:"Choose Operator",[be]:"selected items",[ve]:"Select All",[xe]:"Sortable Column",[$e]:"Sorted in ascending order",[ke]:"Sorted in descending order",[we]:"Filter",[Ne]:"Numeric Filter",[Ye]:"Date Filter",[Xe]:"Text Filter",[Je]:"Boolean Filter",[Qe]:"Group Header",[Ze]:"Collapse Group",[et]:"Expand Group",[tt]:"Expand Details",[it]:"Collapse Details",[Re]:"Group panel",[He]:"Table",[Te]:"Drag row",[Oe]:"Select Row",[_e]:"Columns Chooser",[Ge]:"Filter by",[Be]:"Columns Chooser",[je]:"Selected fields are visible",[Pe]:"Filter by",[ze]:"Selected items",[Me]:"Apply",[Ke]:"Reset","grid.filterEqOperator":"Is equal to","grid.filterNotEqOperator":"Is not equal to","grid.filterIsNullOperator":"Is null","grid.filterIsNotNullOperator":"Is not null","grid.filterIsEmptyOperator":"Is empty","grid.filterIsNotEmptyOperator":"Is not empty","grid.filterStartsWithOperator":"Starts with","grid.filterContainsOperator":"Contains","grid.filterNotContainsOperator":"Does not contain","grid.filterEndsWithOperator":"Ends with","grid.filterGteOperator":"Is greater than or equal to","grid.filterGtOperator":"Is greater than","grid.filterLteOperator":"Is less than or equal to","grid.filterLtOperator":"Is less than","grid.filterIsTrue":"Is true","grid.filterIsFalse":"Is false","grid.filterBooleanAll":"(All)","grid.filterAfterOrEqualOperator":"Is after or equal to","grid.filterAfterOperator":"Is after","grid.filterBeforeOperator":"Is before","grid.filterBeforeOrEqualOperator":"Is before or equal to","grid.filterAndLogic":"And","grid.filterOrLogic":"Or"},pt=t.defineComponent({name:"KendoGridHierarchyCell",inheritAttrs:!1,props:{id:String,field:String,dataItem:Object,format:String,type:String,className:String,colSpan:Number,columnIndex:Number,columnsCount:Number,rowType:String,level:Number,expanded:Boolean,editor:String,isSelected:Boolean,dataIndex:Number,ariaColumnIndex:Number,render:[String,Function,Object],isRtl:Boolean},emits:{change:null,cellkeydown:null},inject:{kendo:{default:null},kendoIntlService:{default:null},kendoLocalizationService:{default:null},getKeyboardNavigationAttributes:{default:i.noop}},methods:{triggerStateChange(){const e=this.kendo;e.dataItemKey&&void 0!==this.$props.dataItem[e.dataItemKey]&&(null==e||e.dispatchDetailExpand({type:r.DETAIL_EXPAND_ACTION.TOGGLE,id:this.$props.dataItem[e.dataItemKey]}))},triggerKeydown(e,t){this.$emit("cellkeydown",{event:e,dataItem:this.$props.dataItem,field:this.$props.field,expanded:t}),!e.defaultPrevented&&e.keyCode===i.Keys.enter&&(e.preventDefault(),this.$emit("change",{dataItem:this.$props.dataItem,dataIndex:this.$props.dataIndex,event:e,field:this.$props.field,value:!t}),this.triggerStateChange())},clickHandler(e,t,i){e.preventDefault(),this.$emit("change",{dataItem:t,event:e,field:void 0,value:!i}),this.triggerStateChange()}},computed:{wrapperClass(){return{"k-table-td":!0,"k-hierarchy-cell":!0,[this.className||""]:this.className}}},render(){let e=null;const o=this.getKeyboardNavigationAttributes(this.$props.id),a=l.provideLocalizationService(this),s=a.toLanguageString(it,ht[it]),d=a.toLanguageString(tt,ht[tt]);if("groupFooter"===this.$props.rowType)e=t.createVNode("td",{class:this.wrapperClass},null);else if("groupHeader"!==this.$props.rowType){const l=this.$props.expanded;e=t.createVNode("td",{style:this.$attrs.style,onKeydown:e=>{this.triggerKeydown(e,l)},class:this.wrapperClass,"aria-expanded":l?"true":"false",role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,tabindex:o.tabIndex,"data-keyboardnavlevel":o[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":o[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode("a",{onClick:e=>{this.clickHandler(e,this.$props.dataItem,l)},href:"#",tabindex:-1,title:l?s:d,"aria-label":l?s:d},[t.createVNode(i.Icon,{name:l?"minus":"plus",icon:l?n.minusIcon:n.plusIcon},null)])])}return i.getTemplate.call(this,{h:t.h,template:this.$props.render,defaultRendering:e,additionalProps:this.$props,additionalListeners:{keydown:this.triggerKeydown,click:this.clickHandler}})}}),ut=t.defineComponent({props:{id:String},inject:{getKeyboardNavigationAttributes:{default:i.noop}},setup:()=>({kendoIntlService:t.inject("kendoIntlService",{})}),render(){const e=this.getKeyboardNavigationAttributes(this.$props.id);return t.createVNode("td",{class:"k-table-td k-hierarchy-cell",tabindex:e.tabIndex,"data-keyboardnavlevel":e[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":e[r.KEYBOARD_NAV_DATA_ID]},null)}}),gt=t.defineComponent({props:{colSpan:Number,ariaColIndex:Number,dataItem:[Object,String,Number],dataIndex:Number,detail:[String,Function,Object],id:String},inject:{getKeyboardNavigationAttributes:{default:i.noop}},setup:()=>({kendoIntlService:t.inject("kendoIntlService",{})}),render(){const{colSpan:e,ariaColIndex:o,dataItem:l,dataIndex:n,id:a}=this.$props,s=this.getKeyboardNavigationAttributes(a);return t.createVNode("td",{class:"k-table-td k-detail-cell",colspan:e,"aria-colindex":o,role:"gridcell",tabindex:s.tabIndex,"data-keyboardnavlevel":s[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":s[r.KEYBOARD_NAV_DATA_ID]},[function(e){return i.getTemplate.call(this,{h:t.h,template:this.$props.detail,additionalProps:e})}.call(this,{dataItem:l,dataIndex:n})])}}),ft=t.defineComponent({name:"GridEditCell",inheritAttrs:!1,props:{id:String,field:String,dataItem:Object,format:String,type:String,className:String,colSpan:Number,columnIndex:Number,columnsCount:Number,rowType:String,level:Number,expanded:Boolean,editor:String,isSelected:Boolean,ariaColumnIndex:Number,render:[String,Function,Object],isRtl:Boolean,readFormat:String,dataIndex:Number},emits:{change:null,cellkeydown:null,edit:null,add:null,cancel:null,save:null,remove:null},inject:{kendoIntlService:{default:null},getKeyboardNavigationAttributes:{default:i.noop}},computed:{tdClass(){const{className:e}=this.$props;return{"k-table-td":!0,[e]:e}}},data:()=>({inputId:i.guid()}),methods:{triggerKeydown(e){this.$emit("cellkeydown",{event:e,dataItem:this.$props.dataItem,field:this.$props.field})},triggerEdit(e){this.$emit("edit",e)},triggerAdd(e){this.$emit("add",e)},triggerCancel(e){this.$emit("cancel",e)},triggerSave(e){this.$emit("save",e)},triggerRemove(e){this.$emit("remove",e)},changeHandler(e,t){t||(t="checkbox"===e.target.type?e.target.checked:e.target.valueAsDate?e.target.valueAsDate:e.target.value),this.$emit("change",{dataItem:this.$props.dataItem,field:this.$props.field,event:e,value:t})}},setup:()=>({kendoIntlService:t.inject("kendoIntlService",{})}),render(){const e=v(this.$props.field,this.$props.dataItem),o=this.getKeyboardNavigationAttributes(this.$props.id);let l=null;switch(this.$props.editor){case"numeric":l=t.createVNode("td",{style:this.$attrs.style,onKeydown:this.triggerKeydown,colspan:this.$props.colSpan,class:this.tdClass,role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,"aria-selected":this.$props.isSelected,"data-grid-col-index":this.$props.columnIndex,tabindex:o.tabIndex,"data-keyboardnavlevel":o[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":o[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode(a.NumericTextBox,{style:{width:"100%"},value:void 0===e?null:e,onChange:this.changeHandler},null)]);break;case"date":l=t.createVNode("td",{style:this.$attrs.style,onKeydown:this.triggerKeydown,colspan:this.$props.colSpan,class:this.tdClass,role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,"aria-selected":this.$props.isSelected,"data-grid-col-index":this.$props.columnIndex,tabindex:o.tabIndex,"data-keyboardnavlevel":o[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":o[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode(s.DatePicker,{style:{width:"100%"},value:e,onChange:this.changeHandler},null)]);break;case"boolean":l=t.createVNode("td",{style:this.$attrs.style,onKeydown:this.triggerKeydown,colspan:this.$props.colSpan,class:this.tdClass,role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,"aria-selected":this.$props.isSelected,"data-grid-col-index":this.$props.columnIndex,tabindex:o.tabIndex,"data-keyboardnavlevel":o[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":o[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode("input",{checked:e||!1,id:this.inputId,type:"checkbox",class:"k-checkbox k-checkbox-md k-rounded-md",onChange:this.changeHandler},null),t.createVNode("label",{class:"k-checkbox-label",for:this.inputId},null)]);break;default:l=t.createVNode("td",{style:this.$attrs.style,onKeydown:this.triggerKeydown,colspan:this.$props.colSpan,class:this.tdClass,role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,"aria-selected":this.$props.isSelected,"data-grid-col-index":this.$props.columnIndex,tabindex:o.tabIndex,"data-keyboardnavlevel":o[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":o[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode("span",{class:"k-textbox k-input k-input-md k-rounded-md k-input-solid"},[t.createVNode("input",{style:{width:"100%"},class:"k-input-inner",value:null!=e?e:"",onChange:this.changeHandler},null)])])}return i.getTemplate.call(this,{h:t.h,template:this.$props.render,defaultRendering:l,additionalProps:this.$props,additionalListeners:{change:this.changeHandler,keydown:this.triggerKeydown,edit:this.triggerEdit,add:this.triggerAdd,cancel:this.triggerCancel,save:this.triggerSave,remove:this.triggerRemove}})}}),mt=t.defineComponent({props:{staticHeaders:Boolean,headerRow:Object,columnResize:Object,cols:Array,size:String,draggable:Boolean},data:()=>({divStyle:{},element:null,headerWrap:null,table:null}),computed:{wrapperClass(){return{"k-grid-header":!0,"k-grid-draggable-header":this.$props.draggable}},tableClass(){const{size:e}=this.$props;return{"k-table":!0,"k-grid-header-table":!0,[`k-table-${i.kendoThemeMaps.sizeMap[e]||e}`]:e}}},mounted(){this.headerWrap=i.getRef(this,"headerWrap"),this.table=i.getRef(this,"table"),this.$props.columnResize.colGroupHeader=i.getRef(this,"colGroupHeader");const e=C(this.$el);this.$props.columnResize&&this.$props.columnResize.setIsRtl(e)},methods:{setScrollLeft(e){this.headerWrap&&(this.headerWrap.scrollLeft=e)},setWidth(e){this.table&&(this.table.style.width=e+"px")}},setup:()=>({headerWrapRef:t.ref(null),tableRef:t.ref(null),colGroupHeaderRef:t.ref(null)}),render(){return this.$props.staticHeaders?t.createVNode("div",{class:this.wrapperClass},[t.createVNode("div",{ref:i.setRef(this,"headerWrap"),class:"k-grid-header-wrap"},[t.createVNode("table",{class:this.tableClass,ref:i.setRef(this,"table"),role:"none"},[t.createVNode("colgroup",{ref:i.setRef(this,"colGroupHeader")},[this.$props.cols]),this.$props.headerRow])])]):this.$props.headerRow}}),vt=(...e)=>Object.assign({allowUnsort:!0,mode:"single"},...e),bt=t.defineComponent({props:{onResize:Function},mounted(){this.$el&&(this.draggable=this.$refs.draggable)},methods:{drag(e){const t=this.draggable&&this.draggable.element;t&&this.$emit("resize",e,t,!1)},release(e){const t=this.draggable&&this.draggable.element;t&&this.$emit("resize",e,t,!0)}},render(){const e={cursor:"col-resize",display:"block",height:"1000%",position:"absolute",top:0,width:".5em"};return t.createVNode(i.Draggable,{onDrag:this.drag,onRelease:this.release,ref:"draggable"},{default:()=>[t.createVNode("span",{class:"k-column-resizer",draggable:!1,style:e},null)]})}}),Ct=t.defineComponent({props:{onPressHandler:Function,onDragHandler:Function,onReleaseHandler:Function},mounted(){this.$el&&(this.draggable=this.$refs.draggable)},methods:{onPress(e){const t=this.draggable&&this.draggable.element;t&&this.$emit("pressHandler",e,t)},onDrag(e){const t=this.draggable&&this.draggable.element;t&&this.$emit("dragHandler",e,t)},onRelease(e){const t=this.draggable&&this.draggable.element;t&&this.$emit("releaseHandler",e,t)}},render(){const e=i.getDefaultSlots(this);return t.createVNode(i.Draggable,{onPress:this.onPress,onDrag:this.onDrag,onRelease:this.onRelease,ref:"draggable"},{default:()=>[t.createVNode("tr",{class:"k-table-row",role:"row"},[e])]})}}),xt=t.defineComponent({props:{field:String,title:String,sortable:[Boolean,Object],render:[Object,Function,String],selectionValue:[Boolean,String,Number],onHeadercellclick:Function},computed:{linkClass(){return{"k-link":!0,"!k-cursor-default":!this.sortable}}},methods:{clickHandler(e){this.sortable&&this.$emit("headercellclick",e)}},render(){const e=i.getDefaultSlots(this),r=this.$props.render,o=this.$props.title||this.$props.field||" ",l=i.getTemplate.call(this,{h:t.h,template:r,defaultRendering:o,additionalProps:this.$props,additionalListeners:{click:this.clickHandler}});return t.createVNode("span",{class:this.linkClass,onClick:this.clickHandler},[t.createVNode("span",{class:"k-column-title"},[l]),e])}}),$t=t.defineComponent({props:{title:String,iconClass:String,icon:String,svgIcon:Object,selected:Boolean,onMenuitemclick:Function},methods:{onClick(e){this.$emit("menuitemclick",e)},onKeyDown(e){e.keyCode===i.Keys.enter&&this.$emit("menuitemclick",e)}},render(){const{title:e,iconClass:r,selected:o,icon:l,svgIcon:n}=this.$props;return t.createVNode("div",{tabindex:0,onKeydown:this.onKeyDown,onClick:this.onClick,class:"k-columnmenu-item "+(o?"k-selected":"")},[r&&t.createVNode(i.Icon,{class:r},null),(l||n)&&t.createVNode(i.Icon,{name:l,icon:n},null),e])}}),kt=t.defineComponent({render(){const e=i.getDefaultSlots(this);return t.createVNode("div",{class:"k-columnmenu-item-wrapper"},[e])}}),St="desc",It={true:{asc:{asc:"",desc:"desc"},desc:{asc:"asc",desc:""},"":{asc:"asc",desc:"desc"}},false:{asc:{asc:"asc",desc:"desc"},desc:{asc:"asc",desc:"desc"},"":{asc:"asc",desc:"desc"}}},yt=(e,t)=>t?t.findIndex((t=>t.field===e)):-1,wt=(e,t)=>!!(t&&e>-1&&"asc"===t[e].dir),Nt=(e,t)=>!!(t&&e>-1&&t[e].dir===St),Rt=t.defineComponent({props:{sortable:[Boolean,Object],sort:{type:Array},column:Object,onSortchange:Function,onClosemenu:Function},inject:{kendoLocalizationService:{default:null}},methods:{onAscClick(e){this.onSort(e,"asc"),this.$emit("closemenu")},onDescClick(e){this.onSort(e,St),this.$emit("closemenu")},onSort(e,t){if(e.preventDefault(),!i.hasListener.call(this,"sortchange"))return;const{column:r,sortable:o,sort:l}=this.$props,{allowUnsort:n,mode:a}=vt(o||!1,!1),s=(l||[]).filter((e=>e.field===r.field))[0],d=It[n][s&&s.dir||""][t],c="single"===a?[]:(this.$props.sort||[]).filter((e=>e.field!==r.field));""!==d&&r.field&&c.push({field:r.field,dir:d}),this.$emit("sortchange",c,{event:e,field:this.$props.column.field})}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const{sort:e,column:i}=this.$props,r=yt(i.field,e),o=l.provideLocalizationService(this);return t.createVNode(kt,null,{default:()=>[t.createVNode($t,{title:o.toLanguageString(se,ht[se]),icon:"sort-asc-small",svgIcon:n.sortAscSmallIcon,selected:wt(r,e),onMenuitemclick:this.onAscClick},null),t.createVNode($t,{title:o.toLanguageString(de,ht[de]),icon:"sort-desc-small",svgIcon:n.sortDescSmallIcon,selected:Nt(r,e),onMenuitemclick:this.onDescClick},null)]})}}),Vt=t.defineComponent({props:{show:Boolean},render(){const e=i.getDefaultSlots(this);return t.createVNode("div",{class:"k-columnmenu-item-content"},[t.createVNode(h.Reveal,{appear:this.$props.show,style:{position:"relative",display:"block"}},{default:()=>[this.$props.show?e:null]})])}}),Ft=[{text:"grid.filterAndLogic",operator:"and"},{text:"grid.filterOrLogic",operator:"or"}],Et={text:[{text:"grid.filterContainsOperator",operator:"contains"},{text:"grid.filterNotContainsOperator",operator:"doesnotcontain"},{text:"grid.filterEqOperator",operator:"eq"},{text:"grid.filterNotEqOperator",operator:"neq"},{text:"grid.filterStartsWithOperator",operator:"startswith"},{text:"grid.filterEndsWithOperator",operator:"endswith"},{text:"grid.filterIsNullOperator",operator:"isnull"},{text:"grid.filterIsNotNullOperator",operator:"isnotnull"},{text:"grid.filterIsEmptyOperator",operator:"isempty"},{text:"grid.filterIsNotEmptyOperator",operator:"isnotempty"}],numeric:[{text:"grid.filterEqOperator",operator:"eq"},{text:"grid.filterNotEqOperator",operator:"neq"},{text:"grid.filterGteOperator",operator:"gte"},{text:"grid.filterGtOperator",operator:"gt"},{text:"grid.filterLteOperator",operator:"lte"},{text:"grid.filterLtOperator",operator:"lt"},{text:"grid.filterIsNullOperator",operator:"isnull"},{text:"grid.filterIsNotNullOperator",operator:"isnotnull"}],date:[{text:"grid.filterEqOperator",operator:"eq"},{text:"grid.filterNotEqOperator",operator:"neq"},{text:"grid.filterAfterOrEqualOperator",operator:"gte"},{text:"grid.filterAfterOperator",operator:"gt"},{text:"grid.filterBeforeOperator",operator:"lt"},{text:"grid.filterBeforeOrEqualOperator",operator:"lte"},{text:"grid.filterIsNullOperator",operator:"isnull"},{text:"grid.filterIsNotNullOperator",operator:"isnotnull"}],boolean:[{text:"grid.filterEqOperator",operator:"eq"}]},At=e=>"isnull"===e||"isnotnull"===e||"isempty"===e||"isnotempty"===e,Dt=(e,t)=>e.map((e=>({text:t.toLanguageString(e.text,ht[e.text]),operator:e.operator}))),Lt=[{text:"grid.filterBooleanAll",operator:""},{text:"grid.filterIsTrue",operator:!0},{text:"grid.filterIsFalse",operator:!1}],Ot=(e,t,i)=>{const r=Ht(i.operators);let o=i.operator;switch(i.filterType){case"numeric":case"date":(!o||At(o))&&(o=r),null===e&&o===r&&(o="");break;case"text":(!o||At(o))&&(o=r),!e&&o===r&&(o="");break;default:return}return{value:e,operator:o,event:t}},Ht=(e,t)=>t?e[t][0].operator:e[0].operator,Tt=e=>e||"text",Gt=(e,t)=>({value:e,operator:""===e?"":"eq",event:t}),_t=(e,t,i)=>(At(e)&&(i=null),{value:i,operator:e,event:t}),zt=t.defineComponent({props:{field:String,filterType:String,value:[Object,String,Number,Date,Boolean],operator:String,operators:Array,booleanValues:Array},emits:{change:null,filtercellfocus:null},methods:{handleFocus(e){this.$emit("filtercellfocus",e)},triggerChange(e){this.$emit("change",e)},inputChange(e,t){const i=Ot(e,t,this.$props);this.triggerChange(i)},boolDropdownChange(e,t){const i=Gt(e.value.operator,t);this.triggerChange(i)}},render(){const{filterType:e,value:i,booleanValues:r}=this.$props;let o;switch(e){case"numeric":return t.createVNode(a.NumericTextBox,{value:i,onChange:e=>{this.inputChange(e.value,e.event)}},null);case"date":return t.createVNode(s.DatePicker,{value:i,onFocus:this.handleFocus,onChange:e=>{this.inputChange(e.value,e.event)}},null);case"boolean":return o=e=>null==e,t.createVNode(u.DropDownList,{onChange:this.boolDropdownChange,value:r.find((e=>e.operator===(o(i)?"":i))),"data-items":r,textField:"text"},null);default:return t.createVNode("span",{class:"k-textbox k-input k-input-md k-rounded-md k-input-solid"},[t.createVNode("input",{class:"k-input-inner",value:i||"",onInput:e=>{this.inputChange(e.target.value,e)}},null)])}}}),Bt=t.defineComponent({props:{filterType:String,operator:String,operators:Array},emits:{change:null},methods:{triggerChange(e){this.$emit("change",e)},operatorChange(e,t){const i=_t(e.value.operator,t,this.$props.value);this.triggerChange(i)}},render(){const e=this.$props.operators.find((e=>e.operator===this.$props.operator))||null;return"boolean"!==this.$props.filterType?t.createVNode(u.DropDownList,{onChange:this.operatorChange,value:e,"data-items":this.$props.operators,textField:"text"},null):null}});function jt(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}const Mt=e=>e||{filters:[],logic:"and"},Kt=(e,t)=>Mt(t).filters.filter((t=>!!c.isCompositeFilterDescriptor(t)&&(t.filters&&t.filters.length&&t.filters.length<=2&&!t.filters.find((t=>c.isCompositeFilterDescriptor(t)||t.field!==e)))))[0]||null,Pt=t.defineComponent({name:"KendoGridColumnMenuFilter",props:{column:Object,filter:Object,expanded:{type:Boolean,default:void 0},filterable:Boolean,filterOperators:{type:Object,default:function(){return Et}},hideSecondFilter:{type:[Boolean,Object],default:function(){}},filterUI:[String,Function,Object],onFilterfocus:Function,onFilterchange:Function,onExpandchange:Function,onClosemenu:Function},inject:{kendoLocalizationService:{default:null}},data:()=>({currentExpanded:!1,filterGroup:null}),created(){let e;if(this.$props.column&&this.$props.column.field){const t=Tt(this.$props.column.filter),i=Ht(this.$props.filterOperators,t);e=Kt(this.$props.column.field,this.$props.filter),e=e?{...e,filters:e.filters.map((e=>({...e})))}:{logic:"and",filters:[{field:this.$props.column.field,operator:i},{field:this.$props.column.field,operator:i}]},1===e.filters.filter((e=>e.field===this.$props.column.field)).length&&e.filters.splice(1,0,{field:this.$props.column.field,operator:i})}this.currentExpanded=this.$props.expanded||!1,this.filterGroup=e},methods:{removeGroup(e,t){const i=[...t.filters],r=i.findIndex((t=>t===e));return r>-1&&i.splice(r,1),{...t,filters:i}},insertGroup:(e,t)=>({...t,filters:[e,...t.filters]}),isControlled(){return void 0!==this.$props.expanded},onFilterExpand(){const e=this.isControlled(),t=!(e?this.$props.expanded:this.currentExpanded);this.$emit("expandchange",t),e||(this.currentExpanded=t)},filterChangeHandler(e,t){this.filterChange(t||0,e)},firstFilterChange(e){this.filterChange(0,e)},secondFilterChange(e){this.filterChange(1,e)},filterChange(e,t){const i=this.filterGroup.filters.map(((i,r)=>r===e?{...i,value:t.value,operator:t.operator}:i));this.filterGroup={...this.filterGroup,filters:i}},logicChange(e){this.filterGroup={...this.filterGroup,logic:e.target.value.operator}},clear(e){if(e.preventDefault(),!i.hasListener.call(this,"filterchange"))return;const t=this.$props.column.field,r=Mt(this.$props.filter),o=Kt(t,this.$props.filter),l=r.filters.filter((e=>e!==o));l.length?this.$emit("filterchange",{...r,filters:l},{event:e,field:this.$props.column.field}):this.$emit("filterchange",null,{event:e,field:this.$props.column.field}),this.$emit("closemenu")},currentFilterGroup(){return{...this.filterGroup,filters:this.filterGroup.filters.filter((e=>void 0!==e.value&&null!==e.value&&""!==e.value||null===e.value&&e.operator))}},submit(e){if(e.preventDefault(),!i.hasListener.call(this,"filterchange"))return;const t=this.$props.column.field,r=Mt(this.$props.filter),o=Kt(t,this.$props.filter),l=this.currentFilterGroup();let n=null;if(o&&l.filters.length>0){const e=r.filters.map((e=>e===o?l:e));n={...r,filters:e}}else if(0===l.filters.length){const e=r.filters.filter((e=>e!==o));e.length&&(n={...r,filters:e})}else n={...r,filters:[...r.filters,l]};this.$emit("filterchange",n,{event:e,field:this.$props.column.field}),this.$emit("closemenu")},handleFocus(e){this.$emit("filterfocus",e)}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){let e,r;const{column:o,filterUI:a,hideSecondFilter:s,filterOperators:d}=this.$props;if(!o||!o.field)return t.createVNode("div",null,null);const c=o.filter||"text",h=l.provideLocalizationService(this),g=this.filterGroup.filters,f=Dt(d[c],h),m=Dt(Lt,h),v={field:o.field,value:g[0].value,operator:g[0].operator,booleanValues:m,filterType:c},b={field:o.field,value:g[1].value,operator:g[1].operator,booleanValues:m,filterType:c},C=this.filterGroup.logic,x=Dt(Ft,h),$={value:x.find((e=>e.operator===(null===C?"":C))),data:x},k=0!==this.currentFilterGroup().filters.length,S=this.isControlled()?this.$props.expanded:this.currentExpanded,I=v.field,y=v.value,w=v.operator,N=v.booleanValues,R=v.filterType,V=b.field,F=b.value,E=b.operator,A=b.booleanValues,D=b.filterType,L=a&&i.templateRendering.call(this,a,i.getListeners.call(this)),O=i.getTemplate.call(this,{h:t.h,template:L,defaultRendering:void 0,additionalProps:this.$props,additionalListeners:{change:this.filterChangeHandler,logicchange:this.logicChange}});return t.createVNode(kt,null,{default:()=>[t.createVNode($t,{title:h.toLanguageString(ae,ht[ae]),icon:"filter",svgIcon:n.filterIcon,onMenuitemclick:this.onFilterExpand},null),t.createVNode(Vt,{show:!!S},{default:()=>[t.createVNode("div",{class:"kendo-grid-filter-menu-container"},[t.createVNode("form",{class:"k-filter-menu k-border-up",onSubmit:this.submit,onReset:this.clear},[t.createVNode("div",{class:"k-filter-menu-container"},[!a&&[t.createVNode(Bt,{operator:w,filterType:R,onChange:e=>{this.filterChangeHandler(e,0)},operators:f},null),t.createVNode(zt,{field:I,value:y,operator:w,booleanValues:N,filterType:R,onFiltercellfocus:this.handleFocus,onChange:e=>{this.filterChangeHandler(e,0)},operators:f},null)],!s&&!a&&[t.createVNode(u.DropDownList,{onChange:this.logicChange,class:"k-filter-and","data-items":$.data,value:$.value,textField:"text"},null),t.createVNode(Bt,{operator:E,filterType:D,onChange:e=>{this.filterChangeHandler(e,1)},operators:f},null),t.createVNode(zt,{field:V,value:F,operator:E,booleanValues:A,filterType:D,onFiltercellfocus:this.handleFocus,onChange:e=>{this.filterChangeHandler(e,1)},operators:f},null)],a&&O,t.createVNode("div",{class:"k-columnmenu-actions"},[t.createVNode(p.Button,{themeColor:"primary",disabled:!k},jt(e=h.toLanguageString(ne,ht[ne]))?e:{default:()=>[e]}),t.createVNode(p.Button,{type:"reset"},jt(r=h.toLanguageString(re,ht[re]))?r:{default:()=>[r]})])])])])]})]})}}),Wt=t.defineComponent({name:"KendoColumnMenuContent",inheritAttrs:!1,props:{column:Object,sortable:[Boolean,Object],sort:{type:Array},filter:Object,filterOperators:Object,filterable:Boolean,render:[Boolean,String,Function,Object],onContentfocus:Function,onClosemenu:Function,onSortchange:Function,onExpandchange:Function,onFilterchange:Function},methods:{handleFocus(e){this.$emit("contentfocus",e)},closeMenu(){this.$emit("closemenu")},expandChange(){this.$emit("expandchange")},sortChange(e,t){this.$emit("sortchange",e,t)},filterChange(e,t){this.$emit("filterchange",e,t)},contentKeyDown(e){e.keyCode===i.Keys.esc&&this.$emit("closemenu")}},render(){const e=this.$props.render,r=t.createVNode("div",{style:this.$attrs.style,onKeydown:this.contentKeyDown},[t.createVNode(Rt,{column:this.$props.column,sortable:this.$props.sortable,sort:this.$props.sort,onClosemenu:this.closeMenu,onSortchange:this.sortChange},null),t.createVNode(Pt,{column:this.$props.column,filterable:this.$props.filterable,filter:this.$props.filter,filterOperators:this.$props.filterOperators,onFilterfocus:this.handleFocus,onClosemenu:this.closeMenu,onExpandchange:this.expandChange,onFilterchange:this.filterChange},null)]);return i.getTemplate.call(this,{h:t.h,template:"boolean"!=typeof e&&e,defaultRendering:r,additionalProps:this.$props,additionalListeners:{closemenu:this.closeMenu,filterchange:this.filterChange,sortchange:this.sortChange,expandchange:this.expandChange,contentfocus:this.handleFocus}})}}),qt=t.defineComponent({name:"KendoColumnMenu",props:{animate:{type:[Boolean,Object],default:function(){return!0}},column:Object,sortable:[Boolean,Object],sort:{type:Array},opened:Boolean,filter:Object,filterable:Boolean,filterOperators:Object,render:[Boolean,String,Function,Object],columnMenuIcon:i.SvgIcon,onClose:Function,onSortchange:Function,onFilterchange:Function},inject:{kendoIntlService:{default:null},kendoLocalizationService:{default:null}},data:()=>({show:!1,blurTimeout:void 0}),created(){this._anchor=i.guid()},computed:{currentOpen(){return this.show||this.$props.opened}},watch:{currentOpen:function(e){this.$nextTick((function(){if(this._content=this.$refs.content,e&&this._content){const e=r.tableKeyboardNavigationTools.getFocusableElements(this._content,{focusable:!0});e.length?e[0].focus():this._content.focus()}}))}},methods:{blur(){clearTimeout(this.blurTimeout),this.blurTimeout=setTimeout((()=>{this.closeMenu()}),200)},focus(){clearTimeout(this.blurTimeout)},handleFocus(e){clearTimeout(this.blurTimeout)},anchorClick(e){e.preventDefault(),this.show=!this.show},closeMenu(){this.$emit("close"),this.show=!1},sortChange(e,t){this.$emit("sortchange",e,t)},filterChange(e,t){this.$emit("filterchange",e,t)}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const e=this.$props.render,r=l.provideLocalizationService(this),{columnMenuIcon:o}=this.$props;return t.createVNode("div",{style:{display:"inline"}},[t.createVNode("a",{class:"k-grid-header-menu k-grid-column-menu",title:`${this.$props.column.field} ${r.toLanguageString(te,ht[te])}`,ref:i.setRef(this,"kendoAnchor"),onClick:this.anchorClick,href:"#"},[o?t.createVNode(i.Icon,{name:o.name,icon:o},null):t.createVNode(i.Icon,{name:"more-vertical",icon:n.moreVerticalIcon},null)]),t.createVNode(d.Popup,{animate:this.$props.animate,anchor:this._anchor,show:this.currentOpen},{default:()=>[t.createVNode("div",{ref:"content",class:"k-column-menu k-grid-columnmenu-popup",tabindex:0,onFocusout:this.blur,onFocusin:this.focus,style:{outline:"none",width:"230px"}},[t.createVNode(Wt,{column:this.$props.column,sortable:this.$props.sortable,sort:this.$props.sort,filter:this.$props.filter,filterable:this.$props.filterable,filterOperators:this.$props.filterOperators,render:e,onContentfocus:this.handleFocus,onClosemenu:this.closeMenu,onSortchange:this.sortChange,onFilterchange:this.filterChange},null)])]})])}});function Ut(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}const Yt={none:"none",asc:"ascending",desc:"descending"},Xt={true:{asc:"desc",desc:"","":"asc"},false:{asc:"desc",desc:"asc","":"asc"}},Jt=t.defineComponent({name:"KendoHeaderRow",props:{grid:Object,cellRender:[String,Function,Object],groupable:[Boolean,Object],reorderable:Boolean,sortable:[Boolean,Object],sort:{type:Array},filter:Object,filterable:Boolean,filterOperators:Object,filterChange:Function,filterRow:Object,columns:Array,columnsMap:Array,columnResize:Object,columnMenu:[Boolean,String,Function,Object],columnMenuAnimate:{type:[Boolean,Object],default:function(){return!0}},columnMenuIcon:Object,isRtl:Boolean,isColCountDefined:Boolean,columnsInitial:Array,onSortChange:Function,onFilterChange:Function,onSelectionchange:Function,onPressHandler:Function,onDragHandler:Function,onReleaseHandler:Function},inject:{onNavFocus:{default:i.noop},kendoLocalizationService:{default:null}},data:()=>({columnMenuOpened:{}}),created(){this.serviceIndex=0,this.index=-1,this._element=null,this.cellClick=this.cellClick.bind(this)},methods:{pressHandler(e,t){this.$emit("pressHandler",e,t)},dragHandler(e,t){this.$emit("dragHandler",e,t)},releaseHandler(e){this.$emit("releaseHandler",e)},selectionChangeHandler(e){this.$emit("selectionchange",e)},cellClick(e,t){if(e.preventDefault(),!i.hasListener.call(this,"sortChange"))return;const{allowUnsort:r,mode:o}=vt(this.$props.sortable||!1,t.sortable||!1),l=(this.$props.sort||[]).filter((e=>e.field===t.field))[0],n=Xt[r][l&&l.dir||""],a="single"===o?[]:(this.$props.sort||[]).filter((e=>e.field!==t.field));""!==n&&t.field&&a.push({field:t.field,dir:n}),this.sortChangeHandler(a,{event:e,field:t.field})},sortChangeHandler(e,t){this.$emit("sortChange",e,t)},filterChangeHandler(e,t){this.$emit("filterChange",e,t)},cellClass(e,t,i){let r="k-header"+(i?" k-grid-header-sticky":"")+(t?" "+t:"");return this.$props.sort&&this.$props.sort.filter((t=>t.field===e)).length>0&&(r+=" k-sorted"),r},cellKeyDown(e,t){e.defaultPrevented||(e.keyCode===i.Keys.enter&&this.cellClick(e,t),e.altKey&&e.keyCode===i.Keys.down&&t.field&&(e.preventDefault(),this.columnMenuOpened={[t.field]:!0}))},getTemplate(e){return i.templateRendering.call(this.$props.grid,e,i.getListeners.call(this.$props.grid))},columnMenuClose(){this.onNavFocus({}),this.columnMenuOpened={}}},computed:{element(){return this._element},theadClasses:()=>({"k-table-thead":!0})},render(e){const o=l.provideLocalizationService(this),a=o.toLanguageString(xe,ht[xe]),s=o.toLanguageString($e,ht[$e]),d=o.toLanguageString(ke,ht[ke]);this.serviceIndex=0,this.index=-1;const c=function(e){return e.map((function(e){const o=this.$props.columns[e],l=this.$props.sortable&&o.sortable,c=this.$props.sort?this.$props.sort.findIndex((e=>e.field===o.field)):-1,h=c>=0&&this.$props.sort[c].dir||"none",p=function(e){if(!this.$props.sort)return null;const r=e>=0?this.$props.sort[e].dir:"";return e>=0&&[t.createVNode("span",{key:1,class:"k-sort-icon"},[t.createVNode(i.Icon,{name:"sort-"+r+"-small",icon:"asc"===r?n.sortAscSmallIcon:n.sortDescSmallIcon},null)]),this.$props.sort.length>1&&t.createVNode("span",{key:2,class:"k-sort-icon"},[t.createVNode("span",{class:"k-sort-order"},[e+1])])]}.call(this,c),u=o.columnMenu||!1===o.columnMenu?o.columnMenu:this.$props.columnMenu,g=o.menuIcon||this.$props.columnMenuIcon,f=(o.kFirst?"k-first ":"")+this.cellClass(o.field,o.headerClassName,o.locked)+(u?" k-filterable":""),m=u&&"boolean"!=typeof u?this.getTemplate(u):!!u,v=void 0!==o.left?this.$props.isRtl?{left:o.right+"px",right:o.left+"px"}:{left:o.left+"px",right:o.right+"px"}:{},b="none"===Yt[h]?a:"ascending"===Yt[h]?s:d;let C=o.isAccessible?{ariaSort:Yt[h],ariaLabel:b,role:"columnheader",ariaColumnIndex:this.$props.isColCountDefined?this.$props.columnsInitial.findIndex((e=>e.field===o.field))+1:void 0,ariaSelected:!1,ariaHaspopup:u?"menu":this.$props.filterable&&o.filterable?"dialog":void 0}:{role:"columnheader"};const x=o.declarationIndex>=0?++this.index:--this.serviceIndex,$=void 0!==o.columnMenuOpened?o.columnMenuOpened:this.columnMenuOpened[o.field];return t.createVNode(r.HeaderThElement,{ariaSort:l?C.ariaSort:void 0,ariaLabel:l?C.ariaLabel:void 0,role:C.role,ariaColumnIndex:C.ariaColumnIndex,ariaSelected:C.ariaSelected,ariaHaspopup:C.ariaHaspopup,key:x,colSpan:o.headerColSpan,rowSpan:o.rowSpan,class:f,style:v,columnId:o.id,navigatable:o.navigatable,onKeydown:e=>this.cellKeyDown(e,o)},{default:()=>[[0===o.children.length&&u&&t.createVNode(qt,{key:0,column:{field:o.field,filter:o.filter},opened:$,animate:this.$props.columnMenuAnimate,sortable:l,sort:this.$props.sort,onClose:this.columnMenuClose,onSortchange:this.sortChangeHandler,filter:this.$props.filter,filterable:this.$props.filterable&&o.filterable,filterOperators:this.$props.filterOperators,onFilterchange:this.filterChangeHandler,render:m,columnMenuIcon:g},null),o.internalHeaderCell&&t.createVNode("span",{class:"k-cell-inner"},[t.createVNode(o.internalHeaderCell,{key:1,field:o.field,sortable:l,onHeadercellclick:e=>this.cellClick(e,o),onSelectionchange:this.selectionChangeHandler,selectionValue:o.headerSelectionValue,title:o.title,render:(o.headerCell||this.$props.cellRender)&&this.getTemplate(o.headerCell||this.$props.cellRender)},Ut(p)?p:{default:()=>[p]})])||t.createVNode("span",{class:"k-cell-inner"},[t.createVNode(xt,{key:1,field:o.field,sortable:l,onHeadercellclick:e=>this.cellClick(e,o),selectionValue:o.headerSelectionValue,title:o.title,render:(o.headerCell||this.$props.cellRender)&&this.getTemplate(o.headerCell||this.$props.cellRender)},Ut(p)?p:{default:()=>[p]})]),this.$props.columnResize&&this.$props.columnResize.resizable&&o.resizable&&t.createVNode(bt,{key:2,onResize:(e,t,i)=>this.$props.columnResize&&this.$props.columnResize.dragHandler(e,o,t,i)},null)]]})}),this)};return t.createVNode("thead",{role:"rowgroup",class:this.theadClasses,"data-keyboardnavheader":!0},[this.$props.columnsMap.map((function(e,i){let r;return(this.$props.groupable||this.$props.reorderable)&&t.createVNode(Ct,{key:i,onPressHandler:this.pressHandler,onDragHandler:this.dragHandler,onReleaseHandler:this.releaseHandler},Ut(r=c.call(this,e))?r:{default:()=>[r]})||t.createVNode("tr",{class:"k-table-row",role:"row","aria-rowindex":this.columnsMap.length},[c.call(this,e)])}),this),this.$props.filterRow])}}),Qt=t.defineComponent({name:"KendoGridFilterCell",inheritAttrs:!1,props:{id:String,grid:Object,field:String,filterType:String,colSpan:Number,title:String,value:[String,Number,Boolean,Date],operator:[String,Function],operators:Array,booleanValues:Array,onChange:Function,render:[String,Function,Object],ariaLabel:String,size:String},inject:{kendoLocalizationService:{default:null},kendoIntlService:{default:null}},methods:{inputChange(e,t){const i=Ot(e,t,this.$props);this.triggerChange(i)},operatorChange(e,t){const i=_t(e.value.operator,t,this.$props.value);this.triggerChange(i)},boolDropdownChange(e,t){const i=Gt(e.value.operator,t);this.triggerChange(i)},clear(e){e.preventDefault(),this.triggerChange({value:"",operator:"",event:e})},triggerChange(e){e.field=this.$props.field,this.$emit("change",e)}},setup:()=>({kendoIntlService:t.inject("kendoIntlService",{}),kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const e=l.provideLocalizationService(this),{size:r}=this.$props,o=this.$props.operators.find((e=>e.operator===this.$props.operator))||null,d=t.createVNode("div",{class:"k-filtercell",style:this.$attrs.style},[t.createVNode("div",{class:"k-filtercell-wrapper"},[function(e,i){let o;switch(e){case"numeric":return t.createVNode(a.NumericTextBox,{size:r,value:i,onChange:e=>{this.inputChange(e.value,e.event)},title:this.$props.title,ariaLabel:this.ariaLabel},null);case"date":return t.createVNode(s.DatePicker,{size:r,value:i,onChange:e=>{this.inputChange(e.value,e)},title:this.$props.title,ariaLabel:this.ariaLabel},null);case"boolean":return o=this.$props.booleanValues,t.createVNode(u.DropDownList,{onChange:this.boolDropdownChange,size:r,value:o.find((e=>e.operator===(null!==i?i:""))),"data-items":o,textField:"text",title:this.$props.title,ariaLabel:this.ariaLabel},null);default:return t.createVNode(a.TextBox,{value:i||"",size:r,onInput:e=>{this.inputChange(e.target.value,e)},title:this.$props.title,"aria-label":this.ariaLabel},null)}}.call(this,this.$props.filterType,this.$props.value),t.createVNode("div",{class:"k-filtercell-operator"},[function(){if("boolean"!==this.$props.filterType)return t.createVNode(u.DropDownList,{onChange:this.operatorChange,value:o,size:r,class:"k-dropdown-operator",icon:"filter",svgIcon:n.filterIcon,iconClassName:"filter k-button-icon","data-items":this.$props.operators,textField:"text",title:e.toLanguageString(me,ht[me]),popupSettings:{width:"",anchor:""},ariaLabel:this.ariaLabel},null)}.call(this),t.createTextVNode(" "),t.createVNode(p.Button,{type:"button",size:r,icon:"filter-clear",svgIcon:n.filterClearIcon,class:{"k-disabled":!(null!==this.$props.value&&""!==this.$props.value||this.$props.operator)},title:e.toLanguageString(re,ht[re]),onClick:this.clear},null)])])]),c=this.$props.grid?i.getListeners.call(this.$props.grid):null,h=i.templateRendering.call(this.$props.grid,this.$props.render,c);return i.getTemplate.call(this,{h:t.h,template:h,defaultRendering:d,additionalProps:this.$props,additionalListeners:{change:this.triggerChange}})}});const Zt=t.defineComponent({name:"kendoFilterRow",props:{grid:Object,columns:Array,filter:Object,filterOperators:Object,sort:[Object,Array],cellRender:[String,Function,Object],isRtl:Boolean,ariaRowIndex:Number,size:String,onFilterchange:Function},inject:{kendoLocalizationService:{default:null}},methods:{headerCellClassName(e,t){let i=t?" k-grid-header-sticky":"";return this.$props.sort&&this.$props.sort.filter((t=>t.field===e)).length>0&&(i+=" k-sorted"),i},setFilter(e,t,i,r){const o=[];(""!==e&&null!==e||""!==t)&&o.push({field:i,operator:t,value:e}),this.$props.filter&&this.$props.filter.filters&&(this.$props.filter.filters||[]).forEach((e=>{const t=e;t&&t.field!==i&&o.push(t)}));const l=o.length>0?{logic:"and",filters:o}:null;this.$emit("filterchange",l,r)}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const e=l.provideLocalizationService(this),i=this.$props.filter&&this.$props.filter.filters||[],o=(e,t=null)=>{const r=i.filter((t=>t.field===e))[0];return r?r.value:t},n=e=>{const t=i.filter((t=>t.field===e))[0];return t?t.operator:null};let a=0,s=-1;const d=this.$props.columns.filter((e=>0===e.children.length)).map((function(i){const l=Tt(i.filter),d=(i.title||i.field)+" "+((e,t)=>{switch(e){case"text":return t.toLanguageString(Xe,ht[Xe]);case"numeric":return t.toLanguageString(Ne,ht[Ne]);case"boolean":return t.toLanguageString(Je,ht[Je]);case"date":return t.toLanguageString(Ye,ht[Ye]);default:return}})(l,e),c=t.createVNode(Qt,{grid:this.$props.grid,field:i.field,title:i.filterTitle,value:o(i.field,"text"===l?"":null),operator:n(i.field),operators:Dt(this.$props.filterOperators[l]||[],e),booleanValues:Dt(Lt,e),filterType:l,onChange:e=>{this.setFilter(e.value,e.operator,i.field,e)},render:i.filterCell||this.$props.cellRender,"aria-label":d,size:this.$props.size},null),h=i.declarationIndex>=0?++s:--a,p={ariaLabel:i.filterable?e.toLanguageString(we,ht[we]):void 0,ariaColumnIndex:i.ariaColumnIndex},u=void 0!==i.left?this.$props.isRtl?{left:i.right+"px",right:i.left+"px"}:{left:i.left+"px",right:i.right+"px"}:{},g=t.createVNode(r.HeaderTdElement,{key:h,role:"gridcell",columnId:r.tableKeyboardNavigationTools.getFilterColumnId(i.id),navigatable:i.navigatable,style:u,class:this.headerCellClassName(i.field,i.locked)||void 0,ariaColumnIndex:p.ariaColumnIndex,"aria-label":d},function(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}(c)?c:{default:()=>[c]});return i.filterable&&g||t.createVNode(r.HeaderTdElement,{key:h,role:"gridcell",columnId:r.tableKeyboardNavigationTools.getFilterColumnId(i.id),navigatable:i.navigatable,style:u,class:this.headerCellClassName(i.field,i.locked)||void 0,ariaColumnIndex:p.ariaColumnIndex,"aria-label":d},null)}),this);return t.createVNode("tr",{class:"k-table-row k-filter-row","aria-rowindex":this.ariaRowIndex,role:"row"},[d])}}),ei=t.defineComponent({props:{title:String,dir:String,onRemove:Function,onSortChange:Function,onPress:Function,onDrag:Function,onRelease:Function},mounted(){this.element=i.getRef(this,"indicatorContainer"),this.element&&(this.draggable=this.$refs.draggable)},methods:{press(e){this.element&&this.$emit("press",e,this.element)},drag(e){this.element&&this.$emit("drag",e,this.element)},release(e){this.element&&this.$emit("release",e,this.element)},sortChange(e){e.preventDefault();const t="asc"===this.$props.dir?"desc":"asc";this.$emit("sortChange",e,t)},groupRemove(e){e.preventDefault(),this.$emit("remove",e)}},setup:()=>({indicatorContainerRef:t.ref(null)}),render(){return t.createVNode(i.Draggable,{onPress:this.press,onDrag:this.drag,onRelease:this.release,ref:"draggable"},{default:()=>[t.createVNode("div",{class:"k-chip k-chip-md k-chip-solid k-chip-solid-base k-rounded-md",ref:i.setRef(this,"indicatorContainer")},[t.createVNode(i.Icon,{name:"sort-"+this.$props.dir+"-small",class:"k-chip-icon",icon:"asc"===this.$props.dir?n.sortAscSmallIcon:n.sortDescSmallIcon},null),t.createVNode("span",{class:"k-chip-content",tabindex:-1,onClick:this.sortChange},[this.$props.title]),t.createVNode("span",{class:"k-chip-actions"},[t.createVNode("span",{class:"k-chip-action k-chip-remove-action",tabindex:-1,onClick:this.groupRemove},[t.createVNode(i.Icon,{name:"x-circle",icon:n.xCircleIcon},null)])])])]})}}),ti=t.defineComponent({props:{group:Array,resolveTitle:Function,ariaControls:String,onPressHandler:Function,onDragHandler:Function,onReleaseHandler:Function,onGroupChange:Function},inject:{kendoLocalizationService:{default:null}},methods:{pressHandler(e,t){this.$emit("pressHandler",e,t)},dragHandler(e,t){this.$emit("dragHandler",e,t)},releaseHandler(e){this.$emit("releaseHandler",e)},onGroupRemove(e,t){const i=this.$props.group.slice();i.splice(t,1),this.$emit("groupChange",i,e)},onGroupSortChange(e,t,i,r){const o=Object.assign({},i,{dir:r}),l=this.$props.group.slice();l.splice(t,1,o),this.$emit("groupChange",l,e)}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const e=this.$props.group||[],i=this.$props.ariaControls,r=e.map((function(e,i){return t.createVNode(ei,{key:i,dir:e.dir||"asc",title:this.$props.resolveTitle(e.field),onRemove:e=>this.onGroupRemove(e,i),onSortChange:(t,r)=>{this.onGroupSortChange(t,i,e,r)},onPress:this.pressHandler,onDrag:this.dragHandler,onRelease:this.releaseHandler},null)}),this),o=l.provideLocalizationService(this).toLanguageString(Qe,ht[Qe]);return t.createVNode("div",{class:"k-grouping-header",role:"toolbar","aria-label":o,"aria-controls":i},[!!r.length&&t.createVNode("div",{class:"k-chip-list k-chip-list-md"},[r]),t.createVNode("div",{class:"k-grouping-drop-container"},[!r.length&&l.provideLocalizationService(this).toLanguageString(Q,ht[Q])])])}}),ii=t.defineComponent({name:"Footer",props:{staticHeaders:Boolean,row:Object,columnResize:Object,cols:Array,size:String},data:()=>({scrollbarWidth:0,rtl:!1,tableWidth:null}),computed:{tableClass(){const{size:e}=this.$props;return{"k-table":!0,"k-grid-footer-table":!0,[`k-table-${i.kendoThemeMaps.sizeMap[e]||e}`]:e}},tableStyle(){return this.tableWidth?{width:this.tableWidth}:null}},mounted(){this.rtl=C(this.$el),this.$props.columnResize.colGroupFooter=i.getRef(this,"colGroupHeader"),this._footerWrap=i.getRef(this,"footerWrap")},methods:{setScrollLeft(e){this._footerWrap&&(this._footerWrap.scrollLeft=e)},setWidth(e){this.$data.tableWidth=e+"px"}},setup(){const e=t.ref(null);return{colGroupHeaderRef:t.ref(null),footerWrapRef:e}},render(){return this.$props.staticHeaders?t.createVNode("div",{class:"k-grid-footer",role:"presentation"},[t.createVNode("div",{class:"k-grid-footer-wrap",ref:i.setRef(this,"footerWrap"),role:"presentation"},[t.createVNode("table",{class:this.tableClass,style:this.tableStyle,role:"presentation"},[t.createVNode("colgroup",{ref:i.setRef(this,"colGroupHeader")},[this.$props.cols]),t.createVNode("tfoot",{class:"k-table-tfoot",role:"rowgroup"},[this.$props.row])])])]):t.createVNode("tfoot",{class:"k-table-tfoot k-grid-footer",role:"rowgroup"},[this.$props.row])}}),ri=t.defineComponent({name:"FooterRow",props:{isRtl:Boolean,columns:Array,rowIndex:Number},methods:{columnStyles(e){return void 0!==e.left?this.$props.isRtl?{left:e.right+"px",right:e.left+"px"}:{left:e.left+"px",right:e.right+"px"}:{}}},render(){return t.createVNode("tr",{class:"k-table-row",role:"row","aria-rowIndex":this.$props.rowIndex},[N(this.$props.columns).map((function(e,r){let o=null;const l=e.locked&&void 0!==e.left?"k-grid-footer-sticky":"",n=e.footerClassName?`k-table-td ${e.footerClassName} ${l}`:"k-table-td "+l;return o=i.getTemplate.call(this,{h:t.h,template:e.footerCell,defaultRendering:null,additionalProps:{field:e.field,colSpan:1!==e.colSpan?e.colSpan:void 0,defaultStyle:this.columnStyles(e)}}),t.createVNode("td",{key:r,colspan:1!==e.colSpan?e.colSpan:void 0,style:this.columnStyles(e),class:n,role:"gridcell"},[o])}),this)])}});let oi=class{constructor(){this.table=null,this.tableBody=null,this.container=null,this.scrollHeightContainer=null,this.total=0,this.scrollableVirtual=!1,this.pageSize=0,this.fixedScroll=!1,this.tableTransform="",this.scrollSyncing=!1,this.firstToLoad=0,this.lastScrollTop=0,this.firstLoaded=0,this.lastLoaded=0,this.scrollHandler=this.scrollHandler.bind(this)}reset(){this.firstToLoad=0,this.firstLoaded=0,this.lastLoaded=0,this.rowHeightService=void 0,!this.fixedScroll&&this.container&&0!==this.container.scrollTop&&(this.scrollSyncing=!0,this.container.scrollTop=0,this.lastScrollTop=0,this.translate(0,!0))}scrollHandler(e){if(this.scrollSyncing)return void(this.scrollSyncing=!1);if(!(this.scrollableVirtual&&this.container&&this.table&&this.rowHeightService&&this.container))return;const t=this.container.scrollTop,i=this.lastScrollTop>=t,r=!i;this.lastScrollTop=t;const o=this.container.offsetHeight;let l=this.rowHeightService.index(t);const n=this.rowHeightService.index(t+o),a=Math.max(l+this.pageSize-this.total,0);if(l=Math.max(l-a,0),r&&n>=this.lastLoaded&&this.lastLoaded<this.total-1)this.firstToLoad=l,this.loadPage(e);else if(i&&l<this.firstToLoad){const t=Math.max(Math.floor(.3*this.pageSize)-a,0);this.firstToLoad=Math.max(l-t,0),this.loadPage(e)}}update(){var e;const t=this.getItemHeights();if(this.firstLoaded>this.firstToLoad){const e=Math.min(this.firstLoaded-this.firstToLoad,this.pageSize),i=this.getTotalHeight(e,t)-this.getExpectedTotalHeight(e);0!==i&&this.adjustScroll(i)}null==(e=this.rowHeightService)||e.update(this.firstToLoad,t),this.setScrollHeightContainerHeight(),this.firstLoaded=this.firstToLoad,this.lastLoaded=this.firstLoaded+t.length-1}loadPage(e){this.rowHeightService&&(this.translate(this.rowHeightService.offset(this.firstToLoad)),this.changePage(this.firstToLoad,e))}translate(e,t){this.scrollableVirtual&&this.table&&(t?this.table.style.transform="translateY("+e+"px)":this.tableTransform="translateY("+e+"px)")}changePage(e,t){this.PageChange&&this.PageChange({skip:Math.max(0,e),take:this.pageSize},t)}adjustScroll(e){this.scrollSyncing=!0,this.container&&(this.container.scrollTop+=e)}setScrollHeightContainerHeight(){var e;if(this.scrollableVirtual&&this.scrollHeightContainer){let t=(null==(e=this.rowHeightService)?void 0:e.totalHeight())||0;t=D?Math.min(L,t):t,this.scrollHeightContainer.style.height=t+"px"}}getItemHeights(){const e=[];return this.tableBody&&Array.from(this.tableBody.children).forEach((t=>{const i=t.getBoundingClientRect().height;t.classList.contains("k-detail-row")?e[e.length-1]+=i:e.push(i)})),e}getTotalHeight(e,t){return t.slice(0,e).reduce(((e,t)=>e+t),0)}getExpectedTotalHeight(e){const t=this.rowHeightService;if(!t)return 0;const i=this.firstToLoad+(e-1);return t.offset(i)+t.height(i)-t.offset(this.firstToLoad)}};class li{constructor(e){this.columns=[],this.columnsState=[],this.resizable=!1,this.isRtl=!1,this.setIsRtl=e=>{this.isRtl=e},this.initWidths=()=>{var e;const t=(null==(e=this.colGroupMain)?void 0:e.children)||[],i=A(this.columnsState),r=this.columns.filter((e=>{var t;return!(null!=(t=e.children)&&t.length)}));for(let e=0;e<t.length;e++){const o=t[e];let l="";const n=i.find((t=>t.id===r[e].id));n&&(l=n.width||""),o.width=l,this.colGroupHeader&&(this.colGroupHeader.children[e].width=l),this.colGroupFooter&&(this.colGroupFooter.children[e].width=l)}},this.dragHandler=(e,t,i,r)=>{const o=e.originalEvent;r||(o.preventDefault(),o.stopPropagation(),o.stopImmediatePropagation());const l=i.closest("th");if(!l)return;const n=l.clientWidth;let a=n;if(this.isRtl?a+=i.getBoundingClientRect().right-i.offsetWidth/2-e.clientX:a+=e.clientX-i.getBoundingClientRect().left-i.offsetWidth/2,!r&&Math.abs(a-n)<1)return;this.fixateInitialWidths(l.parentElement.clientWidth),this.setWidths(t,Math.floor(a)/n);const s=this.columns.filter((e=>!e.children.length)).findIndex((e=>e.id===t.id));this.onResize(s,n,a,o,r,this.columnsState,t.id)},this.dblClickHandler=(e,t)=>{const i=this.columns.filter((e=>t.indexOf(e.id)>-1)),r=A(this.columnsState);if(!this.colGroupMain||!i.length)return;const o={},l=i;for(;l.length>0;){const e=l.pop();if(!e)break;e.children.length?l.push(...e.children):o[e.id]=e}const n=this.columns.filter((e=>!e.children.length)),a=[];n.forEach(((e,t)=>{o[e.id]&&a.push(t)}));const s=[this.colGroupMain.parentElement],d=[this.colGroupMain];this.colGroupHeader&&(s.push(this.colGroupHeader.parentElement),d.push(this.colGroupHeader)),this.colGroupFooter&&(s.push(this.colGroupFooter.parentElement),d.push(this.colGroupFooter)),s.forEach((e=>e.classList.add("k-autofitting")));const c=[];d.forEach((e=>{a.forEach((t=>{e.children[t]&&(e.children[t].width="",c[t]=Math.max(c[t]||0,e.children[t].offsetWidth+1))}))})),d.forEach((e=>{a.forEach((t=>{if(e.children[t]){e.children[t].width=c[t]+"px";const i=r.find((e=>e.id===n[t].id));i&&(i.width=c[t])}}))})),s.forEach((e=>e.classList.remove("k-autofitting"))),this.onResize(a[0],0,0,e,!0,this.columnsState,t[0])},this.updateColElements=e=>{var t,i,r;const o=this.columns.filter((e=>!e.hidden&&!e.children.length));let l=1e-10;for(let n=0;n<e.length;n++){const a=e[n],s=o.findIndex((e=>e.id===a.id)),d=parseFloat((a.width||0).toString()),c=Math.floor(d);l+=d-c;const h=c+Math.floor(l);l-=Math.floor(l);const p=o.find((e=>e.id===a.id));if(!p)return;if(null!=(t=this.colGroupMain)&&t.children[s]){const e=parseInt(this.colGroupMain.children[s].width,10);this.colGroupMain.children[s].width=h+"px",this.updateNextLockedCol(this.colGroupMain.parentElement,p,e-h)}if(null!=(i=this.colGroupHeader)&&i.children[s]){const e=parseInt(this.colGroupHeader.children[s].width,10);this.colGroupHeader.children[s].width=h+"px",this.updateNextLockedCol(this.colGroupHeader.parentElement,p,e-h)}if(null!=(r=this.colGroupFooter)&&r.children[s]){const e=parseInt(this.colGroupFooter.children[s].width,10);this.colGroupFooter.children[s].width=h+"px",this.updateNextLockedCol(this.colGroupFooter.parentElement,p,e-h)}}},this.onResize=e}fixateInitialWidths(e){var t;let i=0;const r=(null==(t=this.colGroupMain)?void 0:t.children)||[];for(let t=0;t<r.length;t++)r[t].width?e-=r[t].clientWidth:i++;if(0===i)return;const o=Math.floor(e/i),l=A(this.columnsState),n=this.columns.filter((e=>!e.children.length));for(let e=0;e<r.length;e++){const t=r[e],i=t.width?t.clientWidth:o;t.width=i;const a=l.find((t=>t.id===n[e].id));a&&(a.width=i.toString()),this.colGroupHeader&&(this.colGroupHeader.children[e].width=i),this.colGroupFooter&&(this.colGroupFooter.children[e].width=i)}}setWidths(e,t){const i=A(this.columnsState),r=this.columns.findIndex((t=>t.id===e.id)),o=[];let l=e.children.filter((e=>!e.hidden)).length;for(let e=r+1;e<this.columns.length&&!(l<=0);e++){const t=this.columns[e];t.children.length?l+=t.children.filter((e=>!e.hidden)).length:o.push(t),l--}0===o.length&&o.push(e);const n=[];o.forEach((e=>{const r=i.find((t=>t.id===e.id));if(r){let i=r.width?parseFloat(r.width.toString())*t:0;const o=void 0===e.minResizableWidth?10:e.minResizableWidth;i<o&&(i=o),r.width=i,n.push(r)}})),this.updateColElements(n)}updateNextLockedCol(e,t,i){const r=t.index,o=this.colGroupMain.parentElement.closest(".k-grid"),l=null==o?void 0:o.clientWidth,n=this.columns.filter((e=>e.locked)).map((e=>parseInt(e.width+"",10))).reduce(((e,t)=>e+t),0);!t.locked||l<=n+20||this.columns.forEach((t=>{if(null!=t&&t.locked&&i){const o=null==e?void 0:e.querySelectorAll('[aria-colindex="'+t.ariaColumnIndex+'"]');null==o||o.forEach((e=>{const o=e.style;this.isRtl?(t.index>r&&null!=o&&o.right&&(o.right=parseInt(o.right,10)-i+"px"),t.index<r&&null!=o&&o.left&&(o.left=parseInt(o.left,10)-i+"px")):(t.index>r&&null!=o&&o.left&&(o.left=parseInt(o.left,10)-i+"px"),t.index<r&&null!=o&&o.right&&(o.right=parseInt(o.right,10)-i+"px"))}))}}))}}let ni=class{constructor(e,t,r){this.reorderable=!1,this.groupable=!1,this.dropElementClue=null,this.dragElementClue=null,this.startColumn=-1,this.startGroup=-1,this.currentColumn=-1,this.currentGroup=-1,this.groupPanelDivElement=null,this.refGroupPanelDiv=e=>{this.groupPanelDivElement=e.children?e.children[0]:e},this.refDropElementClue=e=>{this.dropElementClue=e,this.dropElementClue&&i.canUseDOM&&document.body.appendChild(this.dropElementClue.$el)},this.refDragElementClue=e=>{this.dragElementClue=e,this.dragElementClue&&i.canUseDOM&&document.body.appendChild(this.dragElementClue.$el)},this.pressHandler=(e,t)=>{e.isTouch||e.originalEvent.preventDefault();const i=this.getColumnIndex(e,t);if(this.startGroup=this.getGroupIndex(e),i>=0){const e=this.columns[i];(e.reorderable&&this.reorderable||e.groupable&&this.groupable)&&(this.startColumn=i)}},this.dragHandler=(e,t)=>{if(e.isTouch||e.originalEvent.preventDefault(),e.originalEvent.stopPropagation(),-1===this.startColumn&&-1===this.startGroup)return;this.currentColumn=this.getColumnIndex(e,t);const i=this.groupPanelDivElement&&this.groupPanelDivElement.children;this.currentGroup=this.isTargetGroupingContainer(e)?i&&i.length?i.length:0:this.getGroupIndex(e);const r=!this.isValid();r&&(this.currentColumn=-1,this.currentGroup=-1);const o=this.currentColumn>=0?t.children[this.columns[this.currentColumn].index]:this.isTargetGroupingContainer(e)?e.originalEvent.target:this.groupPanelDivElement&&this.groupPanelDivElement.children[this.currentGroup];this.updateDragElementClue(e,t,o,r),this.updateDropElementClue(e,t,o,r)},this.releaseHandler=e=>{const t=this.startColumn,i=this.currentColumn,r=this.startGroup,o=this.currentGroup;this.dropElementClue&&(this.dropElementClue.visible=!1),this.dragElementClue&&(this.dragElementClue.visible=!1);const l=this.isValid();this.startColumn=this.startGroup=this.currentColumn=this.currentGroup=-1,l&&(t>=0&&i>=0?this.columnReorder(t,i,e.originalEvent):r>=0&&o>=0?this.groupReorder(r,o,e.originalEvent):t>=0&&o>=0&&this.columnToGroup(t,o,e.originalEvent))},this.columnReorder=e,this.groupReorder=t,this.columnToGroup=r}getColumnIndex(e,t){if(!t||t.parentElement===this.groupPanelDivElement)return-1;const i=x(e,t);if(-1===i)return-1;for(let e=0;e<t.parentNode.children.length;e++)if(t.parentNode.children[e]===t)return this.columns.findIndex((t=>t.index===i&&t.depth===e));return-1}isTargetGroupingContainer(e){const t=e.originalEvent.target;return t.className.indexOf&&-1!==t.className.indexOf("k-grouping-drop-container")}getGroupIndex(e){return x(e,this.groupPanelDivElement)}isValid(){return this.startGroup>=0?this.currentGroup>=0&&this.currentGroup!==this.startGroup:-1!==this.startColumn&&(this.currentGroup>=0?!0===this.columns[this.startColumn].groupable&&!0===this.groupable:!0===this.reorderable&&this.currentColumn>=0&&this.currentColumn!==this.startColumn&&!0===this.columns[this.startColumn].reorderable&&this.columns[this.currentColumn].parentIndex===this.columns[this.startColumn].parentIndex)}updateDragElementClue(e,t,i,r){if(!this.dragElementClue)return;const o=this.startColumn>=0?t.children[this.columns[this.startColumn].index].innerText:t.innerText;this.dragElementClue.visible=!0,this.dragElementClue.top=e.pageY+10,this.dragElementClue.left=e.pageX,this.dragElementClue.innerText=o,this.dragElementClue.status=r||!i?"cancel":"plus"}updateDropElementClue(e,t,i,r){if(!this.dropElementClue)return;if(r||!i)return void(this.dropElementClue.visible=!1);const o=i.getBoundingClientRect(),l=(i.closest(".k-grouping-header")||i).getBoundingClientRect();let n=o.left+e.pageX-e.clientX-6;!this.isTargetGroupingContainer(e)&&(this.currentColumn>this.startColumn||this.currentGroup>this.startGroup&&-1!==this.startGroup)&&(n+=o.width);const a=l.top+e.pageY-e.clientY;this.dropElementClue.visible=!0,this.dropElementClue.top=a,this.dropElementClue.left=n,this.dropElementClue.height=this.currentColumn>=0?t.clientHeight:l.height}};const ai=t.defineComponent({data:()=>({visible:!1,top:0,left:0,innerText:"",status:"cancel"}),render(){return this.visible&&t.createVNode("div",{class:"k-header k-drag-clue",style:{display:"block",position:"absolute",zIndex:2e4,padding:"8px 12px",top:this.top+"px",left:this.left+"px"}},[t.createVNode(i.Icon,{name:this.status,class:"k-drag-status",icon:"cancel"===this.status?n.cancelIcon:n.plusIcon},null),this.innerText])}}),si=t.defineComponent({data:()=>({height:0,visible:!1,left:0,top:0}),render(){return this.visible&&t.createVNode("div",{class:"k-grouping-dropclue",style:{zIndex:1e4,display:"block",top:this.top+"px",left:this.left+"px",height:this.height+"px"}},null)}}),di=t.defineComponent({name:"GridCell",inheritAttrs:!1,emits:{cellclick:null,cellkeydown:null},props:{id:String,field:String,dataItem:Object,format:String,readFormat:String,className:String,colSpan:Number,columnIndex:Number,columnsCount:Number,dataIndex:Number,rowType:String,level:Number,expanded:Boolean,type:String,editor:String,rowSpan:[Number,Object],isSelected:Boolean,isHighlighted:Boolean,ariaColumnIndex:Number,render:[String,Function,Object],isRtl:Boolean,onEdit:Function,onSave:Function,onRemove:Function,onCancel:Function,onChange:Function,onSelectionchange:Function},inject:{kendoIntlService:{default:null},getKeyboardNavigationAttributes:{default:i.noop}},methods:{triggerClick(){this.$emit("cellclick",{dataItem:this.$props.dataItem,field:this.$props.field})},triggerKeydown(e){this.$emit("cellkeydown",{event:e,dataItem:this.$props.dataItem,field:this.$props.field})},triggerEdit(e){this.$emit("edit",e)},triggerAdd(e){this.$emit("add",e)},triggerCancel(e){this.$emit("cancel",e)},triggerSave(e){this.$emit("save",e)},triggerRemove(e){this.$emit("remove",e)}},created(){this._intl=l.provideIntlService(this)},computed:{tdClass(){const{className:e,isHighlighted:t}=this.$props;return{"k-table-td":!0,"k-highlighted":t,[e]:e}}},setup:()=>({kendoIntlService:t.inject("kendoIntlService",{})}),render(){var e,o,l;let n=null;const a=this.getKeyboardNavigationAttributes(this.$props.id);if(null===(null==(e=this.$props.rowSpan)?void 0:e.count))return null;if("groupFooter"===this.$props.rowType)n=t.createVNode("td",{class:this.tdClass},null);else if(void 0!==this.$props.field&&"groupHeader"!==this.$props.rowType){const e=v(this.$props.field,this.$props.dataItem);let i="";null!=e&&(i=this.$props.format?this.$props.type?this._intl.format(this.$props.format,R[this.$props.type](e,this._intl,this.$props.readFormat)):this._intl.format(this.$props.format,e):e.toString()),n=t.createVNode("td",{style:this.$attrs.style,colspan:this.$props.colSpan,rowspan:null!=(l=null==(o=this.$props.rowSpan)?void 0:o.count)?l:void 0,class:this.tdClass,onKeydown:this.triggerKeydown,onClick:this.triggerClick,role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,"aria-selected":this.$props.isSelected,"data-grid-col-index":this.$props.columnIndex,tabindex:a.tabIndex,"data-keyboardnavlevel":a[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":a[r.KEYBOARD_NAV_DATA_ID]},[i])}return i.getTemplate.call(this,{h:t.h,template:this.$props.render,defaultRendering:n,additionalProps:this.$props,additionalListeners:{click:this.triggerClick,keydown:this.triggerKeydown,edit:this.triggerEdit,add:this.triggerAdd,cancel:this.triggerCancel,save:this.triggerSave,remove:this.triggerRemove}})}}),ci=t.defineComponent({name:"KendoGridGroupCell",inheritAttrs:!1,props:{id:String,field:String,dataItem:Object,format:String,type:String,colSpan:Number,className:String,columnIndex:Number,columnsCount:Number,rowType:String,level:Number,expanded:Boolean,editor:String,dataIndex:Number,isSelected:Boolean,isRtl:Boolean,ariaColumnIndex:Number,group:Object,render:[String,Function,Object]},emits:{change:null,cellkeydown:null},inject:{kendo:{default:null},kendoIntlService:{default:null},kendoLocalizationService:{default:null},getKeyboardNavigationAttributes:{default:i.noop}},computed:{tdClass(){const{className:e}=this.$props;return{"k-table-td":!0,[e]:e}}},methods:{triggerStateChange(){var e;const t=this.kendo;null==(e=null==t?void 0:t.dispatchGroupExpand)||e.call(t,{type:r.GROUP_EXPAND_ACTION.TOGGLE,group:this.$props.group})},triggerKeydown(e,t){this.$emit("cellkeydown",{event:e,dataItem:this.$props.dataItem,dataIndex:this.$props.dataIndex,field:this.$props.field,expanded:this.$props.expanded}),!e.defaultPrevented&&e.keyCode===i.Keys.enter&&(e.preventDefault(),this.$emit("change",{dataItem:this.$props.dataItem,dataIndex:this.$props.dataIndex,event:e,level:this.$props.level,field:void 0,value:!t}),this.triggerStateChange())},clickHandler(e,t,i){e.preventDefault(),this.$emit("change",{dataItem:t,dataIndex:this.$props.dataIndex,event:e,level:this.$props.level,field:void 0,value:!i}),this.triggerStateChange()}},render(){let e=null;const{columnIndex:o,level:a,columnsCount:s,rowType:d,dataItem:c,field:h,expanded:p,render:u}=this.$props,g=this.getKeyboardNavigationAttributes(this.$props.id),f=l.provideLocalizationService(this).toLanguageString(Ze,ht[Ze]),m=l.provideLocalizationService(this).toLanguageString(et,ht[et]);return void 0===o||void 0===a||o<a||void 0===s||"groupHeader"!==d||void 0===c[h]?e=t.createVNode("td",{style:this.$attrs.style,key:"g"+o,class:"k-table-td k-group-cell"},null):o<=a&&(e=t.createVNode("td",{style:this.$attrs.style,onKeydown:e=>{this.triggerKeydown(e,p)},key:"g-colspan",class:this.tdClass,colspan:s-o,role:"gridcell","aria-colindex":this.$props.ariaColumnIndex,"aria-selected":this.$props.isSelected,"aria-expanded":p,"data-grid-col-index":this.$props.columnIndex,tabindex:g.tabIndex,"data-keyboardnavlevel":g[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":g[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode("p",{class:"k-reset"},[t.createVNode("a",{onClick:e=>{this.clickHandler(e,c,p)},href:"#",tabindex:-1,title:p?f:m,"aria-label":p?f:m},[t.createVNode(i.Icon,{name:p?"caret-alt-down":this.isRtl?"caret-alt-left":"caret-alt-right",icon:p?n.caretAltDownIcon:this.isRtl?n.caretAltLeftIcon:n.caretAltRightIcon},null)]),c[h]?c[h].toString():""])])),i.getTemplate.call(this,{h:t.h,template:u,defaultRendering:e,additionalProps:this.$props,additionalListeners:{keydown:this.triggerKeydown,click:this.clickHandler}})}}),hi=t.defineComponent({name:"KendoGridRow",props:{rowType:String,item:Object,isAltRow:Boolean,isHidden:Boolean,isHighlighted:Boolean,onClick:Function,isInEdit:Boolean,isSelected:Boolean,selectedField:String,rowHeight:Number,ariaRowIndex:Number,absoluteRowIndex:Number,dataIndex:Number,render:[String,Function,Object],onRowclick:Function,onRowdblclick:Function},methods:{handleClick(e){this.$emit("rowclick",e)},handleDoubleClick(e){this.$emit("rowdblclick",e)}},computed:{trClass(){const{rowType:e,isAltRow:t,isInEdit:i,isHighlighted:r,isSelected:o}=this.$props;return{"k-table-row":!0,"k-selected":o,"k-highlighted":r,"k-table-group-row":"groupHeader"===e,"k-grouping-row":"groupHeader"===e,"k-group-footer":"groupFooter"===e,"k-master-row":"groupHeader"!==e&&"groupFooter"!==e,"k-table-alt-row":t,"k-edit-row":i}}},render(){const e=i.getDefaultSlots(this),r=t.createVNode("tr",{onClick:this.handleClick,onDblclick:this.handleDoubleClick,class:this.trClass,style:{height:this.$props.rowHeight?this.$props.rowHeight+"px":"",visibility:this.$props.isHidden?"hidden":""},role:"row","aria-rowindex":this.$props.ariaRowIndex,"absolute-row-index":this.$props.absoluteRowIndex,"data-grid-row-index":"data"===this.$props.rowType?this.$props.dataIndex:void 0},[e]);return i.getTemplate.call(this,{h:t.h,template:this.$props.render,defaultRendering:r,additionalProps:this.$props,additionalListeners:{click:this.handleClick},defaultSlots:e,swapDefaultSlots:!0})}}),pi={id:String,autoProcessData:[Boolean,Object],topCacheCount:{type:Number,default:0},collapsedGroups:{type:Array,default:function(){return[]}},uniqueField:String,totalGroupedHeight:Number,allGroupedItems:Object,alternatePerGroup:Boolean,columns:Array,columnsState:{type:Array,default:function(){}},defaultColumnsState:{type:Array,default:function(){}},columnVirtualization:Boolean,dataItems:[Array,Object],sortable:[Boolean,Object],defaultSort:Array,sort:Array,filterable:Boolean,filterOperators:Object,filterCellRender:[String,Function,Object],headerCellRender:[String,Function,Object],showLoader:{type:Boolean,default:void 0},loader:[String,Function,Object,Boolean],defaultFilter:Object,filter:Object,defaultSearch:Object,search:Object,searchFields:Array,highlight:Object,pageable:[Boolean,Object],pageSize:Number,total:Number,fixedScroll:Boolean,skip:Number,defaultSkip:Number,take:Number,defaultTake:Number,expandField:String,expandColumn:Object,selectedField:String,cellRender:[String,Function,Object],rowRender:[String,Function,Object],rowSpannable:[Boolean,Object],resizable:Boolean,reorderable:Boolean,group:Array,defaultGroup:Array,groupable:[Boolean,Object],groupExpand:Array,defaultGroupExpand:Array,detailExpand:Object,defaultDetailExpand:Object,editField:String,rowClass:Function,scrollable:{type:String,default:"scrollable"},size:{type:String,default:"medium",validator:function(e){return["small","medium"].includes(e)}},pager:[String,Function,Object],rowHeight:Number,detailRowHeight:Number,detail:[String,Function,Object],columnMenu:[Boolean,String,Function,Object],columnMenuAnimate:{type:[Boolean,Object],default:function(){return!0}},columnMenuIcon:i.SvgIcon,dataItemKey:String,navigatable:{type:Boolean,default:!1},onItemchange:Function,onExpandchange:Function,onDatastatechange:Function,onPagechange:Function,onSortchange:Function,onFilterchange:Function,onGroupchange:Function,onSearchchange:Function,onGroupexpandchange:Function,onDetailexpandchange:Function},ui=t.defineComponent({props:{field:String,title:String,selectionValue:Boolean,render:[Object,Function,String]},created(){this.inputId=i.guid()},inject:{kendoLocalizationService:{default:null}},methods:{changeHandle(e){this.$emit("selectionchange",{field:this.$props.field,event:e})}},render(){const e=this.$props.render,r=l.provideLocalizationService(this).toLanguageString(B,ht[B]),o=t.createVNode("input",{checked:this.$props.selectionValue,id:this.inputId,type:"checkbox",class:"k-checkbox k-checkbox-md k-rounded-md","aria-label":r,onChange:this.changeHandle},null),n=i.getTemplate.call(this,{h:t.h,template:e,defaultRendering:o,additionalProps:{...this.$props,selectAll:r},additionalListeners:{selectionchange:this.changeHandle}}),a=e?n:t.createVNode("span",{class:"k-checkbox-wrap"},[n]);return t.createVNode("span",{class:"k-link"},[t.createVNode("span",{class:"k-column-title"},[a])])}}),gi=t.defineComponent({name:"GridNoRecords",inject:{kendoLocalizationService:{default:null}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const e=i.getDefaultSlots(this),r=l.provideLocalizationService(this).toLanguageString(z,ht[z]);return e?t.createVNode("div",null,[e]):r}}),fi=t.defineComponent({name:"GridNoRecordsContainer",props:{id:String},render(){const e=i.getDefaultSlots(this),o=i.uGrid;return t.createVNode("div",{key:"no-records",class:i.classNames(o.noRecords({}))},[t.createVNode("div",t.mergeProps({class:i.classNames(o.noRecordsTemplate({}))},{[r.KEYBOARD_NAV_DATA_ID]:this.$props.id}),[e])])}}),mi={name:"@progress/kendo-vue-grid",productName:"Kendo UI for Vue",productCode:"KENDOUIVUE",productCodes:["KENDOUIVUE"],publishDate:0,version:"7.1.0-develop.7",licensingDocsUrl:"https://www.telerik.com/kendo-vue-ui/my-license/"};function vi(e){const t=e.replace(/^pager\.([a-z])/,((e,t)=>"grid.pager"+t.toUpperCase()));return{messageKey:t,defaultMessage:ht[t]}}const bi=Symbol("kendoKey");const Ci=t.defineComponent({name:"KendoGrid",inheritAttrs:!1,props:{...pi,toolbar:{type:Object},noRecords:{type:Object}},data:()=>({isRtl:!1,context:void 0,navigation:void 0,showLicenseWatermark:!1,licenseMessage:void 0,notHiddenColumns:[]}),watch:{rowHeight:function(e,t){var i;this.onRowHeightChanged(e,t),null==(i=this.vsRef)||i.reset()},scrollable:function(){var e;null==(e=this.vsRef)||e.reset()},filter:function(){var e;null==(e=this.vsRef)||e.reset()},group:function(){var e;null==(e=this.vsRef)||e.reset()},currentGroupable:function(){var e;null==(e=this.vsRef)||e.reset()},sort:function(){var e;null==(e=this.vsRef)||e.reset()}},created(){i.validatePackage(mi),this.showLicenseWatermark=i.shouldShowValidationUI(mi),this.licenseMessage=i.getLicenseMessage(mi),this.initialHeight=null,this._columns=[],this.vsRef=new oi,this.dragLogic=new ni(this.columnReorder.bind(this),this.groupReorder.bind(this),this.columnToGroup.bind(this)),this.columnResize=new li(this.onResize.bind(this)),this._columnsMap=[[]],this._header=null,this._footer=null,this.tableBodyRef=null,this.tableRef=null,this.scrollHeightContainerRef=null,this.forceUpdateTimeout=void 0,this._gridId=i.guid(),this._gridRoleElementId=i.guid(),this.slicedCurrentData=void 0,this._prevTotal=void 0,this._containerHeightRef=0,this._minRowHeightRef=0,this._virtualSkipRef=0,this.wrapperScrollTopRef=0,this.scrollLeftRef=0},mounted(){var e,t;this.setRefs();const r=i.isRtl(this._element);this._prevTotal=this.$props.total,this.isRtl=r,this.initialHeight=(null==(t=null==(e=this._element)?void 0:e.style)?void 0:t.height)||null,this.resizeObserver=i.canUseDOM&&(null==window?void 0:window.ResizeObserver)&&new ResizeObserver(this.calculateMedia),null!=document&&document.body&&this.resizeObserver&&this.resizeObserver.observe(document.body)},updated(){var e;this.setRefs();const t=i.isRtl(this._element);this.isRtl=t,this._prevTotal=this.$props.total,this.vsRef.tableTransform&&this.vsRef.table&&(this.vsRef.table.style.transform=this.vsRef.tableTransform,this.vsRef.tableTransform=""),this.isVirtualScroll&&(this.setContainerHeight(),this.setMinRowHeight(),null==(e=this.vsRef)||e.update())},unmounted(){this.gridUnmounted()},computed:{gridId(){return this.$props.id+"-role-element-id"},idPrefix(){return this.$props.navigatable?this.gridId:""},groupExpandable(){return r.getGroupExpandableOptions("object"==typeof this.$props.groupable&&!1!==this.$props.groupable.enabled?this.$props.groupable.expandable:this.$props.groupable)},hierarchClass:()=>i.uGrid.hierarchyCell({}),computedRowSpannable(){return T(this.$props.rowSpannable)},detailExpandable(){return r.getDetailExpandableOptions(!!this.$props.detail)},nonscrollableWrapperClass(){const{size:e}=this.$props,t=this.$attrs.class;return{"k-grid":!0,"k-grid-md":!e,[`k-grid-${i.kendoThemeMaps.sizeMap[e]||e}`]:e,[t]:!!t}},scrollableWrapperClass(){const{scrollable:e}=this.$props;return{...this.nonscrollableWrapperClass,"k-grid-virtual":"virtual"===e}},gridTableClass(){const{size:e}=this.$props;return{"k-table":!0,"k-grid-table":!0,"k-grid-md":!e,[`k-table-${i.kendoThemeMaps.sizeMap[e]||e}`]:e}},getCorrectHeight(){return"virtual"===this.$props.scrollable?this.initialHeight||"450px":null},currentGroupable(){var e;const t=null==(e=this.gridContext.group)?void 0:e.value;return!0===this.$props.groupable&&(null==t?void 0:t.length)||i.isObject(this.$props.groupable)&&!1!==this.$props.groupable.enabled},computedCollapsed(){let e=[];if(this.$props.group)for(let t=0;t<this.$props.group.length;t++)this.$props.collapsedGroups[t]?e.push(this.$props.collapsedGroups[t]):e.push([]);return e},getAriaRowCount(){const e=this.$props.dataItems,t=this.$props.total||(null==e?void 0:e.total)||(null==e?void 0:e.length)||0;return this.$props.detail?this._columnsMap.length+(this.$props.filterable?1:0)+2*t+(this._columns.some((e=>!!e.footerCell))?1:0):this.$props.pageable||"scrollable"!==this.$props.scrollable?this.$props.groupable?-1:this._columnsMap.length+(this.$props.filterable?1:0)+t+(this._columns.some((e=>!!e.footerCell))?1:0):void 0},getAriaColCount(){const e=this.$props.columns,t=this.$props.columnVirtualization,i=0!==(null==e?void 0:e.filter((e=>void 0!==e.hidden)).length);if(t||i)return 0!==(null==e?void 0:e.length)?null==e?void 0:e.length:-1},isVirtualScroll(){return"virtual"===this.$props.scrollable||void 0===this.$props.scrollable||!1}},methods:{readColumnElements(){return I(this.$props.columns,this.currentColumnsState,{prevId:0,idPrefix:this.idPrefix})},getResolvedFlatColumnsState(){const e=[],t=(i,r)=>null==i?void 0:i.forEach((i=>{const o=i.hidden||r;e.push({...i,hidden:o}),t(i.children,o)}));return t(this.currentColumnsState,!1),e},filterColumns(e){const t=this.getResolvedFlatColumnsState();return[e.filter((e=>{var i;return!(e.hidden||null!=(i=t.find((t=>t.id===e.id)))&&i.hidden)})),e.filter((e=>{var i;return e.hidden||(null==(i=t.find((t=>t.id===e.id)))?void 0:i.hidden)}))]},getFlatData(e,t,i,r,o,l,n){const a=[];return{flattedData:a,resolvedGroupsCount:b(a,e,t,{index:i},void 0!==r,o,l,this.groupExpandable.defaultExpand,n,this.$props.expandField)}},getColumnsEssentialProps:e=>e&&JSON.stringify(e.map((e=>({id:e.id,field:e.field,title:e.title,children:e.children})))),calculateMedia(){const e=this.filterHiddenColumns(this.$props.columns||[]);this.getColumnsEssentialProps(this.notHiddenColumns)!==this.getColumnsEssentialProps(e)&&this.$forceUpdate()},filterHiddenColumns(e){if(!e||0===e.length)return e;const t=e=>({...e,children:e.children&&e.children.length>0?this.filterHiddenColumns(e.children):e.children});return[...e].filter((e=>!e.hidden)).filter((e=>i.canUseDOM&&e&&e.media?window.matchMedia(e.media).matches:e)).map((e=>t(e)))},getColumns(){const e=this._columns.filter((e=>e.declarationIndex>=0&&-1===e.parentIndex)),t=e=>(e.sort(((e,t)=>e.declarationIndex-t.declarationIndex)),e.map((e=>{const{declarationIndex:i,parentIndex:r,depth:o,colSpan:l,rowSpan:n,index:a,kFirst:s,children:d,...c}=e;return d.length?{children:t(d),...c}:c})));return t(e)},setRefs(){const e=i.getRef(this,"gridNav");e&&(this._element=e.$el);const t=i.getRef(this,"groupPanelDiv");if(t){let e=t.$el||null;this.dragLogic.refGroupPanelDiv(e)}const r=i.getRef(this,"dropElementClue"),o=i.getRef(this,"dragElementClue");this.dragLogic.refDropElementClue(r),this.dragLogic.refDragElementClue(o),this.columnResize.colGroupMain=i.getRef(this,"colGroup"),this._header=i.getRef(this,"header"),this._footer=i.getRef(this,"footer"),this.resetTableWidth(),i.setScrollbarWidth()},gridUnmounted(){clearTimeout(this.forceUpdateTimeout),this.columnResize.columns=[],this.dragLogic.columns=[],this.dragLogic&&this.dragLogic.dragElementClue&&(this.dragLogic.dragElementClue.$el.remove(),this.dragLogic.dropElementClue.$el.remove()),this.currentData=[],this._columns=[],null!=document&&document.body&&this.resizeObserver&&this.resizeObserver.disconnect()},isAllData(){const{dataItems:e,total:t}=this.$props;return Array.isArray(e)?e.length===t:!!e&&t===e.total},resetVirtualSkip(){this.isVirtualScroll&&this._virtualSkipRef&&(this._virtualSkipRef=0)},virtualPageChange(e,t){var i;this.$props.pageable||null!=(i=this.$props.group)&&i.length?(this._virtualSkipRef=e.skip,this.$forceUpdate()):this.pageChangeHandler(e,t)},initializeVirtualization(){const e=this.vsRef,t=this.$props.rowHeight||this._minRowHeightRef||0;e&&(e.fixedScroll=this.$props.fixedScroll||!1,e.PageChange=this.virtualPageChange,e.pageSize=this._virtualPageSize,e.scrollableVirtual=this.isVirtualScroll,e.container=i.getRef(this,"scrollContainer"),e.tableBody=i.getRef(this,"tableBody"),e.scrollHeightContainer=i.getRef(this,"scrollHeightContainer"),e.table=i.getRef(this,"table"),(!e.rowHeightService||e.total!==this._virtualTotal)&&t&&(e.total=this._virtualTotal,e.rowHeightService=new i.RowHeightService(this._virtualTotal,t)))},setContainerHeight(){const e=i.getRef(this,"scrollContainer");this._containerHeightRef=(null==e?void 0:e.offsetHeight)||0},setMinRowHeight(){if(!this._minRowHeightRef&&!this.$props.rowHeight){const e=G(i.getRef(this,"tableBody"));e&&(this._minRowHeightRef=e,this.$forceUpdate())}},onRowHeightChanged(e,t){this.setRefs()},scrollHandler(e){clearTimeout(this.forceUpdateTimeout);const t=e.currentTarget.scrollLeft,i=e.currentTarget.scrollTop;this.$props.columnVirtualization&&(!this.isVirtualScroll||i===this.wrapperScrollTopRef)&&(this.forceUpdateTimeout=setTimeout((()=>{this.$forceUpdate()}),0)),this.scrollLeftRef=t,this._header&&this._header.setScrollLeft(e.currentTarget.scrollLeft),this._footer&&this._footer.setScrollLeft(e.currentTarget.scrollLeft),this.vsRef&&i!==this.wrapperScrollTopRef&&this.vsRef.scrollHandler(e),this.$emit("scroll",e),this.wrapperScrollTopRef=i},rowClick(e,t){"checkbox"!==e.target.type&&this.$emit("rowclick",{dataItem:t.dataItem,...this.getArguments(e)})},rowDoubleClick(e,t){"checkbox"!==e.target.type&&this.$emit("rowdblclick",{dataItem:t.dataItem,...this.getArguments(e)})},loopGroupedItems(e,t,i=0,r=null){return e.forEach((e=>{!r&&t(e,i)&&(r=e),e.items&&e.items.length&&!r&&(r=this.loopGroupedItems(e.items,t,i+1,r))})),r},updateGroupCollapsed(e){let t=this.computedCollapsed,i=t[e.level];const r=this.$props.uniqueField,o=this.allGroupedItems?this.loopGroupedItems(this.allGroupedItems.data,(function(t,i){return t.value===e.dataItem.value&&i===e.level}),0,null):e.dataItem,l=E(o||e.dataItem,r);if(e.value){if(i&&i.length){const e=i.indexOf(l);e>-1&&i.splice(e,1)}}else i?i.includes(l)||i.push(l):i=[l];return t},itemChange(e){var t;const r=i.hasListener.call(this,"itemchange"),o=null==(t=this.gridContext.group)?void 0:t.value;e.field===this.$props.expandField||(o||this.$props.detail)&&void 0===e.field?i.hasListener.call(this,"expandchange")&&e.dataItem&&this.$emit("expandchange",{...this.getArguments(e.event),collapsedGroups:this.updateGroupCollapsed(e),dataItem:e.dataItem,value:e.value}):r&&this.$emit("itemchange",{...this.getArguments(e.event),dataItem:e.dataItem,field:e.field,value:e.value})},cellClickHandler(e){this.$emit("cellclick",{dataItem:e.dataItem,field:e.field})},cellKeydownHandler(e){this.$emit("cellkeydown",e)},editHandler(e){this.$emit("edit",{dataItem:e})},removeHandler(e){this.$emit("remove",{dataItem:e})},saveHandler(e){this.$emit("save",{dataItem:e})},cancelHandler(e){this.$emit("cancel",{dataItem:e})},selectionChangeHandler(e){const{event:t,dataItem:i,dataIndex:r,columnIndex:o}=e;this.$emit("selectionchange",{...this.getArguments(t.event),dataItem:i,startColIndex:o,endColIndex:o,startRowIndex:r,endRowIndex:r,dataItems:this.getLeafDataItems(),altKey:!1,ctrlKey:!1,shiftKey:!1,metaKey:!1,isDrag:!1,componentId:this._gridId,selectedField:this.$props.selectedField||""})},onHeaderSelectionChangeHandler(e){this.$emit("headerselectionchange",{field:e.field,event:e.event,target:this})},pageChangeHandler(e,t){this.raiseDataEvent("pagechange",{page:e,event:t},{skip:e.skip,take:e.take},t)},sortChangeHandler(e,t){this.raiseDataEvent("sortchange",{sort:e},{sort:e},t)},filterChangeHandler(e,t){this.raiseDataEvent("filterchange",{filter:e},{filter:e,skip:0},t)},groupChangeHandler(e,t){this.raiseDataEvent("groupchange",{group:e},{group:e,skip:0},t)},handleDetailExpandAction(e,t){var i;if(this.detailExpandable.enabled){const o=null==(i=this.gridContext.detailExpand)?void 0:i.value,l=r.detailExpandReducer(null!=o?o:{},e);this.$emit("detailexpandchange",{...this.getArguments(t),detailExpand:l})}},handleGroupExpandAction(e,t){var i;if(this.groupExpandable.enabled){const o=null==(i=this.gridContext.groupExpand)?void 0:i.value,l=r.groupExpandReducer(null!=o?o:[],e,this.groupExpandable);this.$props.expandField||this.$emit("groupexpandchange",{...this.getArguments(t),groupExpand:l})}},raiseDataEvent(e,t,r,o){if(this.resetVirtualSkip(),this.$props.autoProcessData)this.gridContext[e]({...this.getArguments(o),...t});else if(i.hasListener.call(this,e))this.$emit(e,{...this.getArguments(o),...t});else if(i.hasListener.call(this,"datastatechange")){const e={...this.getDataState(),...r};this.gridContext.datastatechange({...this.getArguments(o),data:e,dataState:e})}},columnReorder(e,t,i){const o=this._columns[e],l=A(this.currentColumnsState),n=o.depth,a=e=>{do{e++}while(e<this._columns.length&&this._columns[e].depth>n);return e},s=this._columns.splice(e,a(e)-e);this._columns.splice(e<t?a(t-s.length):t,0,...s),this._columns.filter((e=>e.declarationIndex>=0)).forEach(((e,t)=>{e.orderIndex=t;const i=l.find((t=>t.id===e.id));i&&(i.orderIndex=t)}));const d=this._columns[e].locked&&this._columns[t].locked;r.updateLeft(this._columnsMap,this._columns,d||this.shouldUpdateLeftRightRef),r.updateRight(this._columnsMap,this._columns,d||this.shouldUpdateLeftRightRef),this.resizedRef&&(this.shouldUpdateLeftRightRef=!1,this.resizedRef=!1);const c=this.getColumns();this.$emit("columnreorder",{target:this,columns:c,event:i,prev:e,next:t}),this.gridContext.columnsstatechange({columnsState:this.currentColumnsState})},groupReorder(e,t,i){var r;const o=null==(r=this.gridContext.group)?void 0:r.value;void 0!==o&&(o.splice(t,0,...o.splice(e,1)),this.groupChangeHandler(o,i))},columnToGroup(e,t,i){var r;const o=this._columns[e].field;if(!o)return;const l=((null==(r=this.gridContext.group)?void 0:r.value)||[]).slice();l.splice(t,0,{field:o}),this.groupChangeHandler(l,i)},resetTableWidth(){var e;let t=0;if(!this.columnResize.colGroupMain)return;const r=null==(e=this.columnResize.colGroupMain)?void 0:e.children;for(let e=0;e<r.length;e++){const i=r[e].width;if(!i)return;t+=parseFloat(i.toString())}t=Math.round(t),this._header&&this._header.setWidth(t),this._footer&&this._footer.setWidth(t);const o=i.getRef(this,"table");o&&t&&(o.style.width=t+"px")},onResize(e,t,i,r,o,l,n){this.resetTableWidth(),this.shouldUpdateLeftRightRef=!0,this.resizedRef=!0,this.$emit("columnresize",{columns:this.getColumns(),index:e,targetColumnId:n,event:r,newWidth:t,oldWidth:i,end:o,target:this}),o&&this.gridContext.columnsstatechange({columnsState:l})},initColumnsState(e,t){const i=e=>{var r;const o=t.find((t=>t.id===e.id));if(o){const t={...o};return t.children=null==(r=e.children)?void 0:r.map(i),t}return e};this.currentColumnsState=e.filter((e=>-1===e.parentIndex)).map(i)},configureColumns(e,o){e.filter((e=>"checkbox"===e.columnType)).forEach((e=>{e.width=e.width||"50px",e.defaultCell=t.markRaw(_),e.defaultHeaderCell=t.markRaw(ui),e._type="edit"})),this.$props.selectedField&&this._columns.filter((e=>e.field===this.$props.selectedField)).forEach((e=>{e.width=e.width||"50px",e.internalCell=t.markRaw(_),e.internalHeaderCell=t.markRaw(ui)}));const l=A(this.currentColumnsState);this.initColumnsState(e,l);const n={id:"",resizable:!0,width:"32px",title:" ",declarationIndex:-1,orderIndex:-1,children:[],parentIndex:-1,depth:0,colSpan:0,headerColSpan:0,rowSpan:0,left:0,right:0,index:0,rightBorder:!1,ariaColumnIndex:0,isAccessible:!0};let a=0;if(this.detailExpandable.enabled&&this.$props.detail&&!this.$props.expandField){const i={...n,_type:"expand",id:r.tableKeyboardNavigationTools.generateNavigatableId(""+a++,"expand","column"),defaultCell:t.markRaw(pt),internalCell:t.markRaw(pt),field:this.detailExpandable.column,headerClassName:this.hierarchClass};e.unshift(i),this.currentColumnsState.unshift(l.find((e=>e.id===i.id))||i)}this.$props.expandField&&i.hasListener.call(this,"expandchange")&&this.$props.detail&&(e.unshift({...n,internalCell:t.markRaw(pt),field:this.$props.expandField,headerClassName:"k-hierarchy-cell k-header",id:r.tableKeyboardNavigationTools.generateNavigatableId(`${e.length}`,this.idPrefix,"column"),...this.expandColumn}),a++);for(let i=0;i<o;i++){const i={...n,isAccessible:!1,defaultCell:t.markRaw(ci),internalCell:t.markRaw(ci),id:r.tableKeyboardNavigationTools.generateNavigatableId(""+a++,"group","column"),field:"value",locked:this.$props.lockGroups};e.unshift(i),this.currentColumnsState.unshift(l.find((e=>e.id===i.id))||i)}e.slice(a).forEach((e=>{e.parentIndex>=0&&(e.parentIndex+=a),e.rowSpannable=void 0!==e.rowSpannable?T(e.rowSpannable):this.computedRowSpannable}))},initColumns(e,t){var i;this._columns=this.readColumnElements();const r=null==(i=this.gridContext.group)?void 0:i.value;0===this._columns.filter((e=>!e.hidden)).length&&(this._columns=w(e,r,{column:this.$props.expandField?this.$props.expandField:this.groupExpandable.column},{prevId:0,idPrefix:this.idPrefix})),this.configureColumns(this._columns,t);const[o,l]=this.filterColumns(this._columns);this._columns=o,this.hiddenColumnsRef=l,this._columnsMap=S(this._columns,!0)},resolveTitle(e){const t=this.findColumnByField(e),i=t&&(t.title||t.field);return void 0===i?e:i},findColumnByField(e){let t;return this.$props.columns.forEach((i=>{const r=this.searchColumn(i,e);r&&(t=r)})),t},searchColumn(e,t){if(e.field===t)return e;if(e.children){let i,r=null;for(i=0;null==r&&i<e.children.length;i++)r=this.searchColumn(e.children[i],t);return r}return null},getDataState(){var e,t,i,r,o;const l=null==(e=this.gridContext.sort)?void 0:e.value,n=null==(t=this.gridContext.filter)?void 0:t.value,a=null==(i=this.gridContext.skip)?void 0:i.value,s=null==(r=this.gridContext.take)?void 0:r.value,d=null==(o=this.gridContext.group)?void 0:o.value;return{filter:n,sort:l,skip:a,take:void 0!==s?s:this.$props.pageSize,group:d}},getArguments(e){return{event:e,target:this}},getLeafDataItems(){return this.currentData.filter((e=>"data"===e.rowType)).map((e=>e.dataItem))},totalGroupedRows(e){let t=0;return e&&(t=this.addSubItems(e,t)),t},addSubItems(e,t){return e.forEach((e=>{t++,!1!==e.expanded&&e.items&&(t=this.addSubItems(e.items,t)),this.group&&this.group.length&&("always"===this.$props.groupable.footer||!1!==e.expanded&&e.items&&"visible"===this.$props.groupable.footer)&&t++})),t},searchChange(e){const t=this.$props.searchFields||this._columns.map((e=>e.field))||[],i=e.event.target.value,r={logic:"or",filters:t.filter((e=>void 0!==e)).map((e=>{var t;return"string"==typeof e?{field:e,value:i,operator:"contains"}:{value:i,operator:null!=(t=e.operator)?t:"contains",field:e.field,ignoreCase:e.ignoreCase}}))};this.raiseDataEvent("searchchange",{search:r},{skip:0},e)},getCellsToRender(e,t){var i;const r=[];let o=null,l=0;if(t.forEach(((i,n)=>{const a=parseFloat((i.width||"").toString())||10;if(l)return l--,void(o&&(o.width+=a));const s=Math.min(H(i,e),t.length-n);l=s-1,o={width:a,colSpan:s,columnIndex:n},r.push(o)})),this.$props.columnVirtualization){const e=this.scrollLeftRef||0,o=this.tableWidth||parseFloat(((null==(i=this.$attrs.style)?void 0:i.width)||"").toString());return function(e){const{cellModels:t,columns:i=[],tableViewPortWidth:r,scrollLeft:o}=e;let l=0,n=t.length-1,a=0,s=0;for(let e=0;e<t.length;e++)if(!i[t[e].columnIndex].locked&&(a=s,s+=t[e].width||10,s>=o)){l=e;break}for(let e=l;e<t.length;e++)if(!i[t[e].columnIndex].locked){if(!(a<r+o))break;a+=t[e].width||10,n=e}l>0&&l--,n<t.length-1&&n++;let d=0,c=0;for(let e=0;e<l;e++)i[t[e].columnIndex].locked||(d+=t[e].colSpan);for(let e=n+1;e<t.length;e++)i[t[e].columnIndex].locked||(c+=t[e].colSpan);t[l].colSpan+=d,t[n].colSpan+=c;const h=t.slice(0,l).filter((e=>i[e.columnIndex].locked)),p=t.slice(n+1).filter((e=>i[e.columnIndex].locked));return[...h,...t.slice(l,n+1),...p]}({cellModels:r,columns:t,tableViewPortWidth:o,scrollLeft:e})}return r},calcVirtualPageSize(){const{pageable:e,take:t,pageSize:i}=this.$props;if(!this.isVirtualScroll)return 0;if(!e){if(t)return t;if(i)return i}const r=this.$props.rowHeight||this._minRowHeightRef,o=this._containerHeightRef;return o&&r?Math.ceil(o/r*1.5):0}},provide(){return{kendo:{dataItemKey:this.$props.dataItemKey,searchChange:this.searchChange,dispatchGroupExpand:this.handleGroupExpandAction,dispatchDetailExpand:this.handleDetailExpandAction}}},setup(e){const i=t.ref(null),r=t.ref(null),o=t.ref(null),l=t.ref(null),n=t.ref(null),a=t.ref(null),s=t.ref(null),d=t.ref(null),c=t.ref(null),h=t.ref(null),p=t.ref(!0),u=t.ref(!1);return{groupPanelDivRef:i,dropElementClueRef:r,dragElementClueRef:o,headerRef:l,footerRef:n,gridNavRef:a,colGroupRef:s,scrollContainerRef:d,scrollTableRef:c,scrollTableBodyRef:h,gridContext:t.inject(bi,{}),shouldUpdateLeftRightRef:p,resizedRef:u,currentColumnsState:e.columnsState}},render(){var e,l,n,a,s,d,h,p,u,f,m;const v=null==(e=this.gridContext.sort)?void 0:e.value,b=null==(l=this.gridContext.filter)?void 0:l.value,C=null==(n=this.gridContext.search)?void 0:n.value,x=null==(a=this.gridContext.skip)?void 0:a.value,$=null==(s=this.gridContext.take)?void 0:s.value,k=null==(d=this.gridContext.group)?void 0:d.value,S=null==(h=this.gridContext.groupExpand)?void 0:h.value,I=null==(p=this.gridContext.detailExpand)?void 0:p.value,y=!(null==k||!k.length);let w;this.currentColumnsState=null==(u=this.gridContext.columnsState)?void 0:u.value;const N=!0===this.$props.autoProcessData?{group:!0,sort:!0,filter:!0,search:!0,page:!0}:this.$props.autoProcessData;let R=this.$props.total||0;const V=r.tableKeyboardNavigationTools.getIdPrefix(this.navigation);let A=[];Array.isArray(this.$props.dataItems)?A=this.$props.dataItems:this.$props.dataItems&&(A=F(this.$props.dataItems,this.$props.collapsedGroups.length?this.computedCollapsed:[],this.$props.uniqueField).data,R=R||this.$props.dataItems.total);const D=!0===this.$props.groupable||i.isObject(this.$props.groupable)&&!1!==this.$props.groupable.enabled;this.dragLogic.reorderable=this.$props.reorderable||!1,this.dragLogic.groupable=D,this._virtualPageSize=this.calcVirtualPageSize();const L=A.length===R,O=i.isObject(this.$props.groupable)&&this.$props.groupable.footer||"none";if(this.currentData=[],N){const e=N.page&&!(this.isVirtualScroll&&!this.$props.pageable),{data:t,total:i}=c.process(A,{group:N.group?k:void 0,sort:N.sort?v:void 0,filter:r.combineFilters(N.filter?b:void 0,N.search?C:void 0),...e?{take:this.$props.pageable?$||10:$,skip:x||0}:{}});A=t,R=null!=(f=this.$props.total)?f:i}const{resolvedGroupsCount:H,flattedData:T}=this.getFlatData(A,O,L?0:this.$props.skip||0,k,I,S,this.$props.dataItemKey);this.currentData=T;const G=this._virtualSkipRef||0;if(this._virtualTotal=R,this.isVirtualScroll){let e=x||0;if((y||this.$props.pageable)&&(e=G,this._virtualTotal=this.currentData.length),L||y||this.$props.pageable)if(0===this._virtualPageSize){const t=Math.min($||this.$props.pageSize||20,this.currentData.length);w=this.currentData.slice(e,e+t)}else w=this.currentData.slice(e,e+this._virtualPageSize)}this.initializeVirtualization(),this.initColumns(this.$props.dataItems,H),this.columnResize.resizable=this.$props.resizable||!1,this.columnResize.columns=this._columns,this.columnResize.columnsState=i.cloneArray(this.currentColumnsState||[]),this.dragLogic.columns=this._columns;const _=this.$props.toolbar,z=this.$props.noRecords,B=this._columns.filter((e=>0===e.children.length)),j=D&&t.createVNode(ti,{ref:e=>{this.groupPanelDivRef=e},group:k||[],ariaControls:this._gridRoleElementId,onGroupChange:this.groupChangeHandler,onPressHandler:this.dragLogic.pressHandler,onDragHandler:this.dragLogic.dragHandler,onReleaseHandler:this.dragLogic.releaseHandler,resolveTitle:this.resolveTitle},null),M=(this.dragLogic.reorderable||this.dragLogic.groupable)&&i.canUseDOM&&document&&document.body,K=[M&&t.createVNode(si,{ref:e=>{this.dropElementClueRef=e}},null),M&&t.createVNode(ai,{ref:e=>{this.dragElementClueRef=e}},null)],P=t.createVNode(mt,{size:this.$props.size,columnResize:this.columnResize,staticHeaders:"none"!==this.$props.scrollable,ref:e=>{this.headerRef=e},headerRow:t.createVNode(Jt,{grid:this,sort:v,groupable:this.$props.groupable,reorderable:this.$props.reorderable,sortable:this.$props.sortable,onSortChange:this.sortChangeHandler,filter:b,filterable:this.$props.filterable,filterOperators:this.$props.filterOperators||Et,onFilterChange:this.filterChangeHandler,columnMenu:this.$props.columnMenu,columnMenuIcon:this.$props.columnMenuIcon,columnMenuAnimate:this.$props.columnMenuAnimate,onSelectionchange:this.onHeaderSelectionChangeHandler,columns:this._columns,columnsInitial:this.$props.columns,columnResize:this.columnResize,onPressHandler:this.dragLogic.pressHandler,onDragHandler:this.dragLogic.dragHandler,onReleaseHandler:this.dragLogic.releaseHandler,columnsMap:this._columnsMap,cellRender:this.$props.headerCellRender,isRtl:this.isRtl,isColCountDefined:void 0!==this.getAriaColCount,filterRow:this.$props.filterable&&t.createVNode(Zt,{grid:this,size:this.$props.size,columns:this._columns,filter:b,filterOperators:this.$props.filterOperators||Et,onFilterchange:this.filterChangeHandler,sort:this.$props.sort,cellRender:this.$props.filterCellRender,isRtl:this.isRtl,ariaRowIndex:this._columnsMap.length+1},null)||void 0},null),cols:B.map((function(e,i){return t.createVNode("col",{key:i.toString(),width:void 0!==e.width?Math.floor(parseFloat(e.width.toString())):void 0},null)}),this)},null),W=this._columns.some((e=>!!e.footerCell))?t.createVNode(ii,{size:this.$props.size,columnResize:this.columnResize,staticHeaders:"none"!==this.$props.scrollable,ref:e=>{this.footerRef=e},row:t.createVNode(ri,{isRtl:this.isRtl,rowIndex:this.getAriaRowCount+1,columns:this._columns},null),cols:B.map((function(e,i){return t.createVNode("col",{key:i.toString(),width:void 0!==e.width?Math.floor(parseFloat(e.width.toString())):void 0},null)}),this)},null):t.createVNode("span",null,null),q=this.showLicenseWatermark?t.createVNode(i.WatermarkOverlay,{message:this.licenseMessage},null):null,U=this.$attrs.style,Y=U&&i.isObject(U)&&U.width||"";this.tableWidth=parseFloat(Y.toString());const X=B.findIndex((e=>"function"==typeof e.colSpan))>-1;let J;X||(J=this.getCellsToRender(null,B));const Q=function(e,o,l,n,a){let s=!1;const d=this.$props.selectedField,c=d?i.getNestedValue(d,e.dataItem):void 0,h=this.$props.highlight&&this.$props.dataItemKey&&void 0!==i.getter(this.$props.dataItemKey)(e.dataItem)?this.$props.highlight[i.getter(this.$props.dataItemKey)(e.dataItem)]:void 0;return X&&(J=this.getCellsToRender(e.dataItem,B)),{row:J.map((function({columnIndex:n,colSpan:d}){var p,u,g,f;const m=B[n];let v;if(null!=(p=m.rowSpannable)&&p.enabled&&"data"===e.rowType&&m.field&&a){const t=m.field?null==(g=(u=m.rowSpannable).valueGetter)?void 0:g.call(u,e.dataItem,m.field):null;v={value:t,count:1},a[m.field]&&(null==(f=a[m.field])?void 0:f.value)===t&&null!==a[m.field]?(a[m.field].count++,v.count=null):a[m.field]=v}const b=`${m.className?m.className+" ":""}${m.locked?"k-grid-content-sticky":""}`,C=void 0!==m.left?this.isRtl?{left:m.right+"px",right:m.left+"px"}:{left:m.left+"px",right:m.right+"px"}:{};let x,$=!1;if(m.editable&&this.$props.editField){const t=i.getNestedValue(this.$props.editField,e.dataItem);(!0===t||t===m.field)&&(s=!0,$=!0)}m.cell&&(x=m.cell);const k=this.computedCollapsed&&this.computedCollapsed[e.level]&&this.computedCollapsed[e.level].some((t=>t===E(e.dataItem,this.$props.uniqueField))),S=m.id?m.id:n,I=k?!k:e.expanded||e.dataItem.expanded,y="expand"===m._type,w=r.tableKeyboardNavigationTools.generateNavigatableId(`${o}-${String(n)}`,V,y||"groupHeader"===e.rowType||"groupFooter"===e.rowType||"value"===m.field?"nodata":"cell");return m.internalCell?t.createVNode(m.internalCell,{key:S,id:w,colSpan:d,dataItem:e.dataItem,field:m.field||"",editor:m.editor,format:m.format,readFormat:m.readFormat,type:m.type,className:b,render:x||this.$props.cellRender,onChange:this.itemChange,onSelectionchange:t=>this.selectionChangeHandler({event:t,dataItem:e.dataItem,dataIndex:l,columnIndex:n}),columnIndex:n,columnsCount:this._columns.filter((e=>!e.children.length)).length,rowType:e.rowType,level:e.level,expanded:I,dataIndex:e.dataIndex,style:C,ariaColumnIndex:m.ariaColumnIndex,isRtl:this.isRtl,isSelected:Array.isArray(c)&&c.indexOf(n)>-1,isHighlighted:!("boolean"==typeof h||!h||!m.field||!0!==h[m.field]),group:e.group,rowSpan:v},null):$?t.createVNode(ft,{id:w,key:S,colSpan:d,dataItem:e.dataItem,field:m.field||"",editor:m.editor,format:m.format,readFormat:m.readFormat,type:m.type,className:b,render:x||this.$props.cellRender,onEdit:this.editHandler,onRemove:this.removeHandler,onSave:this.saveHandler,onCancel:this.cancelHandler,onChange:this.itemChange,columnIndex:n,columnsCount:this._columns.filter((e=>!e.children.length)).length,rowType:e.rowType,level:e.level,expanded:I,dataIndex:e.dataIndex,style:C},null):t.createVNode(di,{key:S,id:w,colSpan:d,dataItem:e.dataItem,field:m.field||"",editor:m.editor,format:m.format,readFormat:m.readFormat,type:m.type,className:b,render:x||this.$props.cellRender,onCellclick:this.cellClickHandler,onCellkeydown:this.cellKeydownHandler,onEdit:this.editHandler,onRemove:this.removeHandler,onSave:this.saveHandler,onCancel:this.cancelHandler,onChange:this.itemChange,onSelectionchange:t=>this.selectionChangeHandler({event:t,dataItem:e.dataItem,dataIndex:l,columnIndex:n}),columnIndex:n,columnsCount:this._columns.filter((e=>!e.children.length)).length,rowType:e.rowType,level:e.level,expanded:I,dataIndex:e.dataIndex,style:C,rowSpan:v,isSelected:Array.isArray(c)&&c.indexOf(n)>-1,isHighlighted:!("boolean"==typeof h||!h||!m.field||!0!==h[m.field])},null)}),this),isInEdit:s,isSelected:"boolean"==typeof c&&c,isHighlighted:"boolean"==typeof h&&h}};let Z=[];const ee=!this.currentData.length,te=e=>e>=this.currentData.length-0;let ie=0;if(this.currentData.length){const e=this._columnsMap.length+(this.$props.filterable?1:0)+1;let o=this.$props.skip||0,l=-1,n=0;const a=this.computedRowSpannable.enabled?{}:void 0;if(this.isVirtualScroll){if(G>0){const e=this.currentData.slice(0,G).filter((e=>"data"===e.rowType)).length;l+=e,o+=e}!this.$props.pageable&&L&&(l+=this.$props.skip||0)}Z=(w||this.currentData).map((function(s,d){"data"===s.rowType&&l++;const c=s.dataIndex%2!=0,h=this.$props.dataItemKey&&i.getter(this.$props.dataItemKey)(s.dataItem),p=d+o,u=h||"ai"+p,g=u+"_1",f=Q.call(this,s,u,l,c,a),m=B.length-(this.detailExpandable.enabled?1:0)-((null==k?void 0:k.length)||0)||1;return ie=p+e+n,[t.createVNode(hi,{key:u,item:s,dataIndex:l,ariaRowIndex:ie,absoluteRowIndex:p,isAltRow:c,isHidden:te(d),rowHeight:this.$props.rowHeight,isSelected:f.isSelected,isHighlighted:f.isHighlighted,isInEdit:f.isInEdit,rowType:s.rowType,onRowclick:e=>this.rowClick(e,s),onRowdblclick:e=>this.rowDoubleClick(e,s),render:this.$props.rowRender,class:this.$props.rowClass?this.$props.rowClass(s):""},{default:()=>[f.row]}),this.$props.detail&&"data"===s.rowType&&(s.expanded||s.dataItem.expanded)&&t.createVNode("tr",{key:g,class:c?"k-table-row k-table-alt-row k-detail-row":"k-table-row k-detail-row",style:{visibility:te(d)?"hidden":"",height:this.$props.detailRowHeight+"px"},role:"row","aria-rowindex":ie},[null==k?void 0:k.map((function(e){return t.createVNode(ci,{id:"",dataIndex:s.dataIndex,field:e.field,dataItem:s.dataItem,key:`group-${e.field}-${s.dataIndex}`,group:s.group},null)}),this),(this.$props.expandField||this.detailExpandable.enabled)&&t.createVNode(ut,{id:r.tableKeyboardNavigationTools.generateNavigatableId(`${g}-dhcell`,V)},null),t.createVNode(gt,{dataItem:s.dataItem,dataIndex:s.dataIndex,colSpan:m,ariaColIndex:2+(k?k.length:0),detail:this.$props.detail?this.$props.detail:void 0,id:r.tableKeyboardNavigationTools.generateNavigatableId(`${g}-dcell`,V)},null)])]}),this)}const re=this.$props.pageable&&t.createVNode(r.Pager,{class:"k-grid-pager",onPagesizechange:this.pageChangeHandler,onPagechange:this.pageChangeHandler,size:this.$props.size,total:R,skip:x||0,pageSize:(void 0!==$?$:this.$props.pageSize)||10,messagesMap:vi,settings:r.normalize(this.$props.pageable||{})},null),oe=i.getTemplate.call(this,{h:t.h,template:this.$props.pager,defaultRendering:re,additionalProps:{...this.$props,skip:this.$props.skip||0,messagesMap:vi},additionalListeners:{pagesizechange:this.pageChangeHandler,pagechange:this.pageChangeHandler}}),le=e=>v&&v.filter((t=>t.field===e)).length>0,ne=t.createVNode("colgroup",{ref:i.setRef(this,"colGroup")},[B.map((function(e,i){return t.createVNode("col",{key:i.toString(),class:le(e.field)?"k-sorted":void 0,width:void 0!==e.width?-1!==e.width.toString().indexOf("%")?e.width:Math.floor(parseFloat(e.width.toString()))+"px":void 0},null)}),this)]),ae={height:this.getCorrectHeight,...this.$attrs.style},se=this.$props.loader&&t.createVNode("div",{class:"k-loader-container k-loader-container-md k-loader-top"},[t.createVNode("div",{class:"k-loader-container-overlay k-overlay-light"},null),t.createVNode("div",{class:"k-loader-container-inner"},[t.createVNode(o.Loader,{size:"large",type:"infinite-spinner"},null)])]),de=(null!=(m=this.$props.showLoader)?m:!!this.$props.loader)&&i.getTemplate.call(this,{h:t.h,template:this.$props.loader,defaultRendering:se});return"none"===this.$props.scrollable?t.createVNode(r.TableKeyboardNavigationProvider,{ref:"navRef",id:this._gridId,navigatable:this.$props.navigatable},{default:()=>[t.createVNode(g,{ref:e=>{this.gridNavRef=e},currentData:this.currentData,id:this.$props.id,style:ae,class:this.nonscrollableWrapperClass},{default:()=>[_,j,t.createVNode("div",{role:"grid",class:"k-grid-aria-root",id:this._gridRoleElementId,"aria-colcount":this.getAriaColCount,"aria-rowcount":this.getAriaRowCount},[t.createVNode("table",{class:"k-table",style:{tableLayout:"fixed"},ref:i.setRef(this,"table"),role:"none"},[t.createTextVNode(" "),ne,P,t.createVNode("tbody",{class:"k-table-tbody","data-keyboardnavbody":!0},[Z,de]),W]),ee&&t.createVNode(fi,{id:r.tableKeyboardNavigationTools.generateNavigatableId("no-records",V)},{default:()=>[z.length?z:t.createVNode(gi,null,null)]})]),oe,K]})]}):t.createVNode(r.TableKeyboardNavigationProvider,{ref:"navRef",id:this._gridId,navigatable:this.$props.navigatable},{default:()=>[t.createVNode(g,{ref:e=>{this.gridNavRef=e},currentData:this.currentData,id:this.$props.id,style:ae,class:this.scrollableWrapperClass},{default:()=>[_,j,t.createVNode("div",{role:"grid",class:"k-grid-aria-root",id:this._gridRoleElementId,"aria-colcount":this.getAriaColCount,"aria-rowcount":this.getAriaRowCount},[P,t.createVNode("div",{class:"k-grid-container",role:"presentation"},[t.createVNode("div",{role:"presentation",ref:i.setRef(this,"scrollContainer"),class:"k-grid-content k-virtual-content",onScroll:this.scrollHandler},[t.createVNode("div",{class:"k-grid-table-wrap",role:"presentation"},[t.createVNode("table",{role:"none",class:this.gridTableClass,ref:i.setRef(this,"table")},[ne,t.createVNode("tbody",{class:"k-table-tbody",role:"rowgroup","data-keyboardnavbody":!0,ref:i.setRef(this,"tableBody")},[Z])]),ee&&t.createVNode(fi,{id:r.tableKeyboardNavigationTools.generateNavigatableId("no-records",V)},{default:()=>[z.length?z:t.createVNode(gi,null,null)]})]),!ee&&t.createVNode("div",{class:"k-height-container",role:"presentation"},[t.createVNode("div",{ref:i.setRef(this,"scrollHeightContainer"),style:"virtual"===this.$props.scrollable?{height:this._containerHeightRef+"px"}:{}},null)])]),de]),W,q]),oe,K]})]})}}),xi=t.defineComponent({name:"KendoVueGridStateProvider",inheritAttrs:!1,props:pi,setup(e,{emit:i}){var r,o,l,n,a,s,d,c,h;const p=t.ref({filter:null!=(r=e.defaultFilter)?r:e.filter,highlight:e.highlight,search:null!=(o=e.defaultSearch)?o:e.search,sort:null!=(l=e.defaultSort)?l:e.sort,take:null!=(n=e.defaultTake)?n:e.take,skip:null!=(a=e.defaultSkip)?a:e.skip,group:null!=(s=e.defaultGroup)?s:e.group,detailExpand:null!=(d=e.defaultDetailExpand)?d:e.detailExpand,groupExpand:null!=(c=e.defaultGroupExpand)?c:e.groupExpand,columnsState:null!=(h=e.defaultColumnsState)?h:e.columnsState}),u=t.computed((()=>e.filter||p.value.filter||null));t.watch((()=>e.filter),(e=>{p.value.filter=e}));const g=t.computed((()=>e.search||p.value.search||null));t.watch((()=>e.search),(e=>{p.value.search=e}));const f=t.computed((()=>e.sort||p.value.sort||[]));t.watch((()=>e.sort),(e=>{p.value.sort=e}));const m=t.computed((()=>e.skip||p.value.skip||0)),v=t.computed((()=>e.take||p.value.take||0));t.watch((()=>e.skip),(e=>{p.value.skip=e})),t.watch((()=>e.take),(e=>{p.value.take=e}));const b=t.computed((()=>e.group||p.value.group||[]));t.watch((()=>e.group),(e=>{p.value.group=e}));const C=t.computed((()=>e.detailExpand||p.value.detailExpand||{}));t.watch((()=>e.detailExpand),(e=>{p.value.detailExpand=e}));const x=t.computed((()=>e.groupExpand||p.value.groupExpand||[]));t.watch((()=>e.groupExpand),(e=>{p.value.groupExpand=e}));const $=t.computed((()=>e.columnsState||e.defaultColumnsState||[]));t.watch((()=>e.columnsState),(e=>{p.value.columnsState=e})),t.provide(bi,{sort:f,sortchange:e=>{p.value.sort=e.sort,i("sortchange",e)},filter:u,filterchange:e=>{p.value.filter=e.filter,i("filterchange",e)},search:g,searchchange:e=>{p.value.search=e.search,i("searchchange",e)},skip:m,take:v,pagechange:e=>{p.value.skip=e.page.skip,p.value.take=e.page.take,i("pagechange",e)},group:b,groupchange:e=>{p.value.group=e.group,i("groupchange",e)},detailExpand:C,detailexpandchange:e=>{p.value.detailExpand=e.detailExpand,i("detailexpandchange",e)},groupExpand:x,groupexpandchange:e=>{p.value.groupExpand=e.groupExpand,i("groupexpandchange",e)},columnsState:$,columnsstatechange:e=>{p.value.columnsState=e.columnsState,i("columnsstatechange",e)},datastatechange:e=>{p.value={...p.value,...e.data},i("datastatechange",e)}})},render(){return i.getDefaultSlots(this)}}),$i=t.defineComponent({name:"KendoVueGrid",props:pi,setup(e,{expose:i}){const r=t.ref(null);i({get element(){var e;return(null==(e=r.value)?void 0:e.element)||null},get props(){return e},get columns(){var e;return(null==(e=r.value)?void 0:e.columns)||[]},scrollIntoView:e=>{var t;null==(t=r.value)||t.scrollIntoView(e)},fitColumns:e=>{var t;null==(t=r.value)||t.fitColumns(e)},exportAsPdf:()=>{var e;null==(e=r.value)||e.exportAsPdf()}})},computed:{columnsWithTemplates(){const e=i.getListeners.call(this);return i.mapTree(this.$props.columns||[],"children",(t=>{const r={...t},o=i.templateRendering.call(this,r.cell,e),l=i.templateRendering.call(this,r.headerCell,e),n=i.templateRendering.call(this,r.filterCell,e),a=i.templateRendering.call(this,r.footerCell,e),s=i.templateRendering.call(this,r.columnMenu,e);return{...r,cell:o,headerCell:l,filterCell:n,footerCell:a,columnMenu:s}}))}},render(){const e=i.getDefaultSlots(this)||[],r=i.getListeners.call(this),o=e.filter((e=>{var t,i;return e.tag&&-1!==e.tag.toLowerCase().indexOf("toolbar")||e.componentOptions&&-1!==(null==(t=e.componentOptions.tag)?void 0:t.toLowerCase().indexOf("toolbar"))||-1!==(null==(i=null==e?void 0:e.type)?void 0:i.name.toLowerCase().indexOf("toolbar"))})),l=e.filter((e=>{var t,i;return e.tag&&-1!==e.tag.toLowerCase().indexOf("records")||e.componentOptions&&-1!==(null==(t=e.componentOptions.tag)?void 0:t.toLowerCase().indexOf("records"))||-1!==(null==(i=null==e?void 0:e.type)?void 0:i.name.toLowerCase().indexOf("records"))})),{cellRender:n,detail:a,columns:s,rowRender:d,pager:c,loader:h,...p}=this.$props,u=i.templateRendering.call(this,a,r),g=i.templateRendering.call(this,n,r),f=i.templateRendering.call(this,d,r),m=i.templateRendering.call(this,c,r),v=i.templateRendering.call(this,h,r),b=this.columnsWithTemplates;return t.createVNode(xi,p,{default:()=>[t.createVNode(Ci,t.mergeProps(p,r,{class:this.$attrs.class,style:this.$attrs.style,columns:b,cellRender:g,rowRender:f,pager:m,loader:v,detail:u,toolbar:o,noRecords:l}),null)]})}}),ki=t.defineComponent({name:"KendoGridColumnMenuFilterUI",inheritAttrs:!1,props:{firstFilterProps:Object,secondFilterProps:Object,logicValue:Object,logicData:Array,hideSecondFilter:Boolean,operators:Array,render:[String,Function,Object]},emits:{change:null,filteruifocus:null,logicChange:null},methods:{handleFocus(e){this.$emit("filteruifocus",e)},changeHandler(e,t){this.$emit("change",e,t)},logicChange(e){this.$emit("logicChange",e)}},render(){const{firstFilterProps:e,hideSecondFilter:r,secondFilterProps:o,logicData:l,logicValue:n,operators:a,render:s}=this.$props,d=e.field,c=e.value,h=e.operator,p=e.booleanValues,g=e.filterType,f=o.field,m=o.value,v=o.operator,b=o.booleanValues,C=o.filterType,x=t.createVNode("div",{style:this.$attrs.style,class:this.$attrs.class},[t.createVNode(zt,{field:d,value:c,operator:h,booleanValues:p,filterType:g,onFiltercellfocus:this.handleFocus,onChange:e=>{this.changeHandler(e,0)},operators:a},null),!r&&t.createVNode("div",null,[t.createVNode(u.DropDownList,{onChange:this.logicChange,class:"k-filter-and","data-items":l,value:n,textField:"text"},null),t.createVNode(zt,{field:f,value:m,operator:v,booleanValues:b,filterType:C,onFiltercellfocus:this.handleFocus,onChange:e=>{this.changeHandler(e,1)},operators:a},null)])]);return i.getTemplate.call(this,{h:t.h,template:s,defaultRendering:x,additionalProps:this.$props,additionalListeners:{change:this.changeHandler,logicchange:this.logicChange}})}});function Si(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}const Ii={name:"KendoGridColumnMenuCheckboxFilter",props:{column:Object,filter:Object,filterable:Boolean,filterOperators:Object,checkAllItem:[String,Object,Function],item:[String,Object,Function],expanded:{type:Boolean,default:void 0},dataItems:Array,searchBox:{type:Boolean,default:!0},uniqueData:{type:Boolean,default:!0}},data:()=>({currentExpanded:!1,currentValue:"",currentData:void 0,dataFromProps:void 0,currentFilter:void 0}),created(){this.compositeFilterIndex=this.getFilterIndex(),this.currentExpanded=this.$props.expanded,this.currentData=this.parseData(this.$props.dataItems,this.$props.uniqueData)||[],this.dataFromProps=this.parseData(this.$props.dataItems,!1)||[],this.currentFilter=this.defaultFilter()},updated(){const e=this.$props.column.field||"",t=this.$props.dataItems.map((t=>v(e,t)));((e,t)=>e.length===t.length&&e.every(((e,i)=>e===t[i])))(t,this.dataFromProps)||(this.currentData=t,this.dataFromProps=t)},inject:{kendoLocalizationService:{default:null}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){let e,r;const{column:o}=this.$props;if(!o||!o.field)return t.createVNode("div",null,null);const s=l.provideLocalizationService(this),d=void 0!==this.$props.expanded?this.$props.expanded:this.currentExpanded,c=[];if(this.currentFilter){const e=[...this.currentFilter.filters];this.compositeFilterIndex=e.findIndex((e=>!!(e.filters&&e.filters.length>0)&&e.filters[0].field===o.field)),-1!==this.compositeFilterIndex&&e[this.compositeFilterIndex].filters.length>0&&e[this.compositeFilterIndex].filters.forEach((e=>{e.field===this.$props.column.field&&c.push(e.value)}))}const h=function(){return this.$props.searchBox&&t.createVNode("span",{class:"k-list-filter"},[t.createVNode("span",{class:"k-textbox k-input k-input-md k-rounded-md k-input-solid"},[t.createVNode(i.Icon,{name:"search",icon:n.searchIcon,class:"k-input-icon"},null),t.createVNode("input",{ref:"searchBox",placeholder:s.toLanguageString(pe,ht[pe]),class:"k-input-inner",value:this.currentValue,onInput:this.handleSearchChange},null)])])},u=c.filter(((e,t)=>c.indexOf(e)===t)),g=i.templateRendering.call(this,this.$props.item,i.getListeners.call(this)),f=i.templateRendering.call(this,this.$props.checkAllItem,i.getListeners.call(this)),m=t.createVNode("li",{class:"k-item"},[t.createVNode(a.Checkbox,{label:s.toLanguageString(fe,ht[fe]),onChange:e=>this.handleCheckBoxChange(e,"all"),checked:this.isAllSelected()},null)]),v=i.getTemplate.call(this,{h:t.h,template:f,defaultRendering:m,additionalProps:{checked:this.isAllSelected()},additionalListeners:{change:e=>this.handleCheckBoxChange(e,"all")}});return t.createVNode(kt,null,{default:()=>[t.createVNode($t,{title:s.toLanguageString(ae,ht[ae]),icon:"filter",svgIcon:n.filterIcon,onMenuitemclick:this.onFilterExpand},null),t.createVNode(Vt,{show:!!d},{default:()=>[t.createVNode("div",{class:"kendo-grid-filter-menu-container"},[t.createVNode("form",{class:"k-filter-menu k-border-up",onSubmit:this.submit,onReset:this.clear},[t.createVNode("div",{class:"k-filter-menu-container"},[h.call(this),t.createVNode("ul",{class:"k-reset k-multicheck-wrap"},[v,this.currentData.map((function(e,r){const o=t.createVNode("li",{class:"k-item",key:r},[t.createVNode(a.Checkbox,{label:String(e),onChange:t=>this.handleCheckBoxChange(t,e),checked:u.includes(e)},null)]);return i.getTemplate.call(this,{h:t.h,template:g,defaultRendering:o,additionalProps:{item:e,index:r,checked:u.includes(e)},additionalListeners:{change:t=>this.handleCheckBoxChange(t,e)}})}),this)]),t.createVNode("div",{class:"k-columnmenu-actions"},[t.createVNode(p.Button,{themeColor:"primary"},Si(e=s.toLanguageString(ne,ht[ne]))?e:{default:()=>[e]}),t.createVNode(p.Button,{type:"reset"},Si(r=s.toLanguageString(re,ht[re]))?r:{default:()=>[r]})])])])])]})]})},methods:{defaultFilter(){return this.$props.filter?i.clone(this.$props.filter):{filters:[],logic:"and"}},parseData(e,t){const i=this.$props.column.field||"",r=e.map((e=>v(i,e)));return t?r.filter(((e,t)=>r.indexOf(e)===t)):r},getFilterIndex(){const e=this.$props.column.field;return this.defaultFilter().filters.findIndex((t=>t.filters&&t.filters.length>0&&t.filters[0].field===e))},onFilterExpand(){const e=void 0!==this.$props.expanded,t=!(e?this.$props.expanded:this.currentExpanded);this.$emit("expandchange",t),e||(this.currentExpanded=t)},handleSearchChange(e){const t={logic:"and",filters:[{field:this.$props.column.field,operator:"startswith",value:e.target.value,ignoreCase:!0}]};this.currentValue=e.target.value,this.currentData=this.parseData(c.filterBy(this.$props.dataItems||[],t),this.$props.uniqueData)},clear(e){e.preventDefault();const t=this.currentFilter||null;null!==t&&t.filters.length>0?(this.compositeFilterIndex>=0&&t.filters.splice(this.compositeFilterIndex,1),this.$emit("filterchange",t,e)):this.$emit("filterchange",null,e),this.$emit("closemenu")},submit(e){e.preventDefault();const t=this.currentFilter||null;this.$emit("filterchange",t,e),this.$emit("closemenu")},handleCheckBoxChange(e,t){const i=this.$props.column.field||"",r={...this.currentFilter},o=[...this.currentFilter.filters];let l=[];if(-1!==this.compositeFilterIndex&&r.filters[this.compositeFilterIndex].filters&&"all"!==t&&(l=r.filters[this.compositeFilterIndex].filters),e.value&&"all"===t)this.currentData.forEach((e=>{l.push({field:i,operator:"eq",value:e})}));else if(e.value)l.push({field:i,operator:"eq",value:t});else if(this.currentFilter){const e=l.findIndex((e=>e.value===t));l.splice(e,1)}r.logic="and",-1!==this.compositeFilterIndex?o[this.compositeFilterIndex]={logic:"or",filters:l}:o.push({logic:"or",filters:l}),(!e.value&&"all"===t||0===l.length)&&o.splice(this.compositeFilterIndex,1),r.filters=o,this.currentFilter=r},isAllSelected(){let e=!1;if(this.currentFilter){const t=[...this.currentFilter.filters];return-1!==this.compositeFilterIndex&&(e=this.currentData.every((e=>!(-1===this.compositeFilterIndex||!t[this.compositeFilterIndex].filters)&&t[this.compositeFilterIndex].filters.findIndex((t=>t.value===e))>=0)),e)}return e}}},yi=t.defineComponent({render:()=>null}),wi=t.defineComponent({name:"GridToolbar",props:{size:{type:String,validator:function(e){return["none","small","medium"].includes(e)}}},computed:{wrapperClass(){const{size:e}=this.$props;return{"k-toolbar":!0,"k-grid-toolbar":!0,"k-toolbar-solid":!0,[`k-toolbar-${i.kendoThemeMaps.sizeMap[e]||e}`]:e}}},render(){const e=i.getDefaultSlots(this);return t.createVNode("div",{class:this.wrapperClass,role:"toolbar"},[e])}}),Ni=t.defineComponent({name:"KendoVueGridSearchBox",inheritAttrs:!1,props:{onChange:Function,className:String,placeholder:String},setup(e,{emit:i}){const o=t.inject("kendoLocalizationService",{}),{searchChange:l}=t.inject("kendo",{}),{search:n}=t.inject(bi,{}),a=t.computed((()=>r.getStringFromSearch(n.value))),s=t.computed((()=>({"k-grid-search":!0,"k-searchbox":!0}))),d=t.computed((()=>{const t=o;return null!=t&&t.toLanguageString?t.toLanguageString("searchboxPlaceholder","Search..."):e.placeholder||"Search..."}));return{handleChange:t=>{l&&l(t),i("change",t),e.onChange&&e.onChange.call(void 0,t)},value:a,rootClassName:s,placeholder:d}},render(){return t.createVNode(a.TextBox,t.mergeProps({placeholder:this.placeholder,value:this.value,prefix:()=>t.createVNode(i.SvgIcon,{icon:n.searchIcon},null)},this.$attrs,{class:this.rootClassName,onInput:this.handleChange}),null)}});e.Footer=ii,e.FooterRow=ri,e.Grid=$i,e.GridCell=di,e.GridColumnMenuCheckboxFilter=Ii,e.GridColumnMenuFilter=Pt,e.GridColumnMenuFilterCell=zt,e.GridColumnMenuFilterUI=ki,e.GridColumnMenuItem=$t,e.GridColumnMenuItemContent=Vt,e.GridColumnMenuItemGroup=kt,e.GridColumnMenuSort=Rt,e.GridDetailRow=yi,e.GridEditCell=ft,e.GridFilterCell=Qt,e.GridGroupCell=ci,e.GridHeaderCell=xt,e.GridHierarchyCell=pt,e.GridNoRecords=gi,e.GridRow=hi,e.GridSearchBox=Ni,e.GridToolbar=wi,e.applyExpandedState=F,e.autoGenerateColumns=w,e.calcRowHeight=G,e.checkPropCompatibility=function(e){for(let t=0;t<$.length;t++){const i=$[t];if(void 0!==e[i]){const e="on"+i.charAt(0).toUpperCase()+i.slice(1);console.warn(k(i,e))}}},e.filterGroupByField=Kt,e.firefox=D,e.firefoxMaxHeight=L,e.flatData=b,e.footerColumns=N,e.getColSpan=H,e.getColumnWidth=e=>void 0!==e.width?Math.floor(parseFloat(e.width.toString()))+"px":void 0,e.getDataAsArray=y,e.getFlatColumnsState=A,e.getIndex=x,e.getNestedValue=v,e.getRowSpanOptions=T,e.groupedFirstItemValue=E,e.isRtl=C,e.isSorted=(e,t)=>t&&t.filter((t=>t.field===e)).length>0,e.mapColumns=S,e.parsers=R,e.readColumns=I,e.sanitizeColumns=O,e.sortGroupByField=(e,t)=>{const i=yt(e,t);return Nt(i,t)||wt(i,t)}}));
package/index.d.mts CHANGED
@@ -1977,11 +1977,10 @@ export declare interface GridFilterCellProps {
1977
1977
  * - small
1978
1978
  * - medium
1979
1979
  * - large
1980
- * - null&mdash;Does not set a size `class`.
1981
1980
  *
1982
- * @default `medium`
1981
+ * @default `undefined`
1983
1982
  */
1984
- size?: null | 'small' | 'medium' | 'large';
1983
+ size?: 'small' | 'medium' | 'large';
1985
1984
  }
1986
1985
 
1987
1986
  /**
@@ -2805,7 +2804,7 @@ export declare interface GridProps {
2805
2804
  * - small
2806
2805
  * - medium
2807
2806
  *
2808
- * @default `medium`
2807
+ * @default `undefined`
2809
2808
  */
2810
2809
  size?: 'small' | 'medium' | string;
2811
2810
  /**
@@ -3208,8 +3207,7 @@ declare type GridState = {
3208
3207
  export declare const GridToolbar: DefineComponent<ExtractPropTypes< {
3209
3208
  size: {
3210
3209
  type: PropType<string>;
3211
- default: string;
3212
- validator: (value: string) => any;
3210
+ validator: (value: string) => boolean;
3213
3211
  };
3214
3212
  }>, {}, {}, {
3215
3213
  wrapperClass(): {
@@ -3221,12 +3219,9 @@ wrapperClass(): {
3221
3219
  }, {}, ComponentOptionsMixin, ComponentOptionsMixin, {}, string, PublicProps, Readonly<ExtractPropTypes< {
3222
3220
  size: {
3223
3221
  type: PropType<string>;
3224
- default: string;
3225
- validator: (value: string) => any;
3222
+ validator: (value: string) => boolean;
3226
3223
  };
3227
- }>> & Readonly<{}>, {
3228
- size: string;
3229
- }, {}, {}, {}, string, ComponentProvideOptions, true, {}, any>;
3224
+ }>> & Readonly<{}>, {}, {}, {}, {}, string, ComponentProvideOptions, true, {}, any>;
3230
3225
 
3231
3226
  /**
3232
3227
  * The props of the GridToolbarProps component.
package/index.d.ts CHANGED
@@ -1977,11 +1977,10 @@ export declare interface GridFilterCellProps {
1977
1977
  * - small
1978
1978
  * - medium
1979
1979
  * - large
1980
- * - null&mdash;Does not set a size `class`.
1981
1980
  *
1982
- * @default `medium`
1981
+ * @default `undefined`
1983
1982
  */
1984
- size?: null | 'small' | 'medium' | 'large';
1983
+ size?: 'small' | 'medium' | 'large';
1985
1984
  }
1986
1985
 
1987
1986
  /**
@@ -2805,7 +2804,7 @@ export declare interface GridProps {
2805
2804
  * - small
2806
2805
  * - medium
2807
2806
  *
2808
- * @default `medium`
2807
+ * @default `undefined`
2809
2808
  */
2810
2809
  size?: 'small' | 'medium' | string;
2811
2810
  /**
@@ -3208,8 +3207,7 @@ declare type GridState = {
3208
3207
  export declare const GridToolbar: DefineComponent<ExtractPropTypes< {
3209
3208
  size: {
3210
3209
  type: PropType<string>;
3211
- default: string;
3212
- validator: (value: string) => any;
3210
+ validator: (value: string) => boolean;
3213
3211
  };
3214
3212
  }>, {}, {}, {
3215
3213
  wrapperClass(): {
@@ -3221,12 +3219,9 @@ wrapperClass(): {
3221
3219
  }, {}, ComponentOptionsMixin, ComponentOptionsMixin, {}, string, PublicProps, Readonly<ExtractPropTypes< {
3222
3220
  size: {
3223
3221
  type: PropType<string>;
3224
- default: string;
3225
- validator: (value: string) => any;
3222
+ validator: (value: string) => boolean;
3226
3223
  };
3227
- }>> & Readonly<{}>, {
3228
- size: string;
3229
- }, {}, {}, {}, string, ComponentProvideOptions, true, {}, any>;
3224
+ }>> & Readonly<{}>, {}, {}, {}, {}, string, ComponentProvideOptions, true, {}, any>;
3230
3225
 
3231
3226
  /**
3232
3227
  * The props of the GridToolbarProps component.
@@ -5,4 +5,4 @@
5
5
  * Licensed under commercial license. See LICENSE.md in the package root for more information
6
6
  *-------------------------------------------------------------------------------------------
7
7
  */
8
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e={name:"@progress/kendo-vue-grid",productName:"Kendo UI for Vue",productCode:"KENDOUIVUE",productCodes:["KENDOUIVUE"],publishDate: 1769676430,version:"7.1.0-develop.6",licensingDocsUrl:"https://www.telerik.com/kendo-vue-ui/my-license/"};exports.packageMetadata=e;
8
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e={name:"@progress/kendo-vue-grid",productName:"Kendo UI for Vue",productCode:"KENDOUIVUE",productCodes:["KENDOUIVUE"],publishDate: 1770355607,version:"7.1.0-develop.7",licensingDocsUrl:"https://www.telerik.com/kendo-vue-ui/my-license/"};exports.packageMetadata=e;
@@ -10,8 +10,8 @@ const e = {
10
10
  productName: "Kendo UI for Vue",
11
11
  productCode: "KENDOUIVUE",
12
12
  productCodes: ["KENDOUIVUE"],
13
- publishDate: 1769676430,
14
- version: "7.1.0-develop.6",
13
+ publishDate: 1770355607,
14
+ version: "7.1.0-develop.7",
15
15
  licensingDocsUrl: "https://www.telerik.com/kendo-vue-ui/my-license/"
16
16
  };
17
17
  export {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@progress/kendo-vue-grid",
3
- "version": "7.1.0-develop.6",
3
+ "version": "7.1.0-develop.7",
4
4
  "description": "TODO",
5
5
  "author": "Progress",
6
6
  "license": "SEE LICENSE IN LICENSE.md",
@@ -21,16 +21,16 @@
21
21
  "@progress/kendo-data-query": "^1.7.0",
22
22
  "@progress/kendo-drawing": "^1.21.1",
23
23
  "@progress/kendo-licensing": "^1.7.2",
24
- "@progress/kendo-vue-animation": "7.1.0-develop.6",
25
- "@progress/kendo-vue-buttons": "7.1.0-develop.6",
26
- "@progress/kendo-vue-common": "7.1.0-develop.6",
27
- "@progress/kendo-vue-data-tools": "7.1.0-develop.6",
28
- "@progress/kendo-vue-dateinputs": "7.1.0-develop.6",
29
- "@progress/kendo-vue-indicators": "7.1.0-develop.6",
30
- "@progress/kendo-vue-dropdowns": "7.1.0-develop.6",
31
- "@progress/kendo-vue-inputs": "7.1.0-develop.6",
32
- "@progress/kendo-vue-intl": "7.1.0-develop.6",
33
- "@progress/kendo-vue-popup": "7.1.0-develop.6",
24
+ "@progress/kendo-vue-animation": "7.1.0-develop.7",
25
+ "@progress/kendo-vue-buttons": "7.1.0-develop.7",
26
+ "@progress/kendo-vue-common": "7.1.0-develop.7",
27
+ "@progress/kendo-vue-data-tools": "7.1.0-develop.7",
28
+ "@progress/kendo-vue-dateinputs": "7.1.0-develop.7",
29
+ "@progress/kendo-vue-indicators": "7.1.0-develop.7",
30
+ "@progress/kendo-vue-dropdowns": "7.1.0-develop.7",
31
+ "@progress/kendo-vue-inputs": "7.1.0-develop.7",
32
+ "@progress/kendo-vue-intl": "7.1.0-develop.7",
33
+ "@progress/kendo-vue-popup": "7.1.0-develop.7",
34
34
  "@progress/kendo-svg-icons": "^4.4.0",
35
35
  "vue": "^3.0.2"
36
36
  },
@@ -51,7 +51,7 @@
51
51
  "package": {
52
52
  "productName": "Kendo UI for Vue",
53
53
  "productCode": "KENDOUIVUE",
54
- "publishDate": 1769676430,
54
+ "publishDate": 1770355607,
55
55
  "licensingDocsUrl": "https://www.telerik.com/kendo-vue-ui/my-license/"
56
56
  }
57
57
  },