@revolist/revogrid 4.4.0-next.2 → 4.4.0-next.21

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 (243) hide show
  1. package/custom-element/columnService.js +1 -1
  2. package/custom-element/consts.js +2 -1
  3. package/custom-element/consts.js.map +1 -1
  4. package/custom-element/localScrollService.js +1 -1
  5. package/custom-element/localScrollService.js.map +1 -1
  6. package/custom-element/revo-grid.js +163 -97
  7. package/custom-element/revo-grid.js.map +1 -1
  8. package/custom-element/revogr-clipboard.js +24 -5
  9. package/custom-element/revogr-clipboard.js.map +1 -1
  10. package/custom-element/revogr-edit2.js +12 -6
  11. package/custom-element/revogr-edit2.js.map +1 -1
  12. package/custom-element/revogr-focus2.js +1 -1
  13. package/custom-element/revogr-focus2.js.map +1 -1
  14. package/custom-element/revogr-header2.js +25 -11
  15. package/custom-element/revogr-header2.js.map +1 -1
  16. package/custom-element/revogr-overlay-selection2.js +99 -32
  17. package/custom-element/revogr-overlay-selection2.js.map +1 -1
  18. package/custom-element/revogr-row-headers2.js +1 -2
  19. package/custom-element/revogr-row-headers2.js.map +1 -1
  20. package/custom-element/revogr-viewport-scroll2.js +39 -6
  21. package/custom-element/revogr-viewport-scroll2.js.map +1 -1
  22. package/dist/cjs/{debounce-525dd66c.js → debounce-f50730b6.js} +1 -38
  23. package/dist/cjs/debounce-f50730b6.js.map +1 -0
  24. package/dist/cjs/dispatcher-20520c70.js +21 -0
  25. package/dist/cjs/dispatcher-20520c70.js.map +1 -0
  26. package/dist/cjs/events-030618fc.js +459 -0
  27. package/dist/cjs/events-030618fc.js.map +1 -0
  28. package/dist/cjs/filter.button-6badec7a.js +44 -0
  29. package/dist/cjs/filter.button-6badec7a.js.map +1 -0
  30. package/dist/cjs/{index-aad39b7b.js → index-ee2ef5ae.js} +96 -36
  31. package/dist/cjs/index-ee2ef5ae.js.map +1 -0
  32. package/dist/cjs/index-effc94b9.js +3944 -0
  33. package/dist/cjs/index-effc94b9.js.map +1 -0
  34. package/dist/cjs/isString-3dde8d95.js +38 -0
  35. package/dist/cjs/isString-3dde8d95.js.map +1 -0
  36. package/dist/cjs/keyCodes.utils-d665ebed.js +271 -0
  37. package/dist/cjs/keyCodes.utils-d665ebed.js.map +1 -0
  38. package/dist/cjs/loader.cjs.js +3 -3
  39. package/dist/cjs/loader.cjs.js.map +1 -1
  40. package/dist/cjs/localScrollService-a81823c5.js +403 -0
  41. package/dist/cjs/localScrollService-a81823c5.js.map +1 -0
  42. package/dist/cjs/revo-grid.cjs.entry.js +3858 -0
  43. package/dist/cjs/revo-grid.cjs.entry.js.map +1 -0
  44. package/dist/cjs/revo-grid.cjs.js +3 -3
  45. package/dist/cjs/revo-grid.cjs.js.map +1 -1
  46. package/dist/cjs/revogr-clipboard.cjs.entry.js +24 -6
  47. package/dist/cjs/revogr-clipboard.cjs.entry.js.map +1 -1
  48. package/dist/cjs/revogr-data_3.cjs.entry.js +1138 -0
  49. package/dist/cjs/revogr-data_3.cjs.entry.js.map +1 -0
  50. package/dist/cjs/revogr-edit_2.cjs.entry.js +325 -0
  51. package/dist/cjs/revogr-edit_2.cjs.entry.js.map +1 -0
  52. package/dist/cjs/revogr-filter-panel.cjs.entry.js +6 -5
  53. package/dist/cjs/revogr-filter-panel.cjs.entry.js.map +1 -1
  54. package/dist/cjs/revogr-focus_5.cjs.entry.js +1231 -0
  55. package/dist/cjs/revogr-focus_5.cjs.entry.js.map +1 -0
  56. package/dist/cjs/{revo-grid_11.cjs.entry.js → viewport.helpers-70ccec8f.js} +13978 -25269
  57. package/dist/cjs/viewport.helpers-70ccec8f.js.map +1 -0
  58. package/dist/collection/collection-manifest.json +1 -1
  59. package/dist/collection/components/clipboard/revogr-clipboard.d.ts +6 -2
  60. package/dist/collection/components/clipboard/revogr-clipboard.js +46 -5
  61. package/dist/collection/components/clipboard/revogr-clipboard.js.map +1 -1
  62. package/dist/collection/components/header/headerCellRenderer.d.ts +2 -1
  63. package/dist/collection/components/header/headerCellRenderer.js +1 -1
  64. package/dist/collection/components/header/headerCellRenderer.js.map +1 -1
  65. package/dist/collection/components/header/headerRenderer.d.ts +2 -2
  66. package/dist/collection/components/header/headerRenderer.js +1 -1
  67. package/dist/collection/components/header/headerRenderer.js.map +1 -1
  68. package/dist/collection/components/header/revogr-header.d.ts +15 -1
  69. package/dist/collection/components/header/revogr-header.js +34 -8
  70. package/dist/collection/components/header/revogr-header.js.map +1 -1
  71. package/dist/collection/components/overlay/autofill.service.d.ts +7 -3
  72. package/dist/collection/components/overlay/autofill.service.js +32 -12
  73. package/dist/collection/components/overlay/autofill.service.js.map +1 -1
  74. package/dist/collection/components/overlay/clipboard.service.d.ts +1 -1
  75. package/dist/collection/components/overlay/clipboard.service.js +2 -2
  76. package/dist/collection/components/overlay/clipboard.service.js.map +1 -1
  77. package/dist/collection/components/overlay/keyboard.service.js +2 -6
  78. package/dist/collection/components/overlay/keyboard.service.js.map +1 -1
  79. package/dist/collection/components/overlay/revogr-edit.d.ts +8 -0
  80. package/dist/collection/components/overlay/revogr-edit.js +34 -9
  81. package/dist/collection/components/overlay/revogr-edit.js.map +1 -1
  82. package/dist/collection/components/overlay/revogr-overlay-selection.d.ts +32 -10
  83. package/dist/collection/components/overlay/revogr-overlay-selection.js +80 -12
  84. package/dist/collection/components/overlay/revogr-overlay-selection.js.map +1 -1
  85. package/dist/collection/components/overlay/revogr-overlay-style.css +71 -4
  86. package/dist/collection/components/revoGrid/revo-grid.d.ts +15 -4
  87. package/dist/collection/components/revoGrid/revo-grid.js +60 -19
  88. package/dist/collection/components/revoGrid/revo-grid.js.map +1 -1
  89. package/dist/collection/components/revoGrid/viewport.scrolling.service.d.ts +6 -2
  90. package/dist/collection/components/revoGrid/viewport.scrolling.service.js +26 -4
  91. package/dist/collection/components/revoGrid/viewport.scrolling.service.js.map +1 -1
  92. package/dist/collection/components/revoGrid/viewport.section.d.ts +3 -2
  93. package/dist/collection/components/revoGrid/viewport.section.js +8 -4
  94. package/dist/collection/components/revoGrid/viewport.section.js.map +1 -1
  95. package/dist/collection/components/revoGrid/viewport.service.d.ts +4 -0
  96. package/dist/collection/components/revoGrid/viewport.service.js +15 -3
  97. package/dist/collection/components/revoGrid/viewport.service.js.map +1 -1
  98. package/dist/collection/components/rowHeaders/revogr-row-headers.js.map +1 -1
  99. package/dist/collection/components/scroll/revogr-viewport-scroll-style.css +3 -0
  100. package/dist/collection/components/scroll/revogr-viewport-scroll.d.ts +16 -5
  101. package/dist/collection/components/scroll/revogr-viewport-scroll.js +64 -9
  102. package/dist/collection/components/scroll/revogr-viewport-scroll.js.map +1 -1
  103. package/dist/collection/components/selectionFocus/revogr-focus-style.css +1 -1
  104. package/dist/collection/components.d.ts +110 -6
  105. package/dist/collection/interfaces.d.ts +4 -1
  106. package/dist/collection/plugins/groupingColumn/columnGroupsRenderer.d.ts +3 -2
  107. package/dist/collection/plugins/groupingColumn/columnGroupsRenderer.js +2 -2
  108. package/dist/collection/plugins/groupingColumn/columnGroupsRenderer.js.map +1 -1
  109. package/dist/collection/plugins/groupingColumn/headerGroupRenderer.d.ts +2 -2
  110. package/dist/collection/plugins/groupingColumn/headerGroupRenderer.js +1 -1
  111. package/dist/collection/plugins/groupingColumn/headerGroupRenderer.js.map +1 -1
  112. package/dist/collection/plugins/sorting/sorting.plugin.d.ts +21 -13
  113. package/dist/collection/plugins/sorting/sorting.plugin.js +77 -70
  114. package/dist/collection/plugins/sorting/sorting.plugin.js.map +1 -1
  115. package/dist/collection/serve/controller.js +183 -0
  116. package/dist/collection/services/localScrollService.js +1 -1
  117. package/dist/collection/services/localScrollService.js.map +1 -1
  118. package/dist/collection/services/resizable.directive.d.ts +8 -7
  119. package/dist/collection/services/resizable.directive.js +13 -36
  120. package/dist/collection/services/resizable.directive.js.map +1 -1
  121. package/dist/collection/services/resizable.element.d.ts +4 -0
  122. package/dist/collection/services/resizable.element.js +39 -0
  123. package/dist/collection/services/resizable.element.js.map +1 -0
  124. package/dist/collection/stencil-public-runtime.d.ts +1 -0
  125. package/dist/collection/store/viewPort/viewport.store.js +0 -1
  126. package/dist/collection/store/viewPort/viewport.store.js.map +1 -1
  127. package/dist/collection/utils/consts.d.ts +1 -0
  128. package/dist/collection/utils/consts.js +1 -0
  129. package/dist/collection/utils/consts.js.map +1 -1
  130. package/dist/collection/utils/events.d.ts +2 -1
  131. package/dist/collection/utils/events.js +18 -2
  132. package/dist/collection/utils/events.js.map +1 -1
  133. package/dist/collection/utils/mobile.d.ts +1 -0
  134. package/dist/collection/utils/mobile.js +7 -0
  135. package/dist/collection/utils/mobile.js.map +1 -0
  136. package/dist/esm/{debounce-301fd4d2.js → debounce-820b5a8b.js} +2 -34
  137. package/dist/esm/debounce-820b5a8b.js.map +1 -0
  138. package/dist/esm/dispatcher-9e9c0233.js +19 -0
  139. package/dist/esm/dispatcher-9e9c0233.js.map +1 -0
  140. package/dist/esm/events-31272e5e.js +454 -0
  141. package/dist/esm/events-31272e5e.js.map +1 -0
  142. package/dist/esm/filter.button-21ce90ef.js +38 -0
  143. package/dist/esm/filter.button-21ce90ef.js.map +1 -0
  144. package/dist/esm/{index-5e90b19b.js → index-05947c5f.js} +97 -37
  145. package/dist/esm/index-05947c5f.js.map +1 -0
  146. package/dist/esm/index-728bf6e3.js +3889 -0
  147. package/dist/esm/index-728bf6e3.js.map +1 -0
  148. package/dist/esm/isString-d539060a.js +36 -0
  149. package/dist/esm/isString-d539060a.js.map +1 -0
  150. package/dist/esm/keyCodes.utils-c0064460.js +265 -0
  151. package/dist/esm/keyCodes.utils-c0064460.js.map +1 -0
  152. package/dist/esm/loader.js +4 -4
  153. package/dist/esm/loader.js.map +1 -1
  154. package/dist/esm/localScrollService-884d8952.js +400 -0
  155. package/dist/esm/localScrollService-884d8952.js.map +1 -0
  156. package/dist/esm/revo-grid.entry.js +3854 -0
  157. package/dist/esm/revo-grid.entry.js.map +1 -0
  158. package/dist/esm/revo-grid.js +4 -4
  159. package/dist/esm/revo-grid.js.map +1 -1
  160. package/dist/esm/revogr-clipboard.entry.js +24 -6
  161. package/dist/esm/revogr-clipboard.entry.js.map +1 -1
  162. package/dist/esm/revogr-data_3.entry.js +1132 -0
  163. package/dist/esm/revogr-data_3.entry.js.map +1 -0
  164. package/dist/esm/revogr-edit_2.entry.js +320 -0
  165. package/dist/esm/revogr-edit_2.entry.js.map +1 -0
  166. package/dist/esm/revogr-filter-panel.entry.js +3 -2
  167. package/dist/esm/revogr-filter-panel.entry.js.map +1 -1
  168. package/dist/esm/revogr-focus_5.entry.js +1223 -0
  169. package/dist/esm/revogr-focus_5.entry.js.map +1 -0
  170. package/dist/esm/{revo-grid_11.entry.js → viewport.helpers-c08e729e.js} +13790 -25093
  171. package/dist/esm/viewport.helpers-c08e729e.js.map +1 -0
  172. package/dist/revo-grid/debounce-820b5a8b.js +5 -0
  173. package/dist/revo-grid/debounce-820b5a8b.js.map +1 -0
  174. package/dist/revo-grid/dispatcher-9e9c0233.js +5 -0
  175. package/dist/revo-grid/dispatcher-9e9c0233.js.map +1 -0
  176. package/dist/revo-grid/events-31272e5e.js +5 -0
  177. package/dist/revo-grid/events-31272e5e.js.map +1 -0
  178. package/dist/revo-grid/filter.button-21ce90ef.js +5 -0
  179. package/dist/revo-grid/filter.button-21ce90ef.js.map +1 -0
  180. package/dist/revo-grid/index-05947c5f.js +6 -0
  181. package/dist/revo-grid/index-05947c5f.js.map +1 -0
  182. package/dist/revo-grid/index-728bf6e3.js +5 -0
  183. package/dist/revo-grid/index-728bf6e3.js.map +1 -0
  184. package/dist/revo-grid/isString-d539060a.js +5 -0
  185. package/dist/revo-grid/isString-d539060a.js.map +1 -0
  186. package/dist/revo-grid/keyCodes.utils-c0064460.js +5 -0
  187. package/dist/revo-grid/keyCodes.utils-c0064460.js.map +1 -0
  188. package/dist/revo-grid/localScrollService-884d8952.js +5 -0
  189. package/dist/revo-grid/localScrollService-884d8952.js.map +1 -0
  190. package/dist/revo-grid/revo-grid.entry.js +5 -0
  191. package/dist/revo-grid/revo-grid.entry.js.map +1 -0
  192. package/dist/revo-grid/revo-grid.esm.js +1 -1
  193. package/dist/revo-grid/revo-grid.esm.js.map +1 -1
  194. package/dist/revo-grid/revogr-clipboard.entry.js +1 -1
  195. package/dist/revo-grid/revogr-clipboard.entry.js.map +1 -1
  196. package/dist/revo-grid/revogr-data_3.entry.js +5 -0
  197. package/dist/revo-grid/revogr-data_3.entry.js.map +1 -0
  198. package/dist/revo-grid/revogr-edit_2.entry.js +5 -0
  199. package/dist/revo-grid/revogr-edit_2.entry.js.map +1 -0
  200. package/dist/revo-grid/revogr-filter-panel.entry.js +1 -1
  201. package/dist/revo-grid/revogr-filter-panel.entry.js.map +1 -1
  202. package/dist/revo-grid/revogr-focus_5.entry.js +5 -0
  203. package/dist/revo-grid/revogr-focus_5.entry.js.map +1 -0
  204. package/dist/revo-grid/viewport.helpers-c08e729e.js +5 -0
  205. package/dist/revo-grid/viewport.helpers-c08e729e.js.map +1 -0
  206. package/dist/types/components/clipboard/revogr-clipboard.d.ts +6 -2
  207. package/dist/types/components/header/headerCellRenderer.d.ts +2 -1
  208. package/dist/types/components/header/headerRenderer.d.ts +2 -2
  209. package/dist/types/components/header/revogr-header.d.ts +15 -1
  210. package/dist/types/components/overlay/autofill.service.d.ts +7 -3
  211. package/dist/types/components/overlay/clipboard.service.d.ts +1 -1
  212. package/dist/types/components/overlay/revogr-edit.d.ts +8 -0
  213. package/dist/types/components/overlay/revogr-overlay-selection.d.ts +32 -10
  214. package/dist/types/components/revoGrid/revo-grid.d.ts +15 -4
  215. package/dist/types/components/revoGrid/viewport.scrolling.service.d.ts +6 -2
  216. package/dist/types/components/revoGrid/viewport.section.d.ts +3 -2
  217. package/dist/types/components/revoGrid/viewport.service.d.ts +4 -0
  218. package/dist/types/components/scroll/revogr-viewport-scroll.d.ts +16 -5
  219. package/dist/types/components.d.ts +110 -6
  220. package/dist/types/interfaces.d.ts +4 -1
  221. package/dist/types/plugins/groupingColumn/columnGroupsRenderer.d.ts +3 -2
  222. package/dist/types/plugins/groupingColumn/headerGroupRenderer.d.ts +2 -2
  223. package/dist/types/plugins/sorting/sorting.plugin.d.ts +21 -13
  224. package/dist/types/services/resizable.directive.d.ts +8 -7
  225. package/dist/types/services/resizable.element.d.ts +4 -0
  226. package/dist/types/stencil-public-runtime.d.ts +1 -0
  227. package/dist/types/utils/consts.d.ts +1 -0
  228. package/dist/types/utils/events.d.ts +2 -1
  229. package/dist/types/utils/mobile.d.ts +1 -0
  230. package/package.json +4 -3
  231. package/dist/cjs/debounce-525dd66c.js.map +0 -1
  232. package/dist/cjs/index-aad39b7b.js.map +0 -1
  233. package/dist/cjs/revo-grid_11.cjs.entry.js.map +0 -1
  234. package/dist/esm/debounce-301fd4d2.js.map +0 -1
  235. package/dist/esm/index-5e90b19b.js.map +0 -1
  236. package/dist/esm/revo-grid_11.entry.js.map +0 -1
  237. package/dist/revo-grid/debounce-301fd4d2.js +0 -5
  238. package/dist/revo-grid/debounce-301fd4d2.js.map +0 -1
  239. package/dist/revo-grid/index-5e90b19b.js +0 -6
  240. package/dist/revo-grid/index-5e90b19b.js.map +0 -1
  241. package/dist/revo-grid/revo-grid_11.entry.js +0 -5
  242. package/dist/revo-grid/revo-grid_11.entry.js.map +0 -1
  243. /package/dist/collection/{utilsExternal/generate-data.js → serve/data.js} +0 -0
