@revolist/revogrid 3.0.96 → 3.0.99

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.
Files changed (50) hide show
  1. package/custom-element/index.js +147 -56
  2. package/dist/cjs/loader.cjs.js +1 -1
  3. package/dist/cjs/revo-grid.cjs.js +1 -1
  4. package/dist/cjs/revo-grid_11.cjs.entry.js +115 -49
  5. package/dist/cjs/revogr-filter-panel.cjs.entry.js +31 -6
  6. package/dist/collection/components/data/revogr-data-style.css +8 -0
  7. package/dist/collection/components/header/revogr-header-style.css +8 -0
  8. package/dist/collection/components/overlay/editors/text.js +1 -1
  9. package/dist/collection/components/overlay/revogr-edit-style.css +8 -0
  10. package/dist/collection/components/overlay/revogr-overlay-selection.js +3 -0
  11. package/dist/collection/components/overlay/revogr-overlay-style.css +8 -0
  12. package/dist/collection/components/revo-grid/revo-grid-style.css +8 -0
  13. package/dist/collection/components/revo-grid/revo-grid.js +40 -10
  14. package/dist/collection/components/revo-grid/viewport.service.js +3 -0
  15. package/dist/collection/components/scroll/revogr-viewport-scroll-style.css +8 -0
  16. package/dist/collection/components/scrollable/revogr-scroll-style.css +8 -0
  17. package/dist/collection/components/selection-focus/revogr-focus-style.css +8 -0
  18. package/dist/collection/components/selection-temp-range/revogr-temp-range-style.css +8 -0
  19. package/dist/collection/plugins/filter/conditions/equal.js +1 -1
  20. package/dist/collection/plugins/filter/filter.plugin.js +11 -1
  21. package/dist/collection/plugins/filter/filter.pop.js +54 -7
  22. package/dist/collection/plugins/filter/filter.style.css +14 -1
  23. package/dist/collection/plugins/sorting/sorting.plugin.js +70 -32
  24. package/dist/collection/services/column.data.provider.js +4 -2
  25. package/dist/collection/services/selection.store.connector.js +4 -0
  26. package/dist/collection/utilsExternal/generate-data.js +7 -1
  27. package/dist/esm/loader.js +1 -1
  28. package/dist/esm/revo-grid.js +1 -1
  29. package/dist/esm/revo-grid_11.entry.js +115 -49
  30. package/dist/esm/revogr-filter-panel.entry.js +31 -6
  31. package/dist/esm-es5/loader.js +1 -1
  32. package/dist/esm-es5/revo-grid.js +1 -1
  33. package/dist/esm-es5/revo-grid_11.entry.js +1 -1
  34. package/dist/esm-es5/revogr-filter-panel.entry.js +1 -1
  35. package/dist/revo-grid/revo-grid.esm.js +1 -1
  36. package/dist/revo-grid/revo-grid.system.js +1 -1
  37. package/dist/revo-grid/revo-grid_11.entry.js +1 -1
  38. package/dist/revo-grid/revo-grid_11.system.entry.js +1 -1
  39. package/dist/revo-grid/revogr-filter-panel.entry.js +1 -1
  40. package/dist/revo-grid/revogr-filter-panel.system.entry.js +1 -1
  41. package/dist/types/components/revo-grid/revo-grid.d.ts +8 -2
  42. package/dist/types/components/revo-grid/viewport.service.d.ts +1 -0
  43. package/dist/types/components.d.ts +11 -3
  44. package/dist/types/interfaces.d.ts +3 -0
  45. package/dist/types/plugins/filter/filter.plugin.d.ts +12 -0
  46. package/dist/types/plugins/filter/filter.pop.d.ts +6 -0
  47. package/dist/types/plugins/sorting/sorting.plugin.d.ts +3 -1
  48. package/dist/types/services/column.data.provider.d.ts +1 -1
  49. package/dist/types/services/selection.store.connector.d.ts +1 -0
  50. package/package.json +1 -1
@@ -1,5 +1,6 @@
1
1
  import size from 'lodash/size';
2
2
  import { setStore } from '../../utils/store.utils';
3
+ import ColumnDataProvider from '../../services/column.data.provider';
3
4
  import BasePlugin from '../basePlugin';
