@progress/kendo-vue-grid 3.5.0 → 3.5.1-dev.202208100944
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cdn/js/kendo-vue-grid.js +1 -1
- package/dist/es/Grid.js +20 -24
- package/dist/es/ScrollMode.js +1 -0
- package/dist/es/columnMenu/ColumnMenu.js +2 -2
- package/dist/es/columnMenu/GridColumnMenuCheckboxFilter.js +9 -13
- package/dist/es/columnMenu/GridColumnMenuFilter.js +423 -107
- package/dist/es/columnMenu/GridColumnMenuFilterCell.js +74 -97
- package/dist/es/columnMenu/GridColumnMenuFilterOperators.d.ts +36 -0
- package/dist/es/columnMenu/GridColumnMenuFilterOperators.js +68 -0
- package/dist/es/columnMenu/GridColumnMenuItem.js +2 -2
- package/dist/es/filterCommon.d.ts +1 -1
- package/dist/es/footer/Footer.js +1 -1
- package/dist/es/footer/FooterRow.js +1 -1
- package/dist/es/header/FilterRow.js +1 -1
- package/dist/es/header/Header.js +1 -1
- package/dist/es/header/HeaderRow.js +1 -1
- package/dist/es/interfaces/ExtendedColumnProps.js +1 -0
- package/dist/es/interfaces/GridCellProps.js +1 -0
- package/dist/es/interfaces/GridColumnMenuColumnProps.js +1 -0
- package/dist/es/interfaces/GridColumnMenuExtendedFilterProps.js +1 -0
- package/dist/es/interfaces/GridColumnMenuFilterBaseProps.js +1 -0
- package/dist/es/interfaces/GridColumnMenuFilterProps.js +1 -0
- package/dist/es/interfaces/GridColumnMenuFilterUIProps.js +1 -0
- package/dist/es/interfaces/GridColumnMenuProps.js +1 -0
- package/dist/es/interfaces/GridColumnMenuSortBaseProps.js +1 -0
- package/dist/es/interfaces/GridColumnProps.js +1 -0
- package/dist/es/interfaces/GridDetailRowProps.js +1 -0
- package/dist/es/interfaces/GridFilterCellProps.js +1 -0
- package/dist/es/interfaces/GridFilterOperator.js +1 -0
- package/dist/es/interfaces/GridFilterOperators.js +1 -0
- package/dist/es/interfaces/GridFooterCellProps.js +1 -0
- package/dist/es/interfaces/GridGroupableSettings.js +1 -0
- package/dist/es/interfaces/GridHeaderCellProps.js +1 -0
- package/dist/es/interfaces/GridHeaderSelectionCellProps.js +1 -0
- package/dist/es/interfaces/GridNoRecordsProps.js +1 -0
- package/dist/es/interfaces/GridProps.js +1 -0
- package/dist/es/interfaces/GridRowProps.js +1 -0
- package/dist/es/interfaces/GridRowType.js +1 -0
- package/dist/es/interfaces/GridSortSettings.js +9 -7
- package/dist/es/interfaces/GridToolbarProps.js +1 -0
- package/dist/es/interfaces/events.js +1 -0
- package/dist/es/package-metadata.js +1 -1
- package/dist/es/rows/GridDetailRow.d.ts +2 -1
- package/dist/es/utils/index.js +4 -4
- package/dist/esm/Grid.d.ts +180 -0
- package/dist/esm/Grid.js +2086 -0
- package/dist/esm/GridNav.d.ts +46 -0
- package/dist/esm/GridNav.js +112 -0
- package/dist/esm/GridNoRecords.d.ts +51 -0
- package/dist/esm/GridNoRecords.js +83 -0
- package/dist/esm/GridToolbar.d.ts +58 -0
- package/dist/esm/GridToolbar.js +77 -0
- package/dist/esm/ScrollMode.d.ts +1 -0
- package/dist/esm/ScrollMode.js +1 -0
- package/dist/esm/VirtualScroll.d.ts +41 -0
- package/dist/esm/VirtualScroll.js +217 -0
- package/dist/esm/additionalTypes.ts +21 -0
- package/dist/esm/cells/GridCell.d.ts +30 -0
- package/dist/esm/cells/GridCell.js +161 -0
- package/dist/esm/cells/GridDetailCell.d.ts +29 -0
- package/dist/esm/cells/GridDetailCell.js +82 -0
- package/dist/esm/cells/GridDetailHierarchyCell.d.ts +24 -0
- package/dist/esm/cells/GridDetailHierarchyCell.js +53 -0
- package/dist/esm/cells/GridEditCell.d.ts +40 -0
- package/dist/esm/cells/GridEditCell.js +312 -0
- package/dist/esm/cells/GridFilterCell.d.ts +26 -0
- package/dist/esm/cells/GridFilterCell.js +259 -0
- package/dist/esm/cells/GridGroupCell.d.ts +23 -0
- package/dist/esm/cells/GridGroupCell.js +179 -0
- package/dist/esm/cells/GridHierarchyCell.d.ts +23 -0
- package/dist/esm/cells/GridHierarchyCell.js +162 -0
- package/dist/esm/cells/GridSelectionCell.d.ts +34 -0
- package/dist/esm/cells/GridSelectionCell.js +138 -0
- package/dist/esm/columnMenu/ColumnMenu.d.ts +56 -0
- package/dist/esm/columnMenu/ColumnMenu.js +252 -0
- package/dist/esm/columnMenu/ColumnMenuContent.d.ts +33 -0
- package/dist/esm/columnMenu/ColumnMenuContent.js +123 -0
- package/dist/esm/columnMenu/GridColumnMenuCheckboxFilter.d.ts +86 -0
- package/dist/esm/columnMenu/GridColumnMenuCheckboxFilter.js +709 -0
- package/dist/esm/columnMenu/GridColumnMenuFilter.d.ts +339 -0
- package/dist/esm/columnMenu/GridColumnMenuFilter.js +1079 -0
- package/dist/esm/columnMenu/GridColumnMenuFilterCell.d.ts +45 -0
- package/dist/esm/columnMenu/GridColumnMenuFilterCell.js +152 -0
- package/dist/esm/columnMenu/GridColumnMenuFilterOperators.d.ts +36 -0
- package/dist/esm/columnMenu/GridColumnMenuFilterOperators.js +68 -0
- package/dist/esm/columnMenu/GridColumnMenuFilterUI.d.ts +24 -0
- package/dist/esm/columnMenu/GridColumnMenuFilterUI.js +155 -0
- package/dist/esm/columnMenu/GridColumnMenuItem.d.ts +42 -0
- package/dist/esm/columnMenu/GridColumnMenuItem.js +63 -0
- package/dist/esm/columnMenu/GridColumnMenuItemContent.d.ts +34 -0
- package/dist/esm/columnMenu/GridColumnMenuItemContent.js +51 -0
- package/dist/esm/columnMenu/GridColumnMenuItemGroup.d.ts +19 -0
- package/dist/esm/columnMenu/GridColumnMenuItemGroup.js +33 -0
- package/dist/esm/columnMenu/GridColumnMenuSort.d.ts +283 -0
- package/dist/esm/columnMenu/GridColumnMenuSort.js +375 -0
- package/dist/esm/drag/ColumnDraggable.d.ts +43 -0
- package/dist/esm/drag/ColumnDraggable.js +73 -0
- package/dist/esm/drag/ColumnResize.d.ts +31 -0
- package/dist/esm/drag/ColumnResize.js +126 -0
- package/dist/esm/drag/ColumnResizer.d.ts +40 -0
- package/dist/esm/drag/ColumnResizer.js +89 -0
- package/dist/esm/drag/CommonDragLogic.d.ts +35 -0
- package/dist/esm/drag/CommonDragLogic.js +177 -0
- package/dist/esm/drag/DragClue.d.ts +25 -0
- package/dist/esm/drag/DragClue.js +52 -0
- package/dist/esm/drag/DropClue.d.ts +24 -0
- package/dist/esm/drag/DropClue.js +46 -0
- package/dist/esm/drag/GroupingIndicator.d.ts +51 -0
- package/dist/esm/drag/GroupingIndicator.js +153 -0
- package/dist/esm/filterCommon.d.ts +75 -0
- package/dist/esm/filterCommon.js +156 -0
- package/dist/esm/footer/Footer.d.ts +52 -0
- package/dist/esm/footer/Footer.js +103 -0
- package/dist/esm/footer/FooterRow.d.ts +30 -0
- package/dist/esm/footer/FooterRow.js +73 -0
- package/dist/esm/header/FilterRow.d.ts +36 -0
- package/dist/esm/header/FilterRow.js +203 -0
- package/dist/esm/header/GridHeaderCell.d.ts +21 -0
- package/dist/esm/header/GridHeaderCell.js +60 -0
- package/dist/esm/header/GridHeaderSelectionCell.d.ts +32 -0
- package/dist/esm/header/GridHeaderSelectionCell.js +81 -0
- package/dist/esm/header/GroupPanel.d.ts +38 -0
- package/dist/esm/header/GroupPanel.js +108 -0
- package/dist/esm/header/Header.d.ts +64 -0
- package/dist/esm/header/Header.js +123 -0
- package/dist/esm/header/HeaderRow.d.ts +86 -0
- package/dist/esm/header/HeaderRow.js +517 -0
- package/dist/esm/interfaces/ExtendedColumnProps.d.ts +20 -0
- package/dist/esm/interfaces/ExtendedColumnProps.js +1 -0
- package/dist/esm/interfaces/GridCellProps.d.ts +156 -0
- package/dist/esm/interfaces/GridCellProps.js +1 -0
- package/dist/esm/interfaces/GridColumnMenuColumnProps.d.ts +13 -0
- package/dist/esm/interfaces/GridColumnMenuColumnProps.js +1 -0
- package/dist/esm/interfaces/GridColumnMenuExtendedFilterProps.d.ts +42 -0
- package/dist/esm/interfaces/GridColumnMenuExtendedFilterProps.js +1 -0
- package/dist/esm/interfaces/GridColumnMenuFilterBaseProps.d.ts +49 -0
- package/dist/esm/interfaces/GridColumnMenuFilterBaseProps.js +1 -0
- package/dist/esm/interfaces/GridColumnMenuFilterProps.d.ts +27 -0
- package/dist/esm/interfaces/GridColumnMenuFilterProps.js +1 -0
- package/dist/esm/interfaces/GridColumnMenuFilterUIProps.d.ts +55 -0
- package/dist/esm/interfaces/GridColumnMenuFilterUIProps.js +1 -0
- package/dist/esm/interfaces/GridColumnMenuProps.d.ts +19 -0
- package/dist/esm/interfaces/GridColumnMenuProps.js +1 -0
- package/dist/esm/interfaces/GridColumnMenuSortBaseProps.d.ts +28 -0
- package/dist/esm/interfaces/GridColumnMenuSortBaseProps.js +1 -0
- package/dist/esm/interfaces/GridColumnProps.d.ts +147 -0
- package/dist/esm/interfaces/GridColumnProps.js +1 -0
- package/dist/esm/interfaces/GridDetailRowProps.d.ts +9 -0
- package/dist/esm/interfaces/GridDetailRowProps.js +1 -0
- package/dist/esm/interfaces/GridFilterCellProps.d.ts +64 -0
- package/dist/esm/interfaces/GridFilterCellProps.js +1 -0
- package/dist/esm/interfaces/GridFilterOperator.d.ts +7 -0
- package/dist/esm/interfaces/GridFilterOperator.js +1 -0
- package/dist/esm/interfaces/GridFilterOperators.d.ts +49 -0
- package/dist/esm/interfaces/GridFilterOperators.js +1 -0
- package/dist/esm/interfaces/GridFooterCellProps.d.ts +7 -0
- package/dist/esm/interfaces/GridFooterCellProps.js +1 -0
- package/dist/esm/interfaces/GridGroupableSettings.d.ts +15 -0
- package/dist/esm/interfaces/GridGroupableSettings.js +1 -0
- package/dist/esm/interfaces/GridHeaderCellProps.d.ts +37 -0
- package/dist/esm/interfaces/GridHeaderCellProps.js +1 -0
- package/dist/esm/interfaces/GridHeaderSelectionCellProps.d.ts +17 -0
- package/dist/esm/interfaces/GridHeaderSelectionCellProps.js +1 -0
- package/dist/esm/interfaces/GridNoRecordsProps.d.ts +9 -0
- package/dist/esm/interfaces/GridNoRecordsProps.js +1 -0
- package/dist/esm/interfaces/GridProps.d.ts +311 -0
- package/dist/esm/interfaces/GridProps.js +1 -0
- package/dist/esm/interfaces/GridRowProps.d.ts +55 -0
- package/dist/esm/interfaces/GridRowProps.js +1 -0
- package/dist/esm/interfaces/GridRowType.d.ts +9 -0
- package/dist/esm/interfaces/GridRowType.js +1 -0
- package/dist/esm/interfaces/GridSortSettings.d.ts +26 -0
- package/dist/esm/interfaces/GridSortSettings.js +20 -0
- package/dist/esm/interfaces/GridToolbarProps.d.ts +9 -0
- package/dist/esm/interfaces/GridToolbarProps.js +1 -0
- package/dist/esm/interfaces/events.d.ts +248 -0
- package/dist/esm/interfaces/events.js +1 -0
- package/dist/esm/main.d.ts +38 -0
- package/dist/esm/main.js +31 -0
- package/dist/esm/messages/index.d.ts +150 -0
- package/dist/esm/messages/index.js +151 -0
- package/dist/esm/package-metadata.d.ts +5 -0
- package/dist/esm/package-metadata.js +11 -0
- package/dist/esm/package.json +3 -0
- package/dist/esm/rows/GridDetailRow.d.ts +16 -0
- package/dist/esm/rows/GridDetailRow.js +29 -0
- package/dist/esm/rows/GridRow.d.ts +28 -0
- package/dist/esm/rows/GridRow.js +84 -0
- package/dist/esm/utils/browser-support.service.d.ts +7 -0
- package/dist/esm/utils/browser-support.service.js +26 -0
- package/dist/esm/utils/index.d.ts +91 -0
- package/dist/esm/utils/index.js +393 -0
- package/dist/npm/Grid.js +66 -70
- package/dist/npm/GridNav.js +1 -1
- package/dist/npm/GridNoRecords.js +2 -2
- package/dist/npm/GridToolbar.js +1 -1
- package/dist/npm/cells/GridCell.js +2 -2
- package/dist/npm/cells/GridEditCell.js +2 -2
- package/dist/npm/cells/GridFilterCell.js +4 -4
- package/dist/npm/cells/GridHierarchyCell.js +1 -1
- package/dist/npm/cells/GridSelectionCell.js +2 -2
- package/dist/npm/columnMenu/ColumnMenu.js +5 -5
- package/dist/npm/columnMenu/GridColumnMenuCheckboxFilter.js +14 -18
- package/dist/npm/columnMenu/GridColumnMenuFilter.js +445 -125
- package/dist/npm/columnMenu/GridColumnMenuFilterCell.js +79 -102
- package/dist/npm/columnMenu/GridColumnMenuFilterOperators.d.ts +36 -0
- package/dist/npm/columnMenu/GridColumnMenuFilterOperators.js +79 -0
- package/dist/npm/columnMenu/GridColumnMenuItem.js +2 -2
- package/dist/npm/columnMenu/GridColumnMenuItemContent.js +1 -1
- package/dist/npm/columnMenu/GridColumnMenuItemGroup.js +1 -1
- package/dist/npm/columnMenu/GridColumnMenuSort.js +5 -4
- package/dist/npm/drag/ColumnDraggable.js +1 -1
- package/dist/npm/drag/CommonDragLogic.js +2 -2
- package/dist/npm/drag/GroupingIndicator.js +3 -3
- package/dist/npm/filterCommon.d.ts +1 -1
- package/dist/npm/filterCommon.js +19 -12
- package/dist/npm/footer/Footer.js +6 -6
- package/dist/npm/footer/FooterRow.js +2 -2
- package/dist/npm/header/FilterRow.js +7 -7
- package/dist/npm/header/GridHeaderCell.js +1 -1
- package/dist/npm/header/GridHeaderSelectionCell.js +1 -1
- package/dist/npm/header/GroupPanel.js +1 -1
- package/dist/npm/header/Header.js +8 -8
- package/dist/npm/header/HeaderRow.js +2 -2
- package/dist/npm/interfaces/GridSortSettings.js +11 -8
- package/dist/npm/main.js +6 -2
- package/dist/npm/package-metadata.js +1 -1
- package/dist/npm/rows/GridDetailRow.d.ts +2 -1
- package/dist/npm/rows/GridRow.js +2 -2
- package/dist/npm/utils/index.js +6 -5
- package/package.json +14 -14
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
// @ts-ignore
|
|
2
|
+
import * as Vue from 'vue';
|
|
3
|
+
var allVue = Vue;
|
|
4
|
+
var gh = allVue.h;
|
|
5
|
+
var isV3 = allVue.version && allVue.version[0] === '3';
|
|
6
|
+
import { getTemplate } from '@progress/kendo-vue-common';
|
|
7
|
+
import { footerColumns } from './../utils.js';
|
|
8
|
+
/**
|
|
9
|
+
* @hidden
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
var FooterRowVue2 = {
|
|
13
|
+
name: 'FooterRow',
|
|
14
|
+
props: {
|
|
15
|
+
isRtl: Boolean,
|
|
16
|
+
columns: Array
|
|
17
|
+
},
|
|
18
|
+
methods: {
|
|
19
|
+
columnStyles: function columnStyles(column) {
|
|
20
|
+
return column.left !== undefined ? !this.$props.isRtl ? {
|
|
21
|
+
left: column.left + 'px',
|
|
22
|
+
right: column.right + 'px'
|
|
23
|
+
} : {
|
|
24
|
+
left: column.right + 'px',
|
|
25
|
+
right: column.left + 'px'
|
|
26
|
+
} : {};
|
|
27
|
+
}
|
|
28
|
+
},
|
|
29
|
+
// @ts-ignore
|
|
30
|
+
setup: !isV3 ? undefined : function () {
|
|
31
|
+
var v3 = !!isV3;
|
|
32
|
+
return {
|
|
33
|
+
v3: v3
|
|
34
|
+
};
|
|
35
|
+
},
|
|
36
|
+
// @ts-ignore
|
|
37
|
+
render: function render(createElement) {
|
|
38
|
+
var h = gh || createElement;
|
|
39
|
+
|
|
40
|
+
var renderCell = function renderCell(column, index) {
|
|
41
|
+
var footerCellRendering = null;
|
|
42
|
+
var stickyClassName = column.locked && column.left !== undefined ? 'k-grid-footer-sticky' : '';
|
|
43
|
+
var tdClassName = column.footerClassName ? "".concat(column.footerClassName, " ").concat(stickyClassName) : stickyClassName;
|
|
44
|
+
footerCellRendering = getTemplate.call(this, {
|
|
45
|
+
h: h,
|
|
46
|
+
template: column.footerCell,
|
|
47
|
+
defaultRendering: null,
|
|
48
|
+
additionalProps: {
|
|
49
|
+
field: column.field,
|
|
50
|
+
colSpan: column.colSpan !== 1 ? column.colSpan : undefined,
|
|
51
|
+
defaultStyle: this.columnStyles(column)
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
return h("td", {
|
|
55
|
+
key: index,
|
|
56
|
+
colspan: column.colSpan !== 1 ? column.colSpan : undefined,
|
|
57
|
+
attrs: this.v3 ? undefined : {
|
|
58
|
+
colspan: column.colSpan !== 1 ? column.colSpan : undefined
|
|
59
|
+
},
|
|
60
|
+
style: this.columnStyles(column),
|
|
61
|
+
"class": tdClassName
|
|
62
|
+
}, [footerCellRendering]);
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
return h("tr", [footerColumns(this.$props.columns).map(renderCell, this)]);
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
/**
|
|
69
|
+
* @hidden
|
|
70
|
+
*/
|
|
71
|
+
|
|
72
|
+
var FooterRow = FooterRowVue2;
|
|
73
|
+
export { FooterRow, FooterRowVue2 };
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { CompositeFilterDescriptor, SortDescriptor } from '@progress/kendo-data-query';
|
|
2
|
+
declare type DefaultData<V> = object | ((this: V) => {});
|
|
3
|
+
declare type DefaultMethods<V> = {
|
|
4
|
+
[key: string]: (this: V, ...args: any[]) => any;
|
|
5
|
+
};
|
|
6
|
+
import { ExtendedColumnProps } from '../interfaces/ExtendedColumnProps';
|
|
7
|
+
import { DefineComponent, RecordPropsDefinition, ComponentOptions, Vue2type } from '../additionalTypes';
|
|
8
|
+
import { GridFilterOperators } from '../interfaces/GridFilterOperators';
|
|
9
|
+
/**
|
|
10
|
+
* @hidden
|
|
11
|
+
*/
|
|
12
|
+
export interface FilterRowProps {
|
|
13
|
+
grid: any;
|
|
14
|
+
columns: ExtendedColumnProps[];
|
|
15
|
+
filter?: CompositeFilterDescriptor;
|
|
16
|
+
filterOperators: GridFilterOperators;
|
|
17
|
+
sort?: SortDescriptor[];
|
|
18
|
+
cellRender?: any;
|
|
19
|
+
isRtl?: boolean;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* @hidden
|
|
23
|
+
*/
|
|
24
|
+
export interface FilterRowMethods extends Vue2type {
|
|
25
|
+
headerCellClassName: (field?: string, locked?: boolean) => string;
|
|
26
|
+
setFilter: (value: string | number, operator: string | Function, field: string | undefined, e: any) => void;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* @hidden
|
|
30
|
+
*/
|
|
31
|
+
declare let FilterRowVue2: ComponentOptions<Vue2type, DefaultData<{}>, DefaultMethods<FilterRowMethods>, {}, RecordPropsDefinition<FilterRowProps>>;
|
|
32
|
+
/**
|
|
33
|
+
* @hidden
|
|
34
|
+
*/
|
|
35
|
+
declare const FilterRow: DefineComponent<FilterRowProps, any, {}, {}, FilterRowMethods, {}, {}, {}, string, FilterRowProps, FilterRowProps, {}>;
|
|
36
|
+
export { FilterRow, FilterRowVue2 };
|
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
// @ts-ignore
|
|
2
|
+
import * as Vue from 'vue';
|
|
3
|
+
var allVue = Vue;
|
|
4
|
+
var gh = allVue.h;
|
|
5
|
+
var isV3 = allVue.version && allVue.version[0] === '3';
|
|
6
|
+
var inject = allVue.inject;
|
|
7
|
+
import { operatorMap, booleanFilterValues, getFilterType } from '../filterCommon.js';
|
|
8
|
+
import { GridFilterCell } from '../cells/GridFilterCell.js';
|
|
9
|
+
import { provideLocalizationService } from '@progress/kendo-vue-intl';
|
|
10
|
+
import { filterAriaLabel, messages } from '../messages.js';
|
|
11
|
+
import { tableKeyboardNavigationTools as navigationTools, HeaderThElement } from '@progress/kendo-vue-data-tools';
|
|
12
|
+
/**
|
|
13
|
+
* @hidden
|
|
14
|
+
*/
|
|
15
|
+
|
|
16
|
+
var FilterRowVue2 = {
|
|
17
|
+
name: 'kendoFilterRow',
|
|
18
|
+
props: {
|
|
19
|
+
grid: Object,
|
|
20
|
+
columns: Array,
|
|
21
|
+
filter: Object,
|
|
22
|
+
filterOperators: Object,
|
|
23
|
+
sort: [Object, Array],
|
|
24
|
+
cellRender: [String, Function, Object],
|
|
25
|
+
isRtl: Boolean
|
|
26
|
+
},
|
|
27
|
+
inject: {
|
|
28
|
+
kendoLocalizationService: {
|
|
29
|
+
default: null
|
|
30
|
+
}
|
|
31
|
+
},
|
|
32
|
+
methods: {
|
|
33
|
+
headerCellClassName: function headerCellClassName(field, locked) {
|
|
34
|
+
var result = "".concat(locked ? 'k-grid-header-sticky' : '');
|
|
35
|
+
|
|
36
|
+
if (this.$props.sort && this.$props.sort.filter(function (descriptor) {
|
|
37
|
+
return descriptor.field === field;
|
|
38
|
+
}).length > 0) {
|
|
39
|
+
result += ' k-sorted';
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
return result;
|
|
43
|
+
},
|
|
44
|
+
setFilter: function setFilter(value, operator, field, e) {
|
|
45
|
+
var filters = [];
|
|
46
|
+
|
|
47
|
+
if (value !== '' && value !== null || operator !== '') {
|
|
48
|
+
filters.push({
|
|
49
|
+
field: field,
|
|
50
|
+
operator: operator,
|
|
51
|
+
value: value
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
if (this.$props.filter && this.$props.filter.filters) {
|
|
56
|
+
var oldFilters = this.$props.filter.filters || [];
|
|
57
|
+
oldFilters.forEach(function (filter) {
|
|
58
|
+
var descriptor = filter;
|
|
59
|
+
|
|
60
|
+
if (descriptor && descriptor.field !== field) {
|
|
61
|
+
filters.push(descriptor);
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
var filtersResult = filters.length > 0 ? {
|
|
67
|
+
logic: 'and',
|
|
68
|
+
filters: filters
|
|
69
|
+
} : null;
|
|
70
|
+
this.$emit('filterchange', filtersResult, e);
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
// @ts-ignore
|
|
74
|
+
setup: !isV3 ? undefined : function () {
|
|
75
|
+
var v3 = !!isV3;
|
|
76
|
+
var kendoLocalizationService = inject('kendoLocalizationService', {});
|
|
77
|
+
return {
|
|
78
|
+
v3: v3,
|
|
79
|
+
kendoLocalizationService: kendoLocalizationService
|
|
80
|
+
};
|
|
81
|
+
},
|
|
82
|
+
// @ts-ignore
|
|
83
|
+
render: function render(createElement) {
|
|
84
|
+
var h = gh || createElement;
|
|
85
|
+
var intl = provideLocalizationService(this);
|
|
86
|
+
var oldFilters = this.$props.filter && this.$props.filter.filters || [];
|
|
87
|
+
|
|
88
|
+
var activeFilterValueFor = function activeFilterValueFor(field, defaultValue) {
|
|
89
|
+
if (defaultValue === void 0) {
|
|
90
|
+
defaultValue = null;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
var found = oldFilters.filter(function (filter) {
|
|
94
|
+
return filter.field === field;
|
|
95
|
+
})[0];
|
|
96
|
+
return found ? found.value : defaultValue;
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
var activeOperatorFor = function activeOperatorFor(field) {
|
|
100
|
+
var found = oldFilters.filter(function (filter) {
|
|
101
|
+
return filter.field === field;
|
|
102
|
+
})[0];
|
|
103
|
+
return found ? found.operator : null;
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
var filterCellProps;
|
|
107
|
+
var serviceIndex = 0,
|
|
108
|
+
index = -1;
|
|
109
|
+
var filterCells = this.$props.columns.filter(function (c) {
|
|
110
|
+
return c.children.length === 0;
|
|
111
|
+
}).map(function (column) {
|
|
112
|
+
var _this = this;
|
|
113
|
+
|
|
114
|
+
var onChangeFn = function onChangeFn(e) {
|
|
115
|
+
_this.setFilter(e.value, e.operator, column.field, e);
|
|
116
|
+
};
|
|
117
|
+
|
|
118
|
+
var filterType = getFilterType(column.filter); // @ts-ignore
|
|
119
|
+
|
|
120
|
+
var filterRender = h(GridFilterCell, {
|
|
121
|
+
grid: this.$props.grid,
|
|
122
|
+
attrs: this.v3 ? undefined : {
|
|
123
|
+
grid: this.$props.grid,
|
|
124
|
+
field: column.field,
|
|
125
|
+
title: column.filterTitle,
|
|
126
|
+
value: activeFilterValueFor(column.field, filterType === 'text' ? '' : null),
|
|
127
|
+
operator: activeOperatorFor(column.field),
|
|
128
|
+
operators: operatorMap(this.$props.filterOperators[filterType] || [], intl),
|
|
129
|
+
booleanValues: operatorMap(booleanFilterValues, intl),
|
|
130
|
+
filterType: filterType,
|
|
131
|
+
render: column.filterCell || this.$props.cellRender
|
|
132
|
+
},
|
|
133
|
+
field: column.field,
|
|
134
|
+
title: column.filterTitle,
|
|
135
|
+
value: activeFilterValueFor(column.field, filterType === 'text' ? '' : null),
|
|
136
|
+
operator: activeOperatorFor(column.field),
|
|
137
|
+
operators: operatorMap(this.$props.filterOperators[filterType] || [], intl),
|
|
138
|
+
booleanValues: operatorMap(booleanFilterValues, intl),
|
|
139
|
+
filterType: filterType,
|
|
140
|
+
onChange: onChangeFn,
|
|
141
|
+
on: this.v3 ? undefined : {
|
|
142
|
+
"change": onChangeFn
|
|
143
|
+
},
|
|
144
|
+
render: column.filterCell || this.$props.cellRender
|
|
145
|
+
});
|
|
146
|
+
var key = column.declarationIndex >= 0 ? ++index : --serviceIndex;
|
|
147
|
+
var ariaAttrs = {
|
|
148
|
+
ariaLabel: column.filterable ? intl.toLanguageString(filterAriaLabel, messages[filterAriaLabel]) : undefined,
|
|
149
|
+
ariaColumnIndex: column.ariaColumnIndex
|
|
150
|
+
};
|
|
151
|
+
var style = column.left !== undefined ? !this.$props.isRtl ? {
|
|
152
|
+
left: column.left + 'px',
|
|
153
|
+
right: column.right + 'px'
|
|
154
|
+
} : {
|
|
155
|
+
left: column.right + 'px',
|
|
156
|
+
right: column.left + 'px'
|
|
157
|
+
} : {};
|
|
158
|
+
var filterCell = // @ts-ignore function children
|
|
159
|
+
h(HeaderThElement, {
|
|
160
|
+
key: key,
|
|
161
|
+
columnId: navigationTools.getFilterColumnId(column.id),
|
|
162
|
+
attrs: this.v3 ? undefined : {
|
|
163
|
+
columnId: navigationTools.getFilterColumnId(column.id),
|
|
164
|
+
navigatable: column.navigatable,
|
|
165
|
+
ariaLabel: ariaAttrs.ariaLabel,
|
|
166
|
+
ariaColumnIndex: ariaAttrs.ariaColumnIndex
|
|
167
|
+
},
|
|
168
|
+
navigatable: column.navigatable,
|
|
169
|
+
style: style,
|
|
170
|
+
"class": this.headerCellClassName(column.field, column.locked) || undefined,
|
|
171
|
+
ariaLabel: ariaAttrs.ariaLabel,
|
|
172
|
+
ariaColumnIndex: ariaAttrs.ariaColumnIndex
|
|
173
|
+
}, this.v3 ? function () {
|
|
174
|
+
return [filterRender];
|
|
175
|
+
} : [filterRender]);
|
|
176
|
+
return column.filterable && filterCell || // @ts-ignore function children
|
|
177
|
+
h(HeaderThElement, {
|
|
178
|
+
key: key,
|
|
179
|
+
columnId: navigationTools.getFilterColumnId(column.id),
|
|
180
|
+
attrs: this.v3 ? undefined : {
|
|
181
|
+
columnId: navigationTools.getFilterColumnId(column.id),
|
|
182
|
+
navigatable: column.navigatable,
|
|
183
|
+
ariaLabel: ariaAttrs.ariaLabel,
|
|
184
|
+
ariaColumnIndex: ariaAttrs.ariaColumnIndex
|
|
185
|
+
},
|
|
186
|
+
navigatable: column.navigatable,
|
|
187
|
+
style: style,
|
|
188
|
+
"class": this.headerCellClassName(column.field, column.locked) || undefined,
|
|
189
|
+
ariaLabel: ariaAttrs.ariaLabel,
|
|
190
|
+
ariaColumnIndex: ariaAttrs.ariaColumnIndex
|
|
191
|
+
});
|
|
192
|
+
}, this);
|
|
193
|
+
return h("tr", {
|
|
194
|
+
"class": "k-filter-row"
|
|
195
|
+
}, [filterCells]);
|
|
196
|
+
}
|
|
197
|
+
};
|
|
198
|
+
/**
|
|
199
|
+
* @hidden
|
|
200
|
+
*/
|
|
201
|
+
|
|
202
|
+
var FilterRow = FilterRowVue2;
|
|
203
|
+
export { FilterRow, FilterRowVue2 };
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { GridHeaderCellProps } from '../interfaces/GridHeaderCellProps';
|
|
2
|
+
declare type DefaultData<V> = object | ((this: V) => {});
|
|
3
|
+
declare type DefaultMethods<V> = {
|
|
4
|
+
[key: string]: (this: V, ...args: any[]) => any;
|
|
5
|
+
};
|
|
6
|
+
import { DefineComponent, RecordPropsDefinition, ComponentOptions, Vue2type } from '../additionalTypes';
|
|
7
|
+
/**
|
|
8
|
+
* @hidden
|
|
9
|
+
*/
|
|
10
|
+
export interface GridHeaderCellMethods extends Vue2type {
|
|
11
|
+
clickHandler: (event: any) => void;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* @hidden
|
|
15
|
+
*/
|
|
16
|
+
declare let GridHeaderCellVue2: ComponentOptions<Vue2type, DefaultData<{}>, DefaultMethods<GridHeaderCellMethods>, {}, RecordPropsDefinition<GridHeaderCellProps>>;
|
|
17
|
+
/**
|
|
18
|
+
* @hidden
|
|
19
|
+
*/
|
|
20
|
+
declare const GridHeaderCell: DefineComponent<GridHeaderCellProps, any, {}, {}, GridHeaderCellMethods, {}, {}, {}, string, GridHeaderCellProps, GridHeaderCellProps, {}>;
|
|
21
|
+
export { GridHeaderCell, GridHeaderCellVue2 };
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
// @ts-ignore
|
|
2
|
+
import * as Vue from 'vue';
|
|
3
|
+
var allVue = Vue;
|
|
4
|
+
var gh = allVue.h;
|
|
5
|
+
var isV3 = allVue.version && allVue.version[0] === '3';
|
|
6
|
+
import { getTemplate, getDefaultSlots } from '@progress/kendo-vue-common';
|
|
7
|
+
/**
|
|
8
|
+
* @hidden
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
var GridHeaderCellVue2 = {
|
|
12
|
+
props: {
|
|
13
|
+
field: String,
|
|
14
|
+
title: String,
|
|
15
|
+
sortable: [Boolean, Object],
|
|
16
|
+
render: [Object, Function, String]
|
|
17
|
+
},
|
|
18
|
+
methods: {
|
|
19
|
+
clickHandler: function clickHandler(event) {
|
|
20
|
+
this.$emit('headercellclick', event);
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
// @ts-ignore
|
|
24
|
+
setup: !isV3 ? undefined : function () {
|
|
25
|
+
var v3 = !!isV3;
|
|
26
|
+
return {
|
|
27
|
+
v3: v3
|
|
28
|
+
};
|
|
29
|
+
},
|
|
30
|
+
// @ts-ignore
|
|
31
|
+
render: function render(createElement) {
|
|
32
|
+
var h = gh || createElement;
|
|
33
|
+
var defaultSlot = getDefaultSlots(this);
|
|
34
|
+
var renderTemplate = this.$props.render;
|
|
35
|
+
var textInCell = this.$props.title || this.$props.field || "\xA0";
|
|
36
|
+
var defaultRendering = this.$props.sortable ? h("span", {
|
|
37
|
+
"class": "k-link",
|
|
38
|
+
onClick: this.clickHandler,
|
|
39
|
+
on: this.v3 ? undefined : {
|
|
40
|
+
"click": this.clickHandler
|
|
41
|
+
}
|
|
42
|
+
}, [textInCell, defaultSlot]) : defaultSlot ? h("span", [textInCell, defaultSlot]) // @ts-ignore
|
|
43
|
+
: this.v3 ? textInCell : this._v(textInCell);
|
|
44
|
+
return getTemplate.call(this, {
|
|
45
|
+
h: h,
|
|
46
|
+
template: renderTemplate,
|
|
47
|
+
defaultRendering: defaultRendering,
|
|
48
|
+
additionalProps: this.$props,
|
|
49
|
+
additionalListeners: {
|
|
50
|
+
click: this.clickHandler
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
/**
|
|
56
|
+
* @hidden
|
|
57
|
+
*/
|
|
58
|
+
|
|
59
|
+
var GridHeaderCell = GridHeaderCellVue2;
|
|
60
|
+
export { GridHeaderCell, GridHeaderCellVue2 };
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { GridHeaderSelectionCellProps } from '../interfaces/GridHeaderSelectionCellProps';
|
|
2
|
+
declare type DefaultData<V> = object | ((this: V) => GridHeaderSelectionCellData);
|
|
3
|
+
declare type DefaultMethods<V> = {
|
|
4
|
+
[key: string]: (this: V, ...args: any[]) => any;
|
|
5
|
+
};
|
|
6
|
+
import { DefineComponent, RecordPropsDefinition, ComponentOptions, Vue2type } from '../additionalTypes';
|
|
7
|
+
/**
|
|
8
|
+
* @hidden
|
|
9
|
+
*/
|
|
10
|
+
export interface GridHeaderSelectionCellMethods extends Vue2type {
|
|
11
|
+
changeHandle: (e: any) => void;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* @hidden
|
|
15
|
+
*/
|
|
16
|
+
export interface GridHeaderSelectionCellData {
|
|
17
|
+
inputId: string;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* @hidden
|
|
21
|
+
*/
|
|
22
|
+
export interface GridHeaderSelectionCellAll extends GridHeaderSelectionCellMethods, GridHeaderSelectionCellData {
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* @hidden
|
|
26
|
+
*/
|
|
27
|
+
declare let GridHeaderSelectionCellVue2: ComponentOptions<Vue2type, DefaultData<GridHeaderSelectionCellData>, DefaultMethods<GridHeaderSelectionCellAll>, {}, RecordPropsDefinition<GridHeaderSelectionCellProps>>;
|
|
28
|
+
/**
|
|
29
|
+
* @hidden
|
|
30
|
+
*/
|
|
31
|
+
declare const GridHeaderSelectionCell: DefineComponent<GridHeaderSelectionCellProps, any, GridHeaderSelectionCellData, {}, GridHeaderSelectionCellMethods, {}, {}, {}, string, GridHeaderSelectionCellProps, GridHeaderSelectionCellProps, {}>;
|
|
32
|
+
export { GridHeaderSelectionCell, GridHeaderSelectionCellVue2 };
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
// @ts-ignore
|
|
2
|
+
import * as Vue from 'vue';
|
|
3
|
+
var allVue = Vue;
|
|
4
|
+
var gh = allVue.h;
|
|
5
|
+
var isV3 = allVue.version && allVue.version[0] === '3';
|
|
6
|
+
import { guid, getTemplate } from '@progress/kendo-vue-common';
|
|
7
|
+
/**
|
|
8
|
+
* @hidden
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
var GridHeaderSelectionCellVue2 = {
|
|
12
|
+
props: {
|
|
13
|
+
field: String,
|
|
14
|
+
title: String,
|
|
15
|
+
selectionValue: Boolean,
|
|
16
|
+
render: [Object, Function, String]
|
|
17
|
+
},
|
|
18
|
+
created: function created() {
|
|
19
|
+
this.inputId = guid();
|
|
20
|
+
},
|
|
21
|
+
methods: {
|
|
22
|
+
changeHandle: function changeHandle(e) {
|
|
23
|
+
this.$emit('selectionchange', {
|
|
24
|
+
field: this.$props.field,
|
|
25
|
+
event: e
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
},
|
|
29
|
+
// @ts-ignore
|
|
30
|
+
setup: !isV3 ? undefined : function () {
|
|
31
|
+
var v3 = !!isV3;
|
|
32
|
+
return {
|
|
33
|
+
v3: v3
|
|
34
|
+
};
|
|
35
|
+
},
|
|
36
|
+
// @ts-ignore
|
|
37
|
+
render: function render(createElement) {
|
|
38
|
+
var h = gh || createElement;
|
|
39
|
+
var renderTemplate = this.$props.render;
|
|
40
|
+
var defaultRendering = h("span", [[h("input", {
|
|
41
|
+
key: 0,
|
|
42
|
+
checked: this.v3 ? this.$props.selectionValue : null,
|
|
43
|
+
domProps: this.v3 ? undefined : {
|
|
44
|
+
"checked": this.$props.selectionValue
|
|
45
|
+
},
|
|
46
|
+
id: this.inputId,
|
|
47
|
+
attrs: this.v3 ? undefined : {
|
|
48
|
+
id: this.inputId,
|
|
49
|
+
type: "checkbox"
|
|
50
|
+
},
|
|
51
|
+
type: "checkbox",
|
|
52
|
+
"class": "k-checkbox k-checkbox-md k-rounded-md",
|
|
53
|
+
onChange: this.changeHandle,
|
|
54
|
+
on: this.v3 ? undefined : {
|
|
55
|
+
"change": this.changeHandle
|
|
56
|
+
}
|
|
57
|
+
}), h("label", {
|
|
58
|
+
key: 1,
|
|
59
|
+
"class": "k-checkbox-label",
|
|
60
|
+
"for": this.inputId,
|
|
61
|
+
attrs: this.v3 ? undefined : {
|
|
62
|
+
"for": this.inputId
|
|
63
|
+
}
|
|
64
|
+
})]]);
|
|
65
|
+
return getTemplate.call(this, {
|
|
66
|
+
h: h,
|
|
67
|
+
template: renderTemplate,
|
|
68
|
+
defaultRendering: defaultRendering,
|
|
69
|
+
additionalProps: this.$props,
|
|
70
|
+
additionalListeners: {
|
|
71
|
+
selectionchange: this.changeHandle
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
/**
|
|
77
|
+
* @hidden
|
|
78
|
+
*/
|
|
79
|
+
|
|
80
|
+
var GridHeaderSelectionCell = GridHeaderSelectionCellVue2;
|
|
81
|
+
export { GridHeaderSelectionCell, GridHeaderSelectionCellVue2 };
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { DefineComponent, RecordPropsDefinition, ComponentOptions, Vue2type } from '../additionalTypes';
|
|
2
|
+
import { GroupDescriptor } from '@progress/kendo-data-query';
|
|
3
|
+
import { ColumnDraggableProps } from '../drag/ColumnDraggable';
|
|
4
|
+
declare type DefaultData<V> = object | ((this: V) => {});
|
|
5
|
+
declare type DefaultMethods<V> = {
|
|
6
|
+
[key: string]: (this: V, ...args: any[]) => any;
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* @hidden
|
|
10
|
+
*/
|
|
11
|
+
export interface GroupPanelProps extends ColumnDraggableProps {
|
|
12
|
+
ref?: any;
|
|
13
|
+
group: GroupDescriptor[];
|
|
14
|
+
onGroupChange?: (groups: GroupDescriptor[], event: any) => void;
|
|
15
|
+
resolveTitle: (field: string) => string;
|
|
16
|
+
onPressHandler?: (draggableEvent: any, element: HTMLElement) => void;
|
|
17
|
+
onDragHandler?: (draggableEvent: any, element: HTMLElement) => void;
|
|
18
|
+
onReleaseHandler?: (draggableEvent: any) => void;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* @hidden
|
|
22
|
+
*/
|
|
23
|
+
export interface GroupPanelMethods extends Vue2type {
|
|
24
|
+
pressHandler: (event: any, element: HTMLElement) => void;
|
|
25
|
+
dragHandler: (event: any, element: HTMLElement) => void;
|
|
26
|
+
releaseHandler: (event: any) => void;
|
|
27
|
+
onGroupRemove: (event: any, index: number) => void;
|
|
28
|
+
onGroupSortChange: (event: any, index: number, groupDesc: GroupDescriptor, dir: string) => void;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* @hidden
|
|
32
|
+
*/
|
|
33
|
+
declare let GroupPanelVue2: ComponentOptions<Vue2type, DefaultData<{}>, DefaultMethods<GroupPanelMethods>, {}, RecordPropsDefinition<GroupPanelProps>>;
|
|
34
|
+
/**
|
|
35
|
+
* @hidden
|
|
36
|
+
*/
|
|
37
|
+
declare const GroupPanel: DefineComponent<GroupPanelProps, any, {}, {}, GroupPanelMethods, {}, {}, {}, string, GroupPanelProps, GroupPanelProps, {}>;
|
|
38
|
+
export { GroupPanel, GroupPanelVue2 };
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
// @ts-ignore
|
|
2
|
+
import * as Vue from 'vue';
|
|
3
|
+
var allVue = Vue;
|
|
4
|
+
var gh = allVue.h;
|
|
5
|
+
var isV3 = allVue.version && allVue.version[0] === '3';
|
|
6
|
+
var inject = allVue.inject;
|
|
7
|
+
import { GroupingIndicator } from '../drag/GroupingIndicator.js';
|
|
8
|
+
import { messages, groupPanelEmpty as messageKey } from './../messages.js';
|
|
9
|
+
import { provideLocalizationService } from '@progress/kendo-vue-intl';
|
|
10
|
+
/**
|
|
11
|
+
* @hidden
|
|
12
|
+
*/
|
|
13
|
+
|
|
14
|
+
var GroupPanelVue2 = {
|
|
15
|
+
props: {
|
|
16
|
+
group: Array,
|
|
17
|
+
resolveTitle: Function
|
|
18
|
+
},
|
|
19
|
+
inject: {
|
|
20
|
+
kendoLocalizationService: {
|
|
21
|
+
default: null
|
|
22
|
+
}
|
|
23
|
+
},
|
|
24
|
+
methods: {
|
|
25
|
+
pressHandler: function pressHandler(event, element) {
|
|
26
|
+
this.$emit('pressHandler', event, element);
|
|
27
|
+
},
|
|
28
|
+
dragHandler: function dragHandler(event, element) {
|
|
29
|
+
this.$emit('dragHandler', event, element);
|
|
30
|
+
},
|
|
31
|
+
releaseHandler: function releaseHandler(event) {
|
|
32
|
+
this.$emit('releaseHandler', event);
|
|
33
|
+
},
|
|
34
|
+
onGroupRemove: function onGroupRemove(event, index) {
|
|
35
|
+
var newGroups = this.$props.group.slice();
|
|
36
|
+
newGroups.splice(index, 1);
|
|
37
|
+
this.$emit('groupChange', newGroups, event);
|
|
38
|
+
},
|
|
39
|
+
onGroupSortChange: function onGroupSortChange(event, index, groupDesc, dir) {
|
|
40
|
+
var group = Object.assign({}, groupDesc, {
|
|
41
|
+
dir: dir
|
|
42
|
+
});
|
|
43
|
+
var newGroups = this.$props.group.slice();
|
|
44
|
+
newGroups.splice(index, 1, group);
|
|
45
|
+
this.$emit('groupChange', newGroups, event);
|
|
46
|
+
}
|
|
47
|
+
},
|
|
48
|
+
// @ts-ignore
|
|
49
|
+
setup: !isV3 ? undefined : function () {
|
|
50
|
+
var v3 = !!isV3;
|
|
51
|
+
var kendoLocalizationService = inject('kendoLocalizationService', {});
|
|
52
|
+
return {
|
|
53
|
+
v3: v3,
|
|
54
|
+
kendoLocalizationService: kendoLocalizationService
|
|
55
|
+
};
|
|
56
|
+
},
|
|
57
|
+
// @ts-ignore
|
|
58
|
+
render: function render(createElement) {
|
|
59
|
+
var h = gh || createElement;
|
|
60
|
+
var groupsProp = this.$props.group || [];
|
|
61
|
+
var groups = groupsProp.map(function (groupDesc, index) {
|
|
62
|
+
var _this = this;
|
|
63
|
+
|
|
64
|
+
return (// @ts-ignore
|
|
65
|
+
h(GroupingIndicator, {
|
|
66
|
+
key: index,
|
|
67
|
+
dir: groupDesc.dir || 'asc',
|
|
68
|
+
attrs: this.v3 ? undefined : {
|
|
69
|
+
dir: groupDesc.dir || 'asc',
|
|
70
|
+
title: this.$props.resolveTitle(groupDesc.field)
|
|
71
|
+
},
|
|
72
|
+
title: this.$props.resolveTitle(groupDesc.field),
|
|
73
|
+
onRemove: function onRemove(event) {
|
|
74
|
+
return _this.onGroupRemove(event, index);
|
|
75
|
+
},
|
|
76
|
+
on: this.v3 ? undefined : {
|
|
77
|
+
"remove": function onRemove(event) {
|
|
78
|
+
return _this.onGroupRemove(event, index);
|
|
79
|
+
},
|
|
80
|
+
"sortChange": function sortChange(event, dir) {
|
|
81
|
+
_this.onGroupSortChange(event, index, groupDesc, dir);
|
|
82
|
+
},
|
|
83
|
+
"press": this.pressHandler,
|
|
84
|
+
"drag": this.dragHandler,
|
|
85
|
+
"release": this.releaseHandler
|
|
86
|
+
},
|
|
87
|
+
onSortChange: function sortChange(event, dir) {
|
|
88
|
+
_this.onGroupSortChange(event, index, groupDesc, dir);
|
|
89
|
+
},
|
|
90
|
+
onPress: this.pressHandler,
|
|
91
|
+
onDrag: this.dragHandler,
|
|
92
|
+
onRelease: this.releaseHandler
|
|
93
|
+
})
|
|
94
|
+
);
|
|
95
|
+
}, this);
|
|
96
|
+
return h("div", {
|
|
97
|
+
"class": "k-grouping-header k-grouping-header-flex"
|
|
98
|
+
}, [groups, h("div", {
|
|
99
|
+
"class": "k-indicator-container"
|
|
100
|
+
}, [!groups.length && provideLocalizationService(this).toLanguageString(messageKey, messages[messageKey])])]);
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
/**
|
|
104
|
+
* @hidden
|
|
105
|
+
*/
|
|
106
|
+
|
|
107
|
+
var GroupPanel = GroupPanelVue2;
|
|
108
|
+
export { GroupPanel, GroupPanelVue2 };
|