@@ -0,0 +1,3858 @@
1
+ /*!
2
+ * Built by Revolist
3
+ */
4
+ 'use strict';
5
+
6
+ Object.defineProperty(exports, '__esModule', { value: true });
7
+
8
+ const index$1 = require('./index-ee2ef5ae.js');
9
+ const index = require('./index-effc94b9.js');
10
+ const viewport_helpers = require('./viewport.helpers-70ccec8f.js');
11
+ const events = require('./events-030618fc.js');
12
+ const filter_button = require('./filter.button-6badec7a.js');
13
+ const isString = require('./isString-3dde8d95.js');
14
+ const debounce = require('./debounce-f50730b6.js');
15
+ const dispatcher = require('./dispatcher-20520c70.js');
16
+
17
+ class ThemeCompact {
18
+ constructor() {
19
+ this.defaultRowSize = 32;
20
+ }
21
+ }
22
+
23
+ class ThemeDefault {
24
+ constructor() {
25
+ this.defaultRowSize = 27;
26
+ }
27
+ }
28
+
29
+ class ThemeMaterial {
30
+ constructor() {
31
+ this.defaultRowSize = 42;
32
+ }
33
+ }
34
+
35
+ const DEFAULT_THEME = 'default';
36
+ const allowedThemes = [DEFAULT_THEME, 'material', 'compact', 'darkMaterial', 'darkCompact'];
37
+ class ThemeService {
38
+ get theme() {
39
+ return this.currentTheme;
40
+ }
41
+ get rowSize() {
42
+ return this.customRowSize || this.currentTheme.defaultRowSize;
43
+ }
44
+ set rowSize(size) {
45
+ this.customRowSize = size;
46
+ }
47
+ constructor(cfg) {
48
+ this.customRowSize = 0;
49
+ this.customRowSize = cfg.rowSize;
50
+ this.register('default');
51
+ }
52
+ register(theme) {
53
+ const parsedTheme = ThemeService.getTheme(theme);
54
+ switch (parsedTheme) {
55
+ case 'material':
56
+ case 'darkMaterial':
57
+ this.currentTheme = new ThemeMaterial();
58
+ break;
59
+ case 'compact':
60
+ case 'darkCompact':
61
+ this.currentTheme = new ThemeCompact();
62
+ break;
63
+ default:
64
+ this.currentTheme = new ThemeDefault();
65
+ break;
66
+ }
67
+ }
68
+ static getTheme(theme) {
69
+ if (allowedThemes.indexOf(theme) > -1) {
70
+ return theme;
71
+ }
72
+ return DEFAULT_THEME;
73
+ }
74
+ }
75
+
76
+ /**
77
+ * Creates a `_.find` or `_.findLast` function.
78
+ *
79
+ * @private
80
+ * @param {Function} findIndexFunc The function to find the collection index.
81
+ * @returns {Function} Returns the new find function.
82
+ */
83
+ function createFind(findIndexFunc) {
84
+ return function(collection, predicate, fromIndex) {
85
+ var iterable = Object(collection);
86
+ if (!index.isArrayLike_1(collection)) {
87
+ var iteratee = index._baseIteratee(predicate);
88
+ collection = index.keys_1(collection);
89
+ predicate = function(key) { return iteratee(iterable[key], key, iterable); };
90
+ }
91
+ var index$1 = findIndexFunc(collection, predicate, fromIndex);
92
+ return index$1 > -1 ? iterable[iteratee ? collection[index$1] : index$1] : undefined;
93
+ };
94
+ }
95
+
96
+ var _createFind = createFind;
97
+
98
+ /**
99
+ * Iterates over elements of `collection`, returning the first element
100
+ * `predicate` returns truthy for. The predicate is invoked with three
101
+ * arguments: (value, index|key, collection).
102
+ *
103
+ * @static
104
+ * @memberOf _
105
+ * @since 0.1.0
106
+ * @category Collection
107
+ * @param {Array|Object} collection The collection to inspect.
108
+ * @param {Function} [predicate=_.identity] The function invoked per iteration.
109
+ * @param {number} [fromIndex=0] The index to search from.
110
+ * @returns {*} Returns the matched element, else `undefined`.
111
+ * @example
112
+ *
113
+ * var users = [
114
+ * { 'user': 'barney', 'age': 36, 'active': true },
115
+ * { 'user': 'fred', 'age': 40, 'active': false },
116
+ * { 'user': 'pebbles', 'age': 1, 'active': true }
117
+ * ];
118
+ *
119
+ * _.find(users, function(o) { return o.age < 40; });
120
+ * // => object for 'barney'
121
+ *
122
+ * // The `_.matches` iteratee shorthand.
123
+ * _.find(users, { 'age': 1, 'active': true });
124
+ * // => object for 'pebbles'
125
+ *
126
+ * // The `_.matchesProperty` iteratee shorthand.
127
+ * _.find(users, ['active', false]);
128
+ * // => object for 'fred'
129
+ *
130
+ * // The `_.property` iteratee shorthand.
131
+ * _.find(users, 'active');
132
+ * // => object for 'barney'
133
+ */
134
+ var find = _createFind(index.findIndex_1);
135
+
136
+ var find_1 = find;
137
+
138
+ const rowTypes = ['rowPinStart', 'rgRow', 'rowPinEnd'];
139
+ const columnTypes = ['colPinStart', 'rgCol', 'colPinEnd'];
140
+ function isRowType(type) {
141
+ return rowTypes.indexOf(type) > -1;
142
+ }
143
+
144
+ /**
145
+ * The base implementation of `_.map` without support for iteratee shorthands.
146
+ *
147
+ * @private
148
+ * @param {Array|Object} collection The collection to iterate over.
149
+ * @param {Function} iteratee The function invoked per iteration.
150
+ * @returns {Array} Returns the new mapped array.
151
+ */
152
+ function baseMap(collection, iteratee) {
153
+ var index$1 = -1,
154
+ result = index.isArrayLike_1(collection) ? Array(collection.length) : [];
155
+
156
+ index._baseEach(collection, function(value, key, collection) {
157
+ result[++index$1] = iteratee(value, key, collection);
158
+ });
159
+ return result;
160
+ }
161
+
162
+ var _baseMap = baseMap;
163
+
164
+ /**
165
+ * Creates an array of values by running each element in `collection` thru
166
+ * `iteratee`. The iteratee is invoked with three arguments:
167
+ * (value, index|key, collection).
168
+ *
169
+ * Many lodash methods are guarded to work as iteratees for methods like
170
+ * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.
171
+ *
172
+ * The guarded methods are:
173
+ * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`,
174
+ * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`,
175
+ * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`,
176
+ * `template`, `trim`, `trimEnd`, `trimStart`, and `words`
177
+ *
178
+ * @static
179
+ * @memberOf _
180
+ * @since 0.1.0
181
+ * @category Collection
182
+ * @param {Array|Object} collection The collection to iterate over.
183
+ * @param {Function} [iteratee=_.identity] The function invoked per iteration.
184
+ * @returns {Array} Returns the new mapped array.
185
+ * @example
186
+ *
187
+ * function square(n) {
188
+ * return n * n;
189
+ * }
190
+ *
191
+ * _.map([4, 8], square);
192
+ * // => [16, 64]
193
+ *
194
+ * _.map({ 'a': 4, 'b': 8 }, square);
195
+ * // => [16, 64] (iteration order is not guaranteed)
196
+ *
197
+ * var users = [
198
+ * { 'user': 'barney' },
199
+ * { 'user': 'fred' }
200
+ * ];
201
+ *
202
+ * // The `_.property` iteratee shorthand.
203
+ * _.map(users, 'user');
204
+ * // => ['barney', 'fred']
205
+ */
206
+ function map(collection, iteratee) {
207
+ var func = index.isArray_1(collection) ? index._arrayMap : _baseMap;
208
+ return func(collection, index._baseIteratee(iteratee));
209
+ }
210
+
211
+ var map_1 = map;
212
+
213
+ /**
214
+ * Base layer for plugins
215
+ * Provide minimal starting core
216
+ */
217
+ class BasePlugin {
218
+ constructor(revogrid) {
219
+ this.revogrid = revogrid;
220
+ this.subscriptions = {};
221
+ }
222
+ /**
223
+ *
224
+ * @param eventName - event name to subscribe to in revo-grid
225
+ * @param callback - callback function for event
226
+ */
227
+ addEventListener(eventName, callback) {
228
+ this.revogrid.addEventListener(eventName, callback);
229
+ this.subscriptions[eventName] = callback;
230
+ }
231
+ /**
232
+ * Subscribe to grid properties to watch changes
233
+ * You can return false in callback to prevent default value set
234
+ *
235
+ * @param prop - property name
236
+ * @param callback - callback function
237
+ * @param immediate - trigger callback immediately with current value
238
+ */
239
+ watch(prop, callback, { immediate } = { immediate: false }) {
240
+ var _a;
241
+ const nativeValueDesc = Object.getOwnPropertyDescriptor(this.revogrid, prop) ||
242
+ Object.getOwnPropertyDescriptor(this.revogrid.constructor.prototype, prop);
243
+ // Overwrite property descriptor for this instance
244
+ Object.defineProperty(this.revogrid, prop, {
245
+ set(val) {
246
+ var _a;
247
+ const keepDefault = callback(val);
248
+ if (keepDefault === false) {
249
+ return;
250
+ }
251
+ // Continue with native behavior
252
+ return (_a = nativeValueDesc === null || nativeValueDesc === void 0 ? void 0 : nativeValueDesc.set) === null || _a === void 0 ? void 0 : _a.call(this, val);
253
+ },
254
+ get() {
255
+ var _a;
256
+ // Continue with native behavior
257
+ return (_a = nativeValueDesc === null || nativeValueDesc === void 0 ? void 0 : nativeValueDesc.get) === null || _a === void 0 ? void 0 : _a.call(this);
258
+ },
259
+ });
260
+ if (immediate) {
261
+ callback((_a = nativeValueDesc === null || nativeValueDesc === void 0 ? void 0 : nativeValueDesc.get) === null || _a === void 0 ? void 0 : _a.call(this.revogrid));
262
+ }
263
+ }
264
+ /**
265
+ * Remove event subscription
266
+ * @param eventName
267
+ */
268
+ removeEventListener(eventName) {
269
+ this.revogrid.removeEventListener(eventName, this.subscriptions[eventName]);
270
+ delete this.subscriptions[eventName];
271
+ }
272
+ /**
273
+ * Trigger event to grid upper level
274
+ * Event can be cancelled
275
+ * @param eventName
276
+ * @param detail
277
+ * @returns event
278
+ */
279
+ emit(eventName, detail) {
280
+ const event = new CustomEvent(eventName, { detail, cancelable: true });
281
+ this.revogrid.dispatchEvent(event);
282
+ return event;
283
+ }
284
+ /**
285
+ * Clearing inner subscription
286
+ */
287
+ clearSubscriptions() {
288
+ for (let type in this.subscriptions) {
289
+ this.removeEventListener(type);
290
+ }
291
+ }
292
+ /**
293
+ * Minimal destroy implementations
294
+ */
295
+ destroy() {
296
+ this.clearSubscriptions();
297
+ }
298
+ }
299
+
300
+ class GroupingColumnPlugin extends BasePlugin {
301
+ static gatherGroup(res, colData, collection, level = 0) {
302
+ // group template
303
+ const group = Object.assign(Object.assign({}, colData), { level, ids: [] });
304
+ // check columns for update
305
+ for (let k in collection.columns) {
306
+ const key = k;
307
+ const resultItem = res.columns[key];
308
+ const collectionItem = collection.columns[key];
309
+ // if column data
310
+ if (index.isArray_1(resultItem) && index.isArray_1(collectionItem)) {
311
+ // fill columns
312
+ resultItem.push(...collectionItem);
313
+ // fill grouping
314
+ if (collectionItem.length) {
315
+ res.columnGrouping[key].push(Object.assign(Object.assign({}, group), { ids: map_1(collectionItem, 'prop') }));
316
+ }
317
+ }
318
+ }
319
+ // merge column groupings
320
+ for (let k in collection.columnGrouping) {
321
+ const key = k;
322
+ const collectionItem = collection.columnGrouping[key];
323
+ res.columnGrouping[key].push(...collectionItem);
324
+ }
325
+ res.maxLevel = Math.max(res.maxLevel, collection.maxLevel);
326
+ res.sort = Object.assign(Object.assign({}, res.sort), collection.sort);
327
+ return res;
328
+ }
329
+ }
330
+ function isColGrouping(colData) {
331
+ return !!colData.children;
332
+ }
333
+
334
+ class ColumnDataProvider {
335
+ get order() {
336
+ return index.reduce_1(this.sorting, (r, c, prop) => {
337
+ r[prop] = c.order;
338
+ return r;
339
+ }, {});
340
+ }
341
+ get stores() {
342
+ return this.dataSources;
343
+ }
344
+ constructor() {
345
+ this.sorting = null;
346
+ this.dataSources = index.reduce_1(columnTypes, (sources, k) => {
347
+ sources[k] = new index.DataStore(k);
348
+ return sources;
349
+ }, {});
350
+ }
351
+ column(c, pin) {
352
+ return this.getColumn(c, pin || 'rgCol');
353
+ }
354
+ getColumn(virtualIndex, type) {
355
+ return index.getSourceItem(this.dataSources[type].store, virtualIndex);
356
+ }
357
+ getRawColumns() {
358
+ return index.reduce_1(this.dataSources, (result, item, type) => {
359
+ result[type] = item.store.get('source');
360
+ return result;
361
+ }, {
362
+ rgCol: [],
363
+ colPinStart: [],
364
+ colPinEnd: [],
365
+ });
366
+ }
367
+ getColumns(type = 'all') {
368
+ if (type !== 'all') {
369
+ return this.dataSources[type].store.get('source');
370
+ }
371
+ return columnTypes.reduce((r, t) => {
372
+ r.push(...this.dataSources[t].store.get('source'));
373
+ return r;
374
+ }, []);
375
+ }
376
+ getColumnIndexByProp(prop, type) {
377
+ return index.getSourceItemVirtualIndexByProp(this.dataSources[type].store, prop);
378
+ }
379
+ getColumnByProp(prop, type) {
380
+ const items = this.dataSources[type].store.get('source');
381
+ return find_1(items, { prop });
382
+ }
383
+ refreshByType(type) {
384
+ this.dataSources[type].refresh();
385
+ }
386
+ setColumns(data) {
387
+ index.each(columnTypes, k => {
388
+ // set columns data
389
+ this.dataSources[k].updateData(data.columns[k], {
390
+ // max depth level
391
+ depth: data.maxLevel,
392
+ // groups
393
+ groups: index.reduce_1(data.columnGrouping[k], (res, g) => {
394
+ if (!res[g.level]) {
395
+ res[g.level] = [];
396
+ }
397
+ res[g.level].push(g);
398
+ return res;
399
+ }, {}),
400
+ });
401
+ });
402
+ this.sorting = data.sort;
403
+ return data;
404
+ }
405
+ updateColumns(cols) {
406
+ // collect column by type and propert
407
+ const columnByKey = cols.reduce((res, c) => {
408
+ const type = ColumnDataProvider.getColumnType(c);
409
+ if (!res[type]) {
410
+ res[type] = {};
411
+ }
412
+ res[type][c.prop] = c;
413
+ return res;
414
+ }, {});
415
+ // find indexes in source
416
+ const colByIndex = {};
417
+ index.each(columnByKey, (colsToUpdate, type) => {
418
+ const items = this.dataSources[type].store.get('source');
419
+ colByIndex[type] = items.reduce((result, rgCol, index) => {
420
+ const colToUpdateIfExists = colsToUpdate[rgCol.prop];
421
+ if (colToUpdateIfExists) {
422
+ result[index] = colToUpdateIfExists;
423
+ }
424
+ return result;
425
+ }, {});
426
+ });
427
+ index.each(colByIndex, (colsToUpdate, type) => index.setSourceByVirtualIndex(this.dataSources[type].store, colsToUpdate));
428
+ }
429
+ updateColumn(column, index$1) {
430
+ const type = ColumnDataProvider.getColumnType(column);
431
+ index.setSourceByVirtualIndex(this.dataSources[type].store, { [index$1]: column });
432
+ }
433
+ updateColumnSorting(column, index, sorting, additive) {
434
+ if (!additive) {
435
+ this.clearSorting();
436
+ }
437
+ column.order = sorting;
438
+ this.sorting[column.prop] = column;
439
+ this.updateColumn(column, index);
440
+ return column;
441
+ }
442
+ clearSorting() {
443
+ const types = index.reduce_1(this.sorting, (r, c) => {
444
+ const k = ColumnDataProvider.getColumnType(c);
445
+ r[k] = true;
446
+ return r;
447
+ }, {});
448
+ index.each(types, (_, type) => {
449
+ const cols = this.dataSources[type].store.get('source');
450
+ index.each(cols, (c) => (c.order = undefined));
451
+ this.dataSources[type].setData({ source: [...cols] });
452
+ });
453
+ this.sorting = {};
454
+ }
455
+ static getSizes(cols) {
456
+ return index.reduce_1(cols, (res, c, i) => {
457
+ if (c.size) {
458
+ res[i] = c.size;
459
+ }
460
+ return res;
461
+ }, {});
462
+ }
463
+ static getColumnByProp(columns, prop) {
464
+ return find_1(columns, c => {
465
+ if (isColGrouping(c)) {
466
+ return ColumnDataProvider.getColumnByProp(c.children, prop);
467
+ }
468
+ return c.prop === prop;
469
+ });
470
+ }
471
+ // columns processing
472
+ static getColumns(columns, level = 0, types) {
473
+ const collection = {
474
+ columns: {
475
+ rgCol: [],
476
+ colPinStart: [],
477
+ colPinEnd: [],
478
+ },
479
+ columnGrouping: {
480
+ rgCol: [],
481
+ colPinStart: [],
482
+ colPinEnd: [],
483
+ },
484
+ maxLevel: level,
485
+ sort: {},
486
+ };
487
+ return index.reduce_1(columns, (res, colData) => {
488
+ // Grouped column
489
+ if (isColGrouping(colData)) {
490
+ return GroupingColumnPlugin.gatherGroup(res, colData, ColumnDataProvider.getColumns(colData.children, level + 1, types), level);
491
+ }
492
+ // Regular column
493
+ const regularColumn = Object.assign(Object.assign({}, (colData.columnType && types && types[colData.columnType])), colData);
494
+ // Regular column, no Pin
495
+ if (!regularColumn.pin) {
496
+ res.columns.rgCol.push(regularColumn);
497
+ // Pin
498
+ }
499
+ else {
500
+ res.columns[regularColumn.pin].push(regularColumn);
501
+ }
502
+ if (regularColumn.order) {
503
+ res.sort[regularColumn.prop] = regularColumn;
504
+ }
505
+ // trigger setup hook if present
506
+ regularColumn.beforeSetup && regularColumn.beforeSetup(regularColumn);
507
+ return res;
508
+ }, collection);
509
+ }
510
+ static getColumnType(rgCol) {
511
+ if (rgCol.pin) {
512
+ return rgCol.pin;
513
+ }
514
+ return 'rgCol';
515
+ }
516
+ }
517
+
518
+ class DataProvider {
519
+ constructor(dimensionProvider) {
520
+ this.dimensionProvider = dimensionProvider;
521
+ this.stores = index.reduce_1(rowTypes, (sources, k) => {
522
+ sources[k] = new index.DataStore(k);
523
+ return sources;
524
+ }, {});
525
+ }
526
+ setData(data, type = 'rgRow', grouping, silent = false) {
527
+ // set rgRow data
528
+ this.stores[type].updateData([...data], grouping, silent);
529
+ this.dimensionProvider.setData(data.length, type, type !== 'rgRow');
530
+ return data;
531
+ }
532
+ getModel(virtualIndex, type = 'rgRow') {
533
+ const store = this.stores[type].store;
534
+ return index.getSourceItem(store, virtualIndex);
535
+ }
536
+ setCellData({ type, rowIndex, prop, val }) {
537
+ const model = this.getModel(rowIndex, type);
538
+ model[prop] = val;
539
+ index.setSourceByVirtualIndex(this.stores[type].store, { [rowIndex]: model });
540
+ }
541
+ refresh(type = 'all') {
542
+ if (isRowType(type)) {
543
+ this.refreshItems(type);
544
+ }
545
+ rowTypes.forEach((t) => this.refreshItems(t));
546
+ }
547
+ refreshItems(type = 'rgRow') {
548
+ const items = this.stores[type].store.get('items');
549
+ this.stores[type].setData({ items: [...items] });
550
+ }
551
+ setGrouping({ depth }, type = 'rgRow') {
552
+ this.stores[type].setData({ groupingDepth: depth });
553
+ }
554
+ setTrimmed(trimmed, type = 'rgRow') {
555
+ const store = this.stores[type];
556
+ store.addTrimmed(trimmed);
557
+ this.dimensionProvider.setTrimmed(trimmed, type);
558
+ if (type === 'rgRow') {
559
+ this.dimensionProvider.setData(index.getVisibleSourceItem(store.store).length, type);
560
+ }
561
+ }
562
+ }
563
+
564
+ /**
565
+ * Storing pre-calculated
566
+ * Dimension information and sizes
567
+ */
568
+ const trimmedPlugin = (store) => {
569
+ let trimmedSize = {};
570
+ const setTrimmed = (sizes, trimmed) => {
571
+ const newSize = Object.assign({}, sizes);
572
+ trimmedSize = {};
573
+ index.each(trimmed, (v, index) => {
574
+ if (v && newSize[index]) {
575
+ trimmedSize[index] = newSize[index];
576
+ delete newSize[index];
577
+ }
578
+ });
579
+ store.setDimensionSize(newSize);
580
+ };
581
+ return {
582
+ set(key, val) {
583
+ switch (key) {
584
+ case 'trimmed':
585
+ const trim = val;
586
+ const sizes = store.store.get('sizes');
587
+ // recover trimmed, apply new trim
588
+ setTrimmed(Object.assign(Object.assign({}, sizes), trimmedSize), trim);
589
+ break;
590
+ }
591
+ }
592
+ };
593
+ };
594
+ const realSizePlugin = (store) => {
595
+ return {
596
+ set(k) {
597
+ switch (k) {
598
+ case 'count':
599
+ case 'sizes':
600
+ case 'originItemSize':
601
+ let realSize = 0;
602
+ const count = store.store.get('count');
603
+ for (let i = 0; i < count; i++) {
604
+ realSize += store.store.get('sizes')[i] || store.store.get('originItemSize');
605
+ }
606
+ store.setStore({ realSize });
607
+ }
608
+ }
609
+ };
610
+ };
611
+ function initialBase() {
612
+ return {
613
+ indexes: [],
614
+ count: 0,
615
+ // plugin support
616
+ trimmed: {},
617
+ // size operations, this provider stores only changed sizes, not all of them
618
+ // same as indexes but for sizes and positions
619
+ // item index to size
620
+ sizes: {},
621
+ // order in indexes[] to coordinate
622
+ positionIndexToItem: {},
623
+ // initial element to coordinate ^
624
+ indexToItem: {},
625
+ positionIndexes: [],
626
+ };
627
+ }
628
+ function initialState() {
629
+ return Object.assign(Object.assign({}, initialBase()), {
630
+ // size which all items can take
631
+ realSize: 0,
632
+ // initial item size if it wasn't changed
633
+ originItemSize: 0 });
634
+ }
635
+ class DimensionStore {
636
+ constructor() {
637
+ this.store = index.createStore(initialState());
638
+ this.store.use(trimmedPlugin(this));
639
+ this.store.use(realSizePlugin(this));
640
+ }
641
+ getCurrentState() {
642
+ const state = initialState();
643
+ const keys = Object.keys(state);
644
+ return index.reduce_1(keys, (r, k) => {
645
+ const data = this.store.get(k);
646
+ r[k] = data;
647
+ return r;
648
+ }, state);
649
+ }
650
+ dispose() {
651
+ index.setStore(this.store, initialState());
652
+ }
653
+ setStore(data) {
654
+ index.setStore(this.store, data);
655
+ }
656
+ drop() {
657
+ index.setStore(this.store, initialBase());
658
+ }
659
+ /**
660
+ * Set custom dimension sizes and overwrite old
661
+ * Generates new indexes based on sizes
662
+ * @param sizes - sizes to set
663
+ */
664
+ setDimensionSize(sizes) {
665
+ const dimensionData = index.calculateDimensionData(this.store.get('originItemSize'), sizes);
666
+ index.setStore(this.store, dimensionData);
667
+ return dimensionData;
668
+ }
669
+ }
670
+
671
+ /**
672
+ * Dimension provider
673
+ * Stores dimension information and custom sizes
674
+ */
675
+ class DimensionProvider {
676
+ constructor(viewports, config) {
677
+ this.viewports = viewports;
678
+ const sizeChanged = viewport_helpers.lodash.debounce((k) => config.realSizeChanged(k), index.RESIZE_INTERVAL);
679
+ this.stores = index.reduce_1([...rowTypes, ...columnTypes], (sources, k) => {
680
+ sources[k] = new DimensionStore();
681
+ sources[k].store.onChange('realSize', () => sizeChanged(k));
682
+ return sources;
683
+ }, {});
684
+ }
685
+ /**
686
+ * Clear old sizes from dimension and viewports
687
+ * @param type - dimension type
688
+ * @param count - count of items
689
+ */
690
+ clearSize(t, count) {
691
+ this.stores[t].drop();
692
+ // after we done with drop trigger viewport recalculaction
693
+ this.viewports.stores[t].setOriginalSizes(this.stores[t].store.get('originItemSize'));
694
+ this.setItemCount(count, t);
695
+ }
696
+ /**
697
+ * Apply new custom sizes to dimension and view port
698
+ * @param type - dimension type
699
+ * @param sizes - new custom sizes
700
+ * @param keepOld - keep old sizes merge new with old
701
+ */
702
+ setCustomSizes(type, sizes, keepOld = false) {
703
+ let newSizes = sizes;
704
+ if (keepOld) {
705
+ const oldSizes = this.stores[type].store.get('sizes');
706
+ newSizes = Object.assign(Object.assign({}, oldSizes), sizes);
707
+ }
708
+ this.stores[type].setDimensionSize(newSizes);
709
+ this.viewports.stores[type].setViewPortDimensionSizes(newSizes, !keepOld ? this.stores[type].store.get('originItemSize') : undefined);
710
+ }
711
+ setItemCount(realCount, type) {
712
+ this.viewports.stores[type].setViewport({ realCount });
713
+ this.stores[type].setStore({ count: realCount });
714
+ }
715
+ /**
716
+ * Apply trimmed items
717
+ * @param trimmed - trimmed items
718
+ * @param type
719
+ */
720
+ setTrimmed(trimmed, type) {
721
+ const allTrimmed = index.gatherTrimmedItems(trimmed);
722
+ const dimStoreType = this.stores[type];
723
+ dimStoreType.setStore({ trimmed: allTrimmed });
724
+ this.viewports.stores[type].setViewPortDimensionSizes(dimStoreType.store.get('sizes'));
725
+ }
726
+ /**
727
+ * Sets dimension data and view port coordinate
728
+ * @param items - data/column items
729
+ * @param type - dimension type
730
+ */
731
+ setData(itemCount, type, noVirtual = false) {
732
+ this.setItemCount(itemCount, type);
733
+ if (noVirtual) {
734
+ this.setNoVirtual(type);
735
+ }
736
+ this.updateViewport(type);
737
+ }
738
+ /**
739
+ * Virtualization will get disabled
740
+ * @param type - dimension type
741
+ */
742
+ setNoVirtual(type) {
743
+ const dimension = this.stores[type].getCurrentState();
744
+ this.viewports.stores[type].setViewport({ virtualSize: dimension.realSize });
745
+ }
746
+ /**
747
+ * Drop all dimension data
748
+ */
749
+ dropColumns(types = columnTypes) {
750
+ for (let type of types) {
751
+ this.stores[type].drop();
752
+ this.viewports.stores[type].clearItems(); // check if needed
753
+ }
754
+ }
755
+ getFullSize() {
756
+ var _a, _b;
757
+ let x = 0;
758
+ let y = 0;
759
+ for (let type of columnTypes) {
760
+ x += ((_a = this.stores[type]) === null || _a === void 0 ? void 0 : _a.store.get('realSize')) || 0;
761
+ }
762
+ for (let type of rowTypes) {
763
+ y += ((_b = this.stores[type]) === null || _b === void 0 ? void 0 : _b.store.get('realSize')) || 0;
764
+ }
765
+ return { y, x };
766
+ }
767
+ setNewColumns(type, newLength, sizes, noVirtual = false) {
768
+ this.setItemCount(newLength, type);
769
+ this.setCustomSizes(type, sizes);
770
+ if (noVirtual) {
771
+ this.setNoVirtual(type);
772
+ }
773
+ this.updateViewport(type);
774
+ }
775
+ updateViewport(type) {
776
+ this.setViewPortCoordinate({
777
+ coordinate: this.viewports.stores[type].lastCoordinate,
778
+ type,
779
+ });
780
+ }
781
+ setViewPortCoordinate({ coordinate, type }) {
782
+ const dimension = this.stores[type].getCurrentState();
783
+ this.viewports.stores[type].setViewPortCoordinate(coordinate, dimension);
784
+ }
785
+ getViewPortPos(e) {
786
+ const dimension = this.stores[e.dimension].getCurrentState();
787
+ const item = index.getItemByIndex(dimension, e.coordinate);
788
+ return item.start;
789
+ }
790
+ setSettings(data, dimensionType) {
791
+ let stores = [];
792
+ switch (dimensionType) {
793
+ case 'rgCol':
794
+ stores = columnTypes;
795
+ break;
796
+ case 'rgRow':
797
+ stores = rowTypes;
798
+ break;
799
+ }
800
+ for (let s of stores) {
801
+ this.stores[s].setStore(data);
802
+ }
803
+ }
804
+ }
805
+
806
+ class ViewportProvider {
807
+ constructor() {
808
+ this.stores = index.reduce_1([...rowTypes, ...columnTypes], (sources, k) => {
809
+ sources[k] = new events.ViewportStore(k);
810
+ return sources;
811
+ }, {});
812
+ }
813
+ setViewport(type, data) {
814
+ this.stores[type].setViewport(data);
815
+ }
816
+ }
817
+
818
+ /**
819
+ * Plugin module for revo-grid grid system
820
+ * Add support for automatic column resize
821
+ */
822
+ const LETTER_BLOCK_SIZE = 7;
823
+ var ColumnAutoSizeMode;
824
+ (function (ColumnAutoSizeMode) {
825
+ // increases column width on header click according the largest text value
826
+ ColumnAutoSizeMode["headerClickAutosize"] = "headerClickAutoSize";
827
+ // increases column width on data set and text edit, decreases performance
828
+ ColumnAutoSizeMode["autoSizeOnTextOverlap"] = "autoSizeOnTextOverlap";
829
+ // increases and decreases column width based on all items sizes, worst for performance
830
+ ColumnAutoSizeMode["autoSizeAll"] = "autoSizeAll";
831
+ })(ColumnAutoSizeMode || (ColumnAutoSizeMode = {}));
832
+ class AutoSizeColumn extends BasePlugin {
833
+ constructor(revogrid, providers, config) {
834
+ super(revogrid);
835
+ this.providers = providers;
836
+ this.config = config;
837
+ this.autoSizeColumns = null;
838
+ /** for edge case when no columns defined before data */
839
+ this.dataResolve = null;
840
+ this.dataReject = null;
841
+ this.letterBlockSize = (config === null || config === void 0 ? void 0 : config.letterBlockSize) || LETTER_BLOCK_SIZE;
842
+ // create test container to check text width
843
+ if (config === null || config === void 0 ? void 0 : config.preciseSize) {
844
+ this.precsizeCalculationArea = this.initiatePresizeElement();
845
+ revogrid.appendChild(this.precsizeCalculationArea);
846
+ }
847
+ const aftersourceset = ({ detail: { source } }) => {
848
+ this.setSource(source);
849
+ };
850
+ const afteredit = ({ detail }) => {
851
+ this.afteredit(detail);
852
+ };
853
+ const afterEditAll = ({ detail }) => {
854
+ this.afterEditAll(detail);
855
+ };
856
+ const beforecolumnsset = ({ detail: { columns } }) => {
857
+ this.columnSet(columns);
858
+ };
859
+ const headerDblClick = ({ detail }) => {
860
+ const type = ColumnDataProvider.getColumnType(detail.column);
861
+ const size = this.getColumnSize(detail.index, type);
862
+ if (size) {
863
+ this.providers.dimensionProvider.setCustomSizes(type, {
864
+ [detail.index]: size,
865
+ }, true);
866
+ }
867
+ };
868
+ this.addEventListener('beforecolumnsset', beforecolumnsset);
869
+ switch (config === null || config === void 0 ? void 0 : config.mode) {
870
+ case ColumnAutoSizeMode.autoSizeOnTextOverlap:
871
+ this.addEventListener('aftersourceset', aftersourceset);
872
+ this.addEventListener('afteredit', afteredit);
873
+ break;
874
+ case ColumnAutoSizeMode.autoSizeAll:
875
+ this.addEventListener('aftersourceset', aftersourceset);
876
+ this.addEventListener('afteredit', afterEditAll);
877
+ break;
878
+ default:
879
+ this.addEventListener('headerdblClick', headerDblClick);
880
+ break;
881
+ }
882
+ }
883
+ async setSource(source) {
884
+ let autoSize = this.autoSizeColumns;
885
+ if (this.dataReject) {
886
+ this.dataReject();
887
+ this.clearPromise();
888
+ }
889
+ /** If data set first and no column provided await until get one */
890
+ if (!autoSize) {
891
+ const request = new Promise((resolve, reject) => {
892
+ this.dataResolve = resolve;
893
+ this.dataReject = reject;
894
+ });
895
+ try {
896
+ autoSize = await request;
897
+ }
898
+ catch (e) {
899
+ return;
900
+ }
901
+ }
902
+ // calculate sizes
903
+ index.each(autoSize, (_v, type) => {
904
+ const sizes = {};
905
+ index.each(autoSize[type], rgCol => {
906
+ // calculate size
907
+ rgCol.size = sizes[rgCol.index] = source.reduce((prev, rgRow) => Math.max(prev, this.getLength(rgRow[rgCol.prop])), this.getLength(rgCol.name || ''));
908
+ });
909
+ this.providers.dimensionProvider.setCustomSizes(type, sizes, true);
910
+ });
911
+ }
912
+ getLength(len) {
913
+ var _a;
914
+ const padding = 15;
915
+ if (!len) {
916
+ return 0;
917
+ }
918
+ try {
919
+ const str = len.toString();
920
+ /**if exact calculation required proxy with html element, slow operation */
921
+ if ((_a = this.config) === null || _a === void 0 ? void 0 : _a.preciseSize) {
922
+ this.precsizeCalculationArea.innerText = str;
923
+ return this.precsizeCalculationArea.scrollWidth + padding * 2;
924
+ }
925
+ return str.length * this.letterBlockSize + padding * 2;
926
+ }
927
+ catch (e) {
928
+ return 0;
929
+ }
930
+ }
931
+ afteredit(e) {
932
+ let data;
933
+ if (this.isRangeEdit(e)) {
934
+ data = e.data;
935
+ }
936
+ else {
937
+ data = { 0: { [e.prop]: e.val } };
938
+ }
939
+ index.each(this.autoSizeColumns, (columns, type) => {
940
+ const sizes = {};
941
+ index.each(columns, rgCol => {
942
+ // calculate size
943
+ const size = index.reduce_1(data, (prev, rgRow) => {
944
+ if (typeof rgRow[rgCol.prop] === 'undefined') {
945
+ return prev;
946
+ }
947
+ return Math.max(prev || 0, this.getLength(rgRow[rgCol.prop]));
948
+ }, undefined);
949
+ if (size && rgCol.size < size) {
950
+ rgCol.size = sizes[rgCol.index] = size;
951
+ }
952
+ });
953
+ this.providers.dimensionProvider.setCustomSizes(type, sizes, true);
954
+ });
955
+ }
956
+ afterEditAll(e) {
957
+ const props = {};
958
+ if (this.isRangeEdit(e)) {
959
+ index.each(e.data, r => index.each(r, (_v, p) => (props[p] = true)));
960
+ }
961
+ else {
962
+ props[e.prop] = true;
963
+ }
964
+ index.each(this.autoSizeColumns, (columns, type) => {
965
+ const sizes = {};
966
+ index.each(columns, rgCol => {
967
+ if (props[rgCol.prop]) {
968
+ const size = this.getColumnSize(rgCol.index, type);
969
+ if (size) {
970
+ sizes[rgCol.index] = size;
971
+ }
972
+ }
973
+ });
974
+ this.providers.dimensionProvider.setCustomSizes(type, sizes, true);
975
+ });
976
+ }
977
+ getColumnSize(index$1, type) {
978
+ const rgCol = this.autoSizeColumns[type][index$1];
979
+ if (!rgCol) {
980
+ return 0;
981
+ }
982
+ return index.reduce_1(this.providers.dataProvider.stores, (r, s) => {
983
+ const perStore = index.reduce_1(s.store.get('items'), (prev, _row, i) => {
984
+ const item = index.getSourceItem(s.store, i);
985
+ return Math.max(prev || 0, this.getLength(item[rgCol.prop]));
986
+ }, 0);
987
+ return Math.max(r, perStore);
988
+ }, rgCol.size || 0);
989
+ }
990
+ columnSet(columns) {
991
+ var _a;
992
+ for (let t of columnTypes) {
993
+ const type = t;
994
+ const cols = columns[type];
995
+ for (let i in cols) {
996
+ if (cols[i].autoSize || ((_a = this.config) === null || _a === void 0 ? void 0 : _a.allColumns)) {
997
+ if (!this.autoSizeColumns) {
998
+ this.autoSizeColumns = {};
999
+ }
1000
+ if (!this.autoSizeColumns[type]) {
1001
+ this.autoSizeColumns[type] = {};
1002
+ }
1003
+ this.autoSizeColumns[type][i] = Object.assign(Object.assign({}, cols[i]), { index: parseInt(i, 10) });
1004
+ }
1005
+ }
1006
+ }
1007
+ if (this.dataResolve) {
1008
+ this.dataResolve(this.autoSizeColumns);
1009
+ this.clearPromise();
1010
+ }
1011
+ }
1012
+ clearPromise() {
1013
+ this.dataResolve = null;
1014
+ this.dataReject = null;
1015
+ }
1016
+ isRangeEdit(e) {
1017
+ return !!e.data;
1018
+ }
1019
+ initiatePresizeElement() {
1020
+ const styleForFontTest = {
1021
+ position: 'absolute',
1022
+ fontSize: '14px',
1023
+ height: '0',
1024
+ width: '0',
1025
+ whiteSpace: 'nowrap',
1026
+ top: '0',
1027
+ overflowX: 'scroll',
1028
+ };
1029
+ const el = document.createElement('div');
1030
+ for (let s in styleForFontTest) {
1031
+ el.style[s] = styleForFontTest[s];
1032
+ }
1033
+ el.classList.add('revo-test-container');
1034
+ return el;
1035
+ }
1036
+ destroy() {
1037
+ var _a;
1038
+ super.destroy();
1039
+ (_a = this.precsizeCalculationArea) === null || _a === void 0 ? void 0 : _a.remove();
1040
+ }
1041
+ }
1042
+
1043
+ const eq = (value, extra) => {
1044
+ if (typeof value === 'undefined' || (value === null && !extra)) {
1045
+ return true;
1046
+ }
1047
+ if (typeof value !== 'string') {
1048
+ value = JSON.stringify(value);
1049
+ }
1050
+ const filterVal = extra.toString().toLocaleLowerCase();
1051
+ if (filterVal.length === 0) {
1052
+ return true;
1053
+ }
1054
+ return value.toLocaleLowerCase() === filterVal;
1055
+ };
1056
+ const notEq = (value, extra) => !eq(value, extra);
1057
+ notEq.extra = 'input';
1058
+ eq.extra = 'input';
1059
+
1060
+ const gtThan = function (value, extra) {
1061
+ let conditionValue;
1062
+ if (typeof value === 'number') {
1063
+ conditionValue = parseFloat(extra === null || extra === void 0 ? void 0 : extra.toString());
1064
+ return value > conditionValue;
1065
+ }
1066
+ return false;
1067
+ };
1068
+ gtThan.extra = 'input';
1069
+
1070
+ const gtThanEq = function (value, extra) {
1071
+ return eq(value, extra) || gtThan(value, extra);
1072
+ };
1073
+ gtThanEq.extra = 'input';
1074
+
1075
+ const lt = function (value, extra) {
1076
+ let conditionValue;
1077
+ if (typeof value === 'number') {
1078
+ conditionValue = parseFloat(extra === null || extra === void 0 ? void 0 : extra.toString());
1079
+ return value < conditionValue;
1080
+ }
1081
+ else {
1082
+ return false;
1083
+ }
1084
+ };
1085
+ lt.extra = 'input';
1086
+
1087
+ const lsEq = function (value, extra) {
1088
+ return eq(value, extra) || lt(value, extra);
1089
+ };
1090
+ lsEq.extra = 'input';
1091
+
1092
+ const set = (value) => !(value === '' || value === null || value === void 0);
1093
+ const notSet = (value) => !set(value);
1094
+
1095
+ const beginsWith = (value, extra) => {
1096
+ if (!value) {
1097
+ return false;
1098
+ }
1099
+ if (!extra) {
1100
+ return true;
1101
+ }
1102
+ if (typeof value !== 'string') {
1103
+ value = JSON.stringify(value);
1104
+ }
1105
+ if (typeof extra !== 'string') {
1106
+ extra = JSON.stringify(extra);
1107
+ }
1108
+ return value.toLocaleLowerCase().indexOf(extra.toLocaleLowerCase()) === 0;
1109
+ };
1110
+ beginsWith.extra = 'input';
1111
+
1112
+ const contains = (value, extra) => {
1113
+ if (!extra) {
1114
+ return true;
1115
+ }
1116
+ if (!value) {
1117
+ return false;
1118
+ }
1119
+ if (extra) {
1120
+ if (typeof value !== 'string') {
1121
+ value = JSON.stringify(value);
1122
+ }
1123
+ return value.toLocaleLowerCase().indexOf(extra.toString().toLowerCase()) > -1;
1124
+ }
1125
+ return true;
1126
+ };
1127
+ const notContains = (value, extra) => {
1128
+ return !contains(value, extra);
1129
+ };
1130
+ notContains.extra = 'input';
1131
+ contains.extra = 'input';
1132
+
1133
+ const filterNames = {
1134
+ none: 'None',
1135
+ empty: 'Not set',
1136
+ notEmpty: 'Set',
1137
+ eq: 'Equal',
1138
+ notEq: 'Not equal',
1139
+ begins: 'Begins with',
1140
+ contains: 'Contains',
1141
+ notContains: 'Does not contain',
1142
+ eqN: '=',
1143
+ neqN: '!=',
1144
+ gt: '>',
1145
+ gte: '>=',
1146
+ lt: '<',
1147
+ lte: '<=',
1148
+ };
1149
+ const filterEntities = {
1150
+ none: () => true,
1151
+ empty: notSet,
1152
+ notEmpty: set,
1153
+ eq: eq,
1154
+ notEq: notEq,
1155
+ begins: beginsWith,
1156
+ contains: contains,
1157
+ notContains: notContains,
1158
+ eqN: eq,
1159
+ neqN: notEq,
1160
+ gt: gtThan,
1161
+ gte: gtThanEq,
1162
+ lt: lt,
1163
+ lte: lsEq,
1164
+ };
1165
+ const filterTypes = {
1166
+ string: ['notEmpty', 'empty', 'eq', 'notEq', 'begins', 'contains', 'notContains'],
1167
+ number: ['notEmpty', 'empty', 'eqN', 'neqN', 'gt', 'gte', 'lt', 'lte'],
1168
+ };
1169
+
1170
+ const FILTER_TRIMMED_TYPE = 'filter';
1171
+ const FILTER_CONFIG_CHANGED_EVENT = 'filterconfigchanged';
1172
+ class FilterPlugin extends BasePlugin {
1173
+ constructor(revogrid, uiid, config) {
1174
+ var _a;
1175
+ super(revogrid);
1176
+ this.revogrid = revogrid;
1177
+ this.filterCollection = {};
1178
+ this.multiFilterItems = {};
1179
+ this.possibleFilters = Object.assign({}, filterTypes);
1180
+ this.possibleFilterNames = Object.assign({}, filterNames);
1181
+ this.possibleFilterEntities = Object.assign({}, filterEntities);
1182
+ this.filterProp = filter_button.FILTER_PROP;
1183
+ if (config) {
1184
+ this.initConfig(config);
1185
+ }
1186
+ const headerclick = (e) => this.headerclick(e);
1187
+ const aftersourceset = async () => {
1188
+ const filterCollectionProps = Object.keys(this.filterCollection);
1189
+ if (filterCollectionProps.length > 0) {
1190
+ // handle old way of filtering by reworking FilterCollection to new MultiFilterItem
1191
+ filterCollectionProps.forEach((prop, index) => {
1192
+ if (!this.multiFilterItems[prop]) {
1193
+ this.multiFilterItems[prop] = [
1194
+ {
1195
+ id: index,
1196
+ type: this.filterCollection[prop].type,
1197
+ value: this.filterCollection[prop].value,
1198
+ relation: 'and',
1199
+ },
1200
+ ];
1201
+ }
1202
+ });
1203
+ }
1204
+ await this.runFiltering();
1205
+ };
1206
+ this.addEventListener('headerclick', headerclick);
1207
+ this.addEventListener(FILTER_CONFIG_CHANGED_EVENT, ({ detail }) => {
1208
+ if (!detail) {
1209
+ this.clearFiltering();
1210
+ return;
1211
+ }
1212
+ if (typeof detail === 'object') {
1213
+ this.initConfig(detail);
1214
+ }
1215
+ aftersourceset();
1216
+ });
1217
+ this.addEventListener('aftersourceset', aftersourceset);
1218
+ this.addEventListener('filter', ({ detail }) => this.onFilterChange(detail));
1219
+ this.revogrid.registerVNode([
1220
+ index$1.h("revogr-filter-panel", { uuid: `filter-${uiid}`, filterItems: this.multiFilterItems, filterNames: this.possibleFilterNames, filterEntities: this.possibleFilterEntities, filterCaptions: (_a = config === null || config === void 0 ? void 0 : config.localization) === null || _a === void 0 ? void 0 : _a.captions, onFilterChange: e => this.onFilterChange(e.detail), disableDynamicFiltering: config === null || config === void 0 ? void 0 : config.disableDynamicFiltering, ref: e => (this.pop = e) }),
1221
+ ]);
1222
+ }
1223
+ initConfig(config) {
1224
+ if (config.multiFilterItems) {
1225
+ this.multiFilterItems = Object.assign({}, config.multiFilterItems);
1226
+ }
1227
+ if (config.customFilters) {
1228
+ for (let cType in config.customFilters) {
1229
+ const cFilter = config.customFilters[cType];
1230
+ if (!this.possibleFilters[cFilter.columnFilterType]) {
1231
+ this.possibleFilters[cFilter.columnFilterType] = [];
1232
+ }
1233
+ this.possibleFilters[cFilter.columnFilterType].push(cType);
1234
+ this.possibleFilterEntities[cType] = cFilter.func;
1235
+ this.possibleFilterNames[cType] = cFilter.name;
1236
+ }
1237
+ }
1238
+ if (config.filterProp) {
1239
+ this.filterProp = config.filterProp;
1240
+ }
1241
+ /**
1242
+ * which filters has to be included/excluded
1243
+ * convinient way to exclude system filters
1244
+ */
1245
+ if (config.include) {
1246
+ const filters = {};
1247
+ for (let t in this.possibleFilters) {
1248
+ // validate filters, if appropriate function present
1249
+ const newTypes = this.possibleFilters[t].filter(f => config.include.indexOf(f) > -1);
1250
+ if (newTypes.length) {
1251
+ filters[t] = newTypes;
1252
+ }
1253
+ }
1254
+ // if any valid filters provided show them
1255
+ if (Object.keys(filters).length > 0) {
1256
+ this.possibleFilters = filters;
1257
+ }
1258
+ }
1259
+ if (config.collection) {
1260
+ this.filterCollection = viewport_helpers.lodash.reduce(config.collection, (result, item, prop) => {
1261
+ if (this.possibleFilterEntities[item.type]) {
1262
+ result[prop] = item;
1263
+ }
1264
+ else {
1265
+ console.warn(`${item.type} type is not found.`);
1266
+ }
1267
+ return result;
1268
+ }, {});
1269
+ }
1270
+ if (config.localization) {
1271
+ if (config.localization.filterNames) {
1272
+ Object.entries(config.localization.filterNames).forEach(([k, v]) => {
1273
+ if (this.possibleFilterNames[k] != void 0) {
1274
+ this.possibleFilterNames[k] = v;
1275
+ }
1276
+ });
1277
+ }
1278
+ }
1279
+ }
1280
+ async headerclick(e) {
1281
+ var _a;
1282
+ const el = (_a = e.detail.originalEvent) === null || _a === void 0 ? void 0 : _a.target;
1283
+ if (!filter_button.isFilterBtn(el)) {
1284
+ return;
1285
+ }
1286
+ e.preventDefault();
1287
+ // close if same
1288
+ const changes = await this.pop.getChanges();
1289
+ if (changes && (changes === null || changes === void 0 ? void 0 : changes.prop) === e.detail.prop) {
1290
+ this.pop.show();
1291
+ return;
1292
+ }
1293
+ // filter button clicked, open filter dialog
1294
+ const gridPos = this.revogrid.getBoundingClientRect();
1295
+ const buttonPos = el.getBoundingClientRect();
1296
+ const prop = e.detail.prop;
1297
+ this.pop.filterTypes = this.getColumnFilter(e.detail.filter);
1298
+ this.pop.show(Object.assign(Object.assign({}, this.filterCollection[prop]), { x: buttonPos.x - gridPos.x, y: buttonPos.y - gridPos.y + buttonPos.height, prop }));
1299
+ }
1300
+ getColumnFilter(type) {
1301
+ let filterType = 'string';
1302
+ if (!type) {
1303
+ return { [filterType]: this.possibleFilters[filterType] };
1304
+ }
1305
+ // if custom column filter
1306
+ if (this.isValidType(type)) {
1307
+ filterType = type;
1308
+ // if multiple filters applied
1309
+ }
1310
+ else if (typeof type === 'object' && type.length) {
1311
+ return type.reduce((r, multiType) => {
1312
+ if (this.isValidType(multiType)) {
1313
+ r[multiType] = this.possibleFilters[multiType];
1314
+ }
1315
+ return r;
1316
+ }, {});
1317
+ }
1318
+ return { [filterType]: this.possibleFilters[filterType] };
1319
+ }
1320
+ isValidType(type) {
1321
+ return !!(typeof type === 'string' && this.possibleFilters[type]);
1322
+ }
1323
+ // called on internal component change
1324
+ async onFilterChange(filterItems) {
1325
+ this.multiFilterItems = filterItems;
1326
+ this.runFiltering();
1327
+ }
1328
+ /**
1329
+ * Triggers grid filtering
1330
+ */
1331
+ async doFiltering(collection, items, columns, filterItems) {
1332
+ const columnsToUpdate = [];
1333
+ columns.forEach(rgCol => {
1334
+ const column = Object.assign({}, rgCol);
1335
+ const hasFilter = filterItems[column.prop];
1336
+ if (column[this.filterProp] && !hasFilter) {
1337
+ delete column[this.filterProp];
1338
+ columnsToUpdate.push(column);
1339
+ }
1340
+ if (!column[this.filterProp] && hasFilter) {
1341
+ columnsToUpdate.push(column);
1342
+ column[this.filterProp] = true;
1343
+ }
1344
+ });
1345
+ const itemsToFilter = this.getRowFilter(items, filterItems);
1346
+ // check is filter event prevented
1347
+ const { defaultPrevented, detail } = this.emit('beforefiltertrimmed', { collection, itemsToFilter, source: items, filterItems });
1348
+ if (defaultPrevented) {
1349
+ return;
1350
+ }
1351
+ // check is trimmed event prevented
1352
+ const isAddedEvent = await this.revogrid.addTrimmed(detail.itemsToFilter, FILTER_TRIMMED_TYPE);
1353
+ if (isAddedEvent.defaultPrevented) {
1354
+ return;
1355
+ }
1356
+ // applies the hasFilter to the columns to show filter icon
1357
+ await this.revogrid.updateColumns(columnsToUpdate);
1358
+ this.emit('afterFilterApply');
1359
+ }
1360
+ async clearFiltering() {
1361
+ this.multiFilterItems = {};
1362
+ await this.runFiltering();
1363
+ }
1364
+ async runFiltering() {
1365
+ const collection = {};
1366
+ // handle old filterCollection to return the first filter only (if any) from multiFilterItems
1367
+ const filterProps = Object.keys(this.multiFilterItems);
1368
+ for (const prop of filterProps) {
1369
+ // check if we have any filter for a column
1370
+ if (this.multiFilterItems[prop].length > 0) {
1371
+ const firstFilterItem = this.multiFilterItems[prop][0];
1372
+ collection[prop] = {
1373
+ filter: filterEntities[firstFilterItem.type],
1374
+ type: firstFilterItem.type,
1375
+ value: firstFilterItem.value,
1376
+ };
1377
+ }
1378
+ }
1379
+ this.filterCollection = collection;
1380
+ const { source, columns } = await this.getData();
1381
+ const { defaultPrevented, detail } = this.emit('beforefilterapply', { collection: this.filterCollection, source, columns, filterItems: this.multiFilterItems });
1382
+ if (defaultPrevented) {
1383
+ return;
1384
+ }
1385
+ this.doFiltering(detail.collection, detail.source, detail.columns, detail.filterItems);
1386
+ }
1387
+ async getData() {
1388
+ return {
1389
+ source: await this.revogrid.getSource(),
1390
+ columns: await this.revogrid.getColumns(),
1391
+ };
1392
+ }
1393
+ getRowFilter(rows, filterItems) {
1394
+ const propKeys = Object.keys(filterItems);
1395
+ const trimmed = {};
1396
+ let propFilterSatisfiedCount = 0;
1397
+ let lastFilterResults = [];
1398
+ // each rows
1399
+ rows.forEach((model, rowIndex) => {
1400
+ // working on all props
1401
+ for (const prop of propKeys) {
1402
+ const propFilters = filterItems[prop];
1403
+ propFilterSatisfiedCount = 0;
1404
+ lastFilterResults = [];
1405
+ // testing each filter for a prop
1406
+ for (const [filterIndex, filterData] of propFilters.entries()) {
1407
+ // the filter LogicFunction based on the type
1408
+ const filter = this.possibleFilterEntities[filterData.type];
1409
+ // THE MAGIC OF FILTERING IS HERE
1410
+ if (filterData.relation === 'or') {
1411
+ lastFilterResults = [];
1412
+ if (filter(model[prop], filterData.value)) {
1413
+ continue;
1414
+ }
1415
+ propFilterSatisfiedCount++;
1416
+ }
1417
+ else {
1418
+ // 'and' relation will need to know the next filter
1419
+ // so we save this current filter to include it in the next filter
1420
+ lastFilterResults.push(!filter(model[prop], filterData.value));
1421
+ // check first if we have a filter on the next index to pair it with this current filter
1422
+ const nextFilterData = propFilters[filterIndex + 1];
1423
+ // stop the sequence if there is no next filter or if the next filter is not an 'and' relation
1424
+ if (!nextFilterData || nextFilterData.relation !== 'and') {
1425
+ // let's just continue since for sure propFilterSatisfiedCount cannot be satisfied
1426
+ if (lastFilterResults.indexOf(true) === -1) {
1427
+ lastFilterResults = [];
1428
+ continue;
1429
+ }
1430
+ // we need to add all of the lastFilterResults since we need to satisfy all
1431
+ propFilterSatisfiedCount += lastFilterResults.length;
1432
+ lastFilterResults = [];
1433
+ }
1434
+ }
1435
+ } // end of propFilters forEach
1436
+ // add to the list of removed/trimmed rows of filter condition is satisfied
1437
+ if (propFilterSatisfiedCount === propFilters.length)
1438
+ trimmed[rowIndex] = true;
1439
+ } // end of for-of propKeys
1440
+ });
1441
+ return trimmed;
1442
+ }
1443
+ }
1444
+
1445
+ /**
1446
+ * Gets the size of an ASCII `string`.
1447
+ *
1448
+ * @private
1449
+ * @param {string} string The string inspect.
1450
+ * @returns {number} Returns the string size.
1451
+ */
1452
+ var asciiSize = index._baseProperty('length');
1453
+
1454
+ var _asciiSize = asciiSize;
1455
+
1456
+ /** Used to compose unicode character classes. */
1457
+ var rsAstralRange$1 = '\\ud800-\\udfff',
1458
+ rsComboMarksRange$1 = '\\u0300-\\u036f',
1459
+ reComboHalfMarksRange$1 = '\\ufe20-\\ufe2f',
1460
+ rsComboSymbolsRange$1 = '\\u20d0-\\u20ff',
1461
+ rsComboRange$1 = rsComboMarksRange$1 + reComboHalfMarksRange$1 + rsComboSymbolsRange$1,
1462
+ rsVarRange$1 = '\\ufe0e\\ufe0f';
1463
+
1464
+ /** Used to compose unicode capture groups. */
1465
+ var rsZWJ$1 = '\\u200d';
1466
+
1467
+ /** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */
1468
+ var reHasUnicode = RegExp('[' + rsZWJ$1 + rsAstralRange$1 + rsComboRange$1 + rsVarRange$1 + ']');
1469
+
1470
+ /**
1471
+ * Checks if `string` contains Unicode symbols.
1472
+ *
1473
+ * @private
1474
+ * @param {string} string The string to inspect.
1475
+ * @returns {boolean} Returns `true` if a symbol is found, else `false`.
1476
+ */
1477
+ function hasUnicode(string) {
1478
+ return reHasUnicode.test(string);
1479
+ }
1480
+
1481
+ var _hasUnicode = hasUnicode;
1482
+
1483
+ /** Used to compose unicode character classes. */
1484
+ var rsAstralRange = '\\ud800-\\udfff',
1485
+ rsComboMarksRange = '\\u0300-\\u036f',
1486
+ reComboHalfMarksRange = '\\ufe20-\\ufe2f',
1487
+ rsComboSymbolsRange = '\\u20d0-\\u20ff',
1488
+ rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,
1489
+ rsVarRange = '\\ufe0e\\ufe0f';
1490
+
1491
+ /** Used to compose unicode capture groups. */
1492
+ var rsAstral = '[' + rsAstralRange + ']',
1493
+ rsCombo = '[' + rsComboRange + ']',
1494
+ rsFitz = '\\ud83c[\\udffb-\\udfff]',
1495
+ rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',
1496
+ rsNonAstral = '[^' + rsAstralRange + ']',
1497
+ rsRegional = '(?:\\ud83c[\\udde6-\\uddff]){2}',
1498
+ rsSurrPair = '[\\ud800-\\udbff][\\udc00-\\udfff]',
1499
+ rsZWJ = '\\u200d';
1500
+
1501
+ /** Used to compose unicode regexes. */
1502
+ var reOptMod = rsModifier + '?',
1503
+ rsOptVar = '[' + rsVarRange + ']?',
1504
+ rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',
1505
+ rsSeq = rsOptVar + reOptMod + rsOptJoin,
1506
+ rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';
1507
+
1508
+ /** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */
1509
+ var reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');
1510
+
1511
+ /**
1512
+ * Gets the size of a Unicode `string`.
1513
+ *
1514
+ * @private
1515
+ * @param {string} string The string inspect.
1516
+ * @returns {number} Returns the string size.
1517
+ */
1518
+ function unicodeSize(string) {
1519
+ var result = reUnicode.lastIndex = 0;
1520
+ while (reUnicode.test(string)) {
1521
+ ++result;
1522
+ }
1523
+ return result;
1524
+ }
1525
+
1526
+ var _unicodeSize = unicodeSize;
1527
+
1528
+ /**
1529
+ * Gets the number of symbols in `string`.
1530
+ *
1531
+ * @private
1532
+ * @param {string} string The string to inspect.
1533
+ * @returns {number} Returns the string size.
1534
+ */
1535
+ function stringSize(string) {
1536
+ return _hasUnicode(string)
1537
+ ? _unicodeSize(string)
1538
+ : _asciiSize(string);
1539
+ }
1540
+
1541
+ var _stringSize = stringSize;
1542
+
1543
+ /** `Object#toString` result references. */
1544
+ var mapTag = '[object Map]',
1545
+ setTag = '[object Set]';
1546
+
1547
+ /**
1548
+ * Gets the size of `collection` by returning its length for array-like
1549
+ * values or the number of own enumerable string keyed properties for objects.
1550
+ *
1551
+ * @static
1552
+ * @memberOf _
1553
+ * @since 0.1.0
1554
+ * @category Collection
1555
+ * @param {Array|Object|string} collection The collection to inspect.
1556
+ * @returns {number} Returns the collection size.
1557
+ * @example
1558
+ *
1559
+ * _.size([1, 2, 3]);
1560
+ * // => 3
1561
+ *
1562
+ * _.size({ 'a': 1, 'b': 2 });
1563
+ * // => 2
1564
+ *
1565
+ * _.size('pebbles');
1566
+ * // => 7
1567
+ */
1568
+ function size(collection) {
1569
+ if (collection == null) {
1570
+ return 0;
1571
+ }
1572
+ if (index.isArrayLike_1(collection)) {
1573
+ return isString.isString_1(collection) ? _stringSize(collection) : collection.length;
1574
+ }
1575
+ var tag = index._getTag(collection);
1576
+ if (tag == mapTag || tag == setTag) {
1577
+ return collection.size;
1578
+ }
1579
+ return index._baseKeys(collection).length;
1580
+ }
1581
+
1582
+ var size_1 = size;
1583
+
1584
+ /**
1585
+ * lifecycle
1586
+ * 1) @event beforesorting - sorting just started, nothing happened yet, can be from column or from source, if type is from rows - column will be undefined
1587
+ * 2) @metod updateColumnSorting - column sorting icon applied to grid and column get updated, data still untiuched
1588
+ * 3) @event beforesortingapply - before we applied sorting data to data source, you can prevent event and data will not be sorted. It's called only from column sorting click
1589
+ * 4) @event afterSortingApply - sorting applied, just finished event, from rows and columns
1590
+ *
1591
+ * If you prevent event it'll not reach farther steps
1592
+ */
1593
+ class SortingPlugin extends BasePlugin {
1594
+ constructor(revogrid) {
1595
+ super(revogrid);
1596
+ this.revogrid = revogrid;
1597
+ // sorting order per column
1598
+ this.sorting = null;
1599
+ // sorting function per column, multiple columns sorting supported
1600
+ this.sortingFunc = null;
1601
+ this.doSort = debounce.debounce_1((order, comparison) => this.sort(order, comparison), 50);
1602
+ const aftersourceset = async ({ detail: { type } }) => {
1603
+ // if sorting was provided - sort data
1604
+ if (!!this.sorting && this.sortingFunc) {
1605
+ const beforeEvent = this.emit('beforesorting', { type });
1606
+ if (beforeEvent.defaultPrevented) {
1607
+ return;
1608
+ }
1609
+ this.doSort(this.sorting, this.sortingFunc);
1610
+ }
1611
+ };
1612
+ const aftercolumnsset = async ({ detail: { order } }) => {
1613
+ const columns = await this.revogrid.getColumns();
1614
+ const sortingFunc = {};
1615
+ for (let prop in order) {
1616
+ const cmp = this.getComparer(ColumnDataProvider.getColumnByProp(columns, prop), order[prop]);
1617
+ sortingFunc[prop] = cmp;
1618
+ }
1619
+ this.doSort(order, sortingFunc);
1620
+ };
1621
+ const headerclick = async (e) => {
1622
+ var _a, _b;
1623
+ if (e.defaultPrevented) {
1624
+ return;
1625
+ }
1626
+ if (!e.detail.column.sortable) {
1627
+ return;
1628
+ }
1629
+ 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);
1630
+ };
1631
+ this.addEventListener('after-any-source', aftersourceset);
1632
+ this.addEventListener('aftercolumnsset', aftercolumnsset);
1633
+ this.addEventListener('initialHeaderClick', headerclick);
1634
+ }
1635
+ getComparer(column, order) {
1636
+ const cellCmp = (column === null || column === void 0 ? void 0 : column.cellCompare.bind({ order })) || this.defaultCellCompare;
1637
+ if (order == 'asc') {
1638
+ return cellCmp;
1639
+ }
1640
+ if (order == 'desc') {
1641
+ return this.descCellCompare(cellCmp);
1642
+ }
1643
+ return undefined;
1644
+ }
1645
+ /**
1646
+ * Apply sorting to data on header click
1647
+ * If additive - add to existing sorting, multiple columns can be sorted
1648
+ */
1649
+ async headerclick(column, index, additive) {
1650
+ let order = this.getNextOrder(column.order);
1651
+ const beforeEvent = this.emit('beforesorting', { column, order, additive });
1652
+ if (beforeEvent.defaultPrevented) {
1653
+ return;
1654
+ }
1655
+ order = beforeEvent.detail.order;
1656
+ const newCol = await this.revogrid.updateColumnSorting(beforeEvent.detail.column, index, order, additive);
1657
+ // apply sort data
1658
+ const beforeApplyEvent = this.emit('beforesortingapply', { column: newCol, order, additive });
1659
+ if (beforeApplyEvent.defaultPrevented) {
1660
+ return;
1661
+ }
1662
+ order = beforeApplyEvent.detail.order;
1663
+ const cmp = this.getComparer(column, order);
1664
+ if (additive && this.sorting) {
1665
+ const sorting = {};
1666
+ const sortingFunc = {};
1667
+ this.sorting = Object.assign(Object.assign({}, this.sorting), sorting);
1668
+ // extend sorting function with new sorting for multiple columns sorting
1669
+ this.sortingFunc = Object.assign(Object.assign({}, this.sortingFunc), sortingFunc);
1670
+ if (column.prop in sorting && size_1(sorting) > 1 && order === undefined) {
1671
+ delete sorting[column.prop];
1672
+ delete sortingFunc[column.prop];
1673
+ }
1674
+ else {
1675
+ sorting[column.prop] = order;
1676
+ sortingFunc[column.prop] = cmp;
1677
+ }
1678
+ }
1679
+ else {
1680
+ // reset sorting
1681
+ this.sorting = { [column.prop]: order };
1682
+ this.sortingFunc = { [column.prop]: cmp };
1683
+ }
1684
+ this.doSort(this.sorting, this.sortingFunc);
1685
+ }
1686
+ /**
1687
+ * Sort items by sorting function
1688
+ * @requires proxyItems applied to row store
1689
+ * @requires source applied to row store
1690
+ *
1691
+ * @param sorting - per column sorting
1692
+ * @param data - this.stores['rgRow'].store.get('source')
1693
+ */
1694
+ async sort(sorting, sortingFunc, types = ['rgRow', 'rowPinStart', 'rowPinEnd']) {
1695
+ // if no sorting - reset
1696
+ if (!size_1(sorting)) {
1697
+ this.sorting = null;
1698
+ this.sortingFunc = null;
1699
+ return;
1700
+ }
1701
+ // set sorting
1702
+ this.sorting = sorting;
1703
+ this.sortingFunc = sortingFunc;
1704
+ // by default it'll sort by rgRow store
1705
+ // todo: support multiple stores
1706
+ for (let type of types) {
1707
+ const store = await this.revogrid.getSourceStore(type);
1708
+ // row data
1709
+ const source = store.get('source');
1710
+ // row indexes
1711
+ const proxyItems = store.get('proxyItems');
1712
+ const data = this.sortIndexByItems([...proxyItems], source, sortingFunc);
1713
+ index.setStore(store, {
1714
+ proxyItems: data,
1715
+ source: [...source],
1716
+ });
1717
+ }
1718
+ this.emit('afterSortingApply');
1719
+ }
1720
+ defaultCellCompare(prop, a, b) {
1721
+ var _a, _b;
1722
+ const av = (_a = a[prop]) === null || _a === void 0 ? void 0 : _a.toString().toLowerCase();
1723
+ const bv = (_b = b[prop]) === null || _b === void 0 ? void 0 : _b.toString().toLowerCase();
1724
+ return av == bv ? 0 : av > bv ? 1 : -1;
1725
+ }
1726
+ descCellCompare(cmp) {
1727
+ return (prop, a, b) => {
1728
+ return -1 * cmp(prop, a, b);
1729
+ };
1730
+ }
1731
+ sortIndexByItems(indexes, source, sortingFunc) {
1732
+ // if no sorting - return unsorted indexes
1733
+ if (Object.entries(sortingFunc).length === 0) {
1734
+ // Unsort indexes
1735
+ return [...Array(indexes.length).keys()];
1736
+ }
1737
+ //
1738
+ /**
1739
+ * go through all indexes and align in new order
1740
+ * performs a multi-level sorting by applying multiple comparison functions to determine the order of the items based on different properties.
1741
+ */
1742
+ return indexes.sort((a, b) => {
1743
+ for (const [prop, cmp] of Object.entries(sortingFunc)) {
1744
+ const itemA = source[a];
1745
+ const itemB = source[b];
1746
+ /**
1747
+ * If the comparison function returns a non-zero value (sorted), it means that the items should be sorted based on the given property. In such a case, the function immediately returns the sorted value, indicating the order in which the items should be arranged.
1748
+ * If none of the comparison functions result in a non-zero value, indicating that the items are equal or should remain in the same order, the function eventually returns 0.
1749
+ */
1750
+ const sorted = cmp(prop, itemA, itemB);
1751
+ if (sorted) {
1752
+ return sorted;
1753
+ }
1754
+ }
1755
+ return 0;
1756
+ });
1757
+ }
1758
+ getNextOrder(currentOrder) {
1759
+ switch (currentOrder) {
1760
+ case undefined:
1761
+ return 'asc';
1762
+ case 'asc':
1763
+ return 'desc';
1764
+ case 'desc':
1765
+ return undefined;
1766
+ }
1767
+ }
1768
+ }
1769
+
1770
+ /**
1771
+ * The base implementation of `_.clamp` which doesn't coerce arguments.
1772
+ *
1773
+ * @private
1774
+ * @param {number} number The number to clamp.
1775
+ * @param {number} [lower] The lower bound.
1776
+ * @param {number} upper The upper bound.
1777
+ * @returns {number} Returns the clamped number.
1778
+ */
1779
+ function baseClamp(number, lower, upper) {
1780
+ if (number === number) {
1781
+ if (upper !== undefined) {
1782
+ number = number <= upper ? number : upper;
1783
+ }
1784
+ if (lower !== undefined) {
1785
+ number = number >= lower ? number : lower;
1786
+ }
1787
+ }
1788
+ return number;
1789
+ }
1790
+
1791
+ var _baseClamp = baseClamp;
1792
+
1793
+ /** Used as references for the maximum length and index of an array. */
1794
+ var MAX_ARRAY_LENGTH = 4294967295;
1795
+
1796
+ /**
1797
+ * Converts `value` to an integer suitable for use as the length of an
1798
+ * array-like object.
1799
+ *
1800
+ * **Note:** This method is based on
1801
+ * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).
1802
+ *
1803
+ * @static
1804
+ * @memberOf _
1805
+ * @since 4.0.0
1806
+ * @category Lang
1807
+ * @param {*} value The value to convert.
1808
+ * @returns {number} Returns the converted integer.
1809
+ * @example
1810
+ *
1811
+ * _.toLength(3.2);
1812
+ * // => 3
1813
+ *
1814
+ * _.toLength(Number.MIN_VALUE);
1815
+ * // => 0
1816
+ *
1817
+ * _.toLength(Infinity);
1818
+ * // => 4294967295
1819
+ *
1820
+ * _.toLength('3.2');
1821
+ * // => 3
1822
+ */
1823
+ function toLength(value) {
1824
+ return value ? _baseClamp(index.toInteger_1(value), 0, MAX_ARRAY_LENGTH) : 0;
1825
+ }
1826
+
1827
+ var toLength_1 = toLength;
1828
+
1829
+ /**
1830
+ * The base implementation of `_.fill` without an iteratee call guard.
1831
+ *
1832
+ * @private
1833
+ * @param {Array} array The array to fill.
1834
+ * @param {*} value The value to fill `array` with.
1835
+ * @param {number} [start=0] The start position.
1836
+ * @param {number} [end=array.length] The end position.
1837
+ * @returns {Array} Returns `array`.
1838
+ */
1839
+ function baseFill(array, value, start, end) {
1840
+ var length = array.length;
1841
+
1842
+ start = index.toInteger_1(start);
1843
+ if (start < 0) {
1844
+ start = -start > length ? 0 : (length + start);
1845
+ }
1846
+ end = (end === undefined || end > length) ? length : index.toInteger_1(end);
1847
+ if (end < 0) {
1848
+ end += length;
1849
+ }
1850
+ end = start > end ? 0 : toLength_1(end);
1851
+ while (start < end) {
1852
+ array[start++] = value;
1853
+ }
1854
+ return array;
1855
+ }
1856
+
1857
+ var _baseFill = baseFill;
1858
+
1859
+ /**
1860
+ * Fills elements of `array` with `value` from `start` up to, but not
1861
+ * including, `end`.
1862
+ *
1863
+ * **Note:** This method mutates `array`.
1864
+ *
1865
+ * @static
1866
+ * @memberOf _
1867
+ * @since 3.2.0
1868
+ * @category Array
1869
+ * @param {Array} array The array to fill.
1870
+ * @param {*} value The value to fill `array` with.
1871
+ * @param {number} [start=0] The start position.
1872
+ * @param {number} [end=array.length] The end position.
1873
+ * @returns {Array} Returns `array`.
1874
+ * @example
1875
+ *
1876
+ * var array = [1, 2, 3];
1877
+ *
1878
+ * _.fill(array, 'a');
1879
+ * console.log(array);
1880
+ * // => ['a', 'a', 'a']
1881
+ *
1882
+ * _.fill(Array(3), 2);
1883
+ * // => [2, 2, 2]
1884
+ *
1885
+ * _.fill([4, 6, 8, 10], '*', 1, 3);
1886
+ * // => [4, '*', '*', 10]
1887
+ */
1888
+ function fill(array, value, start, end) {
1889
+ var length = array == null ? 0 : array.length;
1890
+ if (!length) {
1891
+ return [];
1892
+ }
1893
+ if (start && typeof start != 'number' && index._isIterateeCall(array, value, start)) {
1894
+ start = 0;
1895
+ end = length;
1896
+ }
1897
+ return _baseFill(array, value, start, end);
1898
+ }
1899
+
1900
+ var fill_1 = fill;
1901
+
1902
+ const INITIAL = {
1903
+ mime: 'text/csv',
1904
+ fileKind: 'csv',
1905
+ // BOM signature
1906
+ bom: true,
1907
+ columnDelimiter: ',',
1908
+ rowDelimiter: '\r\n',
1909
+ encoding: '',
1910
+ };
1911
+ // The ASCII character code 13 is called a Carriage Return or CR.
1912
+ const CARRIAGE_RETURN = String.fromCharCode(13);
1913
+ // Chr(13) followed by a Chr(10) that compose a proper CRLF.
1914
+ const LINE_FEED = String.fromCharCode(10);
1915
+ const DOUBLE_QT = String.fromCharCode(34);
1916
+ const NO_BREAK_SPACE = String.fromCharCode(0xfeff);
1917
+ const escapeRegex = new RegExp('"', 'g');
1918
+ class ExportCsv {
1919
+ constructor(options = {}) {
1920
+ this.options = Object.assign(Object.assign({}, INITIAL), options);
1921
+ }
1922
+ doExport({ data, headers, props }) {
1923
+ let result = this.options.bom ? NO_BREAK_SPACE : '';
1924
+ // any header
1925
+ if ((headers === null || headers === void 0 ? void 0 : headers.length) > 0) {
1926
+ headers.forEach(header => {
1927
+ // ignore empty
1928
+ if (!header.length) {
1929
+ return;
1930
+ }
1931
+ result += this.prepareHeader(header, this.options.columnDelimiter);
1932
+ result += this.options.rowDelimiter;
1933
+ });
1934
+ }
1935
+ data.forEach((rgRow, index) => {
1936
+ if (index > 0) {
1937
+ result += this.options.rowDelimiter;
1938
+ }
1939
+ // support grouping
1940
+ if (viewport_helpers.isGrouping(rgRow)) {
1941
+ result += this.parseCell(viewport_helpers.getGroupingName(rgRow), this.options.columnDelimiter);
1942
+ return;
1943
+ }
1944
+ result += props.map(p => this.parseCell(rgRow[p], this.options.columnDelimiter)).join(this.options.columnDelimiter);
1945
+ });
1946
+ return result;
1947
+ }
1948
+ prepareHeader(columnHeaders, columnDelimiter) {
1949
+ let result = '';
1950
+ const newColumnHeaders = columnHeaders.map(v => this.parseCell(v, columnDelimiter, true));
1951
+ result += newColumnHeaders.join(columnDelimiter);
1952
+ return result;
1953
+ }
1954
+ parseCell(value, columnDelimiter, force = false) {
1955
+ let escape = value;
1956
+ if (typeof value !== 'string') {
1957
+ escape = JSON.stringify(value);
1958
+ }
1959
+ const toEscape = [CARRIAGE_RETURN, DOUBLE_QT, LINE_FEED, columnDelimiter];
1960
+ if (typeof escape === 'undefined') {
1961
+ return '';
1962
+ }
1963
+ if (escape !== '' && (force || toEscape.some(i => escape.indexOf(i) >= 0))) {
1964
+ return `"${escape.replace(escapeRegex, '""')}"`;
1965
+ }
1966
+ return escape;
1967
+ }
1968
+ }
1969
+
1970
+ var ExportTypes;
1971
+ (function (ExportTypes) {
1972
+ ExportTypes["csv"] = "csv";
1973
+ })(ExportTypes || (ExportTypes = {}));
1974
+ class ExportFilePlugin extends BasePlugin {
1975
+ /** Exports string */
1976
+ async exportString(options = {}, t = ExportTypes.csv) {
1977
+ const data = await this.beforeexport();
1978
+ if (!data) {
1979
+ return null;
1980
+ }
1981
+ return this.formatter(t, options).doExport(data);
1982
+ }
1983
+ /** Exports Blob */
1984
+ async exportBlob(options = {}, t = ExportTypes.csv) {
1985
+ return await this.getBlob(this.formatter(t, options));
1986
+ }
1987
+ /** Export file */
1988
+ async exportFile(options = {}, t = ExportTypes.csv) {
1989
+ const formatter = this.formatter(t, options);
1990
+ const blob = await this.getBlob(formatter);
1991
+ // url
1992
+ const URL = window.URL || window.webkitURL;
1993
+ const a = document.createElement('a');
1994
+ const { filename, fileKind } = formatter.options;
1995
+ const name = `${filename}.${fileKind}`;
1996
+ const url = URL.createObjectURL(blob);
1997
+ a.style.display = 'none';
1998
+ a.setAttribute('href', url);
1999
+ a.setAttribute('download', name);
2000
+ this.revogrid.appendChild(a);
2001
+ a.dispatchEvent(new MouseEvent('click'));
2002
+ this.revogrid.removeChild(a);
2003
+ // delay for revoke, correct for some browsers
2004
+ await index.timeout(120);
2005
+ URL.revokeObjectURL(url);
2006
+ }
2007
+ /** Blob object */
2008
+ async getBlob(formatter) {
2009
+ const type = `${formatter.options.mime};charset=${formatter.options.encoding}`;
2010
+ if (typeof Blob !== 'undefined') {
2011
+ const data = await this.beforeexport();
2012
+ if (!data) {
2013
+ return null;
2014
+ }
2015
+ return new Blob([formatter.doExport(data)], { type });
2016
+ }
2017
+ return null;
2018
+ }
2019
+ // before event
2020
+ async beforeexport() {
2021
+ let data = await this.getData();
2022
+ const event = this.emit('beforeexport', { data });
2023
+ if (event.defaultPrevented) {
2024
+ return null;
2025
+ }
2026
+ return event.detail.data;
2027
+ }
2028
+ async getData() {
2029
+ const data = await this.getSource();
2030
+ const colSource = [];
2031
+ const colPromises = [];
2032
+ columnTypes.forEach((t, i) => {
2033
+ colPromises.push(this.getColPerSource(t).then(s => (colSource[i] = s)));
2034
+ });
2035
+ await Promise.all(colPromises);
2036
+ const columns = {
2037
+ headers: [],
2038
+ props: [],
2039
+ };
2040
+ for (let source of colSource) {
2041
+ source.headers.forEach((h, i) => {
2042
+ if (!columns.headers[i]) {
2043
+ columns.headers[i] = [];
2044
+ }
2045
+ columns.headers[i].push(...h);
2046
+ });
2047
+ columns.props.push(...source.props);
2048
+ }
2049
+ return Object.assign({ data }, columns);
2050
+ }
2051
+ async getColPerSource(t) {
2052
+ const store = await this.revogrid.getColumnStore(t);
2053
+ const source = store.get('source');
2054
+ const virtualIndexes = store.get('items');
2055
+ const depth = store.get('groupingDepth');
2056
+ const groups = store.get('groups');
2057
+ const colNames = [];
2058
+ const colProps = [];
2059
+ const visibleItems = virtualIndexes.reduce((r, v, virtualIndex) => {
2060
+ const prop = source[v].prop;
2061
+ colNames.push(source[v].name || '');
2062
+ colProps.push(prop);
2063
+ r[prop] = virtualIndex;
2064
+ return r;
2065
+ }, {});
2066
+ const rows = this.getGroupHeaders(depth, groups, virtualIndexes, visibleItems);
2067
+ rows.push(colNames);
2068
+ return {
2069
+ headers: rows,
2070
+ props: colProps,
2071
+ };
2072
+ }
2073
+ getGroupHeaders(depth, groups, items, visibleItems) {
2074
+ const rows = [];
2075
+ const template = fill_1(new Array(items.length), '');
2076
+ for (let d = 0; d < depth; d++) {
2077
+ const rgRow = [...template];
2078
+ rows.push(rgRow);
2079
+ if (!groups[d]) {
2080
+ continue;
2081
+ }
2082
+ const levelGroups = groups[d];
2083
+ // add names of groups
2084
+ levelGroups.forEach((group) => {
2085
+ const minIndex = this.findGroupStartIndex(group.ids, visibleItems);
2086
+ if (typeof minIndex === 'number') {
2087
+ rgRow[minIndex] = group.name;
2088
+ }
2089
+ });
2090
+ }
2091
+ return rows;
2092
+ }
2093
+ findGroupStartIndex(ids, visibleItems) {
2094
+ let min;
2095
+ ids.forEach(id => {
2096
+ const current = visibleItems[id];
2097
+ if (typeof current === 'number') {
2098
+ if (typeof min !== 'number' || min > current) {
2099
+ min = current;
2100
+ }
2101
+ }
2102
+ });
2103
+ return min;
2104
+ }
2105
+ async getSource() {
2106
+ const data = [];
2107
+ const promisesData = [];
2108
+ rowTypes.forEach(t => {
2109
+ const dataPart = [];
2110
+ data.push(dataPart);
2111
+ const promise = this.revogrid.getVisibleSource(t).then((d) => dataPart.push(...d));
2112
+ promisesData.push(promise);
2113
+ });
2114
+ await Promise.all(promisesData);
2115
+ return data.reduce((r, v) => {
2116
+ r.push(...v);
2117
+ return r;
2118
+ }, []);
2119
+ }
2120
+ // get correct class for future multiple types support
2121
+ formatter(type, options = {}) {
2122
+ switch (type) {
2123
+ case ExportTypes.csv:
2124
+ return new ExportCsv(options);
2125
+ default:
2126
+ throw new Error('Unknown format');
2127
+ }
2128
+ }
2129
+ }
2130
+
2131
+ // provide collapse data
2132
+ function doCollapse(pIndex, source) {
2133
+ const model = source[pIndex];
2134
+ const collapseValue = model[viewport_helpers.PSEUDO_GROUP_ITEM_VALUE];
2135
+ const trimmed = {};
2136
+ let i = pIndex + 1;
2137
+ const total = source.length;
2138
+ while (i < total) {
2139
+ const currentModel = source[i];
2140
+ if (viewport_helpers.isGrouping(currentModel)) {
2141
+ const currentValue = currentModel[viewport_helpers.PSEUDO_GROUP_ITEM_VALUE];
2142
+ if (!currentValue.length || !currentValue.startsWith(collapseValue + ',')) {
2143
+ break;
2144
+ }
2145
+ currentModel[viewport_helpers.GROUP_EXPANDED] = false;
2146
+ }
2147
+ trimmed[i++] = true;
2148
+ }
2149
+ model[viewport_helpers.GROUP_EXPANDED] = false;
2150
+ return { trimmed };
2151
+ }
2152
+ /**
2153
+ *
2154
+ * @param pIndex - physical index
2155
+ * @param vIndex - virtual index, need to update item collection
2156
+ * @param source - data source
2157
+ * @param rowItemsIndexes - rgRow indexes
2158
+ */
2159
+ function doExpand(vIndex, source, rowItemsIndexes) {
2160
+ const physicalIndex = rowItemsIndexes[vIndex];
2161
+ const model = source[physicalIndex];
2162
+ const currentGroup = viewport_helpers.getParsedGroup(model[viewport_helpers.PSEUDO_GROUP_ITEM_ID]);
2163
+ const trimmed = {};
2164
+ // no group found
2165
+ if (!currentGroup) {
2166
+ return { trimmed };
2167
+ }
2168
+ const groupItems = [];
2169
+ model[viewport_helpers.GROUP_EXPANDED] = true;
2170
+ let i = physicalIndex + 1;
2171
+ const total = source.length;
2172
+ let groupLevelOnly = 0;
2173
+ // go through all rows
2174
+ while (i < total) {
2175
+ const currentModel = source[i];
2176
+ const isGroup = viewport_helpers.isGrouping(currentModel);
2177
+ // group found
2178
+ if (isGroup) {
2179
+ if (!viewport_helpers.isSameGroup(currentGroup, model, currentModel)) {
2180
+ break;
2181
+ }
2182
+ else if (!groupLevelOnly) {
2183
+ // if get group first it's group only level
2184
+ groupLevelOnly = currentModel[viewport_helpers.GROUP_DEPTH];
2185
+ }
2186
+ }
2187
+ // level 0 or same depth
2188
+ if (!groupLevelOnly || (isGroup && groupLevelOnly === currentModel[viewport_helpers.GROUP_DEPTH])) {
2189
+ trimmed[i] = false;
2190
+ groupItems.push(i);
2191
+ }
2192
+ i++;
2193
+ }
2194
+ const result = {
2195
+ trimmed,
2196
+ };
2197
+ if (groupItems.length) {
2198
+ const items = [...rowItemsIndexes];
2199
+ items.splice(vIndex + 1, 0, ...groupItems);
2200
+ result.items = items;
2201
+ }
2202
+ return result;
2203
+ }
2204
+
2205
+ const TRIMMED_GROUPING = 'grouping';
2206
+ /**
2207
+ * Prepare trimming updated indexes for grouping
2208
+ * @param initiallyTrimed
2209
+ * @param firstLevelMap
2210
+ * @param secondLevelMap
2211
+ */
2212
+ function processDoubleConversionTrimmed(initiallyTrimed, firstLevelMap, secondLevelMap) {
2213
+ const trimemedOptionsToUpgrade = {};
2214
+ /**
2215
+ * go through all groups except grouping
2216
+ */
2217
+ for (let type in initiallyTrimed) {
2218
+ if (type === TRIMMED_GROUPING) {
2219
+ continue;
2220
+ }
2221
+ const items = initiallyTrimed[type];
2222
+ const newItems = {};
2223
+ for (let initialIndex in items) {
2224
+ /**
2225
+ * if item exists we find it in collection
2226
+ * we support 2 level of conversions
2227
+ */
2228
+ let newConversionIndex = firstLevelMap[initialIndex];
2229
+ if (secondLevelMap) {
2230
+ newConversionIndex = secondLevelMap[newConversionIndex];
2231
+ }
2232
+ /**
2233
+ * if item was trimmed previously
2234
+ * trimming makes sense to apply
2235
+ */
2236
+ if (items[initialIndex]) {
2237
+ newItems[newConversionIndex] = true;
2238
+ /**
2239
+ * If changes present apply changes to new source
2240
+ */
2241
+ if (newConversionIndex !== parseInt(initialIndex, 10)) {
2242
+ trimemedOptionsToUpgrade[type] = newItems;
2243
+ }
2244
+ }
2245
+ }
2246
+ }
2247
+ return trimemedOptionsToUpgrade;
2248
+ }
2249
+
2250
+ class GroupingRowPlugin extends BasePlugin {
2251
+ get hasProps() {
2252
+ var _a, _b, _c;
2253
+ return ((_a = this.options) === null || _a === void 0 ? void 0 : _a.props) && ((_c = (_b = this.options) === null || _b === void 0 ? void 0 : _b.props) === null || _c === void 0 ? void 0 : _c.length);
2254
+ }
2255
+ get store() {
2256
+ return this.providers.dataProvider.stores[viewport_helpers.GROUPING_ROW_TYPE].store;
2257
+ }
2258
+ // proxy for items get
2259
+ get rowItems() {
2260
+ return this.store.get('items');
2261
+ }
2262
+ get trimmed() {
2263
+ return this.store.get('trimmed');
2264
+ }
2265
+ constructor(revogrid, providers) {
2266
+ super(revogrid);
2267
+ this.revogrid = revogrid;
2268
+ this.providers = providers;
2269
+ }
2270
+ // befoce cell focus
2271
+ onFocus(e) {
2272
+ if (viewport_helpers.isGrouping(e.detail.model)) {
2273
+ e.preventDefault();
2274
+ }
2275
+ }
2276
+ // expand event triggered
2277
+ onExpand({ virtualIndex }) {
2278
+ const { source } = this.getSource();
2279
+ let newTrimmed = this.trimmed[TRIMMED_GROUPING];
2280
+ let i = index.getPhysical(this.store, virtualIndex);
2281
+ const model = source[i];
2282
+ const prevExpanded = model[viewport_helpers.GROUP_EXPANDED];
2283
+ if (!prevExpanded) {
2284
+ const { trimmed, items } = doExpand(virtualIndex, source, this.rowItems);
2285
+ newTrimmed = Object.assign(Object.assign({}, newTrimmed), trimmed);
2286
+ if (items) {
2287
+ index.setItems(this.store, items);
2288
+ }
2289
+ }
2290
+ else {
2291
+ const { trimmed } = doCollapse(i, source);
2292
+ newTrimmed = Object.assign(Object.assign({}, newTrimmed), trimmed);
2293
+ this.revogrid.clearFocus();
2294
+ }
2295
+ this.store.set('source', source);
2296
+ this.revogrid.addTrimmed(newTrimmed, TRIMMED_GROUPING);
2297
+ }
2298
+ // get source based on proxy item collection to preserve rgRow order
2299
+ getSource(withoutGrouping = false) {
2300
+ const source = this.store.get('source');
2301
+ const items = this.store.get('proxyItems');
2302
+ let index = 0;
2303
+ // order important here, expected parent is first, then others
2304
+ return items.reduce((result, i) => {
2305
+ const model = source[i];
2306
+ if (!withoutGrouping) {
2307
+ result.source.push(model);
2308
+ return result;
2309
+ }
2310
+ // grouping filter
2311
+ if (!viewport_helpers.isGrouping(model)) {
2312
+ result.source.push(model);
2313
+ result.oldNewIndexes[i] = index;
2314
+ index++;
2315
+ }
2316
+ else {
2317
+ if (model[viewport_helpers.GROUP_EXPANDED]) {
2318
+ result.prevExpanded[model[viewport_helpers.PSEUDO_GROUP_ITEM_VALUE]] = true;
2319
+ }
2320
+ }
2321
+ return result;
2322
+ }, {
2323
+ source: [],
2324
+ prevExpanded: {},
2325
+ oldNewIndexes: {},
2326
+ });
2327
+ }
2328
+ setColumnGrouping(cols) {
2329
+ // if 0 column as holder
2330
+ if (cols === null || cols === void 0 ? void 0 : cols.length) {
2331
+ cols[0][viewport_helpers.PSEUDO_GROUP_COLUMN] = true;
2332
+ return true;
2333
+ }
2334
+ return false;
2335
+ }
2336
+ setColumns({ columns }) {
2337
+ for (let type of columnTypes) {
2338
+ if (this.setColumnGrouping(columns[type])) {
2339
+ break;
2340
+ }
2341
+ }
2342
+ }
2343
+ // evaluate drag between groups
2344
+ onDrag(e) {
2345
+ const { from, to } = e.detail;
2346
+ const isDown = to - from >= 0;
2347
+ const { source } = this.getSource();
2348
+ const items = this.rowItems;
2349
+ let i = isDown ? from : to;
2350
+ const end = isDown ? to : from;
2351
+ for (; i < end; i++) {
2352
+ const model = source[items[i]];
2353
+ const isGroup = viewport_helpers.isGrouping(model);
2354
+ if (isGroup) {
2355
+ e.preventDefault();
2356
+ return;
2357
+ }
2358
+ }
2359
+ }
2360
+ beforeTrimmedApply(trimmed, type) {
2361
+ /** Before filter apply remove grouping filtering */
2362
+ if (type === FILTER_TRIMMED_TYPE) {
2363
+ const source = this.store.get('source');
2364
+ for (let index in trimmed) {
2365
+ if (trimmed[index] && viewport_helpers.isGrouping(source[index])) {
2366
+ trimmed[index] = false;
2367
+ }
2368
+ }
2369
+ }
2370
+ }
2371
+ // subscribe to grid events to process them accordingly
2372
+ subscribe() {
2373
+ /** if grouping present and new data source arrived */
2374
+ this.addEventListener('beforesourceset', ({ detail }) => this.onDataSet(detail));
2375
+ this.addEventListener('beforecolumnsset', ({ detail }) => this.setColumns(detail));
2376
+ /**
2377
+ * filter applied need to clear grouping and apply again
2378
+ * based on new results can be new grouping
2379
+ */
2380
+ this.addEventListener('beforetrimmed', ({ detail: { trimmed, trimmedType } }) => this.beforeTrimmedApply(trimmed, trimmedType));
2381
+ /**
2382
+ * sorting applied need to clear grouping and apply again
2383
+ * based on new results whole grouping order will changed
2384
+ */
2385
+ this.addEventListener('afterSortingApply', () => this.doSourceUpdate(Object.assign({}, this.options)));
2386
+ /**
2387
+ * Apply logic for focus inside of grouping
2388
+ * We can't focus on grouping rows, navigation only inside of groups for now
2389
+ */
2390
+ this.addEventListener('beforecellfocus', e => this.onFocus(e));
2391
+ /**
2392
+ * Prevent rgRow drag outside the group
2393
+ */
2394
+ this.addEventListener('roworderchanged', e => this.onDrag(e));
2395
+ /**
2396
+ * When grouping expand icon was clicked
2397
+ */
2398
+ this.addEventListener(viewport_helpers.GROUP_EXPAND_EVENT, ({ detail }) => this.onExpand(detail));
2399
+ }
2400
+ /**
2401
+ * Starts global source update with group clearing and applying new one
2402
+ * Initiated when need to reapply grouping
2403
+ */
2404
+ doSourceUpdate(options) {
2405
+ var _a;
2406
+ if (!this.hasProps) {
2407
+ return;
2408
+ }
2409
+ /**
2410
+ * Get source without grouping
2411
+ * @param newOldIndexMap - provides us mapping with new indexes vs old indexes, we would use it for trimmed mapping
2412
+ */
2413
+ const { source, prevExpanded, oldNewIndexes } = this.getSource(true);
2414
+ /**
2415
+ * Group again
2416
+ * @param oldNewIndexMap - provides us mapping with new indexes vs old indexes
2417
+ */
2418
+ const { sourceWithGroups, depth, trimmed, oldNewIndexMap, childrenByGroup } = viewport_helpers.gatherGrouping(source, ((_a = this.options) === null || _a === void 0 ? void 0 : _a.props) || [], Object.assign({ prevExpanded }, options));
2419
+ // setup source
2420
+ this.providers.dataProvider.setData(sourceWithGroups, viewport_helpers.GROUPING_ROW_TYPE, { depth, customRenderer: options === null || options === void 0 ? void 0 : options.groupLabelTemplate }, true);
2421
+ this.updateTrimmed(trimmed, childrenByGroup, oldNewIndexes, oldNewIndexMap);
2422
+ }
2423
+ /**
2424
+ * Apply grouping on data set
2425
+ * Clear grouping from source
2426
+ * If source came from other plugin
2427
+ */
2428
+ onDataSet(data) {
2429
+ var _a;
2430
+ if (!this.hasProps || !(data === null || data === void 0 ? void 0 : data.source) || !data.source.length) {
2431
+ return;
2432
+ }
2433
+ const source = data.source.filter(s => !viewport_helpers.isGrouping(s));
2434
+ const expanded = this.revogrid.grouping || {};
2435
+ const { sourceWithGroups, depth, trimmed, oldNewIndexMap, childrenByGroup } = viewport_helpers.gatherGrouping(source, ((_a = this.options) === null || _a === void 0 ? void 0 : _a.props) || [], Object.assign({}, (expanded || {})));
2436
+ data.source = sourceWithGroups;
2437
+ this.providers.dataProvider.setGrouping({ depth });
2438
+ this.updateTrimmed(trimmed, childrenByGroup, oldNewIndexMap);
2439
+ }
2440
+ // apply grouping
2441
+ setGrouping(options) {
2442
+ // unsubscribe from all events when group applied
2443
+ this.clearSubscriptions();
2444
+ this.options = options;
2445
+ // clear props, no grouping exists
2446
+ if (!options.props || !Object.keys(options.props).length) {
2447
+ this.clearGrouping();
2448
+ return;
2449
+ }
2450
+ // props exist and source inited
2451
+ const { source } = this.getSource();
2452
+ if (source.length) {
2453
+ this.doSourceUpdate(Object.assign({}, options));
2454
+ }
2455
+ // props exist and columns inited
2456
+ for (let t of columnTypes) {
2457
+ if (this.setColumnGrouping(this.providers.columnProvider.getColumns(t))) {
2458
+ this.providers.columnProvider.refreshByType(t);
2459
+ break;
2460
+ }
2461
+ }
2462
+ // if has any grouping subscribe to events again
2463
+ this.subscribe();
2464
+ }
2465
+ // clear grouping
2466
+ clearGrouping() {
2467
+ // clear columns
2468
+ columnTypes.forEach(t => {
2469
+ const cols = this.providers.columnProvider.getColumns(t);
2470
+ let deleted = false;
2471
+ cols.forEach(c => {
2472
+ if (viewport_helpers.isGroupingColumn(c)) {
2473
+ delete c[viewport_helpers.PSEUDO_GROUP_COLUMN];
2474
+ deleted = true;
2475
+ }
2476
+ });
2477
+ // if column store had grouping clear and refresh
2478
+ if (deleted) {
2479
+ this.providers.columnProvider.refreshByType(t);
2480
+ }
2481
+ });
2482
+ // clear rows
2483
+ const { source, oldNewIndexes } = this.getSource(true);
2484
+ this.providers.dataProvider.setData(source, viewport_helpers.GROUPING_ROW_TYPE, undefined, true);
2485
+ this.updateTrimmed(undefined, undefined, oldNewIndexes);
2486
+ }
2487
+ updateTrimmed(trimmedGroup = {}, _childrenByGroup = {}, firstLevelMap, secondLevelMap) {
2488
+ // map previously trimmed data
2489
+ const trimemedOptionsToUpgrade = processDoubleConversionTrimmed(this.trimmed, firstLevelMap, secondLevelMap);
2490
+ for (let type in trimemedOptionsToUpgrade) {
2491
+ this.revogrid.addTrimmed(trimemedOptionsToUpgrade[type], type);
2492
+ }
2493
+ // const emptyGroups = this.filterOutEmptyGroups(trimemedOptionsToUpgrade, childrenByGroup);
2494
+ // setup trimmed data for grouping
2495
+ this.revogrid.addTrimmed(Object.assign({}, trimmedGroup), TRIMMED_GROUPING);
2496
+ }
2497
+ }
2498
+
2499
+ /**
2500
+ * Draw drag
2501
+ */
2502
+ class OrdererService {
2503
+ constructor() {
2504
+ this.parentY = 0;
2505
+ }
2506
+ start(parent, { pos, text, event }) {
2507
+ var _a;
2508
+ const { top } = parent.getBoundingClientRect();
2509
+ this.parentY = top;
2510
+ if (this.text) {
2511
+ this.text.innerText = text;
2512
+ }
2513
+ this.move(pos);
2514
+ this.moveTip({ x: event.x, y: event.y });
2515
+ (_a = this.el) === null || _a === void 0 ? void 0 : _a.classList.remove('hidden');
2516
+ }
2517
+ end() {
2518
+ var _a;
2519
+ (_a = this.el) === null || _a === void 0 ? void 0 : _a.classList.add('hidden');
2520
+ }
2521
+ move(pos) {
2522
+ this.moveElement(pos.end - this.parentY);
2523
+ }
2524
+ moveTip({ x, y }) {
2525
+ if (!this.draggable) {
2526
+ return;
2527
+ }
2528
+ this.draggable.style.left = `${x}px`;
2529
+ this.draggable.style.top = `${y}px`;
2530
+ }
2531
+ moveElement(y) {
2532
+ if (!this.rgRow) {
2533
+ return;
2534
+ }
2535
+ this.rgRow.style.transform = `translateY(${y}px)`;
2536
+ }
2537
+ }
2538
+ const OrderRenderer = ({ ref }) => {
2539
+ const service = new OrdererService();
2540
+ ref(service);
2541
+ return (index$1.h("div", { class: "draggable-wrapper hidden", ref: e => (service.el = e) },
2542
+ index$1.h("div", { class: "draggable", ref: el => (service.draggable = el) },
2543
+ index$1.h("span", { class: "revo-alt-icon" }),
2544
+ index$1.h("span", { ref: e => (service.text = e) })),
2545
+ index$1.h("div", { class: "drag-position", ref: e => (service.rgRow = e) })));
2546
+ };
2547
+
2548
+ const RevoViewPort = ({ viewports, dimensions, orderRef, nakedClick, registerElement, onScroll }, children) => {
2549
+ const viewPortClick = (e, el) => {
2550
+ if (el === e.target) {
2551
+ nakedClick(e);
2552
+ }
2553
+ };
2554
+ let el;
2555
+ const typeRow = 'rgRow';
2556
+ const typeCol = 'rgCol';
2557
+ return [
2558
+ index$1.h("div", { class: "main-viewport", ref: e => (el = e), onClick: e => viewPortClick(e, el) },
2559
+ index$1.h("div", { class: "viewports" },
2560
+ children,
2561
+ index$1.h("revogr-scroll-virtual", { class: "vertical", dimension: typeRow, viewportStore: viewports[typeRow].store, dimensionStore: dimensions[typeRow].store, ref: el => registerElement(el, 'rowScroll'), onScrollVirtual: e => onScroll(e.detail) }),
2562
+ index$1.h(OrderRenderer, { ref: orderRef }))),
2563
+ index$1.h("revogr-scroll-virtual", { class: "horizontal", dimension: typeCol, viewportStore: viewports[typeCol].store, dimensionStore: dimensions[typeCol].store, ref: el => registerElement(el, 'colScroll'), onScrollVirtual: e => onScroll(e.detail) }),
2564
+ ];
2565
+ };
2566
+
2567
+ class ViewportService {
2568
+ constructor(sv, contentHeight) {
2569
+ var _a, _b;
2570
+ this.sv = sv;
2571
+ (_a = this.sv.selectionStoreConnector) === null || _a === void 0 ? void 0 : _a.beforeUpdate();
2572
+ this.columns = this.getViewportColumnData(contentHeight);
2573
+ (_b = this.sv.scrollingService) === null || _b === void 0 ? void 0 : _b.unregister();
2574
+ }
2575
+ onColumnResize(type, { detail }, store) {
2576
+ var _a;
2577
+ (_a = this.sv.dimensionProvider) === null || _a === void 0 ? void 0 : _a.setCustomSizes(type, detail, true);
2578
+ const changedItems = viewport_helpers.lodash.reduce(detail || {}, (r, size, i) => {
2579
+ const index$1 = parseInt(i, 10);
2580
+ const item = index.getSourceItem(store, index$1);
2581
+ if (item) {
2582
+ r[index$1] = Object.assign(Object.assign({}, item), { size });
2583
+ }
2584
+ return r;
2585
+ }, {});
2586
+ this.sv.resize(changedItems);
2587
+ }
2588
+ /**
2589
+ * Transform data from stores and apply it to different components
2590
+ * Handle columns
2591
+ */
2592
+ getViewportColumnData(contentHeight) {
2593
+ const columns = [];
2594
+ let x = 0; // we increase x only if column present
2595
+ columnTypes.forEach(val => {
2596
+ const colStore = this.sv.columnProvider.stores[val].store;
2597
+ // only columns that have data show
2598
+ if (!colStore.get('items').length) {
2599
+ return;
2600
+ }
2601
+ const column = {
2602
+ colType: val,
2603
+ position: { x, y: 1 },
2604
+ contentHeight,
2605
+ fixWidth: val !== 'rgCol',
2606
+ uuid: `${this.sv.uuid}-${x}`,
2607
+ viewports: this.sv.viewportProvider.stores,
2608
+ dimensions: this.sv.dimensionProvider.stores,
2609
+ rowStores: this.sv.dataProvider.stores,
2610
+ colStore,
2611
+ onHeaderresize: e => this.onColumnResize(val, e, colStore),
2612
+ };
2613
+ if (val === 'rgCol') {
2614
+ column.onResizeViewport = (e) => { var _a; return (_a = this.sv.viewportProvider) === null || _a === void 0 ? void 0 : _a.setViewport(e.detail.dimension, { virtualSize: e.detail.size }); };
2615
+ }
2616
+ const colData = this.gatherColumnData(column);
2617
+ const columnSelectionStore = this.registerCol(colData.position.x, val);
2618
+ // render per each column data collections vertically
2619
+ const dataPorts = this.dataViewPort(column).reduce((r, rgRow) => {
2620
+ // register selection store for Segment
2621
+ const segmentSelection = this.registerSegment(rgRow.position);
2622
+ segmentSelection.setLastCell(rgRow.lastCell);
2623
+ // register selection store for Row
2624
+ const rowSelectionStore = this.registerRow(rgRow.position.y, rgRow.type);
2625
+ const rowDef = Object.assign(Object.assign({}, rgRow), { rowSelectionStore, segmentSelectionStore: segmentSelection.store, ref: (e) => this.sv.selectionStoreConnector.registerSection(e), onSetRange: e => {
2626
+ segmentSelection.setRangeArea(e.detail);
2627
+ }, onSetTempRange: e => {
2628
+ segmentSelection.setTempArea(e.detail);
2629
+ }, onFocusCell: e => {
2630
+ // todo: multi focus
2631
+ segmentSelection.clearFocus();
2632
+ this.sv.selectionStoreConnector.focus(segmentSelection, e.detail);
2633
+ } });
2634
+ r.push(rowDef);
2635
+ return r;
2636
+ }, []);
2637
+ columns.push(Object.assign(Object.assign({}, colData), { columnSelectionStore,
2638
+ dataPorts }));
2639
+ x++;
2640
+ });
2641
+ return columns;
2642
+ }
2643
+ /** register selection store for Segment */
2644
+ registerSegment(position) {
2645
+ return this.sv.selectionStoreConnector.register(position);
2646
+ }
2647
+ /** register selection store for Row */
2648
+ registerRow(y, type) {
2649
+ return this.sv.selectionStoreConnector.registerRow(y, type).store;
2650
+ }
2651
+ /** register selection store for Column */
2652
+ registerCol(x, type) {
2653
+ return this.sv.selectionStoreConnector.registerColumn(x, type).store;
2654
+ }
2655
+ /** Collect Column data */
2656
+ gatherColumnData(data) {
2657
+ const parent = data.uuid;
2658
+ const realSize = data.dimensions[data.colType].store.get('realSize');
2659
+ const prop = {
2660
+ contentWidth: realSize,
2661
+ class: data.colType,
2662
+ [`${index.UUID}`]: data.uuid,
2663
+ contentHeight: data.contentHeight,
2664
+ key: data.colType,
2665
+ onResizeViewport: data.onResizeViewport,
2666
+ };
2667
+ if (data.fixWidth) {
2668
+ prop.style = { minWidth: `${realSize}px` };
2669
+ }
2670
+ const headerProp = {
2671
+ parent,
2672
+ colData: index.getVisibleSourceItem(data.colStore),
2673
+ dimensionCol: data.dimensions[data.colType].store,
2674
+ groups: data.colStore.get('groups'),
2675
+ groupingDepth: data.colStore.get('groupingDepth'),
2676
+ resizeHandler: data.colType === 'colPinEnd' ? ['l'] : undefined,
2677
+ onHeaderresize: data.onHeaderresize,
2678
+ };
2679
+ return {
2680
+ prop,
2681
+ type: data.colType,
2682
+ position: data.position,
2683
+ headerProp,
2684
+ parent,
2685
+ viewportCol: data.viewports[data.colType].store,
2686
+ };
2687
+ }
2688
+ /** Collect Row data */
2689
+ dataViewPort(data) {
2690
+ const slots = {
2691
+ rowPinStart: viewport_helpers.HEADER_SLOT,
2692
+ rgRow: viewport_helpers.CONTENT_SLOT,
2693
+ rowPinEnd: viewport_helpers.FOOTER_SLOT,
2694
+ };
2695
+ // y position for selection
2696
+ let y = 0;
2697
+ return rowTypes.reduce((r, type) => {
2698
+ // filter out empty sources, we still need to return source to keep slot working
2699
+ const isPresent = data.viewports[type].store.get('realCount') || type === 'rgRow';
2700
+ const rgCol = Object.assign(Object.assign({}, data), { position: Object.assign(Object.assign({}, data.position), { y: isPresent ? y : viewport_helpers.EMPTY_INDEX }) });
2701
+ r.push(this.dataPartition(rgCol, type, slots[type], type !== 'rgRow'));
2702
+ if (isPresent) {
2703
+ y++;
2704
+ }
2705
+ return r;
2706
+ }, []);
2707
+ }
2708
+ dataPartition(data, type, slot, fixed) {
2709
+ return {
2710
+ colData: data.colStore,
2711
+ viewportCol: data.viewports[data.colType].store,
2712
+ viewportRow: data.viewports[type].store,
2713
+ lastCell: viewport_helpers.getLastCell(data, type),
2714
+ slot,
2715
+ type,
2716
+ canDrag: !fixed,
2717
+ position: data.position,
2718
+ uuid: `${data.uuid}-${data.position.x}-${data.position.y}`,
2719
+ dataStore: data.rowStores[type].store,
2720
+ dimensionCol: data.dimensions[data.colType].store,
2721
+ dimensionRow: data.dimensions[type].store,
2722
+ style: fixed ? { height: `${data.dimensions[type].store.get('realSize')}px` } : undefined,
2723
+ };
2724
+ }
2725
+ scrollToCell(cell) {
2726
+ for (let key in cell) {
2727
+ const coordinate = cell[key];
2728
+ this.sv.scrollingService.scrollService({ dimension: key === 'x' ? 'rgCol' : 'rgRow', coordinate });
2729
+ }
2730
+ }
2731
+ /**
2732
+ * Clear current grid focus
2733
+ */
2734
+ clearFocused() {
2735
+ this.sv.selectionStoreConnector.clearAll();
2736
+ }
2737
+ clearEdit() {
2738
+ this.sv.selectionStoreConnector.setEdit(false);
2739
+ }
2740
+ /**
2741
+ * Collect focused element data
2742
+ */
2743
+ getFocused() {
2744
+ const focused = this.sv.selectionStoreConnector.focusedStore;
2745
+ if (!focused) {
2746
+ return null;
2747
+ }
2748
+ // get column data
2749
+ const colType = this.sv.selectionStoreConnector.storesXToType[focused.position.x];
2750
+ const column = this.sv.columnProvider.getColumn(focused.cell.x, colType);
2751
+ // get row data
2752
+ const rowType = this.sv.selectionStoreConnector.storesYToType[focused.position.y];
2753
+ const model = this.sv.dataProvider.getModel(focused.cell.y, rowType);
2754
+ return {
2755
+ column,
2756
+ model,
2757
+ cell: focused.cell,
2758
+ colType,
2759
+ rowType,
2760
+ };
2761
+ }
2762
+ getStoreCoordinateByType(colType, rowType) {
2763
+ const stores = this.sv.selectionStoreConnector.storesByType;
2764
+ const storeCoordinate = {
2765
+ x: stores[colType],
2766
+ y: stores[rowType],
2767
+ };
2768
+ return storeCoordinate;
2769
+ }
2770
+ setFocus(colType, rowType, start, end) {
2771
+ var _a;
2772
+ (_a = this.sv.selectionStoreConnector) === null || _a === void 0 ? void 0 : _a.focusByCell(this.getStoreCoordinateByType(colType, rowType), start, end);
2773
+ }
2774
+ getSelectedRange() {
2775
+ return this.sv.selectionStoreConnector.selectedRange;
2776
+ }
2777
+ setEdit(rowIndex, colIndex, colType, rowType) {
2778
+ var _a;
2779
+ (_a = this.sv.selectionStoreConnector) === null || _a === void 0 ? void 0 : _a.setEditByCell(this.getStoreCoordinateByType(colType, rowType), { x: colIndex, y: rowIndex });
2780
+ }
2781
+ }
2782
+
2783
+ function isMobileDevice() {
2784
+ return /Mobi/i.test(navigator.userAgent) || /Android/i.test(navigator.userAgent) || navigator.maxTouchPoints > 0;
2785
+ }
2786
+
2787
+ /**
2788
+ * All render based on sections
2789
+ * First we render vertical parts - pinned start, data, pinned end
2790
+ * Per each column we render data collections: headers, pinned top, center data, pinned bottom
2791
+ */
2792
+ const ViewPortSections = ({ resize, editors, rowClass, readonly, range, columns, useClipboard, columnFilter, applyEditorChangesOnClose, additionalData, onCancelEdit, registerElement, onEdit, scrollSection, focusTemplate, onSelectAll, scrollSectionSilent, }) => {
2793
+ const isMobile = isMobileDevice();
2794
+ const viewPortHtml = [];
2795
+ /** render viewports columns */
2796
+ for (let view of columns) {
2797
+ /** render viewports rows */
2798
+ const headerProperties = Object.assign(Object.assign({}, view.headerProp), { type: view.type, additionalData, viewportCol: view.viewportCol, selectionStore: view.columnSelectionStore, canResize: resize, columnFilter });
2799
+ const dataViews = [
2800
+ index$1.h("revogr-header", Object.assign({}, headerProperties, { slot: viewport_helpers.HEADER_SLOT })),
2801
+ ];
2802
+ view.dataPorts.forEach((data, j) => {
2803
+ const key = view.prop.key + (j + 1);
2804
+ const dataView = (index$1.h("revogr-overlay-selection", Object.assign({}, data, { isMobileDevice: isMobile, selectionStore: data.segmentSelectionStore, onSelectall: () => onSelectAll(), editors: editors, readonly: readonly, range: range, useClipboard: useClipboard, onCancelEdit: () => onCancelEdit(), applyChangesOnClose: applyEditorChangesOnClose, onSetEdit: ({ detail }) => onEdit(detail), additionalData: additionalData, slot: data.slot }),
2805
+ index$1.h("revogr-data", Object.assign({}, data, { [index.UUID]: data.uuid }, { key: key, readonly: readonly, range: range, rowClass: rowClass, rowSelectionStore: data.rowSelectionStore, additionalData: additionalData, slot: viewport_helpers.DATA_SLOT })),
2806
+ index$1.h("revogr-temp-range", { selectionStore: data.segmentSelectionStore, dimensionRow: data.dimensionRow, dimensionCol: data.dimensionCol }),
2807
+ index$1.h("revogr-focus", { colData: data.colData, dataStore: data.dataStore, focusTemplate: focusTemplate, rowType: data.type, colType: view.type, selectionStore: data.segmentSelectionStore, dimensionRow: data.dimensionRow, dimensionCol: data.dimensionCol })));
2808
+ dataViews.push(dataView);
2809
+ });
2810
+ viewPortHtml.push(index$1.h("revogr-viewport-scroll", Object.assign({}, view.prop, { ref: el => registerElement(el, view.prop.key), onScrollViewport: e => scrollSection(e.detail, view.prop.key), onSilentScroll: e => scrollSectionSilent(e.detail, view.prop.key) }), dataViews));
2811
+ }
2812
+ return viewPortHtml;
2813
+ };
2814
+
2815
+ class GridScrollingService {
2816
+ constructor(setViewport) {
2817
+ this.setViewport = setViewport;
2818
+ this.elements = {};
2819
+ }
2820
+ async scrollService(e, key) {
2821
+ let newEvent;
2822
+ let event = e;
2823
+ for (let elKey in this.elements) {
2824
+ if (e.dimension === 'rgCol' && elKey === 'headerRow') {
2825
+ continue;
2826
+ // pinned column only
2827
+ }
2828
+ else if (this.isPinnedColumn(key) && e.dimension === 'rgCol') {
2829
+ if (elKey === key || !e.delta) {
2830
+ continue;
2831
+ }
2832
+ for (let el of this.elements[elKey]) {
2833
+ if (el.changeScroll) {
2834
+ newEvent = el.changeScroll(e);
2835
+ }
2836
+ }
2837
+ }
2838
+ else {
2839
+ for (let el of this.elements[elKey]) {
2840
+ await el.setScroll(e);
2841
+ }
2842
+ }
2843
+ }
2844
+ if (newEvent) {
2845
+ event = await newEvent;
2846
+ }
2847
+ this.setViewport(event);
2848
+ }
2849
+ /**
2850
+ * Silent scroll update for mobile devices when we have negative scroll top
2851
+ */
2852
+ async scrollSilentService(e, key) {
2853
+ var _a;
2854
+ for (let elKey in this.elements) {
2855
+ // skip same element update
2856
+ if (elKey === key) {
2857
+ continue;
2858
+ }
2859
+ if (columnTypes.includes(key) && (elKey === 'headerRow' || columnTypes.includes(elKey))) {
2860
+ for (let el of this.elements[elKey]) {
2861
+ await ((_a = el.changeScroll) === null || _a === void 0 ? void 0 : _a.call(el, e, true));
2862
+ }
2863
+ continue;
2864
+ }
2865
+ }
2866
+ }
2867
+ isPinnedColumn(key) {
2868
+ return ['colPinStart', 'colPinEnd'].indexOf(key) > -1;
2869
+ }
2870
+ registerElements(els) {
2871
+ this.elements = els;
2872
+ }
2873
+ /**
2874
+ * Register new element for farther scroll support
2875
+ * @param el - can be null if holder removed
2876
+ * @param key - element key
2877
+ */
2878
+ registerElement(el, key) {
2879
+ if (!this.elements[key]) {
2880
+ this.elements[key] = [];
2881
+ }
2882
+ // new element added
2883
+ if (el) {
2884
+ this.elements[key].push(el);
2885
+ }
2886
+ else if (this.elements[key]) {
2887
+ // element removed
2888
+ delete this.elements[key];
2889
+ }
2890
+ }
2891
+ unregister() {
2892
+ delete this.elements;
2893
+ this.elements = {};
2894
+ }
2895
+ }
2896
+
2897
+ class StretchColumn extends BasePlugin {
2898
+ constructor(revogrid, providers) {
2899
+ super(revogrid);
2900
+ this.providers = providers;
2901
+ this.stretchedColumn = null;
2902
+ // calculate scroll bar size for current user session
2903
+ this.scrollSize = index.getScrollbarWidth(document);
2904
+ // subscribe to column changes
2905
+ const beforecolumnapplied = ({ detail: { columns } }) => this.applyStretch(columns);
2906
+ this.addEventListener('beforecolumnapplied', beforecolumnapplied);
2907
+ }
2908
+ setScroll({ type, hasScroll }) {
2909
+ var _a;
2910
+ if (type === 'rgRow' && this.stretchedColumn && ((_a = this.stretchedColumn) === null || _a === void 0 ? void 0 : _a.initialSize) === this.stretchedColumn.size) {
2911
+ if (hasScroll) {
2912
+ this.stretchedColumn.size -= this.scrollSize;
2913
+ this.apply();
2914
+ this.dropChanges();
2915
+ }
2916
+ }
2917
+ }
2918
+ activateChanges() {
2919
+ const setScroll = ({ detail }) => this.setScroll(detail);
2920
+ this.addEventListener('scrollchange', setScroll);
2921
+ }
2922
+ dropChanges() {
2923
+ this.stretchedColumn = null;
2924
+ this.removeEventListener('scrollchange');
2925
+ }
2926
+ apply() {
2927
+ if (!this.stretchedColumn) {
2928
+ return;
2929
+ }
2930
+ const type = 'rgCol';
2931
+ const sizes = this.providers.dimensionProvider.stores[type].store.get('sizes');
2932
+ this.providers.dimensionProvider.setCustomSizes(type, Object.assign(Object.assign({}, sizes), { [this.stretchedColumn.index]: this.stretchedColumn.size }), true);
2933
+ }
2934
+ /**
2935
+ * Apply stretch changes
2936
+ */
2937
+ applyStretch(columns) {
2938
+ // unsubscribe from all events
2939
+ this.dropChanges();
2940
+ // calculate grid size
2941
+ let sizeDifference = this.revogrid.clientWidth - 1;
2942
+ viewport_helpers.lodash.each(columns, (_, type) => {
2943
+ const realSize = this.providers.dimensionProvider.stores[type].store.get('realSize');
2944
+ sizeDifference -= realSize;
2945
+ });
2946
+ if (this.revogrid.rowHeaders) {
2947
+ const itemsLength = this.providers.dataProvider.stores.rgRow.store.get('source').length;
2948
+ const header = this.revogrid.rowHeaders;
2949
+ const rowHeaderSize = events.calculateRowHeaderSize(itemsLength, typeof header === 'object' ? header : undefined);
2950
+ if (rowHeaderSize) {
2951
+ sizeDifference -= rowHeaderSize;
2952
+ }
2953
+ }
2954
+ if (sizeDifference > 0) {
2955
+ // currently plugin accepts last column only
2956
+ const index = columns.rgCol.length - 1;
2957
+ const last = columns.rgCol[index];
2958
+ /**
2959
+ * has column
2960
+ * no auto size applied
2961
+ * size for column shouldn't be defined
2962
+ */
2963
+ const colSize = (last === null || last === void 0 ? void 0 : last.size) || this.revogrid.colSize || 0;
2964
+ const size = sizeDifference + colSize - 1;
2965
+ if (last && !last.autoSize && colSize < size) {
2966
+ this.stretchedColumn = {
2967
+ initialSize: size,
2968
+ index,
2969
+ size,
2970
+ };
2971
+ this.apply();
2972
+ this.activateChanges();
2973
+ }
2974
+ }
2975
+ }
2976
+ }
2977
+ /**
2978
+ * Check plugin type is Stretch
2979
+ */
2980
+ function isStretchPlugin(plugin) {
2981
+ return !!plugin.applyStretch;
2982
+ }
2983
+
2984
+ const rowDefinitionByType = (newVal = []) => {
2985
+ return index.reduce_1(newVal, (r, v) => {
2986
+ if (!r[v.type]) {
2987
+ r[v.type] = {};
2988
+ }
2989
+ if (v.size) {
2990
+ if (!r[v.type].sizes) {
2991
+ r[v.type].sizes = {};
2992
+ }
2993
+ r[v.type].sizes[v.index] = v.size;
2994
+ }
2995
+ return r;
2996
+ }, {});
2997
+ };
2998
+ const rowDefinitionRemoveByType = (oldVal = []) => {
2999
+ return index.reduce_1(oldVal, (r, v) => {
3000
+ if (!r[v.type]) {
3001
+ r[v.type] = [];
3002
+ }
3003
+ if (v.size) {
3004
+ r[v.type].push(v.index);
3005
+ }
3006
+ return r;
3007
+ }, {});
3008
+ };
3009
+
3010
+ const COLUMN_DRAG_CLASS = 'column-drag-start';
3011
+ class ColumnOrderHandler {
3012
+ constructor() {
3013
+ this.offset = 0;
3014
+ }
3015
+ renderAutoscroll(_, parent) {
3016
+ if (!parent) {
3017
+ return;
3018
+ }
3019
+ this.autoscrollEl = document.createElement('div');
3020
+ this.autoscrollEl.classList.add('drag-auto-scroll-y');
3021
+ parent.appendChild(this.autoscrollEl);
3022
+ }
3023
+ autoscroll(pos, dataContainerSize, direction = 'translateX') {
3024
+ if (!this.autoscrollEl) {
3025
+ return;
3026
+ }
3027
+ const helperOffset = 10;
3028
+ // calculate current y position inside of the grid active holder
3029
+ // 3 - size of element + border
3030
+ const maxScroll = Math.min(pos + helperOffset, dataContainerSize - 3);
3031
+ this.autoscrollEl.style.transform = `${direction}(${maxScroll}px)`;
3032
+ this.autoscrollEl.scrollIntoView({
3033
+ block: 'nearest',
3034
+ inline: 'nearest',
3035
+ });
3036
+ }
3037
+ start(e, { dataEl, gridRect, scrollEl, gridEl }, dir = 'left') {
3038
+ gridEl.classList.add(COLUMN_DRAG_CLASS);
3039
+ const scrollContainerRect = scrollEl.getBoundingClientRect();
3040
+ if (scrollContainerRect) {
3041
+ this.offset = scrollContainerRect[dir] - gridRect[dir];
3042
+ }
3043
+ this.renderAutoscroll(e, dataEl);
3044
+ }
3045
+ stop(gridEl) {
3046
+ var _a;
3047
+ gridEl.classList.remove(COLUMN_DRAG_CLASS);
3048
+ if (this.element) {
3049
+ this.element.hidden = true;
3050
+ }
3051
+ this.offset = 0;
3052
+ (_a = this.autoscrollEl) === null || _a === void 0 ? void 0 : _a.remove();
3053
+ this.autoscrollEl = undefined;
3054
+ }
3055
+ showHandler(pos, size, direction = 'translateX') {
3056
+ if (!this.element) {
3057
+ return;
3058
+ }
3059
+ // do not allow overcross top of the scrollable area, header excluded
3060
+ if (this.offset) {
3061
+ pos = Math.max(pos, this.offset);
3062
+ }
3063
+ // can not be bigger then grid end
3064
+ pos = Math.min(pos, size);
3065
+ this.element.style.transform = `${direction}(${pos}px)`;
3066
+ this.element.hidden = false;
3067
+ }
3068
+ render() {
3069
+ return index$1.h("div", { class: "drag-position-y", hidden: true, ref: (el) => (this.element = el) });
3070
+ }
3071
+ }
3072
+
3073
+ /**
3074
+ * Plugin for column manual move
3075
+ */
3076
+ const COLUMN_CLICK = 'column-click';
3077
+ const MOVE = 'column-mouse-move';
3078
+ const DRAG_END = 'column-drag-end';
3079
+ const BEFORE_DRAG_END = 'before-column-drag-end';
3080
+ // use this event subscription to drop D&D for particular columns
3081
+ const DRAG_START = 'column-drag-start';
3082
+ class ColumnPlugin extends BasePlugin {
3083
+ constructor(revogrid, providers) {
3084
+ super(revogrid);
3085
+ this.revogrid = revogrid;
3086
+ this.providers = providers;
3087
+ this.moveFunc = debounce.debounce_1((e) => this.doMove(e), 5);
3088
+ this.staticDragData = null;
3089
+ this.dragData = null;
3090
+ this.localSubscriptions = {};
3091
+ this.orderUi = new ColumnOrderHandler();
3092
+ revogrid.registerVNode([this.orderUi.render()]);
3093
+ revogrid.classList.add('column-draggable');
3094
+ /** Register events */
3095
+ this.localSubscriptions['mouseleave'] = {
3096
+ target: document,
3097
+ callback: (e) => this.onMouseOut(e),
3098
+ };
3099
+ this.localSubscriptions['mouseup'] = {
3100
+ target: document,
3101
+ callback: (e) => this.onMouseUp(e),
3102
+ };
3103
+ this.localSubscriptions['mousemove'] = {
3104
+ target: document,
3105
+ callback: (e) => this.move(e),
3106
+ };
3107
+ this.addEventListener(COLUMN_CLICK, ({ detail }) => this.dragStart(detail));
3108
+ }
3109
+ dragStart({ event, data }) {
3110
+ if (event.defaultPrevented) {
3111
+ return;
3112
+ }
3113
+ const { defaultPrevented } = dispatcher.dispatch(this.revogrid, DRAG_START, data);
3114
+ // check if allowed to drag particulat column
3115
+ if (defaultPrevented) {
3116
+ return;
3117
+ }
3118
+ this.clearOrder();
3119
+ const { mouseleave, mouseup, mousemove } = this.localSubscriptions;
3120
+ mouseleave.target.addEventListener('mouseleave', mouseleave.callback);
3121
+ mouseup.target.addEventListener('mouseup', mouseup.callback);
3122
+ const dataEl = event.target.closest('revogr-header');
3123
+ const scrollEl = event.target.closest('revogr-viewport-scroll');
3124
+ if (!dataEl || !scrollEl) {
3125
+ return;
3126
+ }
3127
+ if (isColGrouping(data)) {
3128
+ return;
3129
+ }
3130
+ const cols = this.getDimension(data.pin || 'rgCol');
3131
+ const gridRect = this.revogrid.getBoundingClientRect();
3132
+ const elRect = dataEl.getBoundingClientRect();
3133
+ const startItem = index.getItemByPosition(cols, getLeftRelative(event.x, gridRect.left, elRect.left - gridRect.left));
3134
+ this.staticDragData = {
3135
+ startPos: event.x,
3136
+ startItem,
3137
+ data,
3138
+ dataEl,
3139
+ scrollEl,
3140
+ gridEl: this.revogrid,
3141
+ cols,
3142
+ };
3143
+ this.dragData = this.getData(this.staticDragData);
3144
+ mousemove.target.addEventListener('mousemove', mousemove.callback);
3145
+ this.orderUi.start(event, Object.assign(Object.assign({}, this.dragData), this.staticDragData));
3146
+ }
3147
+ doMove(e) {
3148
+ if (!this.staticDragData) {
3149
+ return;
3150
+ }
3151
+ const dragData = (this.dragData = this.getData(this.staticDragData));
3152
+ if (!dragData) {
3153
+ return;
3154
+ }
3155
+ const start = this.staticDragData.startPos;
3156
+ if (Math.abs(start - e.x) > 10) {
3157
+ const x = getLeftRelative(e.x, this.dragData.gridRect.left, this.dragData.scrollOffset);
3158
+ const rgCol = index.getItemByPosition(this.staticDragData.cols, x);
3159
+ this.orderUi.autoscroll(x, dragData.elRect.width);
3160
+ this.orderUi.showHandler(rgCol.end + dragData.scrollOffset, dragData.gridRect.width);
3161
+ }
3162
+ }
3163
+ move(e) {
3164
+ dispatcher.dispatch(this.revogrid, MOVE, e);
3165
+ // then do move
3166
+ this.moveFunc(e);
3167
+ }
3168
+ onMouseOut(_) {
3169
+ this.clearOrder();
3170
+ }
3171
+ onMouseUp(e) {
3172
+ // apply new positions
3173
+ if (this.dragData) {
3174
+ let relativePos = getLeftRelative(e.x, this.dragData.gridRect.left, this.dragData.scrollOffset);
3175
+ if (relativePos < 0) {
3176
+ relativePos = 0;
3177
+ }
3178
+ const newPosition = index.getItemByPosition(this.staticDragData.cols, relativePos);
3179
+ const store = this.providers.column.stores[this.dragData.type].store;
3180
+ const items = [...store.get('items')];
3181
+ // prevent position change if needed
3182
+ const { defaultPrevented: stopDrag } = dispatcher.dispatch(this.revogrid, BEFORE_DRAG_END, Object.assign(Object.assign({}, this.staticDragData), { startPosition: this.staticDragData.startItem, newPosition, newItem: store.get('source')[items[this.staticDragData.startItem.itemIndex]] }));
3183
+ if (!stopDrag) {
3184
+ // todo: if move item out of group remove item from group
3185
+ const toMove = items.splice(this.staticDragData.startItem.itemIndex, 1);
3186
+ items.splice(newPosition.itemIndex, 0, ...toMove);
3187
+ store.set('items', items);
3188
+ }
3189
+ dispatcher.dispatch(this.revogrid, DRAG_END, this.dragData);
3190
+ }
3191
+ this.clearOrder();
3192
+ }
3193
+ clearLocalSubscriptions() {
3194
+ index.each(this.localSubscriptions, ({ target, callback }, key) => target.removeEventListener(key, callback));
3195
+ }
3196
+ clearOrder() {
3197
+ this.staticDragData = null;
3198
+ this.dragData = null;
3199
+ this.clearLocalSubscriptions();
3200
+ this.orderUi.stop(this.revogrid);
3201
+ }
3202
+ /**
3203
+ * Clearing subscription
3204
+ */
3205
+ clearSubscriptions() {
3206
+ super.clearSubscriptions();
3207
+ this.clearLocalSubscriptions();
3208
+ }
3209
+ getData({ gridEl, dataEl, data, }) {
3210
+ const gridRect = gridEl.getBoundingClientRect();
3211
+ const elRect = dataEl.getBoundingClientRect();
3212
+ const scrollOffset = elRect.left - gridRect.left;
3213
+ return {
3214
+ elRect,
3215
+ gridRect,
3216
+ type: data.pin || 'rgCol',
3217
+ scrollOffset,
3218
+ };
3219
+ }
3220
+ getDimension(type) {
3221
+ return this.providers.dimension.stores[type].getCurrentState();
3222
+ }
3223
+ }
3224
+ function getLeftRelative(absoluteX, gridPos, offset) {
3225
+ return absoluteX - gridPos - offset;
3226
+ }
3227
+
3228
+ const revoGridStyleCss = ".revo-drag-icon{-webkit-mask-image:url(\"data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg viewBox='0 0 438 383' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink'%3E%3Cg%3E%3Cpath d='M421.875,70.40625 C426.432292,70.40625 430.175781,68.9414062 433.105469,66.0117188 C436.035156,63.0820312 437.5,59.3385417 437.5,54.78125 L437.5,54.78125 L437.5,15.71875 C437.5,11.1614583 436.035156,7.41796875 433.105469,4.48828125 C430.175781,1.55859375 426.432292,0.09375 421.875,0.09375 L421.875,0.09375 L15.625,0.09375 C11.0677083,0.09375 7.32421875,1.55859375 4.39453125,4.48828125 C1.46484375,7.41796875 0,11.1614583 0,15.71875 L0,15.71875 L0,54.78125 C0,59.3385417 1.46484375,63.0820312 4.39453125,66.0117188 C7.32421875,68.9414062 11.0677083,70.40625 15.625,70.40625 L15.625,70.40625 L421.875,70.40625 Z M421.875,226.65625 C426.432292,226.65625 430.175781,225.191406 433.105469,222.261719 C436.035156,219.332031 437.5,215.588542 437.5,211.03125 L437.5,211.03125 L437.5,171.96875 C437.5,167.411458 436.035156,163.667969 433.105469,160.738281 C430.175781,157.808594 426.432292,156.34375 421.875,156.34375 L421.875,156.34375 L15.625,156.34375 C11.0677083,156.34375 7.32421875,157.808594 4.39453125,160.738281 C1.46484375,163.667969 0,167.411458 0,171.96875 L0,171.96875 L0,211.03125 C0,215.588542 1.46484375,219.332031 4.39453125,222.261719 C7.32421875,225.191406 11.0677083,226.65625 15.625,226.65625 L15.625,226.65625 L421.875,226.65625 Z M421.875,382.90625 C426.432292,382.90625 430.175781,381.441406 433.105469,378.511719 C436.035156,375.582031 437.5,371.838542 437.5,367.28125 L437.5,367.28125 L437.5,328.21875 C437.5,323.661458 436.035156,319.917969 433.105469,316.988281 C430.175781,314.058594 426.432292,312.59375 421.875,312.59375 L421.875,312.59375 L15.625,312.59375 C11.0677083,312.59375 7.32421875,314.058594 4.39453125,316.988281 C1.46484375,319.917969 0,323.661458 0,328.21875 L0,328.21875 L0,367.28125 C0,371.838542 1.46484375,375.582031 4.39453125,378.511719 C7.32421875,381.441406 11.0677083,382.90625 15.625,382.90625 L15.625,382.90625 L421.875,382.90625 Z'%3E%3C/path%3E%3C/g%3E%3C/svg%3E\");mask-image:url(\"data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg viewBox='0 0 438 383' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink'%3E%3Cg%3E%3Cpath d='M421.875,70.40625 C426.432292,70.40625 430.175781,68.9414062 433.105469,66.0117188 C436.035156,63.0820312 437.5,59.3385417 437.5,54.78125 L437.5,54.78125 L437.5,15.71875 C437.5,11.1614583 436.035156,7.41796875 433.105469,4.48828125 C430.175781,1.55859375 426.432292,0.09375 421.875,0.09375 L421.875,0.09375 L15.625,0.09375 C11.0677083,0.09375 7.32421875,1.55859375 4.39453125,4.48828125 C1.46484375,7.41796875 0,11.1614583 0,15.71875 L0,15.71875 L0,54.78125 C0,59.3385417 1.46484375,63.0820312 4.39453125,66.0117188 C7.32421875,68.9414062 11.0677083,70.40625 15.625,70.40625 L15.625,70.40625 L421.875,70.40625 Z M421.875,226.65625 C426.432292,226.65625 430.175781,225.191406 433.105469,222.261719 C436.035156,219.332031 437.5,215.588542 437.5,211.03125 L437.5,211.03125 L437.5,171.96875 C437.5,167.411458 436.035156,163.667969 433.105469,160.738281 C430.175781,157.808594 426.432292,156.34375 421.875,156.34375 L421.875,156.34375 L15.625,156.34375 C11.0677083,156.34375 7.32421875,157.808594 4.39453125,160.738281 C1.46484375,163.667969 0,167.411458 0,171.96875 L0,171.96875 L0,211.03125 C0,215.588542 1.46484375,219.332031 4.39453125,222.261719 C7.32421875,225.191406 11.0677083,226.65625 15.625,226.65625 L15.625,226.65625 L421.875,226.65625 Z M421.875,382.90625 C426.432292,382.90625 430.175781,381.441406 433.105469,378.511719 C436.035156,375.582031 437.5,371.838542 437.5,367.28125 L437.5,367.28125 L437.5,328.21875 C437.5,323.661458 436.035156,319.917969 433.105469,316.988281 C430.175781,314.058594 426.432292,312.59375 421.875,312.59375 L421.875,312.59375 L15.625,312.59375 C11.0677083,312.59375 7.32421875,314.058594 4.39453125,316.988281 C1.46484375,319.917969 0,323.661458 0,328.21875 L0,328.21875 L0,367.28125 C0,371.838542 1.46484375,375.582031 4.39453125,378.511719 C7.32421875,381.441406 11.0677083,382.90625 15.625,382.90625 L15.625,382.90625 L421.875,382.90625 Z'%3E%3C/path%3E%3C/g%3E%3C/svg%3E\");width:11px;height:7px;background-size:cover;background-repeat:no-repeat}.revo-alt-icon{-webkit-mask-image:url(\"data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg viewBox='0 0 384 383' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink'%3E%3Cg%3E%3Cpath d='M192.4375,383 C197.424479,383 201.663411,381.254557 205.154297,377.763672 L205.154297,377.763672 L264.25,318.667969 C270.234375,312.683594 271.605794,306.075846 268.364258,298.844727 C265.122721,291.613607 259.51237,287.998047 251.533203,287.998047 L251.533203,287.998047 L213.382812,287.998047 L213.382812,212.445312 L288.935547,212.445312 L288.935547,250.595703 C288.935547,258.57487 292.551107,264.185221 299.782227,267.426758 C307.013346,270.668294 313.621094,269.296875 319.605469,263.3125 L319.605469,263.3125 L378.701172,204.216797 C382.192057,200.725911 383.9375,196.486979 383.9375,191.5 C383.9375,186.513021 382.192057,182.274089 378.701172,178.783203 L378.701172,178.783203 L319.605469,119.6875 C313.621094,114.201823 307.013346,112.955078 299.782227,115.947266 C292.551107,118.939453 288.935547,124.42513 288.935547,132.404297 L288.935547,132.404297 L288.935547,170.554688 L213.382812,170.554688 L213.382812,95.0019531 L251.533203,95.0019531 C259.51237,95.0019531 264.998047,91.3863932 267.990234,84.1552734 C270.982422,76.9241536 269.735677,70.3164062 264.25,64.3320312 L264.25,64.3320312 L205.154297,5.23632812 C201.663411,1.74544271 197.424479,0 192.4375,0 C187.450521,0 183.211589,1.74544271 179.720703,5.23632812 L179.720703,5.23632812 L120.625,64.3320312 C114.640625,70.3164062 113.269206,76.9241536 116.510742,84.1552734 C119.752279,91.3863932 125.36263,95.0019531 133.341797,95.0019531 L133.341797,95.0019531 L171.492188,95.0019531 L171.492188,170.554688 L95.9394531,170.554688 L95.9394531,132.404297 C95.9394531,124.42513 92.3238932,118.814779 85.0927734,115.573242 C77.8616536,112.331706 71.2539062,113.703125 65.2695312,119.6875 L65.2695312,119.6875 L6.17382812,178.783203 C2.68294271,182.274089 0.9375,186.513021 0.9375,191.5 C0.9375,196.486979 2.68294271,200.725911 6.17382812,204.216797 L6.17382812,204.216797 L65.2695312,263.3125 C71.2539062,268.798177 77.8616536,270.044922 85.0927734,267.052734 C92.3238932,264.060547 95.9394531,258.57487 95.9394531,250.595703 L95.9394531,250.595703 L95.9394531,212.445312 L171.492188,212.445312 L171.492188,287.998047 L133.341797,287.998047 C125.36263,287.998047 119.876953,291.613607 116.884766,298.844727 C113.892578,306.075846 115.139323,312.683594 120.625,318.667969 L120.625,318.667969 L179.720703,377.763672 C183.211589,381.254557 187.450521,383 192.4375,383 Z'%3E%3C/path%3E%3C/g%3E%3C/svg%3E\");mask-image:url(\"data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg viewBox='0 0 384 383' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink'%3E%3Cg%3E%3Cpath d='M192.4375,383 C197.424479,383 201.663411,381.254557 205.154297,377.763672 L205.154297,377.763672 L264.25,318.667969 C270.234375,312.683594 271.605794,306.075846 268.364258,298.844727 C265.122721,291.613607 259.51237,287.998047 251.533203,287.998047 L251.533203,287.998047 L213.382812,287.998047 L213.382812,212.445312 L288.935547,212.445312 L288.935547,250.595703 C288.935547,258.57487 292.551107,264.185221 299.782227,267.426758 C307.013346,270.668294 313.621094,269.296875 319.605469,263.3125 L319.605469,263.3125 L378.701172,204.216797 C382.192057,200.725911 383.9375,196.486979 383.9375,191.5 C383.9375,186.513021 382.192057,182.274089 378.701172,178.783203 L378.701172,178.783203 L319.605469,119.6875 C313.621094,114.201823 307.013346,112.955078 299.782227,115.947266 C292.551107,118.939453 288.935547,124.42513 288.935547,132.404297 L288.935547,132.404297 L288.935547,170.554688 L213.382812,170.554688 L213.382812,95.0019531 L251.533203,95.0019531 C259.51237,95.0019531 264.998047,91.3863932 267.990234,84.1552734 C270.982422,76.9241536 269.735677,70.3164062 264.25,64.3320312 L264.25,64.3320312 L205.154297,5.23632812 C201.663411,1.74544271 197.424479,0 192.4375,0 C187.450521,0 183.211589,1.74544271 179.720703,5.23632812 L179.720703,5.23632812 L120.625,64.3320312 C114.640625,70.3164062 113.269206,76.9241536 116.510742,84.1552734 C119.752279,91.3863932 125.36263,95.0019531 133.341797,95.0019531 L133.341797,95.0019531 L171.492188,95.0019531 L171.492188,170.554688 L95.9394531,170.554688 L95.9394531,132.404297 C95.9394531,124.42513 92.3238932,118.814779 85.0927734,115.573242 C77.8616536,112.331706 71.2539062,113.703125 65.2695312,119.6875 L65.2695312,119.6875 L6.17382812,178.783203 C2.68294271,182.274089 0.9375,186.513021 0.9375,191.5 C0.9375,196.486979 2.68294271,200.725911 6.17382812,204.216797 L6.17382812,204.216797 L65.2695312,263.3125 C71.2539062,268.798177 77.8616536,270.044922 85.0927734,267.052734 C92.3238932,264.060547 95.9394531,258.57487 95.9394531,250.595703 L95.9394531,250.595703 L95.9394531,212.445312 L171.492188,212.445312 L171.492188,287.998047 L133.341797,287.998047 C125.36263,287.998047 119.876953,291.613607 116.884766,298.844727 C113.892578,306.075846 115.139323,312.683594 120.625,318.667969 L120.625,318.667969 L179.720703,377.763672 C183.211589,381.254557 187.450521,383 192.4375,383 Z'%3E%3C/path%3E%3C/g%3E%3C/svg%3E\");width:11px;height:11px;background-size:cover;background-repeat:no-repeat}.arrow-down{position:absolute;right:5px;top:0}.arrow-down svg{width:8px;margin-top:5px;margin-left:5px;opacity:0.4}.cell-value-wrapper{margin-right:10px;overflow:hidden;text-overflow:ellipsis}.revo-button{position:relative;overflow:hidden;color:#fff;background-color:#6200ee;height:34px;line-height:34px;padding:0 15px;outline:0;border:0;border-radius:7px;box-sizing:border-box;cursor:pointer}.revo-button.green{background-color:#2ee072;border:1px solid #20d565}.revo-button.red{background-color:#E0662E;border:1px solid #d55920}.revo-button:disabled,.revo-button[disabled]{cursor:not-allowed !important;filter:opacity(0.35) !important}.revo-button.light{border:2px solid #cedefa;line-height:32px;background:none;color:#4876ca;box-shadow:none}revo-grid[theme=default]{font-size:12px}revo-grid[theme=default] revogr-header{text-align:center;line-height:30px;background-color:#f8f9fa}revo-grid[theme=default] revogr-header .group-rgRow{box-shadow:none}revo-grid[theme=default] revogr-header .header-rgRow,revo-grid[theme=default] revogr-header .group-rgRow{text-transform:uppercase;font-size:12px;color:#61656a}revo-grid[theme=default] revogr-header .header-rgRow{height:30px;box-shadow:0 -1px 0 0 #c0c0c0 inset}revo-grid[theme=default] revogr-header .rgHeaderCell{box-shadow:-1px 0 0 0 #c0c0c0, -1px 0 0 0 #c0c0c0 inset, 0 -1px 0 0 #c0c0c0, 0 -1px 0 0 #c0c0c0 inset}revo-grid[theme=default] revogr-header .rgHeaderCell.focused-cell{background:rgba(233, 234, 237, 0.5)}revo-grid[theme=default] .rowHeaders{background-color:#f8f9fa}revo-grid[theme=default] .rowHeaders revogr-data .rgCell{color:#61656a;box-shadow:0 -1px 0 0 #c0c0c0 inset, -1px 0 0 0 #c0c0c0 inset}revo-grid[theme=default] .rowHeaders revogr-header{box-shadow:0 -1px 0 0 #c0c0c0 inset, -1px 0 0 0 #c0c0c0 inset}revo-grid[theme=default] revogr-viewport-scroll.colPinStart revogr-data .rgRow .rgCell:last-child{box-shadow:0 -1px 0 0 #e2e3e3 inset, -1px 0 0 0 #c0c0c0 inset}revo-grid[theme=default] revogr-viewport-scroll.colPinStart .footer-wrapper revogr-data .rgRow:first-child .rgCell{box-shadow:0 1px 0 0 #c0c0c0 inset, -1px 0 0 0 #c0c0c0 inset}revo-grid[theme=default] revogr-viewport-scroll.colPinEnd,revo-grid[theme=default] revogr-viewport-scroll.colPinEnd revogr-header{box-shadow:1px 0 0 #c0c0c0 inset}revo-grid[theme=default] .footer-wrapper revogr-data .rgRow:first-child .rgCell{box-shadow:0 1px 0 0 #e2e3e3 inset, -1px 0 0 0 #e2e3e3 inset, 0 -1px 0 0 #e2e3e3 inset}revo-grid[theme=default] revogr-data{text-align:center}revo-grid[theme=default] revogr-data .rgRow{line-height:27px;box-shadow:0 -1px 0 0 #e2e3e3 inset, -1px 0 0 0 #e2e3e3 inset}revo-grid[theme=default] revogr-data .rgRow.focused-rgRow{background-color:rgba(233, 234, 237, 0.5)}revo-grid[theme=default] revogr-data .rgCell{box-shadow:0 -1px 0 0 #e2e3e3 inset, -1px 0 0 0 #e2e3e3 inset}revo-grid[theme=default] revogr-data .rgCell.disabled{background-color:0 -1px 0 0 #e2e3e3 inset, -1px 0 0 0 #e2e3e3 inset}revo-grid[theme=material]{font-family:Nunito, -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\"}revo-grid[theme=material] revogr-header{line-height:50px;font-weight:600;text-align:left}revo-grid[theme=material] revogr-header .rgHeaderCell{padding:0 15px;text-overflow:ellipsis}revo-grid[theme=material] revogr-header .header-rgRow{height:50px}revo-grid[theme=material] revogr-data{text-align:left}revo-grid[theme=material] revogr-data .rgRow{line-height:42px}revo-grid[theme=material] revogr-data .rgCell{padding:0 15px}revo-grid[theme=material] .viewports{width:100%}revo-grid[theme=material] .rowHeaders{background-color:#f7faff}revo-grid[theme=material] .rowHeaders revogr-data .rgCell{color:#757a82}revo-grid[theme=material] revogr-header .header-rgRow.group{box-shadow:0 -1px 0 0 #f1f1f1 inset}revo-grid[theme=material] revogr-header .header-rgRow:not(.group){box-shadow:0 -1px 0 0 #f1f1f1, 0 -1px 0 0 #f1f1f1 inset}revo-grid[theme=material] revogr-header .rgHeaderCell.sortable:hover{background-color:#f1f1f1}revo-grid[theme=material] revogr-header .rgHeaderCell.focused-cell{background:rgba(233, 234, 237, 0.5)}revo-grid[theme=material] .footer-wrapper revogr-data{box-shadow:0 -1px 0 #f1f1f1}revo-grid[theme=material] revogr-viewport-scroll.colPinStart{box-shadow:-1px 0 0 #f1f1f1 inset}revo-grid[theme=material] revogr-viewport-scroll.colPinEnd{box-shadow:-1px 0 0 #f1f1f1}revo-grid[theme=material] revogr-data .rgRow{box-shadow:0 -1px 0 0 #f1f1f1 inset}revo-grid[theme=material] revogr-data .rgRow.focused-rgRow{background-color:rgba(233, 234, 237, 0.5)}revo-grid[theme=material] revogr-data .rgCell{color:rgba(0, 0, 0, 0.87)}revo-grid[theme=material] revogr-data .rgCell.disabled{background-color:#f7f7f7}revo-grid[theme=material] revogr-data .revo-draggable>.revo-drag-icon{background-color:#d4d4d4}revo-grid[theme=material] revogr-data .revo-draggable:hover>.revo-drag-icon{background-color:black}revo-grid[theme=darkMaterial]{font-family:Nunito, -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:#d8d8d8}revo-grid[theme=darkMaterial] revogr-header{line-height:50px;font-weight:600;text-align:left}revo-grid[theme=darkMaterial] revogr-header .rgHeaderCell{padding:0 15px;text-overflow:ellipsis}revo-grid[theme=darkMaterial] revogr-header .header-rgRow{height:50px}revo-grid[theme=darkMaterial] revogr-data{text-align:left}revo-grid[theme=darkMaterial] revogr-data .rgRow{line-height:42px}revo-grid[theme=darkMaterial] revogr-data .rgCell{padding:0 15px}revo-grid[theme=darkMaterial] .viewports{width:100%}revo-grid[theme=darkMaterial] .rowHeaders{background-color:rgba(40, 39, 43, 0.8)}revo-grid[theme=darkMaterial] .rowHeaders revogr-data .rgCell{color:rgba(216, 216, 216, 0.8)}revo-grid[theme=darkMaterial] revogr-header .header-rgRow.group{box-shadow:0 -1px 0 0 #404040 inset}revo-grid[theme=darkMaterial] revogr-header .header-rgRow:not(.group){box-shadow:0 -1px 0 0 #404040, 0 -1px 0 0 #404040 inset}revo-grid[theme=darkMaterial] revogr-header .rgHeaderCell.sortable:hover{background-color:rgba(64, 64, 64, 0.5)}revo-grid[theme=darkMaterial] revogr-header .rgHeaderCell.focused-cell{background:rgba(115, 148, 160, 0.15)}revo-grid[theme=darkMaterial] .footer-wrapper revogr-data{box-shadow:0 -1px 0 #404040}revo-grid[theme=darkMaterial] revogr-data .rgCell{color:rgba(216, 216, 216, 0.9)}revo-grid[theme=darkMaterial] revogr-data .rgRow{box-shadow:0 -1px 0 0 #404040 inset}revo-grid[theme=darkMaterial] revogr-data .rgRow.focused-rgRow{background-color:rgba(115, 148, 160, 0.15)}revo-grid[theme=darkMaterial] revogr-data .revo-draggable>.revo-drag-icon{background-color:rgba(216, 216, 216, 0.5)}revo-grid[theme=darkMaterial] revogr-data .revo-draggable:hover>.revo-drag-icon{background-color:rgba(216, 216, 216, 0.7)}revo-grid[theme=darkMaterial] revogr-viewport-scroll.colPinStart{box-shadow:-1px 0 0 #404040 inset}revo-grid[theme=darkMaterial] revogr-viewport-scroll.colPinEnd{box-shadow:-1px 0 0 #404040}revo-grid[theme=darkCompact]{font-family:Nunito, -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:#d8d8d8}revo-grid[theme=darkCompact] revogr-header{line-height:45px;font-weight:600;text-align:left}revo-grid[theme=darkCompact] revogr-header .rgHeaderCell{padding:0 15px;text-overflow:ellipsis}revo-grid[theme=darkCompact] revogr-header .header-rgRow{height:45px}revo-grid[theme=darkCompact] revogr-data{text-align:left}revo-grid[theme=darkCompact] revogr-data .rgRow{line-height:32px}revo-grid[theme=darkCompact] revogr-data .rgCell{padding:0 15px}revo-grid[theme=darkCompact] .viewports{width:100%}revo-grid[theme=darkCompact] .rowHeaders{background-color:rgba(40, 39, 43, 0.8)}revo-grid[theme=darkCompact] .rowHeaders revogr-data .rgCell{color:rgba(216, 216, 216, 0.8)}revo-grid[theme=darkCompact] revogr-header .header-rgRow.group{box-shadow:0 -1px 0 0 #404040 inset}revo-grid[theme=darkCompact] revogr-header .header-rgRow:not(.group){box-shadow:0 -1px 0 0 #404040, 0 -1px 0 0 #404040 inset}revo-grid[theme=darkCompact] revogr-header .rgHeaderCell.sortable:hover{background-color:rgba(64, 64, 64, 0.5)}revo-grid[theme=darkCompact] revogr-header .rgHeaderCell.focused-cell{background:rgba(115, 148, 160, 0.15)}revo-grid[theme=darkCompact] .footer-wrapper revogr-data{box-shadow:0 -1px 0 #404040}revo-grid[theme=darkCompact] revogr-data .rgCell{color:rgba(216, 216, 216, 0.9)}revo-grid[theme=darkCompact] revogr-data .rgRow{box-shadow:0 -1px 0 0 #404040 inset}revo-grid[theme=darkCompact] revogr-data .rgRow.focused-rgRow{background-color:rgba(115, 148, 160, 0.15)}revo-grid[theme=darkCompact] revogr-data .revo-draggable>.revo-drag-icon{background-color:rgba(216, 216, 216, 0.5)}revo-grid[theme=darkCompact] revogr-data .revo-draggable:hover>.revo-drag-icon{background-color:rgba(216, 216, 216, 0.7)}revo-grid[theme=darkCompact] revogr-viewport-scroll.colPinStart{box-shadow:-1px 0 0 #404040 inset}revo-grid[theme=darkCompact] revogr-viewport-scroll.colPinEnd{box-shadow:-1px 0 0 #404040}revo-grid[theme=compact]{font-family:Nunito, -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\"}revo-grid[theme=compact] revogr-header{line-height:45px;font-weight:600;text-align:left}revo-grid[theme=compact] revogr-header .rgHeaderCell{padding:0 15px;text-overflow:ellipsis}revo-grid[theme=compact] revogr-header .header-rgRow{height:45px}revo-grid[theme=compact] revogr-data{text-align:left}revo-grid[theme=compact] revogr-data .rgRow{line-height:32px}revo-grid[theme=compact] revogr-data .rgCell{padding:0 15px}revo-grid[theme=compact] .viewports{width:100%}revo-grid[theme=compact] .rowHeaders{background-color:#f7faff}revo-grid[theme=compact] .rowHeaders revogr-data .rgCell{color:#757a82}revo-grid[theme=compact] revogr-header .header-rgRow.group{box-shadow:0 -1px 0 0 #f1f1f1 inset}revo-grid[theme=compact] revogr-header .header-rgRow:not(.group){box-shadow:0 -1px 0 0 #f1f1f1, 0 -1px 0 0 #f1f1f1 inset}revo-grid[theme=compact] revogr-header .rgHeaderCell.sortable:hover{background-color:#f1f1f1}revo-grid[theme=compact] revogr-header .rgHeaderCell.focused-cell{background:rgba(233, 234, 237, 0.5)}revo-grid[theme=compact] .footer-wrapper revogr-data{box-shadow:0 -1px 0 #f1f1f1}revo-grid[theme=compact] revogr-viewport-scroll.colPinStart{box-shadow:-1px 0 0 #f1f1f1 inset}revo-grid[theme=compact] revogr-viewport-scroll.colPinEnd{box-shadow:-1px 0 0 #f1f1f1}revo-grid[theme=compact] revogr-data .rgRow{box-shadow:0 -1px 0 0 #f1f1f1 inset}revo-grid[theme=compact] revogr-data .rgRow.focused-rgRow{background-color:rgba(233, 234, 237, 0.5)}revo-grid[theme=compact] revogr-data .rgCell{color:rgba(0, 0, 0, 0.87)}revo-grid[theme=compact] revogr-data .rgCell.disabled{background-color:#f7f7f7}revo-grid[theme=compact] revogr-data .revo-draggable>.revo-drag-icon{background-color:#d4d4d4}revo-grid[theme=compact] revogr-data .revo-draggable:hover>.revo-drag-icon{background-color:black}revo-grid[theme=compact] revo-dropdown .rv-dr-root{padding:0px 9px}revo-grid{display:block;height:100%;font-family:Helvetica, Arial, Sans-Serif, serif;font-size:14px;position:relative;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;display:flex;flex-direction:column;width:100%;height:100%}revo-grid.column-draggable.column-drag-start:hover,revo-grid.column-draggable.column-drag-start *:hover{cursor:grabbing}revo-grid .footer-wrapper,revo-grid .header-wrapper{width:100%}revo-grid .footer-wrapper revogr-data,revo-grid .header-wrapper revogr-data{z-index:3}revo-grid revo-dropdown{width:100%}revo-grid revo-dropdown .rv-dr-root{max-height:100%}revo-grid revo-dropdown.shrink label{opacity:0}revo-grid .viewports{max-height:100%;display:flex;flex-direction:row;align-items:flex-start;max-width:100%}revo-grid .main-viewport{flex-grow:1;height:0;display:flex;flex-direction:row}revo-grid .draggable{position:fixed;height:30px;line-height:30px;background:#fff;border-radius:3px;display:block;z-index:100;margin-top:5px;margin-right:-20px;box-shadow:0 4px 20px 0 rgba(0, 0, 0, 0.15);padding-left:20px;padding-right:5px}revo-grid .draggable.hidden{display:none}revo-grid .draggable .revo-alt-icon{background-color:black;position:absolute;left:5px;top:10px}revo-grid .draggable-wrapper.hidden{display:none}revo-grid .drag-position{position:absolute;left:0;right:0;height:1px;z-index:2;background:gray;pointer-events:none}revo-grid .drag-position-y{position:absolute;top:0;left:0;bottom:0;width:1px;z-index:2;background:gray;pointer-events:none}revo-grid .drag-auto-scroll-y{pointer-events:none;position:absolute;left:0;top:0;height:50px;width:1px}revo-grid .clipboard{position:absolute;left:0;top:0}revo-grid revogr-scroll-virtual{position:relative}revo-grid revogr-scroll-virtual.vertical,revo-grid revogr-scroll-virtual.horizontal{z-index:3}";
3229
+
3230
+ const RevoGridComponent = class {
3231
+ constructor(hostRef) {
3232
+ index$1.registerInstance(this, hostRef);
3233
+ this.contentsizechanged = index$1.createEvent(this, "contentsizechanged", 7);
3234
+ this.beforeedit = index$1.createEvent(this, "beforeedit", 7);
3235
+ this.beforerangeedit = index$1.createEvent(this, "beforerangeedit", 7);
3236
+ this.afteredit = index$1.createEvent(this, "afteredit", 7);
3237
+ this.beforeautofill = index$1.createEvent(this, "beforeautofill", 7);
3238
+ this.beforeange = index$1.createEvent(this, "beforeange", 7);
3239
+ this.afterfocus = index$1.createEvent(this, "afterfocus", 7);
3240
+ this.roworderchanged = index$1.createEvent(this, "roworderchanged", 7);
3241
+ this.beforesourcesortingapply = index$1.createEvent(this, "beforesourcesortingapply", 7);
3242
+ this.beforesortingapply = index$1.createEvent(this, "beforesortingapply", 7);
3243
+ this.beforesorting = index$1.createEvent(this, "beforesorting", 7);
3244
+ this.rowdragstart = index$1.createEvent(this, "rowdragstart", 7);
3245
+ this.headerclick = index$1.createEvent(this, "headerclick", 7);
3246
+ this.beforecellfocus = index$1.createEvent(this, "beforecellfocus", 7);
3247
+ this.beforefocuslost = index$1.createEvent(this, "beforefocuslost", 7);
3248
+ this.beforesourceset = index$1.createEvent(this, "beforesourceset", 7);
3249
+ this.beforeAnySource = index$1.createEvent(this, "before-any-source", 7);
3250
+ this.aftersourceset = index$1.createEvent(this, "aftersourceset", 7);
3251
+ this.afterAnySource = index$1.createEvent(this, "after-any-source", 7);
3252
+ this.beforecolumnsset = index$1.createEvent(this, "beforecolumnsset", 7);
3253
+ this.beforecolumnapplied = index$1.createEvent(this, "beforecolumnapplied", 7);
3254
+ this.aftercolumnsset = index$1.createEvent(this, "aftercolumnsset", 7);
3255
+ this.beforefilterapply = index$1.createEvent(this, "beforefilterapply", 7);
3256
+ this.beforefiltertrimmed = index$1.createEvent(this, "beforefiltertrimmed", 7);
3257
+ this.beforetrimmed = index$1.createEvent(this, "beforetrimmed", 7);
3258
+ this.aftertrimmed = index$1.createEvent(this, "aftertrimmed", 7);
3259
+ this.viewportscroll = index$1.createEvent(this, "viewportscroll", 7);
3260
+ this.beforeexport = index$1.createEvent(this, "beforeexport", 7);
3261
+ this.beforeeditstart = index$1.createEvent(this, "beforeeditstart", 7);
3262
+ this.aftercolumnresize = index$1.createEvent(this, "aftercolumnresize", 7);
3263
+ this.beforerowdefinition = index$1.createEvent(this, "beforerowdefinition", 7);
3264
+ this.filterconfigchanged = index$1.createEvent(this, "filterconfigchanged", 7);
3265
+ this.rowheaderschanged = index$1.createEvent(this, "rowheaderschanged", 7);
3266
+ // --------------------------------------------------------------------------
3267
+ //
3268
+ // Listeners outside scope
3269
+ //
3270
+ // --------------------------------------------------------------------------
3271
+ this.clickTrackForFocusClear = null;
3272
+ this.uuid = null;
3273
+ this.viewport = null;
3274
+ /**
3275
+ * Plugins
3276
+ * Define plugins collection
3277
+ */
3278
+ this.internalPlugins = [];
3279
+ this.rowHeaders = undefined;
3280
+ this.frameSize = 1;
3281
+ this.rowSize = 0;
3282
+ this.colSize = 100;
3283
+ this.range = false;
3284
+ this.readonly = false;
3285
+ this.resize = false;
3286
+ this.canFocus = true;
3287
+ this.useClipboard = true;
3288
+ this.columns = [];
3289
+ this.source = [];
3290
+ this.pinnedTopSource = [];
3291
+ this.pinnedBottomSource = [];
3292
+ this.rowDefinitions = [];
3293
+ this.editors = {};
3294
+ this.applyOnClose = false;
3295
+ this.plugins = undefined;
3296
+ this.columnTypes = {};
3297
+ this.theme = 'default';
3298
+ this.rowClass = '';
3299
+ this.autoSizeColumn = false;
3300
+ this.filter = false;
3301
+ this.focusTemplate = undefined;
3302
+ this.canMoveColumns = false;
3303
+ this.trimmedRows = {};
3304
+ this.exporting = false;
3305
+ this.grouping = undefined;
3306
+ this.stretch = true;
3307
+ this.additionalData = {};
3308
+ this.extraElements = [];
3309
+ }
3310
+ // --------------------------------------------------------------------------
3311
+ //
3312
+ // Methods
3313
+ //
3314
+ // --------------------------------------------------------------------------
3315
+ /**
3316
+ * Refreshes data viewport.
3317
+ * Can be specific part as rgRow or pinned rgRow or 'all' by default.
3318
+ */
3319
+ async refresh(type = 'all') {
3320
+ this.dataProvider.refresh(type);
3321
+ }
3322
+ /** Scrolls view port to specified rgRow index */
3323
+ async scrollToRow(coordinate = 0) {
3324
+ const y = this.dimensionProvider.getViewPortPos({
3325
+ coordinate,
3326
+ dimension: 'rgRow',
3327
+ });
3328
+ await this.scrollToCoordinate({ y });
3329
+ }
3330
+ /** Scrolls view port to specified column index */
3331
+ async scrollToColumnIndex(coordinate = 0) {
3332
+ const x = this.dimensionProvider.getViewPortPos({
3333
+ coordinate,
3334
+ dimension: 'rgCol',
3335
+ });
3336
+ await this.scrollToCoordinate({ x });
3337
+ }
3338
+ /** Scrolls view port to specified column prop */
3339
+ async scrollToColumnProp(prop) {
3340
+ const coordinate = this.columnProvider.getColumnIndexByProp(prop, 'rgCol');
3341
+ if (coordinate < 0) {
3342
+ // already on the screen
3343
+ return;
3344
+ }
3345
+ const x = this.dimensionProvider.getViewPortPos({
3346
+ coordinate,
3347
+ dimension: 'rgCol',
3348
+ });
3349
+ await this.scrollToCoordinate({ x });
3350
+ }
3351
+ /** Update columns */
3352
+ async updateColumns(cols) {
3353
+ this.columnProvider.updateColumns(cols);
3354
+ }
3355
+ /** Add trimmed by type */
3356
+ async addTrimmed(trimmed, trimmedType = 'external', type = 'rgRow') {
3357
+ const event = this.beforetrimmed.emit({
3358
+ trimmed,
3359
+ trimmedType,
3360
+ type,
3361
+ });
3362
+ if (event.defaultPrevented) {
3363
+ return event;
3364
+ }
3365
+ this.dataProvider.setTrimmed({ [trimmedType]: event.detail.trimmed }, type);
3366
+ this.aftertrimmed.emit();
3367
+ return event;
3368
+ }
3369
+ /** Scrolls view port to coordinate */
3370
+ async scrollToCoordinate(cell) {
3371
+ var _a;
3372
+ (_a = this.viewport) === null || _a === void 0 ? void 0 : _a.scrollToCell(cell);
3373
+ }
3374
+ /** Bring cell to edit mode */
3375
+ async setCellEdit(rgRow, prop, rowSource = 'rgRow') {
3376
+ var _a;
3377
+ const rgCol = ColumnDataProvider.getColumnByProp(this.columns, prop);
3378
+ if (!rgCol) {
3379
+ return;
3380
+ }
3381
+ await index.timeout();
3382
+ const colGroup = rgCol.pin || 'rgCol';
3383
+ (_a = this.viewport) === null || _a === void 0 ? void 0 : _a.setEdit(rgRow, this.columnProvider.getColumnIndexByProp(prop, colGroup), colGroup, rowSource);
3384
+ }
3385
+ /** Set focus range */
3386
+ async setCellsFocus(cellStart = { x: 0, y: 0 }, cellEnd = { x: 0, y: 0 }, colType = 'rgCol', rowType = 'rgRow') {
3387
+ var _a;
3388
+ (_a = this.viewport) === null || _a === void 0 ? void 0 : _a.setFocus(colType, rowType, cellStart, cellEnd);
3389
+ }
3390
+ /**
3391
+ * Register new virtual node inside of grid
3392
+ * Used for additional items creation such as plugin elements
3393
+ */
3394
+ async registerVNode(elements) {
3395
+ this.extraElements.push(...elements);
3396
+ this.extraElements = [...this.extraElements];
3397
+ }
3398
+ /** Get data from source */
3399
+ async getSource(type = 'rgRow') {
3400
+ return this.dataProvider.stores[type].store.get('source');
3401
+ }
3402
+ /**
3403
+ * Get data from visible part of source
3404
+ * Trimmed/filtered rows will be excluded
3405
+ * @param type - type of source
3406
+ */
3407
+ async getVisibleSource(type = 'rgRow') {
3408
+ return index.getVisibleSourceItem(this.dataProvider.stores[type].store);
3409
+ }
3410
+ /**
3411
+ * Provides access to rows internal store observer
3412
+ * Can be used for plugin support
3413
+ * @param type - type of source
3414
+ */
3415
+ async getSourceStore(type = 'rgRow') {
3416
+ return this.dataProvider.stores[type].store;
3417
+ }
3418
+ /**
3419
+ * Provides access to column internal store observer
3420
+ * Can be used for plugin support
3421
+ * @param type - type of column
3422
+ */
3423
+ async getColumnStore(type = 'rgCol') {
3424
+ return this.columnProvider.stores[type].store;
3425
+ }
3426
+ /**
3427
+ * Update column sorting
3428
+ * @param column - full column details to update
3429
+ * @param index - virtual column index
3430
+ * @param order - order to apply
3431
+ */
3432
+ async updateColumnSorting(column, index, order, additive) {
3433
+ return this.columnProvider.updateColumnSorting(column, index, order, additive);
3434
+ }
3435
+ /**
3436
+ * Clears column sorting
3437
+ */
3438
+ async clearSorting() {
3439
+ this.columnProvider.clearSorting();
3440
+ }
3441
+ /**
3442
+ * Receive all columns in data source
3443
+ */
3444
+ async getColumns() {
3445
+ return this.columnProvider.getColumns();
3446
+ }
3447
+ /**
3448
+ * Clear current grid focus
3449
+ */
3450
+ async clearFocus() {
3451
+ var _a;
3452
+ const focused = (_a = this.viewport) === null || _a === void 0 ? void 0 : _a.getFocused();
3453
+ const event = this.beforefocuslost.emit(focused);
3454
+ if (event.defaultPrevented) {
3455
+ return;
3456
+ }
3457
+ this.selectionStoreConnector.clearAll();
3458
+ }
3459
+ /**
3460
+ * Get all active plugins instances
3461
+ */
3462
+ async getPlugins() {
3463
+ return [...this.internalPlugins];
3464
+ }
3465
+ /**
3466
+ * Get the currently focused cell.
3467
+ */
3468
+ async getFocused() {
3469
+ var _a;
3470
+ return (_a = this.viewport) === null || _a === void 0 ? void 0 : _a.getFocused();
3471
+ }
3472
+ /**
3473
+ * Get size of content
3474
+ * Including all pinned data
3475
+ */
3476
+ async getContentSize() {
3477
+ var _a;
3478
+ return (_a = this.dimensionProvider) === null || _a === void 0 ? void 0 : _a.getFullSize();
3479
+ }
3480
+ /**
3481
+ * Get the currently selected Range.
3482
+ */
3483
+ async getSelectedRange() {
3484
+ var _a;
3485
+ return (_a = this.viewport) === null || _a === void 0 ? void 0 : _a.getSelectedRange();
3486
+ }
3487
+ mousedownHandle(event) {
3488
+ const screenX = events.getFromEvent(event, 'screenX');
3489
+ const screenY = events.getFromEvent(event, 'screenY');
3490
+ if (screenX === null || screenY === null) {
3491
+ return;
3492
+ }
3493
+ this.clickTrackForFocusClear = screenX + screenY;
3494
+ }
3495
+ mouseupHandle(event) {
3496
+ const screenX = events.getFromEvent(event, 'screenX');
3497
+ const screenY = events.getFromEvent(event, 'screenY');
3498
+ if (screenX === null || screenY === null) {
3499
+ return;
3500
+ }
3501
+ if (event.defaultPrevented) {
3502
+ return;
3503
+ }
3504
+ const target = event.target;
3505
+ const pos = screenX + screenY;
3506
+ // detect if mousemove then do nothing
3507
+ if (Math.abs(this.clickTrackForFocusClear - pos) > 10) {
3508
+ return;
3509
+ }
3510
+ // check if action finished inside of the document
3511
+ // clear data which is outside of grid
3512
+ // if event prevented or it is current table don't clear focus
3513
+ if (target === null || target === void 0 ? void 0 : target.closest(`[${index.UUID}="${this.uuid}"]`)) {
3514
+ return;
3515
+ }
3516
+ this.clearFocus();
3517
+ }
3518
+ // --------------------------------------------------------------------------
3519
+ //
3520
+ // Listeners
3521
+ //
3522
+ // --------------------------------------------------------------------------
3523
+ /** DRAG AND DROP */
3524
+ onRowDragStarted(e) {
3525
+ var _a;
3526
+ // e.cancelBubble = true;
3527
+ const dragStart = this.rowdragstart.emit(e.detail);
3528
+ if (dragStart.defaultPrevented) {
3529
+ e.preventDefault();
3530
+ return;
3531
+ }
3532
+ (_a = this.orderService) === null || _a === void 0 ? void 0 : _a.start(this.element, Object.assign(Object.assign({}, e.detail), dragStart.detail));
3533
+ }
3534
+ onRowDragEnd() {
3535
+ var _a;
3536
+ (_a = this.orderService) === null || _a === void 0 ? void 0 : _a.end();
3537
+ }
3538
+ onRowDrag({ detail }) {
3539
+ var _a;
3540
+ (_a = this.orderService) === null || _a === void 0 ? void 0 : _a.move(detail);
3541
+ }
3542
+ onRowMouseMove(e) {
3543
+ var _a;
3544
+ // e.cancelBubble = true;
3545
+ (_a = this.orderService) === null || _a === void 0 ? void 0 : _a.moveTip(e.detail);
3546
+ }
3547
+ async onBeforeEdit(e) {
3548
+ // e.cancelBubble = true;
3549
+ const { defaultPrevented, detail } = this.beforeedit.emit(e.detail);
3550
+ await index.timeout();
3551
+ // apply data
3552
+ if (!defaultPrevented) {
3553
+ this.dataProvider.setCellData(detail);
3554
+ this.afteredit.emit(detail);
3555
+ }
3556
+ }
3557
+ onBeforeRangeEdit(e) {
3558
+ // e.cancelBubble = true;
3559
+ const { defaultPrevented, detail } = this.beforerangeedit.emit(e.detail);
3560
+ if (defaultPrevented) {
3561
+ e.preventDefault();
3562
+ return;
3563
+ }
3564
+ this.afteredit.emit(detail);
3565
+ }
3566
+ onRangeChanged(e) {
3567
+ // e.cancelBubble = true;
3568
+ const beforeange = this.beforeange.emit(e.detail);
3569
+ if (beforeange.defaultPrevented) {
3570
+ e.preventDefault();
3571
+ }
3572
+ const beforeFill = this.beforeautofill.emit(beforeange.detail);
3573
+ if (beforeFill.defaultPrevented) {
3574
+ e.preventDefault();
3575
+ }
3576
+ }
3577
+ onRowDropped(e) {
3578
+ // e.cancelBubble = true;
3579
+ const { defaultPrevented } = this.roworderchanged.emit(e.detail);
3580
+ if (defaultPrevented) {
3581
+ e.preventDefault();
3582
+ }
3583
+ }
3584
+ onHeaderClick(e) {
3585
+ const { defaultPrevented } = this.headerclick.emit(Object.assign(Object.assign({}, e.detail.column), { originalEvent: e.detail.originalEvent }));
3586
+ if (defaultPrevented) {
3587
+ e.preventDefault();
3588
+ }
3589
+ }
3590
+ onCellFocus(e) {
3591
+ // e.cancelBubble = true;
3592
+ const { defaultPrevented } = this.beforecellfocus.emit(e.detail);
3593
+ if (!this.canFocus || defaultPrevented) {
3594
+ e.preventDefault();
3595
+ }
3596
+ }
3597
+ /**
3598
+ * Column format change will trigger column structure update
3599
+ */
3600
+ columnTypesChanged() {
3601
+ this.columnChanged(this.columns);
3602
+ }
3603
+ columnChanged(newVal = []) {
3604
+ // clear existing data
3605
+ this.dimensionProvider.dropColumns();
3606
+ const columnGather = ColumnDataProvider.getColumns(newVal, 0, this.columnTypes);
3607
+ this.beforecolumnsset.emit(columnGather);
3608
+ for (let type of columnTypes) {
3609
+ const items = columnGather.columns[type];
3610
+ this.dimensionProvider.setNewColumns(type, items.length, ColumnDataProvider.getSizes(items), type !== 'rgCol');
3611
+ }
3612
+ this.beforecolumnapplied.emit(columnGather);
3613
+ const columns = this.columnProvider.setColumns(columnGather);
3614
+ this.aftercolumnsset.emit({
3615
+ columns,
3616
+ order: this.columnProvider.order,
3617
+ });
3618
+ }
3619
+ rowSizeChanged(s) {
3620
+ this.dimensionProvider.setSettings({ originItemSize: s }, 'rgRow');
3621
+ rowTypes.forEach((t) => {
3622
+ this.dimensionProvider.clearSize(t, this.dataProvider.stores[t].store.get('source').length);
3623
+ this.dimensionProvider.setCustomSizes(t, {}, true);
3624
+ });
3625
+ }
3626
+ themeChanged(t) {
3627
+ this.themeService.register(t);
3628
+ this.dimensionProvider.setSettings({ originItemSize: this.themeService.rowSize }, 'rgRow');
3629
+ this.dimensionProvider.setSettings({ originItemSize: this.colSize }, 'rgCol');
3630
+ }
3631
+ dataSourceChanged(newVal = [], _, watchName) {
3632
+ let type = 'rgRow';
3633
+ switch (watchName) {
3634
+ case 'pinnedBottomSource':
3635
+ type = 'rowPinEnd';
3636
+ break;
3637
+ case 'pinnedTopSource':
3638
+ type = 'rowPinStart';
3639
+ break;
3640
+ case 'source':
3641
+ type = 'rgRow';
3642
+ /** applied for source only for cross compatability between plugins */
3643
+ const beforesourceset = this.beforesourceset.emit({
3644
+ type,
3645
+ source: newVal,
3646
+ });
3647
+ newVal = beforesourceset.detail.source;
3648
+ break;
3649
+ }
3650
+ const beforesourceset = this.beforeAnySource.emit({
3651
+ type,
3652
+ source: newVal,
3653
+ });
3654
+ const newSource = [...beforesourceset.detail.source];
3655
+ this.dataProvider.setData(newSource, type);
3656
+ /** applied for source only for cross compatability between plugins */
3657
+ if (watchName === 'source') {
3658
+ this.aftersourceset.emit({
3659
+ type,
3660
+ source: newVal,
3661
+ });
3662
+ }
3663
+ this.afterAnySource.emit({
3664
+ type,
3665
+ source: newVal,
3666
+ });
3667
+ }
3668
+ rowDefChanged(after, before) {
3669
+ const { detail: { vals: newVal, oldVals: oldVal } } = this.beforerowdefinition.emit({
3670
+ vals: after,
3671
+ oldVals: before
3672
+ });
3673
+ // apply new vals
3674
+ const newRows = rowDefinitionByType(newVal);
3675
+ // clear current defs
3676
+ if (oldVal) {
3677
+ const remove = rowDefinitionRemoveByType(oldVal);
3678
+ // clear all old data and drop sizes
3679
+ index.each(remove, (_, t) => {
3680
+ this.dimensionProvider.clearSize(t, this.dataProvider.stores[t].store.get('source').length);
3681
+ });
3682
+ }
3683
+ if (!newVal.length) {
3684
+ return;
3685
+ }
3686
+ index.each(newRows, (r, k) => this.dimensionProvider.setCustomSizes(k, r.sizes || {}));
3687
+ }
3688
+ trimmedRowsChanged(newVal = {}) {
3689
+ this.addTrimmed(newVal);
3690
+ }
3691
+ /**
3692
+ * Grouping
3693
+ */
3694
+ groupingChanged(newVal = {}) {
3695
+ let grPlugin;
3696
+ for (let p of this.internalPlugins) {
3697
+ const isGrouping = p;
3698
+ if (isGrouping.setGrouping) {
3699
+ grPlugin = isGrouping;
3700
+ break;
3701
+ }
3702
+ }
3703
+ if (!grPlugin) {
3704
+ return;
3705
+ }
3706
+ grPlugin.setGrouping(newVal || {});
3707
+ }
3708
+ /**
3709
+ * Stretch Plugin Apply
3710
+ */
3711
+ applyStretch(isStretch) {
3712
+ if (isStretch === 'false') {
3713
+ isStretch = false;
3714
+ }
3715
+ let stretch = this.internalPlugins.filter(p => isStretchPlugin(p))[0];
3716
+ if ((typeof isStretch === 'boolean' && isStretch) || isStretch === 'true') {
3717
+ if (!stretch) {
3718
+ this.internalPlugins.push(new StretchColumn(this.element, {
3719
+ dataProvider: this.dataProvider,
3720
+ columnProvider: this.columnProvider,
3721
+ dimensionProvider: this.dimensionProvider,
3722
+ }));
3723
+ }
3724
+ else if (isStretchPlugin(stretch)) {
3725
+ stretch.applyStretch(this.columnProvider.getRawColumns());
3726
+ }
3727
+ }
3728
+ else if (stretch) {
3729
+ const index = this.internalPlugins.indexOf(stretch);
3730
+ this.internalPlugins.splice(index, 1);
3731
+ }
3732
+ }
3733
+ applyFilter(cfg) {
3734
+ this.filterconfigchanged.emit(cfg);
3735
+ }
3736
+ rowHeadersChange(rowHeaders) {
3737
+ this.rowheaderschanged.emit(rowHeaders);
3738
+ }
3739
+ connectedCallback() {
3740
+ this.viewportProvider = new ViewportProvider();
3741
+ this.themeService = new ThemeService({
3742
+ rowSize: this.rowSize,
3743
+ });
3744
+ const dimensionProviderConfig = {
3745
+ realSizeChanged: (k) => this.contentsizechanged.emit(k),
3746
+ };
3747
+ this.dimensionProvider = new DimensionProvider(this.viewportProvider, dimensionProviderConfig);
3748
+ this.columnProvider = new ColumnDataProvider();
3749
+ this.selectionStoreConnector = new viewport_helpers.SelectionStoreConnector();
3750
+ this.dataProvider = new DataProvider(this.dimensionProvider);
3751
+ this.uuid = `${new Date().getTime()}-rvgrid`;
3752
+ const pluginData = {
3753
+ data: this.dataProvider,
3754
+ column: this.columnProvider,
3755
+ dimension: this.dimensionProvider,
3756
+ viewport: this.viewportProvider,
3757
+ selection: this.selectionStoreConnector,
3758
+ };
3759
+ if (this.autoSizeColumn) {
3760
+ this.internalPlugins.push(new AutoSizeColumn(this.element, {
3761
+ dataProvider: this.dataProvider,
3762
+ columnProvider: this.columnProvider,
3763
+ dimensionProvider: this.dimensionProvider,
3764
+ }, typeof this.autoSizeColumn === 'object' ? this.autoSizeColumn : undefined));
3765
+ }
3766
+ if (this.filter) {
3767
+ this.internalPlugins.push(new FilterPlugin(this.element, this.uuid, typeof this.filter === 'object' ? this.filter : undefined));
3768
+ }
3769
+ if (this.exporting) {
3770
+ this.internalPlugins.push(new ExportFilePlugin(this.element));
3771
+ }
3772
+ this.internalPlugins.push(new SortingPlugin(this.element));
3773
+ this.internalPlugins.push(new GroupingRowPlugin(this.element, {
3774
+ dataProvider: this.dataProvider,
3775
+ columnProvider: this.columnProvider,
3776
+ }));
3777
+ if (this.canMoveColumns) {
3778
+ this.internalPlugins.push(new ColumnPlugin(this.element, pluginData));
3779
+ }
3780
+ if (this.plugins) {
3781
+ this.plugins.forEach(p => {
3782
+ this.internalPlugins.push(new p(this.element, pluginData));
3783
+ });
3784
+ }
3785
+ this.applyStretch(this.stretch);
3786
+ this.themeChanged(this.theme);
3787
+ this.columnChanged(this.columns);
3788
+ this.dataSourceChanged(this.source, undefined, 'source');
3789
+ this.dataSourceChanged(this.pinnedTopSource, undefined, 'pinnedTopSource');
3790
+ this.dataSourceChanged(this.pinnedBottomSource, undefined, 'pinnedBottomSource');
3791
+ this.trimmedRowsChanged(this.trimmedRows);
3792
+ this.rowDefChanged(this.rowDefinitions);
3793
+ this.groupingChanged(this.grouping);
3794
+ this.scrollingService = new GridScrollingService((e) => {
3795
+ this.dimensionProvider.setViewPortCoordinate({
3796
+ coordinate: e.coordinate,
3797
+ type: e.dimension,
3798
+ });
3799
+ this.viewportscroll.emit(e);
3800
+ });
3801
+ }
3802
+ disconnectedCallback() {
3803
+ // destroy plugins on element disconnect
3804
+ index.each(this.internalPlugins, p => p.destroy());
3805
+ this.internalPlugins = [];
3806
+ }
3807
+ render() {
3808
+ const contentHeight = this.dimensionProvider.stores['rgRow'].store.get('realSize');
3809
+ this.viewport = new ViewportService({
3810
+ columnProvider: this.columnProvider,
3811
+ dataProvider: this.dataProvider,
3812
+ dimensionProvider: this.dimensionProvider,
3813
+ viewportProvider: this.viewportProvider,
3814
+ uuid: this.uuid,
3815
+ scrollingService: this.scrollingService,
3816
+ orderService: this.orderService,
3817
+ selectionStoreConnector: this.selectionStoreConnector,
3818
+ resize: c => this.aftercolumnresize.emit(c),
3819
+ }, contentHeight);
3820
+ const views = [];
3821
+ if (this.rowHeaders && this.viewport.columns.length) {
3822
+ const anyView = this.viewport.columns[0];
3823
+ views.push(index$1.h("revogr-row-headers", { additionalData: this.additionalData, height: contentHeight, rowClass: this.rowClass, resize: this.resize, dataPorts: anyView.dataPorts, headerProp: anyView.headerProp, uiid: anyView.prop[index.UUID], rowHeaderColumn: typeof this.rowHeaders === 'object' ? this.rowHeaders : undefined, onScrollViewport: ({ detail: e }) => this.scrollingService.scrollService(e, 'headerRow'), onElementToScroll: ({ detail: e }) => this.scrollingService.registerElement(e, 'headerRow') }));
3824
+ }
3825
+ views.push(index$1.h(ViewPortSections, { additionalData: this.additionalData, columnFilter: !!this.filter, resize: this.resize, readonly: this.readonly, range: this.range, rowClass: this.rowClass, editors: this.editors, applyEditorChangesOnClose: this.applyOnClose, useClipboard: this.useClipboard, columns: this.viewport.columns, onSelectAll: () => {
3826
+ this.selectionStoreConnector.selectAll();
3827
+ }, onEdit: detail => {
3828
+ const event = this.beforeeditstart.emit(detail);
3829
+ if (!event.defaultPrevented) {
3830
+ this.selectionStoreConnector.setEdit(detail.val);
3831
+ }
3832
+ }, onCancelEdit: () => {
3833
+ this.selectionStoreConnector.setEdit(false);
3834
+ }, registerElement: (e, k) => this.scrollingService.registerElement(e, k), scrollSection: (details, k) => this.scrollingService.scrollService(details, k), scrollSectionSilent: (details, k) => this.scrollingService.scrollSilentService(details, k), focusTemplate: this.focusTemplate }));
3835
+ return (index$1.h(index$1.Host, Object.assign({}, { [`${index.UUID}`]: this.uuid }), index$1.h(RevoViewPort, { viewports: this.viewportProvider.stores, dimensions: this.dimensionProvider.stores, orderRef: e => (this.orderService = e), registerElement: (e, k) => this.scrollingService.registerElement(e, k), nakedClick: () => this.viewport.clearEdit(), onScroll: details => this.scrollingService.scrollService(details) }, views), this.extraElements));
3836
+ }
3837
+ get element() { return index$1.getElement(this); }
3838
+ static get watchers() { return {
3839
+ "columnTypes": ["columnTypesChanged"],
3840
+ "columns": ["columnChanged"],
3841
+ "rowSize": ["rowSizeChanged"],
3842
+ "theme": ["themeChanged"],
3843
+ "source": ["dataSourceChanged"],
3844
+ "pinnedBottomSource": ["dataSourceChanged"],
3845
+ "pinnedTopSource": ["dataSourceChanged"],
3846
+ "rowDefinitions": ["rowDefChanged"],
3847
+ "trimmedRows": ["trimmedRowsChanged"],
3848
+ "grouping": ["groupingChanged"],
3849
+ "stretch": ["applyStretch"],
3850
+ "filter": ["applyFilter"],
3851
+ "rowHeaders": ["rowHeadersChange"]
3852
+ }; }
3853
+ };
3854
+ RevoGridComponent.style = revoGridStyleCss;
3855
+
3856
+ exports.revo_grid = RevoGridComponent;
3857
+
3858
+ //# sourceMappingURL=revo-grid.cjs.entry.js.map