4
5
  /**
5
6
  * lifecycle
@@ -15,6 +16,7 @@ export default class SortingPlugin extends BasePlugin {
15
16
  super(revogrid);
16
17
  this.revogrid = revogrid;
17
18
  this.sorting = null;
19
+ this.sortingFunc = null;
18
20
  const beforesourceset = ({ detail }) => {
19
21
  if (this.hasSorting) {
20
22
  // is sorting allowed
@@ -29,15 +31,25 @@ export default class SortingPlugin extends BasePlugin {
29
31
  detail.source = data;
30
32
  }
31
33
  };
32
- const aftercolumnsset = async ({ detail: { order } }) => this.sort(order);
34
+ const aftercolumnsset = async ({ detail: { order } }) => {
35
+ const columns = await this.revogrid.getColumns();
36
+ const sortingFunc = {};
37
+ for (let prop in order) {
38
+ const column = ColumnDataProvider.getColumnByProp(columns, prop);
39
+ const cmp = (column === null || column === void 0 ? void 0 : column.cellCompare) || this.defaultCellCompare;
40
+ sortingFunc[prop] = order[prop] == 'desc' ? this.descCellCompare(cmp) : cmp;
41
+ }
42
+ this.sort(order, sortingFunc);
43
+ };
33
44
  const headerclick = async (e) => {
45
+ var _a, _b;
34
46
  if (e.defaultPrevented) {
35
47
  return;
36
48
  }
37
49
  if (!e.detail.column.sortable) {
38
50
  return;
39
51
  }
40
- this.headerclick(e.detail.column, e.detail.index);
52
+ this.headerclick(e.detail.column, e.detail.index, (_b = (_a = e.detail) === null || _a === void 0 ? void 0 : _a.originalEvent) === null || _b === void 0 ? void 0 : _b.shiftKey);
41
53
  };
42
54
  this.addEventListener('beforesourceset', beforesourceset);
43
55
  this.addEventListener('aftercolumnsset', aftercolumnsset);
@@ -46,26 +58,45 @@ export default class SortingPlugin extends BasePlugin {
46
58
  get hasSorting() {
47
59
  return !!this.sorting;
48
60
  }
49
- async headerclick(column, index) {
61
+ async headerclick(column, index, additive) {
50
62
  let order = this.getNextOrder(column.order);
51
- const beforeEvent = this.emit('beforesorting', { column, order });
63
+ const beforeEvent = this.emit('beforesorting', { column, order, additive });
52
64
  if (beforeEvent.defaultPrevented) {
53
65
  return;
54
66
  }
55
67
  order = beforeEvent.detail.order;
56
- const newCol = await this.revogrid.updateColumnSorting(beforeEvent.detail.column, index, order);
68
+ const newCol = await this.revogrid.updateColumnSorting(beforeEvent.detail.column, index, order, additive);
57
69
  // apply sort data
58
- const beforeApplyEvent = this.emit('beforesortingapply', { column: newCol, order });
70
+ const beforeApplyEvent = this.emit('beforesortingapply', { column: newCol, order, additive });
59
71
  if (beforeApplyEvent.defaultPrevented) {
60
72
  return;
61
73
  }
62
74
  order = beforeApplyEvent.detail.order;
63
- this.sort({ [column.prop]: order });
75
+ const cellCmp = (column === null || column === void 0 ? void 0 : column.cellCompare) || this.defaultCellCompare;
76
+ const cmp = order == 'asc' ? cellCmp : order == 'desc' ? this.descCellCompare(cellCmp) : undefined;
77
+ if (additive && this.sorting) {
78
+ const sorting = {};
79
+ const sortingFunc = {};
80
+ Object.assign(sorting, this.sorting);
81
+ Object.assign(sortingFunc, this.sortingFunc);
82
+ if (column.prop in sorting && size(sorting) > 1 && order === undefined) {
83
+ delete sorting[column.prop];
84
+ delete sortingFunc[column.prop];
85
+ }
86
+ else {
87
+ sorting[column.prop] = order;
88
+ sortingFunc[column.prop] = cmp;
89
+ }
90
+ this.sort(sorting, sortingFunc);
91
+ }
92
+ else {
93
+ this.sort({ [column.prop]: order }, { [column.prop]: cmp });
94
+ }
64
95
  }
65
96
  setData(data, type) {
66
97
  // sorting available for rgRow type only
67
- if (type === 'rgRow' && this.sorting) {
68
- return this.sortItems(data, this.sorting);
98
+ if (type === 'rgRow' && this.sortingFunc) {
99
+ return this.sortItems(data, this.sortingFunc);
69
100
  }
70
101
  }
71
102
  /**
@@ -73,56 +104,63 @@ export default class SortingPlugin extends BasePlugin {
73
104
  * @param sorting - per column sorting
74
105
  * @param data - this.stores['rgRow'].store.get('source')
75
106
  */
