@progress/kendo-vue-grid 8.1.0-develop.1 → 8.1.0-develop.2

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.
@@ -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:{columnsRef:Array,currentData:Array,id:String},emits:["keydown","navigationaction","keyboardselectionchange","movetonextpage","movetoprevpage","columnreorder"],inject:{onNavKeyDown:{default:i.noop},onNavFocus:{default:i.noop},onNavMount:{default:i.noop},onNavBeforeUpdate:{default:i.noop},onNavUpdate:{default:i.noop},handleDispatchFocus:{default:i.noop},kbContext:{default:null},navigation:{default:null}},mounted(){this.onNavMount({scope:this.$el||void 0})},updated(){this.onNavUpdate({scope:this.$el||void 0})},methods:{onKeyDown(e){this.onNavKeyDown(e,{navigation:this.navigation,kbContext:this.kbContext,onNavigationAction:this.onNavigationAction}),this.onNavBeforeUpdate({scope:this.$el||void 0,kbContext:this.kbContext,navigation:this.navigation}),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){const{columnsRef:t}=this.$props;if("moveToNextPage"===e.action&&this.$emit("movetonextpage",e.event),"moveToPrevPage"===e.action&&this.$emit("movetoprevpage",e.event),e.focusElement&&("reorderToRight"===e.action||"reorderToLeft"===e.action)){const i=parseInt(e.focusElement.ariaColIndex,10)-1;if(!t[i].reorderable)return;if("reorderToRight"===e.action&&i<this.$props.columnsRef.length-1){if(t[i+1].disableReorder)return;this.$emit("columnreorder",i,i+1,e.event)}if("reorderToLeft"===e.action&&i>0){if(t[i-1].disableReorder)return;this.$emit("columnreorder",i,i-1,e.event)}}"select"===e.action&&this.$emit("keyboardselectionchange",e.event),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])}}),m={filterable:!0,editable:!0,sortable:!0,resizable:!0,reorderable:!0,groupable:!0},f="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 m=0;m<t.length;m++){let f;if(!n||void 0===t[m].value||void 0===t[m].items){const r=!!c&&!(null==a||!a[i.getter(c)(t[m])]);e[e.length]={dataIndex:l.index,dataItem:t[m],rowType:"data",level:p,group:u,expanded:void 0!==h?v(h,t[m]):null!=r&&r},l.index++;continue}{let e;e=null!=u&&u.parents?[{field:u.field,value:u.value},...u.parents]:u?[u]:[],f={field:t[m].field,value:t[m].value,parents:e}}g=Math.max(g,p+1);let C=!1;const x=r.findGroupExpand(s||[],f);C=h?void 0===h||void 0===v(h,t[m])||v(h,t[m]):x?!1!==x.expanded:!1!==d,e[e.length]={dataIndex:-1,dataItem:t[m],level:p,group:f,rowType:"groupHeader",expanded:C},C&&(f.expanded=C,g=Math.max(b(e,t[m].items,o,l,n,a,s,d,c,h,p+1,f),g)),("always"===o||C&&"visible"===o)&&(e[e.length]={dataIndex:-1,dataItem:t[m],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"],S=(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 k(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((t,r)=>{i[t.depth]=i[t.depth]||[];let a=!1;0===i[t.depth].length&&(n<=1?n=1+(t.children.length>0?0:o-t.depth):(n--,a=!0)),t.rowSpan=1+(t.children.length>0?0:o-t.depth),t.kFirst=a,t.index=i[t.depth].length,t.ariaColumnIndex=l[t.depth]?l[t.depth]+1:1;let s=0;const d=[],c=new Set;let h=t.parentIndex;for(;h>=0&&!c.has(h);)c.add(h),d.unshift(h),h=e[h].parentIndex;for(let t=0;t<d.length;t++){const r=d[t],o=e[r],l=i[o.depth],n=l.indexOf(r);for(let t=0;t<n;t++){const i=l[t];s+=e[i].headerColSpan}}for(let o=0;o<t.depth;o++){const l=i[o]||[],n=(i[t.depth]||[]).indexOf(r);let a=0;for(const i of l){const r=e[i];a<n&&r.depth+r.rowSpan-1>=t.depth&&(d.includes(i)||(s+=r.headerColSpan)),a+=r.headerColSpan}}const p=i[t.depth];for(const i of p){const r=e[i];r.parentIndex===t.parentIndex&&(s+=r.headerColSpan)}t.virtualColumnOffset=s,i[t.depth].push(r);for(let e=t.depth;e<t.depth+t.rowSpan;e++)l[e]=(l[e]||0)+t.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,...m,...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 R(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,...m,field:e})})}return n}const w=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))),N={number:function(e,t,i){return typeof e===f&&"null"===e.toLowerCase()?null:t.parseNumber(e,i)},date:function(e,t,i){return typeof e===f&&"null"===e.toLowerCase()?null:t.parseDate(e,i)},boolean:function(e){return typeof e===f?"null"===e.toLowerCase()?null:"true"===e.toLowerCase():null!=e?!!e:e},string:function(e){return typeof e===f&&"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 T=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),A=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})),L=(e,t)=>"function"==typeof e.colSpan?e.colSpan({dataItem:t,column:e}):e.colSpan||1,H=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},z=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=this.$props.isSelected||v(this.$props.field,this.$props.dataItem),o="boolean"==typeof e&&e,l=this.$props.render,n=this.getKeyboardNavigationAttributes(this.$props.id),a="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:n.tabIndex,"data-keyboardnavlevel":n[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":n[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode("span",{class:"k-checkbox-wrap"},[t.createVNode("input",{checked:o,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:l,defaultRendering:a,additionalProps:this.$props,additionalListeners:{keydown:this.triggerKeydown,change:this.handleOnChange}})}}),K="grid.noRecords",M="grid.selectAllRows",j="grid.pagerInfo",B="grid.pagerFirstPage",_="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",me="grid.filterCheckAll",fe="grid.filterChooseOperator",ve="grid.filterSelectAll",be="grid.filterSelectedItems",Ce="grid.sortAriaLabel",xe="grid.sortableColumnAriaLabel",$e="grid.sortableColumnAscendingAriaLabel",Se="grid.sortableColumnDescendingAriaLabel",ke="grid.editDialogTitle",Ie="grid.editDialogSaveButtonTitle",ye="grid.editDialogCancelButtonTitle",Re="grid.filterAriaLabel",we="grid.numericFilterAriaLabel",Ne="grid.groupPanelAriaLabel",Ve="grid.groupExpand",Fe="grid.groupCollapse",Ee="grid.groupClearButton",Te="grid.groupApplyButton",De="grid.detailExpand",Ae="grid.detailCollapse",Oe="grid.selectRow",Le="grid.gridAriaLabel",He="grid.gridRowReorderAriaLabel",Ge="grid.gridAdaptiveColumnMenuFilterTitle",ze="grid.columnMenuColumnChooserTitle",Ke="grid.columnMenuColumnChooserSelectedItems",Me="grid.adaptiveColumnMenuChooserTitle",je="grid.adaptiveColumnMenuChooserSubTitle",Be="grid.columnChooserApplyButton",_e="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",[Ae]:"Collapse detail row",[Ve]:"Expand group",[Fe]:"Collapse Group",[Ee]:"Clear grouping",[Te]:"Done",[K]:"No records available",[M]:"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",[B]:"Go to the first page",[_]:"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",[me]:"Check All",[ke]:"Edit Dialog",[Ie]:"Save",[ye]:"Cancel",[fe]:"Choose Operator",[be]:"selected items",[ve]:"Select All",[xe]:"Sortable Column",[$e]:"Sorted in ascending order",[Se]:"Sorted in descending order",[Re]:"Filter",[we]:"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",[Ne]:"Group panel",[Le]:"Table",[He]:"Drag row",[Oe]:"Select Row",[ze]:"Columns Chooser",[Ge]:"Filter by",[Me]:"Columns Chooser",[je]:"Selected fields are visible",[Pe]:"Filter by",[Ke]:"Selected items",[Be]:"Apply",[_e]:"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})])}}),mt=t.defineComponent({name:"GridEditCell",inheritAttrs:!1,props:{id:String,field:String,dataItem:Object,format:String,type:String,className:String,colSpan:Number,columnType:String,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}})}}),ft=t.defineComponent({props:{staticHeaders:Boolean,headerRow:Object,columnResize:Object,cols:Array,size:String,draggable:Boolean},emits:["headerscroll"],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")},handleHeaderScroll(e){this.$emit("headerscroll",e)}},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",onScroll:this.handleHeaderScroll},[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","aria-rowindex":this.$props.key},[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])}}),St=t.defineComponent({render(){const e=i.getDefaultSlots(this);return t.createVNode("div",{class:"k-columnmenu-item-wrapper"},[e])}}),kt="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,Rt=(e,t)=>!!(t&&e>-1&&"asc"===t[e].dir),wt=(e,t)=>!!(t&&e>-1&&t[e].dir===kt),Nt=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,kt),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(St,null,{default:()=>[t.createVNode($t,{title:o.toLanguageString(se,ht[se]),icon:"sort-asc-small",svgIcon:n.sortAscSmallIcon,selected:Rt(r,e),onMenuitemclick:this.onAscClick},null),t.createVNode($t,{title:o.toLanguageString(de,ht[de]),icon:"sort-desc-small",svgIcon:n.sortDescSmallIcon,selected:wt(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"}]},Tt=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})),At=[{text:"grid.filterBooleanAll",operator:""},{text:"grid.filterIsTrue",operator:!0},{text:"grid.filterIsFalse",operator:!1}],Ot=(e,t,i)=>{const r=Lt(i.operators);let o=i.operator;switch(i.filterType){case"numeric":case"date":(!o||Tt(o))&&(o=r),null===e&&o===r&&(o="");break;case"text":(!o||Tt(o))&&(o=r),!e&&o===r&&(o="");break;default:return}return{value:e,operator:o,event:t}},Lt=(e,t)=>t?e[t][0].operator:e[0].operator,Ht=e=>e||"text",Gt=(e,t)=>({value:e,operator:""===e?"":"eq",event:t}),zt=(e,t,i)=>(Tt(e)&&(i=null),{value:i,operator:e,event:t}),Kt=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)])}}}),Mt=t.defineComponent({props:{filterType:String,operator:String,operators:Array},emits:{change:null},methods:{triggerChange(e){this.$emit("change",e)},operatorChange(e,t){const i=zt(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 Bt=e=>e||{filters:[],logic:"and"},_t=(e,t)=>Bt(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=Ht(this.$props.column.filter),i=Lt(this.$props.filterOperators,t);e=_t(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=Bt(this.$props.filter),o=_t(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=Bt(this.$props.filter),o=_t(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,m=Dt(d[c],h),f=Dt(At,h),v={field:o.field,value:g[0].value,operator:g[0].operator,booleanValues:f,filterType:c},b={field:o.field,value:g[1].value,operator:g[1].operator,booleanValues:f,filterType:c},C=this.filterGroup.logic,x=Dt(Ft,h),$={value:x.find(e=>e.operator===(null===C?"":C)),data:x},S=0!==this.currentFilterGroup().filters.length,k=this.isControlled()?this.$props.expanded:this.currentExpanded,I=v.field,y=v.value,R=v.operator,w=v.booleanValues,N=v.filterType,V=b.field,F=b.value,E=b.operator,T=b.booleanValues,D=b.filterType,A=a&&i.templateRendering.call(this,a,i.getListeners.call(this)),O=i.getTemplate.call(this,{h:t.h,template:A,defaultRendering:void 0,additionalProps:this.$props,additionalListeners:{change:this.filterChangeHandler,logicchange:this.logicChange}});return t.createVNode(St,null,{default:()=>[t.createVNode($t,{title:h.toLanguageString(ae,ht[ae]),icon:"filter",svgIcon:n.filterIcon,onMenuitemclick:this.onFilterExpand},null),t.createVNode(Vt,{show:!!k},{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(Mt,{operator:R,filterType:N,onChange:e=>{this.filterChangeHandler(e,0)},operators:m},null),t.createVNode(Kt,{field:I,value:y,operator:R,booleanValues:w,filterType:N,onFiltercellfocus:this.handleFocus,onChange:e=>{this.filterChangeHandler(e,0)},operators:m},null)],!s&&!a&&[t.createVNode(u.DropDownList,{onChange:this.logicChange,class:"k-filter-and","data-items":$.data,value:$.value,textField:"text"},null),t.createVNode(Mt,{operator:E,filterType:D,onChange:e=>{this.filterChangeHandler(e,1)},operators:m},null),t.createVNode(Kt,{field:V,value:F,operator:E,booleanValues:T,filterType:D,onFiltercellfocus:this.handleFocus,onChange:e=>{this.filterChangeHandler(e,1)},operators:m},null)],a&&O,t.createVNode("div",{class:"k-columnmenu-actions"},[t.createVNode(p.Button,{themeColor:"primary",disabled:!S},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(Nt,{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,t){const i=e[t];return!i||i.parentIndex<0?[]:[i.parentIndex,...Ut(e,i.parentIndex)]}function Yt(e,t,i){var r;const o=e[t];(null==(r=null==o?void 0:o.children)?void 0:r.length)>0&&o.children.forEach(t=>{let r="number"==typeof t?t:e.indexOf(t);r>=0&&!i.has(r)&&(i.add(r),Yt(e,r,i))})}function Xt(e){const{cellsToRender:t,columns:i,rowIndex:r,enableVirtualization:o,columnsMap:l}=e;if(!o||!t||0===t.length)return{columnsToRender:[],colSpans:[]};const n=[],a=[];let s=-1,d=-1;const c=t.reduce((e,t)=>e+t.colSpan,0);let h=[],p=[];const u=i.filter(e=>0===e.children.length),g=new Map;i.forEach((e,t)=>{if(0===e.children.length){const i=u.findIndex(t=>t===e);i>=0&&g.set(i,t)}});const m=new Set;if(t.forEach(e=>{const t=g.get(e.columnIndex);if(void 0!==t){m.add(t);const e=Ut(i,t);e.forEach(e=>m.add(e)),function(e,t,i){t.forEach(t=>{Ut(e,t).forEach(e=>i.add(e))})}(i,e,m),Yt(i,t,m),e.forEach(e=>{Yt(i,e,m)})}}),l&&Array.isArray(l)){for(let e=0;e<l.length;e++)h[e]=l[e].filter(e=>m.has(e));p=h[r]||[]}const f=function(e,t){let i=-1,r=-1;for(let o=0;o<t.length;o++)e[t[o]].locked||(-1===i&&(i=o),r=o);return{first:i,last:r}}(i,p);s=f.first,d=f.last;let v=0,b=0,C=!1;return p.forEach((e,t)=>{n.push(e);const o=i[e],u=o.headerColSpan||1;let g;if(s===d)g=c;else if(t===s){const e=o.virtualColumnOffset?o.virtualColumnOffset:0,{emptyColSpan:t,skipOffset:l}=function(e,t,i){let r=0,o=!1;if(i>0&&t)for(let l=0;l<i;l++){const n=t[l]||[];for(let t=0;t<n.length;t++){const a=e[n[t]];(a.rowSpan||1)>i-l&&(r+=a.headerColSpan||1,0===t&&(o=!0))}}return{emptyColSpan:r,skipOffset:o}}(i,h,r);b+=t,l&&(b+=e,C=!0),g=e>0&&!l?u+e:u}else if(t===d){let o=t===p.length-1;if(null!=l&&l[r]){const t=l[r],n=e;let a=-1;for(let e=t.length-1;e>=0;e--)if(!i[t[e]].locked){a=t[e];break}o=n===a}if(o)g=u;else{const e=c-v-b;if(g=Math.max(e,u),u>e&&a.length>0){const t=u-e;a[0]-=t}}}else g=u;a.push(g),v+=g}),{columnsToRender:n,colSpans:a,skipOffset:C}}function Jt(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}const Qt={none:"none",asc:"ascending",desc:"descending"},Zt={true:{asc:"desc",desc:"","":"asc"},false:{asc:"desc",desc:"asc","":"asc"}},ei=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,cellsToRender:Array,columnVirtualization:Boolean,columnsMap:Array,columnResize:Object,columnMenu:[Boolean,String,Function,Object],columnMenuAnimate:{type:[Boolean,Object],default:function(){return!0}},columnMenuIcon:Object,isRtl:Boolean,isColCountDefined:Boolean,headerSelectionValue:[Boolean,Array],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=Zt[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(){const e=l.provideLocalizationService(this),o=e.toLanguageString(xe,ht[xe]),a=e.toLanguageString($e,ht[$e]),s=e.toLanguageString(Se,ht[Se]);this.serviceIndex=0,this.index=-1;const d=this.$props.columnVirtualization,c=function(e,l){const c=Xt({cellsToRender:this.$props.cellsToRender||[],columns:this.$props.columns,rowIndex:l,enableVirtualization:d,columnsMap:this.$props.columnsMap}),h=d;let p=h&&c.columnsToRender?c.columnsToRender:e;const u=h?c.colSpans:[];return p&&0!==p.length?p.map(function(e,l){var d;const h=this.$props.columns[e],p=this.$props.sortable&&h.sortable,g=this.$props.sort?this.$props.sort.findIndex(e=>e.field===h.field):-1,m=g>=0&&this.$props.sort[g].dir||"none",f=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,g),v=h.columnMenu||!1===h.columnMenu?h.columnMenu:this.$props.columnMenu,b=h.menuIcon||this.$props.columnMenuIcon,C=(h.kFirst?"k-first ":"")+this.cellClass(h.field,h.headerClassName,h.locked)+(v?" k-filterable":""),x=v&&"boolean"!=typeof v?this.getTemplate(v):!!v,$=c.skipOffset?{borderLeftWidth:"1px"}:void 0,S=h.locked&&void 0!==h.left?this.$props.isRtl?{left:h.right+"px",right:h.left+"px"}:{left:h.left+"px",right:h.right+"px"}:$,k="none"===Qt[m]?o:"ascending"===Qt[m]?a:s;let I=h.isAccessible?{ariaSort:Qt[m],ariaLabel:k,role:"columnheader",ariaColumnIndex:this.$props.isColCountDefined?this.$props.columnsInitial.findIndex(e=>e.field===h.field)+1:void 0,ariaSelected:!1,ariaHaspopup:v?"menu":this.$props.filterable&&h.filterable?"dialog":void 0}:{role:"columnheader"};const y=h.declarationIndex>=0?++this.index:--this.serviceIndex,R=void 0!==h.columnMenuOpened?h.columnMenuOpened:this.columnMenuOpened[h.field],w=null!=(d=u[l])?d:h.headerColSpan;return t.createVNode(r.HeaderThElement,{ariaSort:p?I.ariaSort:void 0,ariaLabel:p?I.ariaLabel:void 0,role:I.role,ariaColumnIndex:I.ariaColumnIndex,ariaSelected:I.ariaSelected,ariaHaspopup:I.ariaHaspopup,key:y,colSpan:w,rowSpan:h.rowSpan,class:C,style:S,columnId:h.id,navigatable:h.navigatable,onKeydown:e=>this.cellKeyDown(e,h)},{default:()=>{var e,i;return[[0===h.children.length&&v&&t.createVNode(qt,{key:0,column:{field:h.field,filter:h.filter},opened:R,animate:this.$props.columnMenuAnimate,sortable:p,sort:this.$props.sort,onClose:this.columnMenuClose,onSortchange:this.sortChangeHandler,filter:this.$props.filter,filterable:this.$props.filterable&&h.filterable,filterOperators:this.$props.filterOperators,onFilterchange:this.filterChangeHandler,render:x,columnMenuIcon:b},null),h.internalHeaderCell&&t.createVNode("span",{class:"k-cell-inner"},[t.createVNode(h.internalHeaderCell,{key:1,field:h.field,sortable:p,onHeadercellclick:e=>this.cellClick(e,h),onSelectionchange:this.selectionChangeHandler,selectionValue:null!=(e=h.headerSelectionValue)?e:this.$props.headerSelectionValue,title:h.title,render:(h.headerCell||this.$props.cellRender)&&this.getTemplate(h.headerCell||this.$props.cellRender)},Jt(f)?f:{default:()=>[f]})])||t.createVNode("span",{class:"k-cell-inner"},[t.createVNode(xt,{key:1,field:h.field,sortable:p,onHeadercellclick:e=>this.cellClick(e,h),selectionValue:null!=(i=h.headerSelectionValue)?i:this.$props.headerSelectionValue,title:h.title,render:(h.headerCell||this.$props.cellRender)&&this.getTemplate(h.headerCell||this.$props.cellRender)},Jt(f)?f:{default:()=>[f]})]),this.$props.columnResize&&this.$props.columnResize.resizable&&h.resizable&&t.createVNode(bt,{key:2,onResize:(e,t,i)=>this.$props.columnResize&&this.$props.columnResize.dragHandler(e,h,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},Jt(r=c.call(this,e,i))?r:{default:()=>[r]})||t.createVNode("tr",{class:"k-table-row",role:"row","aria-rowindex":i+1},[c.call(this,e,i)])},this),this.$props.filterRow])}}),ti=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=zt(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(fe,ht[fe]),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 ii=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,cellsToRender:Array,columnVirtualization:Boolean,columnsMap:Array,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=Xt({cellsToRender:this.$props.cellsToRender||[],columns:this.$props.columns,rowIndex:0,enableVirtualization:this.$props.columnVirtualization,columnsMap:this.$props.columnsMap}),c=d.columnsToRender.length>0,h=this.$props.columns.filter(e=>0===e.children.length),p=c?d.columnsToRender.map(e=>this.$props.columns[e]).filter(e=>0===e.children.length):h,u=c?d.colSpans:[],g=p.map(function(i,l){const d=Ht(i.filter),h=(i.title||i.field)+" "+((e,t)=>{switch(e){case"text":return t.toLanguageString(Xe,ht[Xe]);case"numeric":return t.toLanguageString(we,ht[we]);case"boolean":return t.toLanguageString(Je,ht[Je]);case"date":return t.toLanguageString(Ye,ht[Ye]);default:return}})(d,e),p=t.createVNode(ti,{grid:this.$props.grid,field:i.field,title:i.filterTitle,value:o(i.field,"text"===d?"":null),operator:n(i.field),operators:Dt(this.$props.filterOperators[d]||[],e),booleanValues:Dt(At,e),filterType:d,onChange:e=>{this.setFilter(e.value,e.operator,i.field,e)},render:i.filterCell||this.$props.cellRender,"aria-label":h,size:this.$props.size},null),g=i.declarationIndex>=0?++s:--a,m={ariaLabel:i.filterable?e.toLanguageString(Re,ht[Re]):void 0,ariaColumnIndex:i.ariaColumnIndex},f=i.locked&&void 0!==i.left?this.$props.isRtl?{left:i.right+"px",right:i.left+"px"}:{left:i.left+"px",right:i.right+"px"}:void 0,v=c&&void 0!==u[l]?u[l]:void 0,b=t.createVNode(r.HeaderTdElement,{key:g,role:"gridcell",columnId:r.tableKeyboardNavigationTools.getFilterColumnId(i.id),navigatable:i.navigatable,style:f,class:this.headerCellClassName(i.field,i.locked)||void 0,ariaColumnIndex:m.ariaColumnIndex,"aria-label":h,colSpan:v},function(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}(p)?p:{default:()=>[p]});return i.filterable&&b||t.createVNode(r.HeaderTdElement,{key:g,role:"gridcell",columnId:r.tableKeyboardNavigationTools.getFilterColumnId(i.id),navigatable:i.navigatable,style:f,class:this.headerCellClassName(i.field,i.locked)||void 0,ariaColumnIndex:m.ariaColumnIndex,"aria-label":h,colSpan:v},null)},this);return t.createVNode("tr",{class:"k-table-row k-filter-row","aria-rowindex":this.ariaRowIndex,role:"row"},[g])}}),ri=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)])])])]})}}),oi=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(ri,{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])])])}}),li=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])}}),ni=t.defineComponent({name:"FooterRow",props:{isRtl:Boolean,columns:Array,rowIndex:Number},methods:{columnStyles(e){return e.locked&&void 0!==e.left?this.$props.isRtl?{left:e.right+"px",right:e.left+"px"}:{left:e.left+"px",right:e.right+"px"}:void 0}},render(){return t.createVNode("tr",{class:"k-table-row",role:"row","aria-rowIndex":this.$props.rowIndex},[w(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)])}}),ai=t.defineComponent({name:"GridTable",props:{selectable:Object,tableClassName:String},setup(e,{slots:i}){const{selectionRelease:o}=t.inject("kendo",{});return()=>t.createVNode(r.TableSelection,{selectable:e.selectable,onRelease:o},{default:()=>{var r;return[t.createVNode("table",{style:{tableLayout:"fixed"},role:"none",class:e.tableClassName},[null==(r=i.default)?void 0:r.call(i)])]}})}}),si=t.defineComponent({name:"GridTableScrollable",props:{selectable:Object,tableClassName:Object,tableStyle:Object},setup(e,{slots:i}){const{selectionRelease:o}=t.inject("kendo",{});return()=>{const l={...e.tableStyle};return t.createVNode(r.TableSelection,{selectable:e.selectable,onRelease:o},{default:()=>{var r;return[t.createVNode("table",{role:"none",class:e.tableClassName,style:l},[null==(r=i.default)?void 0:r.call(i)])]}})}}});let di=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),!0),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(A,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 ci{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=T(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=T(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=T(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=T(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 hi=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 pi=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])}}),ui=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)}}),gi=t.defineComponent({name:"GridCell",inheritAttrs:!1,emits:{cellclick:null,cellkeydown:null},props:{id:String,field:String,dataItem:Object,format:String,readFormat:String,className:String,columnType: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,isSelected:t,isHighlighted:i}=this.$props;return{"k-table-td":!0,"k-selected":t,"k-highlighted":i,[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,N[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}})}}),mi=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),m=l.provideLocalizationService(this).toLanguageString(Ze,ht[Ze]),f=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?m:f,"aria-label":p?m:f},[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}})}}),fi=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,dataItem:this.$props.item.dataItem},additionalListeners:{click:this.handleClick},defaultSlots:e,swapDefaultSlots:!0})}}),vi={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],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,select:Object,defaultSelect:Object,selectable:[Boolean,Object],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},bi=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(M,ht[M]),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])])}}),Ci=t.defineComponent({name:"GridNoRecords",inject:{kendoLocalizationService:{default:null}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const e=i.getDefaultSlots(this),r=l.provideLocalizationService(this).toLanguageString(K,ht[K]);return e?t.createVNode("div",null,[e]):r}}),xi=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])])}}),$i={name:"@progress/kendo-vue-grid",productName:"Kendo UI for Vue",productCode:"KENDOUIVUE",productCodes:["KENDOUIVUE"],publishDate:0,version:"8.1.0-develop.1",licensingDocsUrl:"https://www.telerik.com/kendo-vue-ui/my-license/"};function Si(e){const t=e.replace(/^pager\.([a-z])/,(e,t)=>"grid.pager"+t.toUpperCase());return{messageKey:t,defaultMessage:ht[t]}}const ki=Symbol("kendoKey"),Ii=t.defineComponent({name:"KendoGrid",inheritAttrs:!1,props:{...vi,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($i),this.showLicenseWatermark=i.shouldShowValidationUI($i),this.licenseMessage=i.getLicenseMessage($i),this.initialHeight=null,this.columnsRef=[],this.vsRef=new di,this.dragLogic=new hi(this.columnReorder.bind(this),this.groupReorder.bind(this),this.columnToGroup.bind(this)),this.columnResize=new ci(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 H(this.$props.rowSpannable)},computedSelectable(){return r.getSelectionOptions(this.$props.selectable)},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.columnsRef.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.columnsRef.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:{getTotal(){let e=this.$props.total||0;return Array.isArray(this.$props.dataItems)?e=e||this.$props.dataItems.length:this.$props.dataItems&&(e=e||this.$props.dataItems.total),e},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.columnsRef.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.columnsRef=[],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.getComponentElementRef(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()},onHeaderScroll(e){const t=e.target.scrollLeft,r=i.getRef(this,"scrollContainer");r&&(r.scrollLeft=t),this.scrollLeftRef=t},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){var t;if(this.computedSelectable.enabled){const{event:i,dataItem:o,dataIndex:l,columnIndex:n}=e,a={...this.getArguments(i),dataItem:o,startColIndex:n,endColIndex:n,startRowIndex:l,endRowIndex:l,dataItems:this.getLeafDataItems(),altKey:!1,ctrlKey:!1,shiftKey:!1,metaKey:!1,mode:this.computedSelectable.mode,cell:this.computedSelectable.cell,isDrag:!1,componentId:this.$props.id||this._gridId,selectedField:this.$props.selectedField||""};this.gridContext.selectionchange({...a,select:this.$props.dataItemKey?r.getSelectedState({event:a,selectedState:null!=(t=this.$props.select)?t:{},dataItemKey:this.$props.dataItemKey}):{}})}},onKeyboardSelectionChangeHandler(e){var t,i;if(!this.computedSelectable.enabled||!this.$props.dataItemKey)return;const o=null==(t=this.gridContext.select)?void 0:t.value,l={dataItems:this.getLeafDataItems(),mode:this.computedSelectable.mode,cell:this.computedSelectable.cell,componentId:this.$props.id,selectedField:"",...this.getArguments(e)},n=r.getSelectedStateFromKeyDown({event:l,selectedState:null!=o?o:{},dataItemKey:this.$props.dataItemKey});if(n===o)return;const a=e.target,s=r.closestTagName(a,"TD"),d=r.closestTagName(a,"TR"),c=r.getColumnIndex(s),h=r.getRowIndex(d);if(void 0!==c&&void 0!==h){const t=null==(i=y(this.$props.dataItems))?void 0:i[h];this.gridContext.selectionchange({...l,select:n,dataItem:t,startRowIndex:h,startColIndex:c,startDataItem:t,endDataItem:t,endRowIndex:h,endColIndex:c,ctrlKey:e.ctrlKey,altKey:e.altKey,metaKey:e.metaKey,shiftKey:e.shiftKey,isDrag:!1})}},onHeaderSelectionChangeHandler(e){if(this.computedSelectable.enabled){const t=this.getLeafDataItems();this.gridContext.headerselectionchange({select:e.event.target.checked?t.reduce((e,t)=>(this.$props.dataItemKey&&void 0!==i.getter(this.$props.dataItemKey)(t)&&(e[i.getter(this.$props.dataItemKey)(t)]=!0),e),{}):{},field:e.field,event:e.event,target:this,dataItems:t})}},selectionRelease(e){var t;if(this.computedSelectable.enabled){const i=this.getLeafDataItems(),o=i[e.startRowIndex],l=i[e.endRowIndex],n={event:void 0,target:this,selectedField:"",componentId:this.$props.id||this._gridId,dataItems:i,dataItem:null,startDataItem:o,endDataItem:l,...e},a=r.getSelectedState({event:n,selectedState:null!=(t=this.$props.select)?t:{},dataItemKey:this.$props.dataItemKey});this.raiseSelectionEvent(n,a)}},clearSelection(e){this.computedSelectable.enabled&&this.raiseSelectionEvent(e,{})},raiseSelectionEvent(e,t){this.computedSelectable.enabled&&this.gridContext.selectionchange({...e,select:t})},moveToNextPage(e){var t,i,r,o;const l=null!=(r=null!=(i=null==(t=this.gridContext.take)?void 0:t.value)?i:this.$props.pageSize)?r:0,n=((null==(o=this.gridContext.skip)?void 0:o.value)||0)+l;n<this.getTotal()&&this.pageChangeHandler({skip:n,take:l},e)},moveToPrevPage(e){var t,i,r,o;const l=null!=(r=null!=(i=null==(t=this.gridContext.take)?void 0:t.value)?i:this.$props.pageSize)?r:0,n=((null==(o=this.gridContext.skip)?void 0:o.value)||0)-l;n>=0&&this.pageChangeHandler({skip:n,take:l},e)},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.gridContext.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.gridContext.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.columnsRef[e],l=T(this.currentColumnsState),n=o.depth,a=e=>{do{e++}while(e<this.columnsRef.length&&this.columnsRef[e].depth>n);return e},s=this.columnsRef.splice(e,a(e)-e);this.columnsRef.splice(e<t?a(t-s.length):t,0,...s),this.columnsRef.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.columnsRef[e].locked&&this.columnsRef[t].locked;r.updateLeft(this._columnsMap,this.columnsRef,d||this.shouldUpdateLeftRightRef),r.updateRight(this._columnsMap,this.columnsRef,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.columnsRef[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.getComponentElementRef(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.internalCell=t.markRaw(z),e.internalHeaderCell=t.markRaw(bi),e._type="edit",e.columnMenu=!1}),this.$props.selectedField&&this.columnsRef.filter(e=>e.field===this.$props.selectedField).forEach(e=>{e.width=e.width||"50px",e.internalCell=t.markRaw(z),e.internalHeaderCell=t.markRaw(bi),e.columnMenu=!1});const l=T(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(mi),internalCell:t.markRaw(mi),id:r.tableKeyboardNavigationTools.generateNavigatableId(""+a++,"group","column"),field:"value",locked:this.$props.lockGroups,columnMenu:!1};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?H(e.rowSpannable):this.computedRowSpannable})},initColumns(e,t){var i;this.columnsRef=this.readColumnElements();const r=null==(i=this.gridContext.group)?void 0:i.value;0===this.columnsRef.filter(e=>!e.hidden).length&&(this.columnsRef=R(e,r,{column:this.$props.expandField?this.$props.expandField:this.groupExpandable.column},{prevId:0,idPrefix:this.idPrefix})),this.configureColumns(this.columnsRef,t);const[o,l]=this.filterColumns(this.columnsRef);this.columnsRef=o,this.hiddenColumnsRef=l,this._columnsMap=k(this.columnsRef,!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.columnsRef.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(L(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,selectionRelease:this.selectionRelease,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(ki,{}),shouldUpdateLeftRightRef:p,resizedRef:u,currentColumnsState:e.columnsState}},render(){var e,l,n,a,s,d,h,p,u,m,f,v,b,C,x,$,S;const k=null==(e=this.gridContext.sort)?void 0:e.value,I=null==(l=this.gridContext.filter)?void 0:l.value,y=null==(n=this.gridContext.search)?void 0:n.value,R=null==(a=this.gridContext.select)?void 0:a.value,w=null==(s=this.gridContext.skip)?void 0:s.value,N=null==(d=this.gridContext.take)?void 0:d.value,V=null==(h=this.gridContext.group)?void 0:h.value,T=null==(p=this.gridContext.groupExpand)?void 0:p.value,D=null==(u=this.gridContext.detailExpand)?void 0:u.value,A=!(null==V||!V.length);let O;this.currentColumnsState=null==(m=this.gridContext.columnsState)?void 0:m.value;const L=!0===this.$props.autoProcessData?{group:!0,sort:!0,filter:!0,search:!0,page:!0}:this.$props.autoProcessData;let H;const G=r.tableKeyboardNavigationTools.getIdPrefix(this.navigation);let z=[];Array.isArray(this.$props.dataItems)?(z=this.$props.dataItems,H=null!=(f=this.$props.total)?f:z.length):(z=(null==(v=F(this.$props.dataItems,this.$props.collapsedGroups.length?this.computedCollapsed:[],this.$props.uniqueField))?void 0:v.data)||[],H=null!=(x=null!=(C=this.$props.total)?C:null==(b=this.$props.dataItems)?void 0:b.total)?x:z.length);const K=!0===this.$props.groupable||i.isObject(this.$props.groupable)&&!1!==this.$props.groupable.enabled;this.dragLogic.reorderable=this.$props.reorderable||!1,this.dragLogic.groupable=K,this._virtualPageSize=this.calcVirtualPageSize();const M=z.length===H,j=i.isObject(this.$props.groupable)&&this.$props.groupable.footer||"none";if(this.currentData=[],L){const e=L.page&&!(this.isVirtualScroll&&!this.$props.pageable),{data:t,total:i}=c.process(z,{group:L.group?V:void 0,sort:L.sort?k:void 0,filter:r.combineFilters(L.filter?I:void 0,L.search?y:void 0),...e?{take:this.$props.pageable?N||10:N,skip:w||0}:{}});z=t,H=null!=($=this.$props.total)?$:i}const{resolvedGroupsCount:B,flattedData:_}=this.getFlatData(z,j,M?0:this.$props.skip||0,V,D,T,this.$props.dataItemKey);this.currentData=_;const P=this._virtualSkipRef||0;if(this._virtualTotal=H,this.isVirtualScroll){let e=w||0;if((A||this.$props.pageable)&&(e=P,this._virtualTotal=this.currentData.length),M||A||this.$props.pageable)if(0===this._virtualPageSize){const t=Math.min(N||this.$props.pageSize||20,this.currentData.length);O=this.currentData.slice(e,e+t)}else O=this.currentData.slice(e,e+this._virtualPageSize)}this.initializeVirtualization();const W=null!=(S=this.selectable)&&S.drag?"none":void 0;this.initColumns(this.$props.dataItems,B),this.columnResize.resizable=this.$props.resizable||!1,this.columnResize.columns=this.columnsRef,this.columnResize.columnsState=i.cloneArray(this.currentColumnsState||[]),this.dragLogic.columns=this.columnsRef;const q=this.$props.toolbar,U=this.$props.noRecords,Y=this.columnsRef.filter(e=>0===e.children.length),X=K&&t.createVNode(oi,{ref:e=>{this.groupPanelDivRef=e},group:V||[],ariaControls:this._gridRoleElementId,onGroupChange:this.groupChangeHandler,onPressHandler:this.dragLogic.pressHandler,onDragHandler:this.dragLogic.dragHandler,onReleaseHandler:this.dragLogic.releaseHandler,resolveTitle:this.resolveTitle},null),J=(this.dragLogic.reorderable||this.dragLogic.groupable)&&i.canUseDOM&&document&&document.body,Q=[J&&t.createVNode(ui,{ref:e=>{this.dropElementClueRef=e}},null),J&&t.createVNode(pi,{ref:e=>{this.dragElementClueRef=e}},null)],Z=this.showLicenseWatermark?t.createVNode(i.WatermarkOverlay,{message:this.licenseMessage},null):null,ee=this.$attrs.style,te=ee&&i.isObject(ee)&&ee.width||"";this.tableWidth=parseFloat(te.toString());const ie=Y.findIndex(e=>"function"==typeof e.colSpan)>-1;let re;re=this.getCellsToRender({},Y);const oe=(this.$props.columnVirtualization?this.getCellsToRender({},Y).map(({columnIndex:e})=>Y[e]):Y).map(function(e,i){return t.createVNode("col",{key:e.id||`col-${i}`,width:void 0!==e.width?Math.floor(parseFloat(e.width.toString())):void 0},null)},this),le=t.createVNode(ft,{size:this.$props.size,columnResize:this.columnResize,staticHeaders:"none"!==this.$props.scrollable,ref:e=>{this.headerRef=e},onHeaderscroll:this.onHeaderScroll,headerRow:t.createVNode(ei,{grid:this,sort:k,groupable:this.$props.groupable,reorderable:this.$props.reorderable,sortable:this.$props.sortable,onSortChange:this.sortChangeHandler,filter:I,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.columnsRef,cellsToRender:re,columnVirtualization:this.$props.columnVirtualization,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,headerSelectionValue:!(!R||!this.currentData.filter(e=>"data"===e.rowType).every(e=>R&&this.$props.dataItemKey&&void 0!==i.getter(this.$props.dataItemKey)(e.dataItem)?R[i.getter(this.$props.dataItemKey)(e.dataItem)]:void 0)),filterRow:this.$props.filterable&&t.createVNode(ii,{grid:this,size:this.$props.size,columns:this.columnsRef,columnsMap:this._columnsMap,cellsToRender:re,columnVirtualization:this.$props.columnVirtualization,filter:I,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:oe},null),ne=this.columnsRef.some(e=>!!e.footerCell)?t.createVNode(li,{size:this.$props.size,columnResize:this.columnResize,staticHeaders:"none"!==this.$props.scrollable,ref:e=>{this.footerRef=e},row:t.createVNode(ni,{isRtl:this.isRtl,rowIndex:this.getAriaRowCount+1,columns:this.columnsRef},null),cols:oe},null):t.createVNode("span",null,null),ae=function(e,o,l,n,a){let s=!1;const d=this.$props.selectedField,c=this.$props.dataItemKey,h=R&&c&&void 0!==i.getter(c)(e.dataItem)?R[i.getter(c)(e.dataItem)]:void 0,p=d?i.getNestedValue(d,e.dataItem):h,u=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 ie&&(re=this.getCellsToRender(e.dataItem,Y)),{row:re.map(function({columnIndex:n,colSpan:d}){var c,h,g,m;const f=Y[n];let v;if(null!=(c=f.rowSpannable)&&c.enabled&&"data"===e.rowType&&f.field&&a){const t=f.field?null==(g=(h=f.rowSpannable).valueGetter)?void 0:g.call(h,e.dataItem,f.field):null;v={value:t,count:1},a[f.field]&&(null==(m=a[f.field])?void 0:m.value)===t&&null!==a[f.field]?(a[f.field].count++,v.count=null):a[f.field]=v}const b=`${f.className?f.className+" ":""}${f.locked?"k-grid-content-sticky":""}`,C=f.locked&&void 0!==f.left?this.isRtl?{left:f.right+"px",right:f.left+"px"}:{left:f.left+"px",right:f.right+"px"}:void 0;let x,$=!1;if(f.editable&&this.$props.editField){const t=i.getNestedValue(this.$props.editField,e.dataItem);(!0===t||t===f.field)&&(s=!0,$=!0)}f.cell&&(x=f.cell);const S=this.computedCollapsed&&this.computedCollapsed[e.level]&&this.computedCollapsed[e.level].some(t=>t===E(e.dataItem,this.$props.uniqueField)),k=f.id?f.id:n,I=S?!S:e.expanded||e.dataItem.expanded,y="expand"===f._type,R=r.tableKeyboardNavigationTools.generateNavigatableId(`${o}-${String(n)}`,G,y||"groupHeader"===e.rowType||"groupFooter"===e.rowType||"value"===f.field?"nodata":"cell");return f.internalCell?t.createVNode(f.internalCell,{key:k,id:R,colSpan:d,dataItem:e.dataItem,field:f.field||"",editor:f.editor,format:f.format,readFormat:f.readFormat,type:f.type,columnType:f.columnType,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.columnsRef.filter(e=>!e.children.length).length,rowType:e.rowType,level:e.level,expanded:I,dataIndex:e.dataIndex,style:C,ariaColumnIndex:f.ariaColumnIndex,isRtl:this.isRtl,isSelected:!!("edit"===(null==f?void 0:f._type)?p:Array.isArray(p)&&p.indexOf(n)>-1),isHighlighted:!("boolean"==typeof u||!u||!f.field||!0!==u[f.field]),group:e.group,rowSpan:v},null):$?t.createVNode(mt,{id:R,key:k,colSpan:d,dataItem:e.dataItem,field:f.field||"",editor:f.editor,format:f.format,readFormat:f.readFormat,type:f.type,columnType:f.columnType,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.columnsRef.filter(e=>!e.children.length).length,rowType:e.rowType,level:e.level,expanded:I,dataIndex:e.dataIndex,style:C},null):t.createVNode(gi,{key:k,id:R,colSpan:d,dataItem:e.dataItem,field:f.field||"",editor:f.editor,format:f.format,readFormat:f.readFormat,type:f.type,columnType:f.columnType,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.columnsRef.filter(e=>!e.children.length).length,rowType:e.rowType,level:e.level,expanded:I,dataIndex:e.dataIndex,style:C,rowSpan:v,isSelected:!!("edit"===(null==f?void 0:f._type)?p:Array.isArray(p)&&p.indexOf(n)>-1),isHighlighted:!("boolean"==typeof u||!u||!f.field||!0!==u[f.field])},null)},this),isInEdit:s,isSelected:"boolean"==typeof p&&p,isHighlighted:"boolean"==typeof u&&u}};let se=[];const de=!this.currentData.length,ce=e=>e>=this.currentData.length-0;let he=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(P>0){const e=this.currentData.slice(0,P).filter(e=>"data"===e.rowType).length;l+=e,o+=e}!this.$props.pageable&&M&&(l+=this.$props.skip||0)}se=(O||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",m=ae.call(this,s,u,l,c,a),f=Y.length-(this.detailExpandable.enabled?1:0)-((null==V?void 0:V.length)||0)||1;return he=p+e+n,[t.createVNode(fi,{key:u,item:s,dataIndex:l,ariaRowIndex:he,absoluteRowIndex:p,isAltRow:c,isHidden:ce(d),rowHeight:this.$props.rowHeight,isSelected:m.isSelected,isHighlighted:m.isHighlighted,isInEdit:m.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:()=>[m.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:ce(d)?"hidden":"",height:this.$props.detailRowHeight+"px"},role:"row","aria-rowindex":he},[null==V?void 0:V.map(function(e){return t.createVNode(mi,{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`,G)},null),t.createVNode(gt,{dataItem:s.dataItem,dataIndex:s.dataIndex,colSpan:f,ariaColIndex:2+(V?V.length:0),detail:this.$props.detail?this.$props.detail:void 0,id:r.tableKeyboardNavigationTools.generateNavigatableId(`${g}-dcell`,G)},null)])]},this)}const pe=this.$props.pageable&&t.createVNode(r.Pager,{class:"k-grid-pager",onPagesizechange:this.pageChangeHandler,onPagechange:this.pageChangeHandler,size:this.$props.size,total:H,skip:w||0,pageSize:(void 0!==N?N:this.$props.pageSize)||10,messagesMap:Si,settings:r.normalize(this.$props.pageable||{})},null),ue=i.getTemplate.call(this,{h:t.h,template:this.$props.pager,defaultRendering:pe,additionalProps:{...this.$props,skip:this.$props.skip||0,messagesMap:Si},additionalListeners:{pagesizechange:this.pageChangeHandler,pagechange:this.pageChangeHandler}}),ge=e=>k&&k.filter(t=>t.field===e).length>0,me=t.createVNode("colgroup",{ref:i.setRef(this,"colGroup")},[Y.map(function(e,i){return t.createVNode("col",{key:e.id||`col-${i}`,class:ge(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)]),fe={height:this.getCorrectHeight,...this.$attrs.style},ve=t.createVNode("div",{class:"k-loading-mask"},[t.createVNode("div",{class:"k-loading-color"},null),t.createVNode("div",{style:{height:"100%",display:"flex",justifyContent:"center",alignItems:"center"}},[t.createVNode(o.Loader,{size:"large",type:"converging-spinner"},null)])]),be=this.$props.showLoader&&i.getTemplate.call(this,{h:t.h,template:this.$props.loader,defaultRendering:ve});return"none"===this.$props.scrollable?t.createVNode(r.TableKeyboardNavigationProvider,{ref:"navRef",id:this._gridId,navigatable:this.$props.navigatable,scrollable:this.$props.scrollable,columnVirtualization:this.$props.columnVirtualization},{default:()=>[t.createVNode(g,{ref:e=>{this.gridNavRef=e},columnsRef:this.columnsRef,currentData:this.currentData,id:this.$props.id,style:fe,class:this.nonscrollableWrapperClass,onMovetonextpage:this.moveToNextPage,onMovetoprevpage:this.moveToPrevPage,onColumnreorder:this.columnReorder,onKeyboardselectionchange:this.onKeyboardSelectionChangeHandler},{default:()=>[q,X,t.createVNode("div",{role:"grid",class:"k-grid-aria-root",id:this._gridRoleElementId,"aria-colcount":this.getAriaColCount,"aria-rowcount":this.getAriaRowCount},[t.createVNode(ai,{selectable:this.computedSelectable,class:"k-table",ref:i.setRef(this,"table")},{default:()=>[me,le,t.createVNode("tbody",{class:"k-table-tbody","data-keyboardnavbody":!0},[se,t.createTextVNode(" "),be]),ne]}),de&&t.createVNode(xi,{id:r.tableKeyboardNavigationTools.generateNavigatableId("no-records",G)},{default:()=>[U.length?U:t.createVNode(Ci,null,null)]})]),ue,be,Q]})]}):t.createVNode(r.TableKeyboardNavigationProvider,{ref:"navRef",id:this._gridId,navigatable:this.$props.navigatable,scrollable:this.$props.scrollable,columnVirtualization:this.$props.columnVirtualization},{default:()=>[t.createVNode(g,{ref:e=>{this.gridNavRef=e},currentData:this.currentData,id:this.$props.id,style:fe,class:this.scrollableWrapperClass,onMovetonextpage:this.moveToNextPage,onMovetoprevpage:this.moveToPrevPage,onColumnreorder:this.columnReorder,onKeyboardselectionchange:this.onKeyboardSelectionChangeHandler},{default:()=>[q,X,t.createVNode("div",{role:"grid",class:"k-grid-aria-root",id:this._gridRoleElementId,"aria-colcount":this.getAriaColCount,"aria-rowcount":this.getAriaRowCount},[le,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(si,{selectable:this.computedSelectable,tableClassName:this.gridTableClass,tableStyle:{userSelect:W},ref:i.setRef(this,"table")},{default:()=>[me,t.createVNode("tbody",{class:"k-table-tbody",role:"rowgroup","data-keyboardnavbody":!0,ref:i.setRef(this,"tableBody")},[se])]}),de&&t.createVNode(xi,{id:r.tableKeyboardNavigationTools.generateNavigatableId("no-records",G)},{default:()=>[U.length?U:t.createVNode(Ci,null,null)]})]),!de&&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)])])]),ne,Z]),ue,be,Q]})]})}}),yi=t.defineComponent({name:"KendoVueGridStateProvider",inheritAttrs:!1,props:vi,setup(e,{emit:i}){var r,o,l,n,a,s,d,c,h,p;const u=t.ref({filter:null!=(r=e.defaultFilter)?r:e.filter,highlight:e.highlight,select:null!=(o=e.defaultSelect)?o:e.select,search:null!=(l=e.defaultSearch)?l:e.search,sort:null!=(n=e.defaultSort)?n:e.sort,take:null!=(a=e.defaultTake)?a:e.take,skip:null!=(s=e.defaultSkip)?s:e.skip,group:null!=(d=e.defaultGroup)?d:e.group,detailExpand:null!=(c=e.defaultDetailExpand)?c:e.detailExpand,groupExpand:null!=(h=e.defaultGroupExpand)?h:e.groupExpand,columnsState:null!=(p=e.defaultColumnsState)?p:e.columnsState}),g=t.computed(()=>e.filter||u.value.filter||null);t.watch(()=>e.filter,e=>{u.value.filter=e});const m=t.computed(()=>e.search||u.value.search||null);t.watch(()=>e.search,e=>{u.value.search=e});const f=t.computed(()=>e.select||u.value.select||null),v=t.computed(()=>e.sort||u.value.sort||[]);t.watch(()=>e.sort,e=>{u.value.sort=e});const b=t.computed(()=>e.skip||u.value.skip),C=t.computed(()=>e.take||u.value.take);t.watch(()=>e.skip,e=>{u.value.skip=e}),t.watch(()=>e.take,e=>{u.value.take=e});const x=t.computed(()=>e.group||u.value.group||[]);t.watch(()=>e.group,e=>{u.value.group=e});const $=t.computed(()=>e.detailExpand||u.value.detailExpand||{});t.watch(()=>e.detailExpand,e=>{u.value.detailExpand=e});const S=t.computed(()=>e.groupExpand||u.value.groupExpand||[]);t.watch(()=>e.groupExpand,e=>{u.value.groupExpand=e});const k=t.computed(()=>e.columnsState||e.defaultColumnsState||[]);t.watch(()=>e.columnsState,e=>{u.value.columnsState=e}),t.provide(ki,{sort:v,sortchange:e=>{u.value.sort=e.sort,i("sortchange",e)},filter:g,filterchange:e=>{u.value.filter=e.filter,i("filterchange",e)},search:m,searchchange:e=>{u.value.search=e.search,u.value.skip=0,i("searchchange",e)},skip:b,take:C,pagechange:e=>{u.value.skip=e.page.skip,u.value.take=e.page.take,i("pagechange",e)},select:f,selectionchange:e=>{u.value.select=e.select,i("selectionchange",e)},headerselectionchange:e=>{u.value.select=e.select,i("headerselectionchange",e)},group:x,groupchange:e=>{u.value.group=e.group,i("groupchange",e)},detailExpand:$,detailexpandchange:e=>{u.value.detailExpand=e.detailExpand,i("detailexpandchange",e)},groupExpand:S,groupexpandchange:e=>{u.value.groupExpand=e.groupExpand,i("groupexpandchange",e)},columnsState:k,columnsstatechange:e=>{u.value.columnsState=e.columnsState,i("columnsstatechange",e)},datastatechange:e=>{u.value={...u.value,...e.data},i("datastatechange",e)}})},render(){return i.getDefaultSlots(this)}}),Ri=t.defineComponent({name:"KendoVueGrid",props:vi,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=!1!==r.columnMenu&&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),m=i.templateRendering.call(this,d,r),f=i.templateRendering.call(this,c,r),v=i.templateRendering.call(this,h,r),b=this.columnsWithTemplates;return t.createVNode(yi,p,{default:()=>[t.createVNode(Ii,t.mergeProps(p,r,{class:this.$attrs.class,style:this.$attrs.style,columns:b,cellRender:g,rowRender:m,pager:f,loader:v,detail:u,toolbar:o,noRecords:l}),null)]})}}),wi=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,m=o.field,f=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(Kt,{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(Kt,{field:m,value:f,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 Ni(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}const Vi={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)),m=i.templateRendering.call(this,this.$props.checkAllItem,i.getListeners.call(this)),f=t.createVNode("li",{class:"k-item"},[t.createVNode(a.Checkbox,{label:s.toLanguageString(me,ht[me]),onChange:e=>this.handleCheckBoxChange(e,"all"),checked:this.isAllSelected()},null)]),v=i.getTemplate.call(this,{h:t.h,template:m,defaultRendering:f,additionalProps:{checked:this.isAllSelected()},additionalListeners:{change:e=>this.handleCheckBoxChange(e,"all")}});return t.createVNode(St,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"},Ni(e=s.toLanguageString(ne,ht[ne]))?e:{default:()=>[e]}),t.createVNode(p.Button,{type:"reset"},Ni(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}}},Fi=t.defineComponent({render:()=>null}),Ei=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])}}),Ti=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(ki,{}),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.Icon,{name:"search",icon:n.searchIcon},null)},this.$attrs,{wrapperClass:"k-grid-search k-searchbox",onInput:this.handleChange}),null)}}),Di=t.defineComponent({name:"KendoVueGridStatusBar",props:{data:{type:Array,default:()=>[]}},setup:e=>()=>t.createVNode("div",{class:"k-selection-aggregates k-grid-selection-aggregates"},[e.data.map((e,i)=>t.createVNode("div",{key:`${e.type}-${i}`},[t.createVNode("span",{class:"k-selection-aggregates-item-text"},[e.type,t.createTextVNode(": ")]),t.createVNode("span",{class:"k-selection-aggregates-item-value"},[e.formattedValue])]))])}),Ai=e=>{var t,i,r,o;const l=e.slice();for(let e=0;e<l.length;e++)for(;null!=(i=null==(t=l[e])?void 0:t.children)&&i.length;)l.splice(e,1,...null!=(o=null==(r=l[e])?void 0:r.children)?o:[]);return l};e.Footer=li,e.FooterRow=ni,e.Grid=Ri,e.GridCell=gi,e.GridColumnMenuCheckboxFilter=Vi,e.GridColumnMenuFilter=Pt,e.GridColumnMenuFilterCell=Kt,e.GridColumnMenuFilterUI=wi,e.GridColumnMenuItem=$t,e.GridColumnMenuItemContent=Vt,e.GridColumnMenuItemGroup=St,e.GridColumnMenuSort=Nt,e.GridDetailRow=Fi,e.GridEditCell=mt,e.GridFilterCell=ti,e.GridGroupCell=mi,e.GridHeaderCell=xt,e.GridHierarchyCell=pt,e.GridNoRecords=Ci,e.GridRow=fi,e.GridSearchBox=Ti,e.GridToolbar=Ei,e.StatusBar=Di,e.applyExpandedState=F,e.autoGenerateColumns=R,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(S(i,e))}}},e.filterGroupByField=_t,e.firefox=D,e.firefoxMaxHeight=A,e.flatData=b,e.footerColumns=w,e.getColSpan=L,e.getColumnWidth=e=>void 0!==e.width?Math.floor(parseFloat(e.width.toString()))+"px":void 0,e.getDataAsArray=y,e.getFlatColumnsState=T,e.getIndex=x,e.getNestedValue=v,e.getRowSpanOptions=H,e.getStatusData=e=>{const{dataItems:t,target:r}=e,o=Ai(r.columns).map(e=>e.field).filter(e=>e&&"string"==typeof e).map(e=>i.getter(e)),l={dates:[],numbers:[],booleans:[],others:[]};t.forEach(t=>{const r=(t=>{var r;return null==(r=e.select)?void 0:r[i.getter(e.dataItemKey)(t)]})(t);Array.isArray(r)&&r.forEach(e=>{(e=>{"number"==typeof e?l.numbers.push(e):"boolean"==typeof e?l.booleans.push(e):e instanceof Date?l.dates.push(e):l.others.push(e)})(o[e](t))})});const n=l.dates.map(e=>e.getTime()),a=l.booleans.filter(Boolean).length,s=l.booleans.length-a,d=l.numbers.length?l.numbers.reduce((e,t)=>e+t,0):void 0,c={sum:d,average:"number"==typeof d?d/l.numbers.length:void 0,min:l.numbers.length?Math.min(...l.numbers):void 0,max:l.numbers.length?Math.max(...l.numbers):void 0,count:l.numbers.length+l.booleans.length+l.dates.length+l.others.length,isTrue:a>0?a:void 0,isFalse:s>0?s:void 0,earliest:l.dates.length?new Date(Math.min(...n)):void 0,latest:l.dates.length?new Date(Math.max(...n)):void 0},h=(e,t)=>"sum"!==t&&"average"!==t||"number"!=typeof e?("earliest"===t||"latest"===t)&&e instanceof Date?e.toLocaleDateString():String(e):e.toFixed(2),p=[];return Object.keys(c).forEach(e=>{const t=e,i=c[t];void 0!==i&&p.push({type:t,value:i,formattedValue:h(i,t)})}),p},e.groupedFirstItemValue=E,e.isRtl=C,e.isSorted=(e,t)=>t&&t.filter(t=>t.field===e).length>0,e.leafColumns=Ai,e.mapColumns=k,e.parsers=N,e.readColumns=I,e.sanitizeColumns=O,e.sortGroupByField=(e,t)=>{const i=yt(e,t);return wt(i,t)||Rt(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:{columnsRef:Array,currentData:Array,id:String},emits:["keydown","navigationaction","keyboardselectionchange","movetonextpage","movetoprevpage","columnreorder"],inject:{onNavKeyDown:{default:i.noop},onNavFocus:{default:i.noop},onNavMount:{default:i.noop},onNavBeforeUpdate:{default:i.noop},onNavUpdate:{default:i.noop},handleDispatchFocus:{default:i.noop},kbContext:{default:null},navigation:{default:null}},mounted(){this.onNavMount({scope:this.$el||void 0})},updated(){this.onNavUpdate({scope:this.$el||void 0})},methods:{onKeyDown(e){this.onNavKeyDown(e,{navigation:this.navigation,kbContext:this.kbContext,onNavigationAction:this.onNavigationAction}),this.onNavBeforeUpdate({scope:this.$el||void 0,kbContext:this.kbContext,navigation:this.navigation}),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){const{columnsRef:t}=this.$props;if("moveToNextPage"===e.action&&this.$emit("movetonextpage",e.event),"moveToPrevPage"===e.action&&this.$emit("movetoprevpage",e.event),e.focusElement&&("reorderToRight"===e.action||"reorderToLeft"===e.action)){const i=parseInt(e.focusElement.ariaColIndex,10)-1;if(!t[i].reorderable)return;if("reorderToRight"===e.action&&i<this.$props.columnsRef.length-1){if(t[i+1].disableReorder)return;this.$emit("columnreorder",i,i+1,e.event)}if("reorderToLeft"===e.action&&i>0){if(t[i-1].disableReorder)return;this.$emit("columnreorder",i,i-1,e.event)}}"select"===e.action&&this.$emit("keyboardselectionchange",e.event),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])}}),m={filterable:!0,editable:!0,sortable:!0,resizable:!0,reorderable:!0,groupable:!0},f="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 m=0;m<t.length;m++){let f;if(!n||void 0===t[m].value||void 0===t[m].items){const r=!!c&&!(null==a||!a[i.getter(c)(t[m])]);e[e.length]={dataIndex:l.index,dataItem:t[m],rowType:"data",level:p,group:u,expanded:void 0!==h?v(h,t[m]):null!=r&&r},l.index++;continue}{let e;e=null!=u&&u.parents?[{field:u.field,value:u.value},...u.parents]:u?[u]:[],f={field:t[m].field,value:t[m].value,parents:e}}g=Math.max(g,p+1);let C=!1;const x=r.findGroupExpand(s||[],f);C=h?void 0===h||void 0===v(h,t[m])||v(h,t[m]):x?!1!==x.expanded:!1!==d,e[e.length]={dataIndex:-1,dataItem:t[m],level:p,group:f,rowType:"groupHeader",expanded:C},C&&(f.expanded=C,g=Math.max(b(e,t[m].items,o,l,n,a,s,d,c,h,p+1,f),g)),("always"===o||C&&"visible"===o)&&(e[e.length]={dataIndex:-1,dataItem:t[m],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"],S=(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 k(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((t,r)=>{i[t.depth]=i[t.depth]||[];let a=!1;0===i[t.depth].length&&(n<=1?n=1+(t.children.length>0?0:o-t.depth):(n--,a=!0)),t.rowSpan=1+(t.children.length>0?0:o-t.depth),t.kFirst=a,t.index=i[t.depth].length,t.ariaColumnIndex=l[t.depth]?l[t.depth]+1:1;let s=0;const d=[],c=new Set;let h=t.parentIndex;for(;h>=0&&!c.has(h);)c.add(h),d.unshift(h),h=e[h].parentIndex;for(let t=0;t<d.length;t++){const r=d[t],o=e[r],l=i[o.depth],n=l.indexOf(r);for(let t=0;t<n;t++){const i=l[t];s+=e[i].headerColSpan}}for(let o=0;o<t.depth;o++){const l=i[o]||[],n=(i[t.depth]||[]).indexOf(r);let a=0;for(const i of l){const r=e[i];a<n&&r.depth+r.rowSpan-1>=t.depth&&(d.includes(i)||(s+=r.headerColSpan)),a+=r.headerColSpan}}const p=i[t.depth];for(const i of p){const r=e[i];r.parentIndex===t.parentIndex&&(s+=r.headerColSpan)}t.virtualColumnOffset=s,i[t.depth].push(r);for(let e=t.depth;e<t.depth+t.rowSpan;e++)l[e]=(l[e]||0)+t.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,...m,...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 R(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,...m,field:e})})}return n}const w=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))),N={number:function(e,t,i){return typeof e===f&&"null"===e.toLowerCase()?null:t.parseNumber(e,i)},date:function(e,t,i){return typeof e===f&&"null"===e.toLowerCase()?null:t.parseDate(e,i)},boolean:function(e){return typeof e===f?"null"===e.toLowerCase()?null:"true"===e.toLowerCase():null!=e?!!e:e},string:function(e){return typeof e===f&&"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 T=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),A=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})),L=(e,t)=>"function"==typeof e.colSpan?e.colSpan({dataItem:t,column:e}):e.colSpan||1,H=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},z=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=this.$props.isSelected||v(this.$props.field,this.$props.dataItem),o="boolean"==typeof e&&e,l=this.$props.render,n=this.getKeyboardNavigationAttributes(this.$props.id),a="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:n.tabIndex,"data-keyboardnavlevel":n[r.KEYBOARD_NAV_DATA_LEVEL],"data-keyboardnavid":n[r.KEYBOARD_NAV_DATA_ID]},[t.createVNode("span",{class:"k-checkbox-wrap"},[t.createVNode("input",{checked:o,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:l,defaultRendering:a,additionalProps:this.$props,additionalListeners:{keydown:this.triggerKeydown,change:this.handleOnChange}})}}),K="grid.noRecords",M="grid.selectAllRows",j="grid.pagerInfo",B="grid.pagerFirstPage",_="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",me="grid.filterCheckAll",fe="grid.filterChooseOperator",ve="grid.filterSelectAll",be="grid.filterSelectedItems",Ce="grid.sortAriaLabel",xe="grid.sortableColumnAriaLabel",$e="grid.sortableColumnAscendingAriaLabel",Se="grid.sortableColumnDescendingAriaLabel",ke="grid.editDialogTitle",Ie="grid.editDialogSaveButtonTitle",ye="grid.editDialogCancelButtonTitle",Re="grid.filterAriaLabel",we="grid.numericFilterAriaLabel",Ne="grid.groupPanelAriaLabel",Ve="grid.groupExpand",Fe="grid.groupCollapse",Ee="grid.groupClearButton",Te="grid.groupApplyButton",De="grid.detailExpand",Ae="grid.detailCollapse",Oe="grid.selectRow",Le="grid.gridAriaLabel",He="grid.gridRowReorderAriaLabel",Ge="grid.gridAdaptiveColumnMenuFilterTitle",ze="grid.columnMenuColumnChooserTitle",Ke="grid.columnMenuColumnChooserSelectedItems",Me="grid.adaptiveColumnMenuChooserTitle",je="grid.adaptiveColumnMenuChooserSubTitle",Be="grid.columnChooserApplyButton",_e="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",[Ae]:"Collapse detail row",[Ve]:"Expand group",[Fe]:"Collapse Group",[Ee]:"Clear grouping",[Te]:"Done",[K]:"No records available",[M]:"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",[B]:"Go to the first page",[_]:"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",[me]:"Check All",[ke]:"Edit Dialog",[Ie]:"Save",[ye]:"Cancel",[fe]:"Choose Operator",[be]:"selected items",[ve]:"Select All",[xe]:"Sortable Column",[$e]:"Sorted in ascending order",[Se]:"Sorted in descending order",[Re]:"Filter",[we]:"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",[Ne]:"Group panel",[Le]:"Table",[He]:"Drag row",[Oe]:"Select Row",[ze]:"Columns Chooser",[Ge]:"Filter by",[Me]:"Columns Chooser",[je]:"Selected fields are visible",[Pe]:"Filter by",[Ke]:"Selected items",[Be]:"Apply",[_e]:"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})])}}),mt=t.defineComponent({name:"GridEditCell",inheritAttrs:!1,props:{id:String,field:String,dataItem:Object,format:String,type:String,className:String,colSpan:Number,columnType:String,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}})}}),ft=t.defineComponent({props:{staticHeaders:Boolean,headerRow:Object,columnResize:Object,cols:Array,size:String,draggable:Boolean},emits:["headerscroll"],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")},handleHeaderScroll(e){this.$emit("headerscroll",e)}},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",onScroll:this.handleHeaderScroll},[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","aria-rowindex":this.$props.key},[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])}}),St=t.defineComponent({render(){const e=i.getDefaultSlots(this);return t.createVNode("div",{class:"k-columnmenu-item-wrapper"},[e])}}),kt="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,Rt=(e,t)=>!!(t&&e>-1&&"asc"===t[e].dir),wt=(e,t)=>!!(t&&e>-1&&t[e].dir===kt),Nt=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,kt),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(St,null,{default:()=>[t.createVNode($t,{title:o.toLanguageString(se,ht[se]),icon:"sort-asc-small",svgIcon:n.sortAscSmallIcon,selected:Rt(r,e),onMenuitemclick:this.onAscClick},null),t.createVNode($t,{title:o.toLanguageString(de,ht[de]),icon:"sort-desc-small",svgIcon:n.sortDescSmallIcon,selected:wt(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"}]},Tt=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})),At=[{text:"grid.filterBooleanAll",operator:""},{text:"grid.filterIsTrue",operator:!0},{text:"grid.filterIsFalse",operator:!1}],Ot=(e,t,i)=>{const r=Lt(i.operators);let o=i.operator;switch(i.filterType){case"numeric":case"date":(!o||Tt(o))&&(o=r),null===e&&o===r&&(o="");break;case"text":(!o||Tt(o))&&(o=r),!e&&o===r&&(o="");break;default:return}return{value:e,operator:o,event:t}},Lt=(e,t)=>t?e[t][0].operator:e[0].operator,Ht=e=>e||"text",Gt=(e,t)=>({value:e,operator:""===e?"":"eq",event:t}),zt=(e,t,i)=>(Tt(e)&&(i=null),{value:i,operator:e,event:t}),Kt=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)])}}}),Mt=t.defineComponent({props:{filterType:String,operator:String,operators:Array},emits:{change:null},methods:{triggerChange(e){this.$emit("change",e)},operatorChange(e,t){const i=zt(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 Bt=e=>e||{filters:[],logic:"and"},_t=(e,t)=>Bt(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=Ht(this.$props.column.filter),i=Lt(this.$props.filterOperators,t);e=_t(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=Bt(this.$props.filter),o=_t(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=Bt(this.$props.filter),o=_t(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,m=Dt(d[c],h),f=Dt(At,h),v={field:o.field,value:g[0].value,operator:g[0].operator,booleanValues:f,filterType:c},b={field:o.field,value:g[1].value,operator:g[1].operator,booleanValues:f,filterType:c},C=this.filterGroup.logic,x=Dt(Ft,h),$={value:x.find(e=>e.operator===(null===C?"":C)),data:x},S=0!==this.currentFilterGroup().filters.length,k=this.isControlled()?this.$props.expanded:this.currentExpanded,I=v.field,y=v.value,R=v.operator,w=v.booleanValues,N=v.filterType,V=b.field,F=b.value,E=b.operator,T=b.booleanValues,D=b.filterType,A=a&&i.templateRendering.call(this,a,i.getListeners.call(this)),O=i.getTemplate.call(this,{h:t.h,template:A,defaultRendering:void 0,additionalProps:this.$props,additionalListeners:{change:this.filterChangeHandler,logicchange:this.logicChange}});return t.createVNode(St,null,{default:()=>[t.createVNode($t,{title:h.toLanguageString(ae,ht[ae]),icon:"filter",svgIcon:n.filterIcon,onMenuitemclick:this.onFilterExpand},null),t.createVNode(Vt,{show:!!k},{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(Mt,{operator:R,filterType:N,onChange:e=>{this.filterChangeHandler(e,0)},operators:m},null),t.createVNode(Kt,{field:I,value:y,operator:R,booleanValues:w,filterType:N,onFiltercellfocus:this.handleFocus,onChange:e=>{this.filterChangeHandler(e,0)},operators:m},null)],!s&&!a&&[t.createVNode(u.DropDownList,{onChange:this.logicChange,class:"k-filter-and","data-items":$.data,value:$.value,textField:"text"},null),t.createVNode(Mt,{operator:E,filterType:D,onChange:e=>{this.filterChangeHandler(e,1)},operators:m},null),t.createVNode(Kt,{field:V,value:F,operator:E,booleanValues:T,filterType:D,onFiltercellfocus:this.handleFocus,onChange:e=>{this.filterChangeHandler(e,1)},operators:m},null)],a&&O,t.createVNode("div",{class:"k-columnmenu-actions"},[t.createVNode(p.Button,{themeColor:"primary",disabled:!S},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(Nt,{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,t){const i=e[t];return!i||i.parentIndex<0?[]:[i.parentIndex,...Ut(e,i.parentIndex)]}function Yt(e,t,i){var r;const o=e[t];(null==(r=null==o?void 0:o.children)?void 0:r.length)>0&&o.children.forEach(t=>{let r="number"==typeof t?t:e.indexOf(t);r>=0&&!i.has(r)&&(i.add(r),Yt(e,r,i))})}function Xt(e){const{cellsToRender:t,columns:i,rowIndex:r,enableVirtualization:o,columnsMap:l}=e;if(!o||!t||0===t.length)return{columnsToRender:[],colSpans:[]};const n=[],a=[];let s=-1,d=-1;const c=t.reduce((e,t)=>e+t.colSpan,0);let h=[],p=[];const u=i.filter(e=>0===e.children.length),g=new Map;i.forEach((e,t)=>{if(0===e.children.length){const i=u.findIndex(t=>t===e);i>=0&&g.set(i,t)}});const m=new Set;if(t.forEach(e=>{const t=g.get(e.columnIndex);if(void 0!==t){m.add(t);const e=Ut(i,t);e.forEach(e=>m.add(e)),function(e,t,i){t.forEach(t=>{Ut(e,t).forEach(e=>i.add(e))})}(i,e,m),Yt(i,t,m),e.forEach(e=>{Yt(i,e,m)})}}),l&&Array.isArray(l)){for(let e=0;e<l.length;e++)h[e]=l[e].filter(e=>m.has(e));p=h[r]||[]}const f=function(e,t){let i=-1,r=-1;for(let o=0;o<t.length;o++)e[t[o]].locked||(-1===i&&(i=o),r=o);return{first:i,last:r}}(i,p);s=f.first,d=f.last;let v=0,b=0,C=!1;return p.forEach((e,t)=>{n.push(e);const o=i[e],u=o.headerColSpan||1;let g;if(s===d)g=c;else if(t===s){const e=o.virtualColumnOffset?o.virtualColumnOffset:0,{emptyColSpan:t,skipOffset:l}=function(e,t,i){let r=0,o=!1;if(i>0&&t)for(let l=0;l<i;l++){const n=t[l]||[];for(let t=0;t<n.length;t++){const a=e[n[t]];(a.rowSpan||1)>i-l&&(r+=a.headerColSpan||1,0===t&&(o=!0))}}return{emptyColSpan:r,skipOffset:o}}(i,h,r);b+=t,l&&(b+=e,C=!0),g=e>0&&!l?u+e:u}else if(t===d){let o=t===p.length-1;if(null!=l&&l[r]){const t=l[r],n=e;let a=-1;for(let e=t.length-1;e>=0;e--)if(!i[t[e]].locked){a=t[e];break}o=n===a}if(o)g=u;else{const e=c-v-b;if(g=Math.max(e,u),u>e&&a.length>0){const t=u-e;a[0]-=t}}}else g=u;a.push(g),v+=g}),{columnsToRender:n,colSpans:a,skipOffset:C}}function Jt(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}const Qt={none:"none",asc:"ascending",desc:"descending"},Zt={true:{asc:"desc",desc:"","":"asc"},false:{asc:"desc",desc:"asc","":"asc"}},ei=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,cellsToRender:Array,columnVirtualization:Boolean,columnsMap:Array,columnResize:Object,columnMenu:[Boolean,String,Function,Object],columnMenuAnimate:{type:[Boolean,Object],default:function(){return!0}},columnMenuIcon:Object,isRtl:Boolean,isColCountDefined:Boolean,headerSelectionValue:[Boolean,Array],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=Zt[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(){const e=l.provideLocalizationService(this),o=e.toLanguageString(xe,ht[xe]),a=e.toLanguageString($e,ht[$e]),s=e.toLanguageString(Se,ht[Se]);this.serviceIndex=0,this.index=-1;const d=this.$props.columnVirtualization,c=function(e,l){const c=Xt({cellsToRender:this.$props.cellsToRender||[],columns:this.$props.columns,rowIndex:l,enableVirtualization:d,columnsMap:this.$props.columnsMap}),h=d;let p=h&&c.columnsToRender?c.columnsToRender:e;const u=h?c.colSpans:[];return p&&0!==p.length?p.map(function(e,l){var d;const h=this.$props.columns[e],p=this.$props.sortable&&h.sortable,g=this.$props.sort?this.$props.sort.findIndex(e=>e.field===h.field):-1,m=g>=0&&this.$props.sort[g].dir||"none",f=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,g),v=h.columnMenu||!1===h.columnMenu?h.columnMenu:this.$props.columnMenu,b=h.menuIcon||this.$props.columnMenuIcon,C=(h.kFirst?"k-first ":"")+this.cellClass(h.field,h.headerClassName,h.locked)+(v?" k-filterable":""),x=v&&"boolean"!=typeof v?this.getTemplate(v):!!v,$=c.skipOffset?{borderLeftWidth:"1px"}:void 0,S=h.locked&&void 0!==h.left?this.$props.isRtl?{left:h.right+"px",right:h.left+"px"}:{left:h.left+"px",right:h.right+"px"}:$,k="none"===Qt[m]?o:"ascending"===Qt[m]?a:s;let I=h.isAccessible?{ariaSort:Qt[m],ariaLabel:k,role:"columnheader",ariaColumnIndex:this.$props.isColCountDefined?this.$props.columnsInitial.findIndex(e=>e.field===h.field)+1:void 0,ariaSelected:!1,ariaHaspopup:v?"menu":this.$props.filterable&&h.filterable?"dialog":void 0}:{role:"columnheader"};const y=h.declarationIndex>=0?++this.index:--this.serviceIndex,R=void 0!==h.columnMenuOpened?h.columnMenuOpened:this.columnMenuOpened[h.field],w=null!=(d=u[l])?d:h.headerColSpan;return t.createVNode(r.HeaderThElement,{ariaSort:p?I.ariaSort:void 0,ariaLabel:p?I.ariaLabel:void 0,role:I.role,ariaColumnIndex:I.ariaColumnIndex,ariaSelected:I.ariaSelected,ariaHaspopup:I.ariaHaspopup,key:y,colSpan:w,rowSpan:h.rowSpan,class:C,style:S,columnId:h.id,navigatable:h.navigatable,onKeydown:e=>this.cellKeyDown(e,h)},{default:()=>{var e,i;return[[0===h.children.length&&v&&t.createVNode(qt,{key:0,column:{field:h.field,filter:h.filter},opened:R,animate:this.$props.columnMenuAnimate,sortable:p,sort:this.$props.sort,onClose:this.columnMenuClose,onSortchange:this.sortChangeHandler,filter:this.$props.filter,filterable:this.$props.filterable&&h.filterable,filterOperators:this.$props.filterOperators,onFilterchange:this.filterChangeHandler,render:x,columnMenuIcon:b},null),h.internalHeaderCell&&t.createVNode("span",{class:"k-cell-inner"},[t.createVNode(h.internalHeaderCell,{key:1,field:h.field,sortable:p,onHeadercellclick:e=>this.cellClick(e,h),onSelectionchange:this.selectionChangeHandler,selectionValue:null!=(e=h.headerSelectionValue)?e:this.$props.headerSelectionValue,title:h.title,render:(h.headerCell||this.$props.cellRender)&&this.getTemplate(h.headerCell||this.$props.cellRender)},Jt(f)?f:{default:()=>[f]})])||t.createVNode("span",{class:"k-cell-inner"},[t.createVNode(xt,{key:1,field:h.field,sortable:p,onHeadercellclick:e=>this.cellClick(e,h),selectionValue:null!=(i=h.headerSelectionValue)?i:this.$props.headerSelectionValue,title:h.title,render:(h.headerCell||this.$props.cellRender)&&this.getTemplate(h.headerCell||this.$props.cellRender)},Jt(f)?f:{default:()=>[f]})]),this.$props.columnResize&&this.$props.columnResize.resizable&&h.resizable&&t.createVNode(bt,{key:2,onResize:(e,t,i)=>this.$props.columnResize&&this.$props.columnResize.dragHandler(e,h,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},Jt(r=c.call(this,e,i))?r:{default:()=>[r]})||t.createVNode("tr",{class:"k-table-row",role:"row","aria-rowindex":i+1},[c.call(this,e,i)])},this),this.$props.filterRow])}}),ti=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=zt(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(fe,ht[fe]),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 ii=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,cellsToRender:Array,columnVirtualization:Boolean,columnsMap:Array,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=Xt({cellsToRender:this.$props.cellsToRender||[],columns:this.$props.columns,rowIndex:0,enableVirtualization:this.$props.columnVirtualization,columnsMap:this.$props.columnsMap}),c=d.columnsToRender.length>0,h=this.$props.columns.filter(e=>0===e.children.length),p=c?d.columnsToRender.map(e=>this.$props.columns[e]).filter(e=>0===e.children.length):h,u=c?d.colSpans:[],g=p.map(function(i,l){const d=Ht(i.filter),h=(i.title||i.field)+" "+((e,t)=>{switch(e){case"text":return t.toLanguageString(Xe,ht[Xe]);case"numeric":return t.toLanguageString(we,ht[we]);case"boolean":return t.toLanguageString(Je,ht[Je]);case"date":return t.toLanguageString(Ye,ht[Ye]);default:return}})(d,e),p=t.createVNode(ti,{grid:this.$props.grid,field:i.field,title:i.filterTitle,value:o(i.field,"text"===d?"":null),operator:n(i.field),operators:Dt(this.$props.filterOperators[d]||[],e),booleanValues:Dt(At,e),filterType:d,onChange:e=>{this.setFilter(e.value,e.operator,i.field,e)},render:i.filterCell||this.$props.cellRender,"aria-label":h,size:this.$props.size},null),g=i.declarationIndex>=0?++s:--a,m={ariaLabel:i.filterable?e.toLanguageString(Re,ht[Re]):void 0,ariaColumnIndex:i.ariaColumnIndex},f=i.locked&&void 0!==i.left?this.$props.isRtl?{left:i.right+"px",right:i.left+"px"}:{left:i.left+"px",right:i.right+"px"}:void 0,v=c&&void 0!==u[l]?u[l]:void 0,b=t.createVNode(r.HeaderTdElement,{key:g,role:"gridcell",columnId:r.tableKeyboardNavigationTools.getFilterColumnId(i.id),navigatable:i.navigatable,style:f,class:this.headerCellClassName(i.field,i.locked)||void 0,ariaColumnIndex:m.ariaColumnIndex,"aria-label":h,colSpan:v},function(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}(p)?p:{default:()=>[p]});return i.filterable&&b||t.createVNode(r.HeaderTdElement,{key:g,role:"gridcell",columnId:r.tableKeyboardNavigationTools.getFilterColumnId(i.id),navigatable:i.navigatable,style:f,class:this.headerCellClassName(i.field,i.locked)||void 0,ariaColumnIndex:m.ariaColumnIndex,"aria-label":h,colSpan:v},null)},this);return t.createVNode("tr",{class:"k-table-row k-filter-row","aria-rowindex":this.ariaRowIndex,role:"row"},[g])}}),ri=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)])])])]})}}),oi=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(ri,{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])])])}}),li=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])}}),ni=t.defineComponent({name:"FooterRow",props:{isRtl:Boolean,columns:Array,rowIndex:Number},methods:{columnStyles(e){return e.locked&&void 0!==e.left?this.$props.isRtl?{left:e.right+"px",right:e.left+"px"}:{left:e.left+"px",right:e.right+"px"}:void 0}},render(){return t.createVNode("tr",{class:"k-table-row",role:"row","aria-rowIndex":this.$props.rowIndex},[w(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)])}}),ai=t.defineComponent({name:"GridTable",props:{selectable:Object,tableClassName:String},setup(e,{slots:i}){const{selectionRelease:o}=t.inject("kendo",{});return()=>t.createVNode(r.TableSelection,{selectable:e.selectable,onRelease:o},{default:()=>{var r;return[t.createVNode("table",{style:{tableLayout:"fixed"},role:"none",class:e.tableClassName},[null==(r=i.default)?void 0:r.call(i)])]}})}}),si=t.defineComponent({name:"GridTableScrollable",props:{selectable:Object,tableClassName:Object,tableStyle:Object},setup(e,{slots:i}){const{selectionRelease:o}=t.inject("kendo",{});return()=>{const l={...e.tableStyle};return t.createVNode(r.TableSelection,{selectable:e.selectable,onRelease:o},{default:()=>{var r;return[t.createVNode("table",{role:"none",class:e.tableClassName,style:l},[null==(r=i.default)?void 0:r.call(i)])]}})}}});let di=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),!0),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(A,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 ci{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=T(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=T(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=T(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=T(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 hi=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 pi=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])}}),ui=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)}}),gi=t.defineComponent({name:"GridCell",inheritAttrs:!1,emits:{cellclick:null,cellkeydown:null},props:{id:String,field:String,dataItem:Object,format:String,readFormat:String,className:String,columnType: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,isSelected:t,isHighlighted:i}=this.$props;return{"k-table-td":!0,"k-selected":t,"k-highlighted":i,[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,N[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}})}}),mi=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),m=l.provideLocalizationService(this).toLanguageString(Ze,ht[Ze]),f=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?m:f,"aria-label":p?m:f},[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}})}}),fi=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,dataItem:this.$props.item.dataItem},additionalListeners:{click:this.handleClick},defaultSlots:e,swapDefaultSlots:!0})}}),vi={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],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,select:Object,defaultSelect:Object,selectable:[Boolean,Object],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},bi=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(M,ht[M]),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])])}}),Ci=t.defineComponent({name:"GridNoRecords",inject:{kendoLocalizationService:{default:null}},setup:()=>({kendoLocalizationService:t.inject("kendoLocalizationService",{})}),render(){const e=i.getDefaultSlots(this),r=l.provideLocalizationService(this).toLanguageString(K,ht[K]);return e?t.createVNode("div",null,[e]):r}}),xi=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])])}}),$i={name:"@progress/kendo-vue-grid",productName:"Kendo UI for Vue",productCode:"KENDOUIVUE",productCodes:["KENDOUIVUE"],publishDate:0,version:"8.1.0-develop.2",licensingDocsUrl:"https://www.telerik.com/kendo-vue-ui/my-license/"};function Si(e){const t=e.replace(/^pager\.([a-z])/,(e,t)=>"grid.pager"+t.toUpperCase());return{messageKey:t,defaultMessage:ht[t]}}const ki=Symbol("kendoKey"),Ii=t.defineComponent({name:"KendoGrid",inheritAttrs:!1,props:{...vi,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($i),this.showLicenseWatermark=i.shouldShowValidationUI($i),this.licenseMessage=i.getLicenseMessage($i),this.initialHeight=null,this.columnsRef=[],this.vsRef=new di,this.dragLogic=new hi(this.columnReorder.bind(this),this.groupReorder.bind(this),this.columnToGroup.bind(this)),this.columnResize=new ci(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 H(this.$props.rowSpannable)},computedSelectable(){return r.getSelectionOptions(this.$props.selectable)},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.columnsRef.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.columnsRef.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:{getTotal(){let e=this.$props.total||0;return Array.isArray(this.$props.dataItems)?e=e||this.$props.dataItems.length:this.$props.dataItems&&(e=e||this.$props.dataItems.total),e},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.columnsRef.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.columnsRef=[],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.getComponentElementRef(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()},onHeaderScroll(e){const t=e.target.scrollLeft,r=i.getRef(this,"scrollContainer");r&&(r.scrollLeft=t),this.scrollLeftRef=t},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){var t;if(this.computedSelectable.enabled){const{event:i,dataItem:o,dataIndex:l,columnIndex:n}=e,a={...this.getArguments(i),dataItem:o,startColIndex:n,endColIndex:n,startRowIndex:l,endRowIndex:l,dataItems:this.getLeafDataItems(),altKey:!1,ctrlKey:!1,shiftKey:!1,metaKey:!1,mode:this.computedSelectable.mode,cell:this.computedSelectable.cell,isDrag:!1,componentId:this.$props.id||this._gridId,selectedField:this.$props.selectedField||""};this.gridContext.selectionchange({...a,select:this.$props.dataItemKey?r.getSelectedState({event:a,selectedState:null!=(t=this.$props.select)?t:{},dataItemKey:this.$props.dataItemKey}):{}})}},onKeyboardSelectionChangeHandler(e){var t,i;if(!this.computedSelectable.enabled||!this.$props.dataItemKey)return;const o=null==(t=this.gridContext.select)?void 0:t.value,l={dataItems:this.getLeafDataItems(),mode:this.computedSelectable.mode,cell:this.computedSelectable.cell,componentId:this.$props.id,selectedField:"",...this.getArguments(e)},n=r.getSelectedStateFromKeyDown({event:l,selectedState:null!=o?o:{},dataItemKey:this.$props.dataItemKey});if(n===o)return;const a=e.target,s=r.closestTagName(a,"TD"),d=r.closestTagName(a,"TR"),c=r.getColumnIndex(s),h=r.getRowIndex(d);if(void 0!==c&&void 0!==h){const t=null==(i=y(this.$props.dataItems))?void 0:i[h];this.gridContext.selectionchange({...l,select:n,dataItem:t,startRowIndex:h,startColIndex:c,startDataItem:t,endDataItem:t,endRowIndex:h,endColIndex:c,ctrlKey:e.ctrlKey,altKey:e.altKey,metaKey:e.metaKey,shiftKey:e.shiftKey,isDrag:!1})}},onHeaderSelectionChangeHandler(e){if(this.computedSelectable.enabled){const t=this.getLeafDataItems();this.gridContext.headerselectionchange({select:e.event.target.checked?t.reduce((e,t)=>(this.$props.dataItemKey&&void 0!==i.getter(this.$props.dataItemKey)(t)&&(e[i.getter(this.$props.dataItemKey)(t)]=!0),e),{}):{},field:e.field,event:e.event,target:this,dataItems:t})}},selectionRelease(e){var t;if(this.computedSelectable.enabled){const i=this.getLeafDataItems(),o=i[e.startRowIndex],l=i[e.endRowIndex],n={event:void 0,target:this,selectedField:"",componentId:this.$props.id||this._gridId,dataItems:i,dataItem:null,startDataItem:o,endDataItem:l,...e},a=r.getSelectedState({event:n,selectedState:null!=(t=this.$props.select)?t:{},dataItemKey:this.$props.dataItemKey});this.raiseSelectionEvent(n,a)}},clearSelection(e){this.computedSelectable.enabled&&this.raiseSelectionEvent(e,{})},raiseSelectionEvent(e,t){this.computedSelectable.enabled&&this.gridContext.selectionchange({...e,select:t})},moveToNextPage(e){var t,i,r,o;const l=null!=(r=null!=(i=null==(t=this.gridContext.take)?void 0:t.value)?i:this.$props.pageSize)?r:0,n=((null==(o=this.gridContext.skip)?void 0:o.value)||0)+l;n<this.getTotal()&&this.pageChangeHandler({skip:n,take:l},e)},moveToPrevPage(e){var t,i,r,o;const l=null!=(r=null!=(i=null==(t=this.gridContext.take)?void 0:t.value)?i:this.$props.pageSize)?r:0,n=((null==(o=this.gridContext.skip)?void 0:o.value)||0)-l;n>=0&&this.pageChangeHandler({skip:n,take:l},e)},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.gridContext.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.gridContext.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.columnsRef[e],l=T(this.currentColumnsState),n=o.depth,a=e=>{do{e++}while(e<this.columnsRef.length&&this.columnsRef[e].depth>n);return e},s=this.columnsRef.splice(e,a(e)-e);this.columnsRef.splice(e<t?a(t-s.length):t,0,...s),this.columnsRef.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.columnsRef[e].locked&&this.columnsRef[t].locked;r.updateLeft(this._columnsMap,this.columnsRef,d||this.shouldUpdateLeftRightRef),r.updateRight(this._columnsMap,this.columnsRef,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.columnsRef[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.getComponentElementRef(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.internalCell=t.markRaw(z),e.internalHeaderCell=t.markRaw(bi),e._type="edit",e.columnMenu=!1}),this.$props.selectedField&&this.columnsRef.filter(e=>e.field===this.$props.selectedField).forEach(e=>{e.width=e.width||"50px",e.internalCell=t.markRaw(z),e.internalHeaderCell=t.markRaw(bi),e.columnMenu=!1});const l=T(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(mi),internalCell:t.markRaw(mi),id:r.tableKeyboardNavigationTools.generateNavigatableId(""+a++,"group","column"),field:"value",locked:this.$props.lockGroups,columnMenu:!1};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?H(e.rowSpannable):this.computedRowSpannable})},initColumns(e,t){var i;this.columnsRef=this.readColumnElements();const r=null==(i=this.gridContext.group)?void 0:i.value;0===this.columnsRef.filter(e=>!e.hidden).length&&(this.columnsRef=R(e,r,{column:this.$props.expandField?this.$props.expandField:this.groupExpandable.column},{prevId:0,idPrefix:this.idPrefix})),this.configureColumns(this.columnsRef,t);const[o,l]=this.filterColumns(this.columnsRef);this.columnsRef=o,this.hiddenColumnsRef=l,this._columnsMap=k(this.columnsRef,!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.columnsRef.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(L(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,selectionRelease:this.selectionRelease,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(ki,{}),shouldUpdateLeftRightRef:p,resizedRef:u,currentColumnsState:e.columnsState}},render(){var e,l,n,a,s,d,h,p,u,m,f,v,b,C,x,$,S;const k=null==(e=this.gridContext.sort)?void 0:e.value,I=null==(l=this.gridContext.filter)?void 0:l.value,y=null==(n=this.gridContext.search)?void 0:n.value,R=null==(a=this.gridContext.select)?void 0:a.value,w=null==(s=this.gridContext.skip)?void 0:s.value,N=null==(d=this.gridContext.take)?void 0:d.value,V=null==(h=this.gridContext.group)?void 0:h.value,T=null==(p=this.gridContext.groupExpand)?void 0:p.value,D=null==(u=this.gridContext.detailExpand)?void 0:u.value,A=!(null==V||!V.length);let O;this.currentColumnsState=null==(m=this.gridContext.columnsState)?void 0:m.value;const L=!0===this.$props.autoProcessData?{group:!0,sort:!0,filter:!0,search:!0,page:!0}:this.$props.autoProcessData;let H;const G=r.tableKeyboardNavigationTools.getIdPrefix(this.navigation);let z=[];Array.isArray(this.$props.dataItems)?(z=this.$props.dataItems,H=null!=(f=this.$props.total)?f:z.length):(z=(null==(v=F(this.$props.dataItems,this.$props.collapsedGroups.length?this.computedCollapsed:[],this.$props.uniqueField))?void 0:v.data)||[],H=null!=(x=null!=(C=this.$props.total)?C:null==(b=this.$props.dataItems)?void 0:b.total)?x:z.length);const K=!0===this.$props.groupable||i.isObject(this.$props.groupable)&&!1!==this.$props.groupable.enabled;this.dragLogic.reorderable=this.$props.reorderable||!1,this.dragLogic.groupable=K,this._virtualPageSize=this.calcVirtualPageSize();const M=z.length===H,j=i.isObject(this.$props.groupable)&&this.$props.groupable.footer||"none";if(this.currentData=[],L){const e=L.page&&!(this.isVirtualScroll&&!this.$props.pageable),{data:t,total:i}=c.process(z,{group:L.group?V:void 0,sort:L.sort?k:void 0,filter:r.combineFilters(L.filter?I:void 0,L.search?y:void 0),...e?{take:this.$props.pageable?N||10:N,skip:w||0}:{}});z=t,H=null!=($=this.$props.total)?$:i}const{resolvedGroupsCount:B,flattedData:_}=this.getFlatData(z,j,M?0:this.$props.skip||0,V,D,T,this.$props.dataItemKey);this.currentData=_;const P=this._virtualSkipRef||0;if(this._virtualTotal=H,this.isVirtualScroll){let e=w||0;if((A||this.$props.pageable)&&(e=P,this._virtualTotal=this.currentData.length),M||A||this.$props.pageable)if(0===this._virtualPageSize){const t=Math.min(N||this.$props.pageSize||20,this.currentData.length);O=this.currentData.slice(e,e+t)}else O=this.currentData.slice(e,e+this._virtualPageSize)}this.initializeVirtualization();const W=null!=(S=this.selectable)&&S.drag?"none":void 0;this.initColumns(this.$props.dataItems,B),this.columnResize.resizable=this.$props.resizable||!1,this.columnResize.columns=this.columnsRef,this.columnResize.columnsState=i.cloneArray(this.currentColumnsState||[]),this.dragLogic.columns=this.columnsRef;const q=this.$props.toolbar,U=this.$props.noRecords,Y=this.columnsRef.filter(e=>0===e.children.length),X=K&&t.createVNode(oi,{ref:e=>{this.groupPanelDivRef=e},group:V||[],ariaControls:this._gridRoleElementId,onGroupChange:this.groupChangeHandler,onPressHandler:this.dragLogic.pressHandler,onDragHandler:this.dragLogic.dragHandler,onReleaseHandler:this.dragLogic.releaseHandler,resolveTitle:this.resolveTitle},null),J=(this.dragLogic.reorderable||this.dragLogic.groupable)&&i.canUseDOM&&document&&document.body,Q=[J&&t.createVNode(ui,{ref:e=>{this.dropElementClueRef=e}},null),J&&t.createVNode(pi,{ref:e=>{this.dragElementClueRef=e}},null)],Z=this.showLicenseWatermark?t.createVNode(i.WatermarkOverlay,{message:this.licenseMessage},null):null,ee=this.$attrs.style,te=ee&&i.isObject(ee)&&ee.width||"";this.tableWidth=parseFloat(te.toString());const ie=Y.findIndex(e=>"function"==typeof e.colSpan)>-1;let re;re=this.getCellsToRender({},Y);const oe=(this.$props.columnVirtualization?this.getCellsToRender({},Y).map(({columnIndex:e})=>Y[e]):Y).map(function(e,i){return t.createVNode("col",{key:e.id||`col-${i}`,width:void 0!==e.width?Math.floor(parseFloat(e.width.toString())):void 0},null)},this),le=t.createVNode(ft,{size:this.$props.size,columnResize:this.columnResize,staticHeaders:"none"!==this.$props.scrollable,ref:e=>{this.headerRef=e},onHeaderscroll:this.onHeaderScroll,headerRow:t.createVNode(ei,{grid:this,sort:k,groupable:this.$props.groupable,reorderable:this.$props.reorderable,sortable:this.$props.sortable,onSortChange:this.sortChangeHandler,filter:I,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.columnsRef,cellsToRender:re,columnVirtualization:this.$props.columnVirtualization,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,headerSelectionValue:!(!R||!this.currentData.filter(e=>"data"===e.rowType).every(e=>R&&this.$props.dataItemKey&&void 0!==i.getter(this.$props.dataItemKey)(e.dataItem)?R[i.getter(this.$props.dataItemKey)(e.dataItem)]:void 0)),filterRow:this.$props.filterable&&t.createVNode(ii,{grid:this,size:this.$props.size,columns:this.columnsRef,columnsMap:this._columnsMap,cellsToRender:re,columnVirtualization:this.$props.columnVirtualization,filter:I,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:oe},null),ne=this.columnsRef.some(e=>!!e.footerCell)?t.createVNode(li,{size:this.$props.size,columnResize:this.columnResize,staticHeaders:"none"!==this.$props.scrollable,ref:e=>{this.footerRef=e},row:t.createVNode(ni,{isRtl:this.isRtl,rowIndex:this.getAriaRowCount+1,columns:this.columnsRef},null),cols:oe},null):t.createVNode("span",null,null),ae=function(e,o,l,n,a){let s=!1;const d=this.$props.selectedField,c=this.$props.dataItemKey,h=R&&c&&void 0!==i.getter(c)(e.dataItem)?R[i.getter(c)(e.dataItem)]:void 0,p=d?i.getNestedValue(d,e.dataItem):h,u=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 ie&&(re=this.getCellsToRender(e.dataItem,Y)),{row:re.map(function({columnIndex:n,colSpan:d}){var c,h,g,m;const f=Y[n];let v;if(null!=(c=f.rowSpannable)&&c.enabled&&"data"===e.rowType&&f.field&&a){const t=f.field?null==(g=(h=f.rowSpannable).valueGetter)?void 0:g.call(h,e.dataItem,f.field):null;v={value:t,count:1},a[f.field]&&(null==(m=a[f.field])?void 0:m.value)===t&&null!==a[f.field]?(a[f.field].count++,v.count=null):a[f.field]=v}const b=`${f.className?f.className+" ":""}${f.locked?"k-grid-content-sticky":""}`,C=f.locked&&void 0!==f.left?this.isRtl?{left:f.right+"px",right:f.left+"px"}:{left:f.left+"px",right:f.right+"px"}:void 0;let x,$=!1;if(f.editable&&this.$props.editField){const t=i.getNestedValue(this.$props.editField,e.dataItem);(!0===t||t===f.field)&&(s=!0,$=!0)}f.cell&&(x=f.cell);const S=this.computedCollapsed&&this.computedCollapsed[e.level]&&this.computedCollapsed[e.level].some(t=>t===E(e.dataItem,this.$props.uniqueField)),k=f.id?f.id:n,I=S?!S:e.expanded||e.dataItem.expanded,y="expand"===f._type,R=r.tableKeyboardNavigationTools.generateNavigatableId(`${o}-${String(n)}`,G,y||"groupHeader"===e.rowType||"groupFooter"===e.rowType||"value"===f.field?"nodata":"cell");return f.internalCell?t.createVNode(f.internalCell,{key:k,id:R,colSpan:d,dataItem:e.dataItem,field:f.field||"",editor:f.editor,format:f.format,readFormat:f.readFormat,type:f.type,columnType:f.columnType,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.columnsRef.filter(e=>!e.children.length).length,rowType:e.rowType,level:e.level,expanded:I,dataIndex:e.dataIndex,style:C,ariaColumnIndex:f.ariaColumnIndex,isRtl:this.isRtl,isSelected:!!("edit"===(null==f?void 0:f._type)?p:Array.isArray(p)&&p.indexOf(n)>-1),isHighlighted:!("boolean"==typeof u||!u||!f.field||!0!==u[f.field]),group:e.group,rowSpan:v},null):$?t.createVNode(mt,{id:R,key:k,colSpan:d,dataItem:e.dataItem,field:f.field||"",editor:f.editor,format:f.format,readFormat:f.readFormat,type:f.type,columnType:f.columnType,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.columnsRef.filter(e=>!e.children.length).length,rowType:e.rowType,level:e.level,expanded:I,dataIndex:e.dataIndex,style:C},null):t.createVNode(gi,{key:k,id:R,colSpan:d,dataItem:e.dataItem,field:f.field||"",editor:f.editor,format:f.format,readFormat:f.readFormat,type:f.type,columnType:f.columnType,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.columnsRef.filter(e=>!e.children.length).length,rowType:e.rowType,level:e.level,expanded:I,dataIndex:e.dataIndex,style:C,rowSpan:v,isSelected:!!("edit"===(null==f?void 0:f._type)?p:Array.isArray(p)&&p.indexOf(n)>-1),isHighlighted:!("boolean"==typeof u||!u||!f.field||!0!==u[f.field])},null)},this),isInEdit:s,isSelected:"boolean"==typeof p&&p,isHighlighted:"boolean"==typeof u&&u}};let se=[];const de=!this.currentData.length,ce=e=>e>=this.currentData.length-0;let he=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(P>0){const e=this.currentData.slice(0,P).filter(e=>"data"===e.rowType).length;l+=e,o+=e}!this.$props.pageable&&M&&(l+=this.$props.skip||0)}se=(O||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",m=ae.call(this,s,u,l,c,a),f=Y.length-(this.detailExpandable.enabled?1:0)-((null==V?void 0:V.length)||0)||1;return he=p+e+n,[t.createVNode(fi,{key:u,item:s,dataIndex:l,ariaRowIndex:he,absoluteRowIndex:p,isAltRow:c,isHidden:ce(d),rowHeight:this.$props.rowHeight,isSelected:m.isSelected,isHighlighted:m.isHighlighted,isInEdit:m.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:()=>[m.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:ce(d)?"hidden":"",height:this.$props.detailRowHeight+"px"},role:"row","aria-rowindex":he},[null==V?void 0:V.map(function(e){return t.createVNode(mi,{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`,G)},null),t.createVNode(gt,{dataItem:s.dataItem,dataIndex:s.dataIndex,colSpan:f,ariaColIndex:2+(V?V.length:0),detail:this.$props.detail?this.$props.detail:void 0,id:r.tableKeyboardNavigationTools.generateNavigatableId(`${g}-dcell`,G)},null)])]},this)}const pe=this.$props.pageable&&t.createVNode(r.Pager,{class:"k-grid-pager",onPagesizechange:this.pageChangeHandler,onPagechange:this.pageChangeHandler,size:this.$props.size,total:H,skip:w||0,pageSize:(void 0!==N?N:this.$props.pageSize)||10,messagesMap:Si,settings:r.normalize(this.$props.pageable||{})},null),ue=i.getTemplate.call(this,{h:t.h,template:this.$props.pager,defaultRendering:pe,additionalProps:{...this.$props,skip:this.$props.skip||0,messagesMap:Si},additionalListeners:{pagesizechange:this.pageChangeHandler,pagechange:this.pageChangeHandler}}),ge=e=>k&&k.filter(t=>t.field===e).length>0,me=t.createVNode("colgroup",{ref:i.setRef(this,"colGroup")},[Y.map(function(e,i){return t.createVNode("col",{key:e.id||`col-${i}`,class:ge(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)]),fe={height:this.getCorrectHeight,...this.$attrs.style},ve=t.createVNode("div",{class:"k-loading-mask"},[t.createVNode("div",{class:"k-loading-color"},null),t.createVNode("div",{style:{height:"100%",display:"flex",justifyContent:"center",alignItems:"center"}},[t.createVNode(o.Loader,{size:"large",type:"converging-spinner"},null)])]),be=this.$props.showLoader&&i.getTemplate.call(this,{h:t.h,template:this.$props.loader,defaultRendering:ve});return"none"===this.$props.scrollable?t.createVNode(r.TableKeyboardNavigationProvider,{ref:"navRef",id:this._gridId,navigatable:this.$props.navigatable,scrollable:this.$props.scrollable,columnVirtualization:this.$props.columnVirtualization},{default:()=>[t.createVNode(g,{ref:e=>{this.gridNavRef=e},columnsRef:this.columnsRef,currentData:this.currentData,id:this.$props.id,style:fe,class:this.nonscrollableWrapperClass,onMovetonextpage:this.moveToNextPage,onMovetoprevpage:this.moveToPrevPage,onColumnreorder:this.columnReorder,onKeyboardselectionchange:this.onKeyboardSelectionChangeHandler},{default:()=>[q,X,t.createVNode("div",{role:"grid",class:"k-grid-aria-root",id:this._gridRoleElementId,"aria-colcount":this.getAriaColCount,"aria-rowcount":this.getAriaRowCount},[t.createVNode(ai,{selectable:this.computedSelectable,class:"k-table",ref:i.setRef(this,"table")},{default:()=>[me,le,t.createVNode("tbody",{class:"k-table-tbody","data-keyboardnavbody":!0},[se,t.createTextVNode(" "),be]),ne]}),de&&t.createVNode(xi,{id:r.tableKeyboardNavigationTools.generateNavigatableId("no-records",G)},{default:()=>[U.length?U:t.createVNode(Ci,null,null)]})]),ue,be,Q]})]}):t.createVNode(r.TableKeyboardNavigationProvider,{ref:"navRef",id:this._gridId,navigatable:this.$props.navigatable,scrollable:this.$props.scrollable,columnVirtualization:this.$props.columnVirtualization},{default:()=>[t.createVNode(g,{ref:e=>{this.gridNavRef=e},currentData:this.currentData,id:this.$props.id,style:fe,class:this.scrollableWrapperClass,onMovetonextpage:this.moveToNextPage,onMovetoprevpage:this.moveToPrevPage,onColumnreorder:this.columnReorder,onKeyboardselectionchange:this.onKeyboardSelectionChangeHandler},{default:()=>[q,X,t.createVNode("div",{role:"grid",class:"k-grid-aria-root",id:this._gridRoleElementId,"aria-colcount":this.getAriaColCount,"aria-rowcount":this.getAriaRowCount},[le,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(si,{selectable:this.computedSelectable,tableClassName:this.gridTableClass,tableStyle:{userSelect:W},ref:i.setRef(this,"table")},{default:()=>[me,t.createVNode("tbody",{class:"k-table-tbody",role:"rowgroup","data-keyboardnavbody":!0,ref:i.setRef(this,"tableBody")},[se])]}),de&&t.createVNode(xi,{id:r.tableKeyboardNavigationTools.generateNavigatableId("no-records",G)},{default:()=>[U.length?U:t.createVNode(Ci,null,null)]})]),!de&&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)])])]),ne,Z]),ue,be,Q]})]})}}),yi=t.defineComponent({name:"KendoVueGridStateProvider",inheritAttrs:!1,props:vi,setup(e,{emit:i}){var r,o,l,n,a,s,d,c,h,p;const u=t.ref({filter:null!=(r=e.defaultFilter)?r:e.filter,highlight:e.highlight,select:null!=(o=e.defaultSelect)?o:e.select,search:null!=(l=e.defaultSearch)?l:e.search,sort:null!=(n=e.defaultSort)?n:e.sort,take:null!=(a=e.defaultTake)?a:e.take,skip:null!=(s=e.defaultSkip)?s:e.skip,group:null!=(d=e.defaultGroup)?d:e.group,detailExpand:null!=(c=e.defaultDetailExpand)?c:e.detailExpand,groupExpand:null!=(h=e.defaultGroupExpand)?h:e.groupExpand,columnsState:null!=(p=e.defaultColumnsState)?p:e.columnsState}),g=t.computed(()=>e.filter||u.value.filter||null);t.watch(()=>e.filter,e=>{u.value.filter=e});const m=t.computed(()=>e.search||u.value.search||null);t.watch(()=>e.search,e=>{u.value.search=e});const f=t.computed(()=>e.select||u.value.select||null),v=t.computed(()=>e.sort||u.value.sort||[]);t.watch(()=>e.sort,e=>{u.value.sort=e});const b=t.computed(()=>e.skip||u.value.skip),C=t.computed(()=>e.take||u.value.take);t.watch(()=>e.skip,e=>{u.value.skip=e}),t.watch(()=>e.take,e=>{u.value.take=e});const x=t.computed(()=>e.group||u.value.group||[]);t.watch(()=>e.group,e=>{u.value.group=e});const $=t.computed(()=>e.detailExpand||u.value.detailExpand||{});t.watch(()=>e.detailExpand,e=>{u.value.detailExpand=e});const S=t.computed(()=>e.groupExpand||u.value.groupExpand||[]);t.watch(()=>e.groupExpand,e=>{u.value.groupExpand=e});const k=t.computed(()=>e.columnsState||e.defaultColumnsState||[]);t.watch(()=>e.columnsState,e=>{u.value.columnsState=e}),t.provide(ki,{sort:v,sortchange:e=>{u.value.sort=e.sort,i("sortchange",e)},filter:g,filterchange:e=>{u.value.filter=e.filter,i("filterchange",e)},search:m,searchchange:e=>{u.value.search=e.search,u.value.skip=0,i("searchchange",e)},skip:b,take:C,pagechange:e=>{u.value.skip=e.page.skip,u.value.take=e.page.take,i("pagechange",e)},select:f,selectionchange:e=>{u.value.select=e.select,i("selectionchange",e)},headerselectionchange:e=>{u.value.select=e.select,i("headerselectionchange",e)},group:x,groupchange:e=>{u.value.group=e.group,i("groupchange",e)},detailExpand:$,detailexpandchange:e=>{u.value.detailExpand=e.detailExpand,i("detailexpandchange",e)},groupExpand:S,groupexpandchange:e=>{u.value.groupExpand=e.groupExpand,i("groupexpandchange",e)},columnsState:k,columnsstatechange:e=>{u.value.columnsState=e.columnsState,i("columnsstatechange",e)},datastatechange:e=>{u.value={...u.value,...e.data},i("datastatechange",e)}})},render(){return i.getDefaultSlots(this)}}),Ri=t.defineComponent({name:"KendoVueGrid",props:vi,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=!1!==r.columnMenu&&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),m=i.templateRendering.call(this,d,r),f=i.templateRendering.call(this,c,r),v=i.templateRendering.call(this,h,r),b=this.columnsWithTemplates;return t.createVNode(yi,p,{default:()=>[t.createVNode(Ii,t.mergeProps(p,r,{class:this.$attrs.class,style:this.$attrs.style,columns:b,cellRender:g,rowRender:m,pager:f,loader:v,detail:u,toolbar:o,noRecords:l}),null)]})}}),wi=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,m=o.field,f=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(Kt,{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(Kt,{field:m,value:f,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 Ni(e){return"function"==typeof e||"[object Object]"===Object.prototype.toString.call(e)&&!t.isVNode(e)}const Vi={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)),m=i.templateRendering.call(this,this.$props.checkAllItem,i.getListeners.call(this)),f=t.createVNode("li",{class:"k-item"},[t.createVNode(a.Checkbox,{label:s.toLanguageString(me,ht[me]),onChange:e=>this.handleCheckBoxChange(e,"all"),checked:this.isAllSelected()},null)]),v=i.getTemplate.call(this,{h:t.h,template:m,defaultRendering:f,additionalProps:{checked:this.isAllSelected()},additionalListeners:{change:e=>this.handleCheckBoxChange(e,"all")}});return t.createVNode(St,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"},Ni(e=s.toLanguageString(ne,ht[ne]))?e:{default:()=>[e]}),t.createVNode(p.Button,{type:"reset"},Ni(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}}},Fi=t.defineComponent({render:()=>null}),Ei=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])}}),Ti=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(ki,{}),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.Icon,{name:"search",icon:n.searchIcon},null)},this.$attrs,{wrapperClass:"k-grid-search k-searchbox",onInput:this.handleChange}),null)}}),Di=t.defineComponent({name:"KendoVueGridStatusBar",props:{data:{type:Array,default:()=>[]}},setup:e=>()=>t.createVNode("div",{class:"k-selection-aggregates k-grid-selection-aggregates"},[e.data.map((e,i)=>t.createVNode("div",{key:`${e.type}-${i}`},[t.createVNode("span",{class:"k-selection-aggregates-item-text"},[e.type,t.createTextVNode(": ")]),t.createVNode("span",{class:"k-selection-aggregates-item-value"},[e.formattedValue])]))])}),Ai=e=>{var t,i,r,o;const l=e.slice();for(let e=0;e<l.length;e++)for(;null!=(i=null==(t=l[e])?void 0:t.children)&&i.length;)l.splice(e,1,...null!=(o=null==(r=l[e])?void 0:r.children)?o:[]);return l};e.Footer=li,e.FooterRow=ni,e.Grid=Ri,e.GridCell=gi,e.GridColumnMenuCheckboxFilter=Vi,e.GridColumnMenuFilter=Pt,e.GridColumnMenuFilterCell=Kt,e.GridColumnMenuFilterUI=wi,e.GridColumnMenuItem=$t,e.GridColumnMenuItemContent=Vt,e.GridColumnMenuItemGroup=St,e.GridColumnMenuSort=Nt,e.GridDetailRow=Fi,e.GridEditCell=mt,e.GridFilterCell=ti,e.GridGroupCell=mi,e.GridHeaderCell=xt,e.GridHierarchyCell=pt,e.GridNoRecords=Ci,e.GridRow=fi,e.GridSearchBox=Ti,e.GridToolbar=Ei,e.StatusBar=Di,e.applyExpandedState=F,e.autoGenerateColumns=R,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(S(i,e))}}},e.filterGroupByField=_t,e.firefox=D,e.firefoxMaxHeight=A,e.flatData=b,e.footerColumns=w,e.getColSpan=L,e.getColumnWidth=e=>void 0!==e.width?Math.floor(parseFloat(e.width.toString()))+"px":void 0,e.getDataAsArray=y,e.getFlatColumnsState=T,e.getIndex=x,e.getNestedValue=v,e.getRowSpanOptions=H,e.getStatusData=e=>{const{dataItems:t,target:r}=e,o=Ai(r.columns).map(e=>e.field).filter(e=>e&&"string"==typeof e).map(e=>i.getter(e)),l={dates:[],numbers:[],booleans:[],others:[]};t.forEach(t=>{const r=(t=>{var r;return null==(r=e.select)?void 0:r[i.getter(e.dataItemKey)(t)]})(t);Array.isArray(r)&&r.forEach(e=>{(e=>{"number"==typeof e?l.numbers.push(e):"boolean"==typeof e?l.booleans.push(e):e instanceof Date?l.dates.push(e):l.others.push(e)})(o[e](t))})});const n=l.dates.map(e=>e.getTime()),a=l.booleans.filter(Boolean).length,s=l.booleans.length-a,d=l.numbers.length?l.numbers.reduce((e,t)=>e+t,0):void 0,c={sum:d,average:"number"==typeof d?d/l.numbers.length:void 0,min:l.numbers.length?Math.min(...l.numbers):void 0,max:l.numbers.length?Math.max(...l.numbers):void 0,count:l.numbers.length+l.booleans.length+l.dates.length+l.others.length,isTrue:a>0?a:void 0,isFalse:s>0?s:void 0,earliest:l.dates.length?new Date(Math.min(...n)):void 0,latest:l.dates.length?new Date(Math.max(...n)):void 0},h=(e,t)=>"sum"!==t&&"average"!==t||"number"!=typeof e?("earliest"===t||"latest"===t)&&e instanceof Date?e.toLocaleDateString():String(e):e.toFixed(2),p=[];return Object.keys(c).forEach(e=>{const t=e,i=c[t];void 0!==i&&p.push({type:t,value:i,formattedValue:h(i,t)})}),p},e.groupedFirstItemValue=E,e.isRtl=C,e.isSorted=(e,t)=>t&&t.filter(t=>t.field===e).length>0,e.leafColumns=Ai,e.mapColumns=k,e.parsers=N,e.readColumns=I,e.sanitizeColumns=O,e.sortGroupByField=(e,t)=>{const i=yt(e,t);return wt(i,t)||Rt(i,t)}});
@@ -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: 1773767206,version:"8.1.0-develop.1",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: 1773825498,version:"8.1.0-develop.2",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: 1773767206,
14
- version: "8.1.0-develop.1",
13
+ publishDate: 1773825498,
14
+ version: "8.1.0-develop.2",
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": "8.1.0-develop.1",
3
+ "version": "8.1.0-develop.2",
4
4
  "description": "TODO",
5
5
  "author": "Progress",
6
6
  "license": "SEE LICENSE IN LICENSE.md",
@@ -27,16 +27,16 @@
27
27
  "@progress/kendo-data-query": "^1.7.0",
28
28
  "@progress/kendo-drawing": "^1.21.1",
29
29
  "@progress/kendo-licensing": "^1.7.2",
30
- "@progress/kendo-vue-animation": "8.1.0-develop.1",
31
- "@progress/kendo-vue-buttons": "8.1.0-develop.1",
32
- "@progress/kendo-vue-common": "8.1.0-develop.1",
33
- "@progress/kendo-vue-data-tools": "8.1.0-develop.1",
34
- "@progress/kendo-vue-dateinputs": "8.1.0-develop.1",
35
- "@progress/kendo-vue-indicators": "8.1.0-develop.1",
36
- "@progress/kendo-vue-dropdowns": "8.1.0-develop.1",
37
- "@progress/kendo-vue-inputs": "8.1.0-develop.1",
38
- "@progress/kendo-vue-intl": "8.1.0-develop.1",
39
- "@progress/kendo-vue-popup": "8.1.0-develop.1",
30
+ "@progress/kendo-vue-animation": "8.1.0-develop.2",
31
+ "@progress/kendo-vue-buttons": "8.1.0-develop.2",
32
+ "@progress/kendo-vue-common": "8.1.0-develop.2",
33
+ "@progress/kendo-vue-data-tools": "8.1.0-develop.2",
34
+ "@progress/kendo-vue-dateinputs": "8.1.0-develop.2",
35
+ "@progress/kendo-vue-indicators": "8.1.0-develop.2",
36
+ "@progress/kendo-vue-dropdowns": "8.1.0-develop.2",
37
+ "@progress/kendo-vue-inputs": "8.1.0-develop.2",
38
+ "@progress/kendo-vue-intl": "8.1.0-develop.2",
39
+ "@progress/kendo-vue-popup": "8.1.0-develop.2",
40
40
  "@progress/kendo-svg-icons": "^4.4.0",
41
41
  "vue": "^3.0.2"
42
42
  },
@@ -57,7 +57,7 @@
57
57
  "package": {
58
58
  "productName": "Kendo UI for Vue",
59
59
  "productCode": "KENDOUIVUE",
60
- "publishDate": 1773767206,
60
+ "publishDate": 1773825498,
61
61
  "licensingDocsUrl": "https://www.telerik.com/kendo-vue-ui/my-license/"
62
62
  }
63
63
  },