@revolist/revogrid 4.0.2-next → 4.0.2

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