76
- async sort(sorting) {
107
+ async sort(sorting, sortingFunc) {
77
108
  if (!size(sorting)) {
78
109
  this.sorting = null;
110
+ this.sortingFunc = null;
79
111
  return;
80
112
  }
81
113
  this.sorting = sorting;
114
+ this.sortingFunc = sortingFunc;
82
115
  const store = await this.revogrid.getSourceStore();
83
116
  const source = store.get('source');
84
- const proxyItems = this.sortIndexByItems([...store.get('proxyItems')], source, this.sorting);
117
+ const proxyItems = this.sortIndexByItems([...store.get('proxyItems')], source, this.sortingFunc);
85
118
  setStore(store, {
86
119
  proxyItems,
87
120
  source: [...source],
88
121
  });
89
122
  this.emit('afterSortingApply');
90
123
  }
91
- keySort(a, b, dir) {
92
- const directionIndex = dir === 'asc' ? 1 : -1;
93
- if (a === b) {
94
- return 0;
95
- }
96
- return (a === null || a === void 0 ? void 0 : a.toString().toLowerCase()) > (b === null || b === void 0 ? void 0 : b.toString().toLowerCase()) ?
97
- 1 * directionIndex : -1 * directionIndex;
124
+ defaultCellCompare(prop, a, b) {
125
+ var _a, _b;
126
+ const av = (_a = a[prop]) === null || _a === void 0 ? void 0 : _a.toString().toLowerCase();
127
+ const bv = (_b = b[prop]) === null || _b === void 0 ? void 0 : _b.toString().toLowerCase();
128
+ return av == bv ? 0 : av > bv ? 1 : -1;
129
+ }
130
+ descCellCompare(cmp) {
131
+ return (prop, a, b) => { return -1 * cmp(prop, a, b); };
98
132
  }
99
- sortIndexByItems(indexes, source, sorting) {
133
+ sortIndexByItems(indexes, source, sortingFunc) {
100
134
  // TODO - is there a situation where multiple kvps in the `sorting` object would cause this to break?
101
- for (let prop in sorting) {
102
- if (typeof sorting[prop] === 'undefined') {
135
+ for (let prop in sortingFunc) {
136
+ if (typeof sortingFunc[prop] === 'undefined') {
103
137
  // Unsort indexes
104
138
  return [...Array(indexes.length).keys()];
105
139
  }
106
140
  }
107
141
  return indexes.sort((a, b) => {
108
142
  let sorted = 0;
109
- for (let prop in sorting) {
110
- const dir = sorting[prop];
111
- const itemA = source[a][prop];
112
- const itemB = source[b][prop];
113
- sorted = this.keySort(itemA, itemB, dir);
143
+ for (let prop in sortingFunc) {
144
+ const cmp = sortingFunc[prop];
145
+ const itemA = source[a];
146
+ const itemB = source[b];
147
+ sorted = cmp(prop, itemA, itemB);
148
+ if (sorted) {
149
+ break;
150
+ }
114
151
  }
115
152
  return sorted;
116
153
  });
117
154
  }
118
- sortItems(source, sorting) {
155
+ sortItems(source, sortingFunc) {
119
156
  return source.sort((a, b) => {
120
157
  let sorted = 0;
121
- for (let prop in sorting) {
122
- const dir = sorting[prop];
123
- const itemA = a[prop];
124
- const itemB = b[prop];
125
- sorted = this.keySort(itemA, itemB, dir);
158
+ for (let prop in sortingFunc) {
159
+ const cmp = sortingFunc[prop];
160
+ sorted = cmp(prop, a, b);
161
+ if (sorted) {
162
+ break;
163
+ }
126
164
  }
127
165
  return sorted;
128
166
  });
@@ -103,8 +103,10 @@ export default class ColumnDataProvider {
103
103
  const type = ColumnDataProvider.getColumnType(column);
104
104
  setSourceByVirtualIndex(this.dataSources[type].store, { [index]: column });
105
105
  }
106
- updateColumnSorting(column, index, sorting) {
107
- this.clearSorting();
106
+ updateColumnSorting(column, index, sorting, additive) {
107
+ if (!additive) {
108
+ this.clearSorting();
109
+ }
108
110
  column.order = sorting;
109
111
  this.sorting[column.prop] = column;
110
112
  this.updateColumn(column, index);
@@ -37,6 +37,10 @@ export default class SelectionStoreConnector {
37
37
  var _a;
38
38
  return (_a = this.focusedStore) === null || _a === void 0 ? void 0 : _a.entity.store.get('focus');
39
39
  }
40
+ get selectedRange() {
41
+ var _a;
42
+ return (_a = this.focusedStore) === null || _a === void 0 ? void 0 : _a.entity.store.get('range');
43
+ }
40
44
  registerSection(e) {
41
45
  if (!e) {
42
46
  this.sections.length = 0;
@@ -12,6 +12,11 @@ function generateHeader(index) {
12
12
  return label.toLowerCase();
13
13
  }
14
14
 
15
+ function naturalSort(prop,a,b) {
16
+
17
+ return a[prop].localeCompare(b[prop],"en",{numeric:true})
18
+ }
19
+
15
20
  const DEFAULT_CONFIG = {
16
21
  topPinned: [],
17
22
  groupedHeader: false,
@@ -61,7 +66,8 @@ export function generateFakeDataObject(config = {}) {
61
66
  name: generateHeader(rgCol),
62
67
  prop: rgCol,
63
68
  sortable: true,
64
- size: 200
69
+ size: 200,
70
+ cellCompare: (rgCol % 2) == 0 ? naturalSort : undefined
65
71
  };
66
72
 
67
73
  // apply config
@@ -24,7 +24,7 @@ const patchEsm = () => {
24
24
  const defineCustomElements = (win, options) => {
25
25
  if (typeof window === 'undefined') return Promise.resolve();
26
26
  return patchEsm().then(() => {
27
- return bootstrapLazy([["revogr-clipboard",[[0,"revogr-clipboard",{"doCopy":[64]},[[4,"paste","onPaste"],[4,"copy","copyStarted"]]]]],["revogr-filter-panel",[[0,"revogr-filter-panel",{"uuid":[1537],"filterTypes":[16],"filterNames":[16],"filterEntities":[16],"changes":[32],"show":[64],"getChanges":[64]},[[5,"mousedown","onMouseDown"]]]]],["revo-grid_11",[[0,"revo-grid",{"rowHeaders":[4,"row-headers"],"frameSize":[2,"frame-size"],"rowSize":[2,"row-size"],"colSize":[2,"col-size"],"range":[4],"readonly":[4],"resize":[4],"canFocus":[4,"can-focus"],"useClipboard":[4,"use-clipboard"],"columns":[16],"source":[16],"pinnedTopSource":[16],"pinnedBottomSource":[16],"rowDefinitions":[16],"editors":[16],"plugins":[16],"columnTypes":[16],"theme":[1537],"rowClass":[513,"row-class"],"autoSizeColumn":[4,"auto-size-column"],"filter":[4],"trimmedRows":[16],"exporting":[4],"grouping":[16],"stretch":[8],"extraElements":[32],"refresh":[64],"scrollToRow":[64],"scrollToColumnIndex":[64],"scrollToColumnProp":[64],"updateColumns":[64],"addTrimmed":[64],"scrollToCoordinate":[64],"setCellEdit":[64],"registerVNode":[64],"getSource":[64],"getVisibleSource":[64],"getSourceStore":[64],"getColumnStore":[64],"updateColumnSorting":[64],"clearSorting":[64],"getColumns":[64],"clearFocus":[64],"getPlugins":[64],"getFocused":[64]},[[0,"internalRowDragStart","onRowDragStarted"],[0,"internalRowDragEnd","onRowDragEnd"],[0,"internalRowDrag","onRowDrag"],[0,"internalRowMouseMove","onRowMouseMove"],[0,"internalCellEdit","onBeforeEdit"],[0,"internalRangeDataApply","onBeforeRangeEdit"],[0,"internalSelectionChanged","onRangeChanged"],[0,"initialRowDropped","onRowDropped"],[0,"initialHeaderClick","onHeaderClick"],[0,"internalFocusCell","onCellFocus"]]],[0,"revogr-row-headers",{"height":[2],"dataPorts":[16],"headerProp":[16],"uiid":[1],"resize":[4],"rowHeaderColumn":[16]}],[4,"revogr-overlay-selection",{"readonly":[4],"range":[4],"canDrag":[4,"can-drag"],"useClipboard":[4,"use-clipboard"],"selectionStore":[16],"dimensionRow":[16],"dimensionCol":[16],"dataStore":[16],"colData":[16],"lastCell":[16],"editors":[16]},[[5,"mousemove","onMouseMove"],[5,"mouseleave","onMouseOut"],[5,"mouseup","onMouseUp"],[0,"dragStartCell","onCellDrag"],[4,"keyup","onKeyUp"],[4,"keydown","onKeyDown"]]],[0,"revogr-focus",{"selectionStore":[16],"dimensionRow":[16],"dimensionCol":[16]}],[0,"revogr-scroll-virtual",{"dimension":[1],"viewportStore":[16],"dimensionStore":[16],"setScroll":[64],"changeScroll":[64]}],[0,"revogr-temp-range",{"selectionStore":[16],"dimensionRow":[16],"dimensionCol":[16]}],[0,"revogr-data",{"readonly":[4],"range":[4],"canDrag":[4,"can-drag"],"rowClass":[1,"row-class"],"rowSelectionStore":[16],"viewportRow":[16],"viewportCol":[16],"dimensionRow":[16],"colData":[16],"dataStore":[16]}],[0,"revogr-edit",{"editCell":[16],"column":[16],"editor":[16]}],[0,"revogr-header",{"viewportCol":[16],"dimensionCol":[16],"selectionStore":[16],"parent":[1],"groups":[16],"groupingDepth":[2,"grouping-depth"],"canResize":[4,"can-resize"],"colData":[16],"columnFilter":[4,"column-filter"]}],[0,"revogr-order-editor",{"parent":[16],"dimensionRow":[16],"dimensionCol":[16],"dataStore":[16],"dragStart":[64],"endOrder":[64],"clearOrder":[64]},[[5,"mouseleave","onMouseOut"],[5,"mouseup","onMouseUp"]]],[4,"revogr-viewport-scroll",{"contentWidth":[2,"content-width"],"contentHeight":[2,"content-height"],"setScroll":[64],"changeScroll":[64]}]]]], options);
27
+ return bootstrapLazy([["revogr-clipboard",[[0,"revogr-clipboard",{"doCopy":[64]},[[4,"paste","onPaste"],[4,"copy","copyStarted"]]]]],["revogr-filter-panel",[[0,"revogr-filter-panel",{"uuid":[1537],"filterTypes":[16],"filterNames":[16],"filterEntities":[16],"filterCaptions":[16],"changes":[32],"show":[64],"getChanges":[64]},[[5,"mousedown","onMouseDown"]]]]],["revo-grid_11",[[0,"revo-grid",{"rowHeaders":[4,"row-headers"],"frameSize":[2,"frame-size"],"rowSize":[2,"row-size"],"colSize":[2,"col-size"],"range":[4],"readonly":[4],"resize":[4],"canFocus":[4,"can-focus"],"useClipboard":[4,"use-clipboard"],"columns":[16],"source":[16],"pinnedTopSource":[16],"pinnedBottomSource":[16],"rowDefinitions":[16],"editors":[16],"plugins":[16],"columnTypes":[16],"theme":[1537],"rowClass":[513,"row-class"],"autoSizeColumn":[4,"auto-size-column"],"filter":[4],"trimmedRows":[16],"exporting":[4],"grouping":[16],"stretch":[8],"extraElements":[32],"refresh":[64],"scrollToRow":[64],"scrollToColumnIndex":[64],"scrollToColumnProp":[64],"updateColumns":[64],"addTrimmed":[64],"scrollToCoordinate":[64],"setCellEdit":[64],"registerVNode":[64],"getSource":[64],"getVisibleSource":[64],"getSourceStore":[64],"getColumnStore":[64],"updateColumnSorting":[64],"clearSorting":[64],"getColumns":[64],"clearFocus":[64],"getPlugins":[64],"getFocused":[64],"getSelectedRange":[64]},[[0,"internalRowDragStart","onRowDragStarted"],[0,"internalRowDragEnd","onRowDragEnd"],[0,"internalRowDrag","onRowDrag"],[0,"internalRowMouseMove","onRowMouseMove"],[0,"internalCellEdit","onBeforeEdit"],[0,"internalRangeDataApply","onBeforeRangeEdit"],[0,"internalSelectionChanged","onRangeChanged"],[0,"initialRowDropped","onRowDropped"],[0,"initialHeaderClick","onHeaderClick"],[0,"internalFocusCell","onCellFocus"]]],[0,"revogr-row-headers",{"height":[2],"dataPorts":[16],"headerProp":[16],"uiid":[1],"resize":[4],"rowHeaderColumn":[16]}],[4,"revogr-overlay-selection",{"readonly":[4],"range":[4],"canDrag":[4,"can-drag"],"useClipboard":[4,"use-clipboard"],"selectionStore":[16],"dimensionRow":[16],"dimensionCol":[16],"dataStore":[16],"colData":[16],"lastCell":[16],"editors":[16]},[[5,"mousemove","onMouseMove"],[5,"mouseleave","onMouseOut"],[5,"mouseup","onMouseUp"],[0,"dragStartCell","onCellDrag"],[4,"keyup","onKeyUp"],[4,"keydown","onKeyDown"]]],[0,"revogr-focus",{"selectionStore":[16],"dimensionRow":[16],"dimensionCol":[16]}],[0,"revogr-scroll-virtual",{"dimension":[1],"viewportStore":[16],"dimensionStore":[16],"setScroll":[64],"changeScroll":[64]}],[0,"revogr-temp-range",{"selectionStore":[16],"dimensionRow":[16],"dimensionCol":[16]}],[0,"revogr-data",{"readonly":[4],"range":[4],"canDrag":[4,"can-drag"],"rowClass":[1,"row-class"],"rowSelectionStore":[16],"viewportRow":[16],"viewportCol":[16],"dimensionRow":[16],"colData":[16],"dataStore":[16]}],[0,"revogr-edit",{"editCell":[16],"column":[16],"editor":[16]}],[0,"revogr-header",{"viewportCol":[16],"dimensionCol":[16],"selectionStore":[16],"parent":[1],"groups":[16],"groupingDepth":[2,"grouping-depth"],"canResize":[4,"can-resize"],"colData":[16],"columnFilter":[4,"column-filter"]}],[0,"revogr-order-editor",{"parent":[16],"dimensionRow":[16],"dimensionCol":[16],"dataStore":[16],"dragStart":[64],"endOrder":[64],"clearOrder":[64]},[[5,"mouseleave","onMouseOut"],[5,"mouseup","onMouseUp"]]],[4,"revogr-viewport-scroll",{"contentWidth":[2,"content-width"],"contentHeight":[2,"content-height"],"setScroll":[64],"changeScroll":[64]}]]]], options);
28
28
  });
29
29
  };
30
30
 
@@ -67,5 +67,5 @@ const patchDynamicImport = (base, orgScriptElm) => {
67
67
  };
68
68
 
69
69
  patchBrowser().then(options => {
70
- return bootstrapLazy([["revogr-clipboard",[[0,"revogr-clipboard",{"doCopy":[64]},[[4,"paste","onPaste"],[4,"copy","copyStarted"]]]]],["revogr-filter-panel",[[0,"revogr-filter-panel",{"uuid":[1537],"filterTypes":[16],"filterNames":[16],"filterEntities":[16],"changes":[32],"show":[64],"getChanges":[64]},[[5,"mousedown","onMouseDown"]]]]],["revo-grid_11",[[0,"revo-grid",{"rowHeaders":[4,"row-headers"],"frameSize":[2,"frame-size"],"rowSize":[2,"row-size"],"colSize":[2,"col-size"],"range":[4],"readonly":[4],"resize":[4],"canFocus":[4,"can-focus"],"useClipboard":[4,"use-clipboard"],"columns":[16],"source":[16],"pinnedTopSource":[16],"pinnedBottomSource":[16],"rowDefinitions":[16],"editors":[16],"plugins":[16],"columnTypes":[16],"theme":[1537],"rowClass":[513,"row-class"],"autoSizeColumn":[4,"auto-size-column"],"filter":[4],"trimmedRows":[16],"exporting":[4],"grouping":[16],"stretch":[8],"extraElements":[32],"refresh":[64],"scrollToRow":[64],"scrollToColumnIndex":[64],"scrollToColumnProp":[64],"updateColumns":[64],"addTrimmed":[64],"scrollToCoordinate":[64],"setCellEdit":[64],"registerVNode":[64],"getSource":[64],"getVisibleSource":[64],"getSourceStore":[64],"getColumnStore":[64],"updateColumnSorting":[64],"clearSorting":[64],"getColumns":[64],"clearFocus":[64],"getPlugins":[64],"getFocused":[64]},[[0,"internalRowDragStart","onRowDragStarted"],[0,"internalRowDragEnd","onRowDragEnd"],[0,"internalRowDrag","onRowDrag"],[0,"internalRowMouseMove","onRowMouseMove"],[0,"internalCellEdit","onBeforeEdit"],[0,"internalRangeDataApply","onBeforeRangeEdit"],[0,"internalSelectionChanged","onRangeChanged"],[0,"initialRowDropped","onRowDropped"],[0,"initialHeaderClick","onHeaderClick"],[0,"internalFocusCell","onCellFocus"]]],[0,"revogr-row-headers",{"height":[2],"dataPorts":[16],"headerProp":[16],"uiid":[1],"resize":[4],"rowHeaderColumn":[16]}],[4,"revogr-overlay-selection",{"readonly":[4],"range":[4],"canDrag":[4,"can-drag"],"useClipboard":[4,"use-clipboard"],"selectionStore":[16],"dimensionRow":[16],"dimensionCol":[16],"dataStore":[16],"colData":[16],"lastCell":[16],"editors":[16]},[[5,"mousemove","onMouseMove"],[5,"mouseleave","onMouseOut"],[5,"mouseup","onMouseUp"],[0,"dragStartCell","onCellDrag"],[4,"keyup","onKeyUp"],[4,"keydown","onKeyDown"]]],[0,"revogr-focus",{"selectionStore":[16],"dimensionRow":[16],"dimensionCol":[16]}],[0,"revogr-scroll-virtual",{"dimension":[1],"viewportStore":[16],"dimensionStore":[16],"setScroll":[64],"changeScroll":[64]}],[0,"revogr-temp-range",{"selectionStore":[16],"dimensionRow":[16],"dimensionCol":[16]}],[0,"revogr-data",{"readonly":[4],"range":[4],"canDrag":[4,"can-drag"],"rowClass":[1,"row-class"],"rowSelectionStore":[16],"viewportRow":[16],"viewportCol":[16],"dimensionRow":[16],"colData":[16],"dataStore":[16]}],[0,"revogr-edit",{"editCell":[16],"column":[16],"editor":[16]}],[0,"revogr-header",{"viewportCol":[16],"dimensionCol":[16],"selectionStore":[16],"parent":[1],"groups":[16],"groupingDepth":[2,"grouping-depth"],"canResize":[4,"can-resize"],"colData":[16],"columnFilter":[4,"column-filter"]}],[0,"revogr-order-editor",{"parent":[16],"dimensionRow":[16],"dimensionCol":[16],"dataStore":[16],"dragStart":[64],"endOrder":[64],"clearOrder":[64]},[[5,"mouseleave","onMouseOut"],[5,"mouseup","onMouseUp"]]],[4,"revogr-viewport-scroll",{"contentWidth":[2,"content-width"],"contentHeight":[2,"content-height"],"setScroll":[64],"changeScroll":[64]}]]]], options);
70
+ return bootstrapLazy([["revogr-clipboard",[[0,"revogr-clipboard",{"doCopy":[64]},[[4,"paste","onPaste"],[4,"copy","copyStarted"]]]]],["revogr-filter-panel",[[0,"revogr-filter-panel",{"uuid":[1537],"filterTypes":[16],"filterNames":[16],"filterEntities":[16],"filterCaptions":[16],"changes":[32],"show":[64],"getChanges":[64]},[[5,"mousedown","onMouseDown"]]]]],["revo-grid_11",[[0,"revo-grid",{"rowHeaders":[4,"row-headers"],"frameSize":[2,"frame-size"],"rowSize":[2,"row-size"],"colSize":[2,"col-size"],"range":[4],"readonly":[4],"resize":[4],"canFocus":[4,"can-focus"],"useClipboard":[4,"use-clipboard"],"columns":[16],"source":[16],"pinnedTopSource":[16],"pinnedBottomSource":[16],"rowDefinitions":[16],"editors":[16],"plugins":[16],"columnTypes":[16],"theme":[1537],"rowClass":[513,"row-class"],"autoSizeColumn":[4,"auto-size-column"],"filter":[4],"trimmedRows":[16],"exporting":[4],"grouping":[16],"stretch":[8],"extraElements":[32],"refresh":[64],"scrollToRow":[64],"scrollToColumnIndex":[64],"scrollToColumnProp":[64],"updateColumns":[64],"addTrimmed":[64],"scrollToCoordinate":[64],"setCellEdit":[64],"registerVNode":[64],"getSource":[64],"getVisibleSource":[64],"getSourceStore":[64],"getColumnStore":[64],"updateColumnSorting":[64],"clearSorting":[64],"getColumns":[64],"clearFocus":[64],"getPlugins":[64],"getFocused":[64],"getSelectedRange":[64]},[[0,"internalRowDragStart","onRowDragStarted"],[0,"internalRowDragEnd","onRowDragEnd"],[0,"internalRowDrag","onRowDrag"],[0,"internalRowMouseMove","onRowMouseMove"],[0,"internalCellEdit","onBeforeEdit"],[0,"internalRangeDataApply","onBeforeRangeEdit"],[0,"internalSelectionChanged","onRangeChanged"],[0,"initialRowDropped","onRowDropped"],[0,"initialHeaderClick","onHeaderClick"],[0,"internalFocusCell","onCellFocus"]]],[0,"revogr-row-headers",{"height":[2],"dataPorts":[16],"headerProp":[16],"uiid":[1],"resize":[4],"rowHeaderColumn":[16]}],[4,"revogr-overlay-selection",{"readonly":[4],"range":[4],"canDrag":[4,"can-drag"],"useClipboard":[4,"use-clipboard"],"selectionStore":[16],"dimensionRow":[16],"dimensionCol":[16],"dataStore":[16],"colData":[16],"lastCell":[16],"editors":[16]},[[5,"mousemove","onMouseMove"],[5,"mouseleave","onMouseOut"],[5,"mouseup","onMouseUp"],[0,"dragStartCell","onCellDrag"],[4,"keyup","onKeyUp"],[4,"keydown","onKeyDown"]]],[0,"revogr-focus",{"selectionStore":[16],"dimensionRow":[16],"dimensionCol":[16]}],[0,"revogr-scroll-virtual",{"dimension":[1],"viewportStore":[16],"dimensionStore":[16],"setScroll":[64],"changeScroll":[64]}],[0,"revogr-temp-range",{"selectionStore":[16],"dimensionRow":[16],"dimensionCol":[16]}],[0,"revogr-data",{"readonly":[4],"range":[4],"canDrag":[4,"can-drag"],"rowClass":[1,"row-class"],"rowSelectionStore":[16],"viewportRow":[16],"viewportCol":[16],"dimensionRow":[16],"colData":[16],"dataStore":[16]}],[0,"revogr-edit",{"editCell":[16],"column":[16],"editor":[16]}],[0,"revogr-header",{"viewportCol":[16],"dimensionCol":[16],"selectionStore":[16],"parent":[1],"groups":[16],"groupingDepth":[2,"grouping-depth"],"canResize":[4,"can-resize"],"colData":[16],"columnFilter":[4,"column-filter"]}],[0,"revogr-order-editor",{"parent":[16],"dimensionRow":[16],"dimensionCol":[16],"dataStore":[16],"dragStart":[64],"endOrder":[64],"clearOrder":[64]},[[5,"mouseleave","onMouseOut"],[5,"mouseup","onMouseUp"]]],[4,"revogr-viewport-scroll",{"contentWidth":[2,"content-width"],"contentHeight":[2,"content-height"],"setScroll":[64],"changeScroll":[64]}]]]], options);
71
71
  });