@elliemae/ds-shared 3.0.0-next.1 → 3.0.0-next.10

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 (312) hide show
  1. package/dist/cjs/Animations/BaseAnimation.js +56 -0
  2. package/dist/cjs/Animations/BaseAnimation.js.map +7 -0
  3. package/dist/cjs/Animations/Grow.js +55 -0
  4. package/dist/cjs/Animations/Grow.js.map +7 -0
  5. package/dist/cjs/Animations/GrowRight.js +64 -0
  6. package/dist/cjs/Animations/GrowRight.js.map +7 -0
  7. package/dist/cjs/Animations/GrowVertical.js +47 -0
  8. package/dist/cjs/Animations/GrowVertical.js.map +7 -0
  9. package/dist/cjs/CheckableGroup.js +92 -0
  10. package/dist/cjs/CheckableGroup.js.map +7 -0
  11. package/dist/cjs/DeferRenderAfterComputation.js +52 -0
  12. package/dist/cjs/DeferRenderAfterComputation.js.map +7 -0
  13. package/dist/cjs/FocusGroup/FocusGrid.js +193 -0
  14. package/dist/cjs/FocusGroup/FocusGrid.js.map +7 -0
  15. package/dist/cjs/FocusGroup/FocusGroup.js +262 -0
  16. package/dist/cjs/FocusGroup/FocusGroup.js.map +7 -0
  17. package/dist/cjs/FocusGroup/FocusGroupContext.js +38 -0
  18. package/dist/cjs/FocusGroup/FocusGroupContext.js.map +7 -0
  19. package/dist/cjs/FocusGroup/FocusGroupManager.js +126 -0
  20. package/dist/cjs/FocusGroup/FocusGroupManager.js.map +7 -0
  21. package/dist/cjs/FocusGroup/focusGroupManagerHoc.js +82 -0
  22. package/dist/cjs/FocusGroup/focusGroupManagerHoc.js.map +7 -0
  23. package/dist/cjs/FocusGroup/index.js +47 -0
  24. package/dist/cjs/FocusGroup/index.js.map +7 -0
  25. package/dist/cjs/FocusGroup/useFocusGroupItem.js +81 -0
  26. package/dist/cjs/FocusGroup/useFocusGroupItem.js.map +7 -0
  27. package/dist/cjs/FocusGroup/utils/getNextCellPosition.js +80 -0
  28. package/dist/cjs/FocusGroup/utils/getNextCellPosition.js.map +7 -0
  29. package/dist/cjs/GroupContext/Group.js +115 -0
  30. package/dist/cjs/GroupContext/Group.js.map +7 -0
  31. package/dist/cjs/GroupContext/GroupContext.js +36 -0
  32. package/dist/cjs/GroupContext/GroupContext.js.map +7 -0
  33. package/dist/cjs/GroupContext/GroupItem.js +40 -0
  34. package/dist/cjs/GroupContext/GroupItem.js.map +7 -0
  35. package/dist/cjs/GroupContext/index.js +39 -0
  36. package/dist/cjs/GroupContext/index.js.map +7 -0
  37. package/dist/cjs/ScrollSync/ScrollSync.js +138 -0
  38. package/dist/cjs/ScrollSync/ScrollSync.js.map +7 -0
  39. package/dist/cjs/ScrollSync/ScrollSyncPane.js +89 -0
  40. package/dist/cjs/ScrollSync/ScrollSyncPane.js.map +7 -0
  41. package/dist/cjs/ScrollSync/ScrollSyncProvider.js +120 -0
  42. package/dist/cjs/ScrollSync/ScrollSyncProvider.js.map +7 -0
  43. package/dist/cjs/ScrollSync/index.js +37 -0
  44. package/dist/cjs/ScrollSync/index.js.map +7 -0
  45. package/dist/cjs/ScrollSync/useScrollSync.js +41 -0
  46. package/dist/cjs/ScrollSync/useScrollSync.js.map +7 -0
  47. package/dist/cjs/constants.js +70 -0
  48. package/dist/cjs/constants.js.map +7 -0
  49. package/dist/cjs/createDataInstance/createInstancePlugin.js +62 -0
  50. package/dist/cjs/createDataInstance/createInstancePlugin.js.map +7 -0
  51. package/dist/cjs/createDataInstance/createInstanceRef.js +124 -0
  52. package/dist/cjs/createDataInstance/createInstanceRef.js.map +7 -0
  53. package/dist/cjs/createDataInstance/utils.js +104 -0
  54. package/dist/cjs/createDataInstance/utils.js.map +7 -0
  55. package/dist/cjs/defer-render-hoc/index.js +68 -0
  56. package/dist/cjs/defer-render-hoc/index.js.map +7 -0
  57. package/dist/cjs/dimsum.config.js +39 -0
  58. package/dist/cjs/dimsum.config.js.map +7 -0
  59. package/dist/cjs/index.js +40 -0
  60. package/dist/cjs/index.js.map +7 -0
  61. package/dist/cjs/prop-types.js +116 -0
  62. package/dist/cjs/prop-types.js.map +7 -0
  63. package/dist/cjs/react-spring/index.js +28 -0
  64. package/dist/cjs/react-spring/index.js.map +7 -0
  65. package/dist/cjs/react-spring/renderprops.js +28 -0
  66. package/dist/cjs/react-spring/renderprops.js.map +7 -0
  67. package/dist/cjs/toolbar/ToolbarProvider.js +126 -0
  68. package/dist/cjs/toolbar/ToolbarProvider.js.map +7 -0
  69. package/dist/cjs/useDataGrid/VolatileRowsListener.js +49 -0
  70. package/dist/cjs/useDataGrid/VolatileRowsListener.js.map +7 -0
  71. package/dist/cjs/useDataGrid/index.js +36 -0
  72. package/dist/cjs/useDataGrid/index.js.map +7 -0
  73. package/dist/cjs/useDataGrid/initColumnDefinition.js +147 -0
  74. package/dist/cjs/useDataGrid/initColumnDefinition.js.map +7 -0
  75. package/dist/cjs/useDataGrid/useDataGrid.js +216 -0
  76. package/dist/cjs/useDataGrid/useDataGrid.js.map +7 -0
  77. package/dist/cjs/useDataList/index.js +36 -0
  78. package/dist/cjs/useDataList/index.js.map +7 -0
  79. package/dist/cjs/useDataList/recordIterator.js +55 -0
  80. package/dist/cjs/useDataList/recordIterator.js.map +7 -0
  81. package/dist/cjs/useDataList/useDataList.js +126 -0
  82. package/dist/cjs/useDataList/useDataList.js.map +7 -0
  83. package/dist/cjs/utils.js +123 -0
  84. package/dist/cjs/utils.js.map +7 -0
  85. package/dist/cjs/virtualization/AutoHeightList.js +106 -0
  86. package/dist/cjs/virtualization/AutoHeightList.js.map +7 -0
  87. package/dist/cjs/virtualization/FluidHeightList.js +74 -0
  88. package/dist/cjs/virtualization/FluidHeightList.js.map +7 -0
  89. package/dist/cjs/virtualization/index.js +50 -0
  90. package/dist/cjs/virtualization/index.js.map +7 -0
  91. package/dist/esm/Animations/BaseAnimation.js +27 -0
  92. package/dist/esm/Animations/BaseAnimation.js.map +7 -0
  93. package/dist/esm/Animations/Grow.js +26 -0
  94. package/dist/esm/Animations/Grow.js.map +7 -0
  95. package/dist/esm/Animations/GrowRight.js +35 -0
  96. package/dist/esm/Animations/GrowRight.js.map +7 -0
  97. package/dist/esm/Animations/GrowVertical.js +29 -0
  98. package/dist/esm/Animations/GrowVertical.js.map +7 -0
  99. package/dist/esm/CheckableGroup.js +65 -0
  100. package/dist/esm/CheckableGroup.js.map +7 -0
  101. package/dist/esm/DeferRenderAfterComputation.js +23 -0
  102. package/dist/esm/DeferRenderAfterComputation.js.map +7 -0
  103. package/dist/esm/FocusGroup/FocusGrid.js +166 -0
  104. package/dist/esm/FocusGroup/FocusGrid.js.map +7 -0
  105. package/{esm → dist/esm}/FocusGroup/FocusGroup.js +70 -136
  106. package/dist/esm/FocusGroup/FocusGroup.js.map +7 -0
  107. package/dist/esm/FocusGroup/FocusGroupContext.js +9 -0
  108. package/dist/esm/FocusGroup/FocusGroupContext.js.map +7 -0
  109. package/{esm → dist/esm}/FocusGroup/FocusGroupManager.js +24 -38
  110. package/dist/esm/FocusGroup/FocusGroupManager.js.map +7 -0
  111. package/dist/esm/FocusGroup/focusGroupManagerHoc.js +55 -0
  112. package/dist/esm/FocusGroup/focusGroupManagerHoc.js.map +7 -0
  113. package/dist/esm/FocusGroup/index.js +18 -0
  114. package/dist/esm/FocusGroup/index.js.map +7 -0
  115. package/dist/esm/FocusGroup/useFocusGroupItem.js +53 -0
  116. package/dist/esm/FocusGroup/useFocusGroupItem.js.map +7 -0
  117. package/{esm → dist/esm}/FocusGroup/utils/getNextCellPosition.js +18 -25
  118. package/dist/esm/FocusGroup/utils/getNextCellPosition.js.map +7 -0
  119. package/dist/esm/GroupContext/Group.js +86 -0
  120. package/dist/esm/GroupContext/Group.js.map +7 -0
  121. package/dist/esm/GroupContext/GroupContext.js +7 -0
  122. package/dist/esm/GroupContext/GroupContext.js.map +7 -0
  123. package/dist/esm/GroupContext/GroupItem.js +11 -0
  124. package/dist/esm/GroupContext/GroupItem.js.map +7 -0
  125. package/dist/esm/GroupContext/index.js +10 -0
  126. package/dist/esm/GroupContext/index.js.map +7 -0
  127. package/{esm → dist/esm}/ScrollSync/ScrollSync.js +30 -64
  128. package/dist/esm/ScrollSync/ScrollSync.js.map +7 -0
  129. package/dist/esm/ScrollSync/ScrollSyncPane.js +62 -0
  130. package/dist/esm/ScrollSync/ScrollSyncPane.js.map +7 -0
  131. package/dist/esm/ScrollSync/ScrollSyncProvider.js +91 -0
  132. package/dist/esm/ScrollSync/ScrollSyncProvider.js.map +7 -0
  133. package/dist/esm/ScrollSync/index.js +8 -0
  134. package/dist/esm/ScrollSync/index.js.map +7 -0
  135. package/dist/esm/ScrollSync/useScrollSync.js +12 -0
  136. package/dist/esm/ScrollSync/useScrollSync.js.map +7 -0
  137. package/dist/esm/constants.js +41 -0
  138. package/dist/esm/constants.js.map +7 -0
  139. package/dist/esm/createDataInstance/createInstancePlugin.js +35 -0
  140. package/dist/esm/createDataInstance/createInstancePlugin.js.map +7 -0
  141. package/dist/esm/createDataInstance/createInstanceRef.js +101 -0
  142. package/dist/esm/createDataInstance/createInstanceRef.js.map +7 -0
  143. package/dist/esm/createDataInstance/utils.js +77 -0
  144. package/dist/esm/createDataInstance/utils.js.map +7 -0
  145. package/dist/esm/defer-render-hoc/index.js +41 -0
  146. package/dist/esm/defer-render-hoc/index.js.map +7 -0
  147. package/dist/esm/dimsum.config.js +10 -0
  148. package/dist/esm/dimsum.config.js.map +7 -0
  149. package/dist/esm/index.js +11 -0
  150. package/dist/esm/index.js.map +7 -0
  151. package/dist/esm/prop-types.js +87 -0
  152. package/dist/esm/prop-types.js.map +7 -0
  153. package/dist/esm/react-spring/index.js +3 -0
  154. package/dist/esm/react-spring/index.js.map +7 -0
  155. package/dist/esm/react-spring/renderprops.js +3 -0
  156. package/dist/esm/react-spring/renderprops.js.map +7 -0
  157. package/dist/esm/toolbar/ToolbarProvider.js +99 -0
  158. package/dist/esm/toolbar/ToolbarProvider.js.map +7 -0
  159. package/dist/esm/useDataGrid/VolatileRowsListener.js +20 -0
  160. package/dist/esm/useDataGrid/VolatileRowsListener.js.map +7 -0
  161. package/dist/esm/useDataGrid/index.js +7 -0
  162. package/dist/esm/useDataGrid/index.js.map +7 -0
  163. package/dist/esm/useDataGrid/initColumnDefinition.js +126 -0
  164. package/dist/esm/useDataGrid/initColumnDefinition.js.map +7 -0
  165. package/dist/esm/useDataGrid/useDataGrid.js +201 -0
  166. package/dist/esm/useDataGrid/useDataGrid.js.map +7 -0
  167. package/dist/esm/useDataList/index.js +7 -0
  168. package/dist/esm/useDataList/index.js.map +7 -0
  169. package/dist/esm/useDataList/recordIterator.js +26 -0
  170. package/dist/esm/useDataList/recordIterator.js.map +7 -0
  171. package/dist/esm/useDataList/useDataList.js +102 -0
  172. package/dist/esm/useDataList/useDataList.js.map +7 -0
  173. package/dist/esm/utils.js +96 -0
  174. package/dist/esm/utils.js.map +7 -0
  175. package/dist/esm/virtualization/AutoHeightList.js +79 -0
  176. package/dist/esm/virtualization/AutoHeightList.js.map +7 -0
  177. package/dist/esm/virtualization/FluidHeightList.js +47 -0
  178. package/dist/esm/virtualization/FluidHeightList.js.map +7 -0
  179. package/dist/esm/virtualization/index.js +21 -0
  180. package/dist/esm/virtualization/index.js.map +7 -0
  181. package/package.json +119 -110
  182. package/cjs/Animations/BaseAnimation.js +0 -36
  183. package/cjs/Animations/Grow.js +0 -42
  184. package/cjs/Animations/GrowRight.js +0 -42
  185. package/cjs/Animations/GrowVertical.js +0 -7
  186. package/cjs/CheckableGroup.js +0 -74
  187. package/cjs/DeferRenderAfterComputation.js +0 -28
  188. package/cjs/FocusGroup/FocusGrid.js +0 -215
  189. package/cjs/FocusGroup/FocusGroup.js +0 -308
  190. package/cjs/FocusGroup/FocusGroupContext.js +0 -11
  191. package/cjs/FocusGroup/FocusGroupManager.js +0 -117
  192. package/cjs/FocusGroup/focusGroupManagerHoc.js +0 -44
  193. package/cjs/FocusGroup/index.js +0 -21
  194. package/cjs/FocusGroup/useFocusGroupItem.js +0 -59
  195. package/cjs/FocusGroup/utils/getNextCellPosition.js +0 -60
  196. package/cjs/GroupContext/Group.js +0 -124
  197. package/cjs/GroupContext/GroupContext.js +0 -13
  198. package/cjs/GroupContext/GroupItem.js +0 -22
  199. package/cjs/GroupContext/index.js +0 -13
  200. package/cjs/ScrollSync/ScrollSync.js +0 -153
  201. package/cjs/ScrollSync/ScrollSyncPane.js +0 -81
  202. package/cjs/ScrollSync/ScrollSyncProvider.js +0 -67
  203. package/cjs/ScrollSync/index.js +0 -11
  204. package/cjs/ScrollSync/useScrollSync.js +0 -10
  205. package/cjs/constants.js +0 -51
  206. package/cjs/createDataInstance/createInstancePlugin.js +0 -36
  207. package/cjs/createDataInstance/createInstanceRef.js +0 -97
  208. package/cjs/createDataInstance/utils.js +0 -123
  209. package/cjs/defer-render-hoc/index.js +0 -49
  210. package/cjs/dimsum.config.js +0 -7
  211. package/cjs/index.js +0 -17
  212. package/cjs/prop-types.js +0 -59
  213. package/cjs/react-spring/index.js +0 -14
  214. package/cjs/react-spring/renderprops.js +0 -14
  215. package/cjs/toolbar/ToolbarProvider.js +0 -123
  216. package/cjs/useDataGrid/VolatileRowsListener.js +0 -24
  217. package/cjs/useDataGrid/index.js +0 -7
  218. package/cjs/useDataGrid/initColumnDefinition.js +0 -146
  219. package/cjs/useDataGrid/useDataGrid.js +0 -220
  220. package/cjs/useDataList/index.js +0 -7
  221. package/cjs/useDataList/recordIterator.js +0 -31
  222. package/cjs/useDataList/useDataList.js +0 -102
  223. package/cjs/utils.js +0 -116
  224. package/cjs/virtualization/AutoHeightList.js +0 -61
  225. package/cjs/virtualization/FluidHeightList.js +0 -49
  226. package/cjs/virtualization/index.js +0 -22
  227. package/esm/Animations/BaseAnimation.js +0 -30
  228. package/esm/Animations/Grow.js +0 -36
  229. package/esm/Animations/GrowRight.js +0 -36
  230. package/esm/Animations/GrowVertical.js +0 -4
  231. package/esm/CheckableGroup.js +0 -64
  232. package/esm/DeferRenderAfterComputation.js +0 -22
  233. package/esm/FocusGroup/FocusGrid.js +0 -204
  234. package/esm/FocusGroup/FocusGroupContext.js +0 -5
  235. package/esm/FocusGroup/focusGroupManagerHoc.js +0 -37
  236. package/esm/FocusGroup/index.js +0 -6
  237. package/esm/FocusGroup/useFocusGroupItem.js +0 -50
  238. package/esm/GroupContext/Group.js +0 -118
  239. package/esm/GroupContext/GroupContext.js +0 -5
  240. package/esm/GroupContext/GroupItem.js +0 -16
  241. package/esm/GroupContext/index.js +0 -3
  242. package/esm/ScrollSync/ScrollSyncPane.js +0 -74
  243. package/esm/ScrollSync/ScrollSyncProvider.js +0 -59
  244. package/esm/ScrollSync/index.js +0 -2
  245. package/esm/ScrollSync/useScrollSync.js +0 -8
  246. package/esm/constants.js +0 -32
  247. package/esm/createDataInstance/createInstancePlugin.js +0 -30
  248. package/esm/createDataInstance/createInstanceRef.js +0 -90
  249. package/esm/createDataInstance/utils.js +0 -107
  250. package/esm/defer-render-hoc/index.js +0 -41
  251. package/esm/dimsum.config.js +0 -5
  252. package/esm/index.js +0 -5
  253. package/esm/prop-types.js +0 -43
  254. package/esm/react-spring/index.js +0 -1
  255. package/esm/react-spring/renderprops.js +0 -1
  256. package/esm/toolbar/ToolbarProvider.js +0 -111
  257. package/esm/useDataGrid/VolatileRowsListener.js +0 -22
  258. package/esm/useDataGrid/index.js +0 -1
  259. package/esm/useDataGrid/initColumnDefinition.js +0 -134
  260. package/esm/useDataGrid/useDataGrid.js +0 -194
  261. package/esm/useDataList/index.js +0 -1
  262. package/esm/useDataList/recordIterator.js +0 -27
  263. package/esm/useDataList/useDataList.js +0 -90
  264. package/esm/utils.js +0 -95
  265. package/esm/virtualization/AutoHeightList.js +0 -52
  266. package/esm/virtualization/FluidHeightList.js +0 -38
  267. package/esm/virtualization/index.js +0 -18
  268. package/types/Animations/BaseAnimation.d.ts +0 -12
  269. package/types/Animations/Grow.d.ts +0 -11
  270. package/types/Animations/GrowRight.d.ts +0 -11
  271. package/types/Animations/GrowVertical.d.ts +0 -1
  272. package/types/CheckableGroup.d.ts +0 -20
  273. package/types/DeferRenderAfterComputation.d.ts +0 -6
  274. package/types/FocusGroup/FocusGrid.d.ts +0 -10
  275. package/types/FocusGroup/FocusGroup.d.ts +0 -36
  276. package/types/FocusGroup/FocusGroupContext.d.ts +0 -3
  277. package/types/FocusGroup/FocusGroupManager.d.ts +0 -24
  278. package/types/FocusGroup/focusGroupManagerHoc.d.ts +0 -7
  279. package/types/FocusGroup/index.d.ts +0 -6
  280. package/types/FocusGroup/useFocusGroupItem.d.ts +0 -2
  281. package/types/FocusGroup/utils/getNextCellPosition.d.ts +0 -12
  282. package/types/GroupContext/Group.d.ts +0 -14
  283. package/types/GroupContext/GroupContext.d.ts +0 -2
  284. package/types/GroupContext/GroupItem.d.ts +0 -5
  285. package/types/GroupContext/index.d.ts +0 -3
  286. package/types/ScrollSync/ScrollSync.d.ts +0 -21
  287. package/types/ScrollSync/ScrollSyncPane.d.ts +0 -3
  288. package/types/ScrollSync/ScrollSyncProvider.d.ts +0 -12
  289. package/types/ScrollSync/index.d.ts +0 -2
  290. package/types/ScrollSync/useScrollSync.d.ts +0 -6
  291. package/types/constants.d.ts +0 -30
  292. package/types/createDataInstance/createInstancePlugin.d.ts +0 -1
  293. package/types/createDataInstance/createInstanceRef.d.ts +0 -12
  294. package/types/createDataInstance/tests/createInstanceRef.test.d.ts +0 -0
  295. package/types/createDataInstance/utils.d.ts +0 -9
  296. package/types/dimsum.config.d.ts +0 -4
  297. package/types/index.d.ts +0 -2
  298. package/types/prop-types.d.ts +0 -41
  299. package/types/react-spring/index.d.ts +0 -1
  300. package/types/react-spring/renderprops.d.ts +0 -1
  301. package/types/toolbar/ToolbarProvider.d.ts +0 -10
  302. package/types/useDataGrid/VolatileRowsListener.d.ts +0 -5
  303. package/types/useDataGrid/index.d.ts +0 -1
  304. package/types/useDataGrid/initColumnDefinition.d.ts +0 -5
  305. package/types/useDataGrid/useDataGrid.d.ts +0 -8
  306. package/types/useDataList/index.d.ts +0 -1
  307. package/types/useDataList/recordIterator.d.ts +0 -1
  308. package/types/useDataList/useDataList.d.ts +0 -13
  309. package/types/utils.d.ts +0 -22
  310. package/types/virtualization/AutoHeightList.d.ts +0 -2
  311. package/types/virtualization/FluidHeightList.d.ts +0 -2
  312. package/types/virtualization/index.d.ts +0 -9
@@ -1,111 +0,0 @@
1
- import 'core-js/modules/esnext.async-iterator.filter.js';
2
- import 'core-js/modules/esnext.iterator.constructor.js';
3
- import 'core-js/modules/esnext.iterator.filter.js';
4
- import 'core-js/modules/esnext.async-iterator.for-each.js';
5
- import 'core-js/modules/esnext.iterator.for-each.js';
6
- import _jsx from '@babel/runtime/helpers/esm/jsx';
7
- import _defineProperty from '@babel/runtime/helpers/esm/defineProperty';
8
- import 'core-js/modules/web.dom-collections.iterator.js';
9
- import React, { useRef, useState, useEffect, useMemo } from 'react';
10
- import DSPopover from '@elliemae/ds-popper';
11
- import { useOnClickOutside } from '@elliemae/ds-utilities';
12
- import { jsx } from 'react/jsx-runtime';
13
-
14
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
15
-
16
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
17
- const ToolbarContext = /*#__PURE__*/React.createContext();
18
- const {
19
- Provider
20
- } = ToolbarContext;
21
-
22
- const useScrollListener = (callback, dependencies) => {
23
- useEffect(() => {
24
- window.addEventListener('scroll', callback, true);
25
- return () => {
26
- window.removeEventListener('scroll', callback, true);
27
- };
28
- }, [dependencies]);
29
- };
30
-
31
- const noop = () => null;
32
-
33
- function ToolbarProvider(_ref) {
34
- let {
35
- delay = 200,
36
- children,
37
- onHide = noop,
38
- onShow = noop
39
- } = _ref;
40
- const showTimer = useRef();
41
- const hideTimer = useRef();
42
- const toolbarRef = useRef();
43
- const [tooltipState, setTooltipState] = useState({});
44
-
45
- const show = state => {
46
- if (state.reference === tooltipState.reference) clearTimeout(hideTimer.current);
47
- showTimer.current = setTimeout(() => setTooltipState(_objectSpread(_objectSpread({}, state), {}, {
48
- visible: true
49
- })), delay);
50
- onShow();
51
- };
52
-
53
- const hide = (e, force) => {
54
- if (!force) clearTimeout(showTimer.current);
55
- hideTimer.current = setTimeout(() => setTooltipState(prevState => _objectSpread(_objectSpread({}, prevState), {}, {
56
- visible: false
57
- })), 100);
58
- onHide(tooltipState, e);
59
- };
60
-
61
- useScrollListener(e => hide(e, true), tooltipState.visible);
62
- useOnClickOutside(toolbarRef, () => hide());
63
-
64
- const keyDownHandler = e => {
65
- if (e.key === 'Escape') {
66
- hide(e);
67
- }
68
- };
69
-
70
- useEffect(() => {
71
- window.addEventListener('keydown', keyDownHandler);
72
- return () => {
73
- window.removeEventListener('keydown', keyDownHandler);
74
- };
75
- });
76
- const value = useMemo(() => ({
77
- state: tooltipState,
78
- show,
79
- hide
80
- }), [tooltipState.reference]);
81
- return /*#__PURE__*/_jsx(Provider, {
82
- value: value
83
- }, void 0, children, /*#__PURE__*/jsx(DSPopover, _objectSpread(_objectSpread({
84
- boundaries: "scrollParent"
85
- }, tooltipState.options || {}), {}, {
86
- content: tooltipState.renderer,
87
- placement: "left",
88
- referenceEl: tooltipState.reference,
89
- renderer: _ref2 => {
90
- let {
91
- as: Component,
92
- style,
93
- children: Content
94
- } = _ref2;
95
- return /*#__PURE__*/jsx("div", {
96
- ref: toolbarRef,
97
- onMouseEnter: e => show(tooltipState),
98
- onMouseLeave: hide,
99
- children: /*#__PURE__*/_jsx(Component, {
100
- style: style
101
- }, void 0, Content)
102
- });
103
- },
104
- style: tooltipState.style,
105
- visible: tooltipState.visible
106
- })));
107
- }
108
-
109
- var ToolbarProvider$1 = /*#__PURE__*/React.memo(ToolbarProvider);
110
-
111
- export { ToolbarContext, ToolbarProvider$1 as default };
@@ -1,22 +0,0 @@
1
- import 'core-js/modules/esnext.async-iterator.for-each.js';
2
- import 'core-js/modules/esnext.iterator.constructor.js';
3
- import 'core-js/modules/esnext.iterator.for-each.js';
4
- import { safeCall } from '@elliemae/ds-utilities';
5
-
6
- class VolatileRowsListener {
7
- constructor() {
8
- this.observers = [];
9
- }
10
-
11
- observe(listener) {
12
- this.observers.push(listener);
13
- }
14
-
15
- notify(nextRows) {
16
- this.observers.forEach(observer => safeCall(observer, nextRows));
17
- this.observers = [];
18
- }
19
-
20
- }
21
-
22
- export { VolatileRowsListener as default };
@@ -1 +0,0 @@
1
- export { default } from './useDataGrid.js';
@@ -1,134 +0,0 @@
1
- import 'core-js/modules/esnext.async-iterator.filter.js';
2
- import 'core-js/modules/esnext.iterator.constructor.js';
3
- import 'core-js/modules/esnext.iterator.filter.js';
4
- import 'core-js/modules/esnext.async-iterator.for-each.js';
5
- import 'core-js/modules/esnext.iterator.for-each.js';
6
- import _jsx from '@babel/runtime/helpers/esm/jsx';
7
- import _defineProperty from '@babel/runtime/helpers/esm/defineProperty';
8
- import 'core-js/modules/web.dom-collections.iterator.js';
9
- import 'core-js/modules/es.string.replace.js';
10
- import 'react';
11
- import { v4 } from 'uuid';
12
- import { curry, get, cloneDeep, set, isFunction } from '@elliemae/ds-utilities';
13
-
14
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
15
-
16
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
17
-
18
- const appendHeaderFormatter = curry((formatter, column) => _objectSpread(_objectSpread({}, column), {}, {
19
- header: _objectSpread(_objectSpread({}, column.header), {}, {
20
- formatters: [...get(column, 'header.formatters', []), formatter]
21
- })
22
- }));
23
- const appendCellFormatter = curry(function (formatter, column) {
24
- let path = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'formatters';
25
- const nextColumn = cloneDeep(column);
26
- const formatters = get(nextColumn, ['cell', path], []);
27
- const scrollingFormatters = get(nextColumn, 'cell.scrollingFormatters', []);
28
-
29
- if (Array.isArray(formatter)) {
30
- if (formatter[1]) scrollingFormatters.push(formatter[1]);
31
- formatters.push(formatter[0]);
32
- } else {
33
- formatters.push(formatter);
34
- scrollingFormatters.push(formatter);
35
- }
36
-
37
- set(nextColumn, ['cell', path], formatters);
38
- set(nextColumn, 'cell.scrollingFormatters', scrollingFormatters);
39
- return nextColumn;
40
- });
41
- const defaultColumnDefinitionOptions = {
42
- normalize: false,
43
- useTextTruncation: true,
44
- isUserColumn: true,
45
- visible: true
46
- };
47
- const mergeClassNameToColumnHeader = curry((className, column) => {
48
- const headerProps = get(column, ['header', 'props'], {});
49
- const headerClassName = headerProps.className || '';
50
- return _objectSpread(_objectSpread({}, column), {}, {
51
- header: _objectSpread(_objectSpread({}, column.header), {}, {
52
- props: _objectSpread(_objectSpread({}, headerProps), {}, {
53
- className: "".concat(headerClassName, " ").concat(className)
54
- })
55
- })
56
- });
57
- });
58
- function initColumnDefinition() {
59
- let options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
60
- // eslint-disable-next-line complexity
61
- return column => {
62
- // todo: clean this
63
- if (column.type === 'number') {
64
- // eslint-disable-next-line no-param-reassign
65
- column.cellStyle = {
66
- textAlign: 'right'
67
- };
68
- }
69
-
70
- const {
71
- useTextTruncation = true,
72
- isUserColumn,
73
- visible,
74
- normalize
75
- } = _objectSpread(_objectSpread({}, defaultColumnDefinitionOptions), options);
76
-
77
- if (normalize) {
78
- // eslint-disable-next-line no-param-reassign
79
- column.originalProperty = column.property; // eslint-disable-next-line no-param-reassign
80
-
81
- column.property = column.property.replace(/\s+/g, '');
82
- } // eslint-disable-next-line no-param-reassign
83
-
84
-
85
- column.props = _objectSpread(_objectSpread({}, column.props), {}, {
86
- style: {}
87
- }); // eslint-disable-next-line no-param-reassign
88
-
89
- column.header = _objectSpread(_objectSpread({}, column.header), {}, {
90
- label: column.label,
91
- formatters: [...get(column, ['header', 'formatters'], [])],
92
- props: {
93
- style: column.headerStyle || {}
94
- }
95
- });
96
-
97
- if (useTextTruncation && !(isFunction(column.customHeaderRenderer) || column.header.formatters.length)) {
98
- column.header.formatters.push(value => /*#__PURE__*/_jsx("span", {
99
- className: "cell-value"
100
- }, void 0, value));
101
- } // eslint-disable-next-line no-param-reassign
102
-
103
-
104
- column.cell = _objectSpread(_objectSpread({}, column.cell), {}, {
105
- transforms: [],
106
- formatters: [...get(column, ['cell', 'formatters'], [])],
107
- scrollingFormatters: [...get(column, ['cell', 'formatters'], [])],
108
- props: {
109
- style: column.cellStyle || {}
110
- }
111
- });
112
-
113
- if (useTextTruncation && !(isFunction(column.customRenderer) || column.cell.formatters.length)) {
114
- column.cell.formatters.push(value => /*#__PURE__*/_jsx("span", {
115
- className: "cell-value",
116
- style: {
117
- justifyContent: column.type === 'number' ? 'flex-end' : 'flex-start'
118
- }
119
- }, void 0, value));
120
- } // eslint-disable-next-line no-param-reassign
121
-
122
-
123
- column.uuid = column.uuid || v4(); // eslint-disable-next-line no-param-reassign
124
-
125
- column.visible = column.visible === undefined ? visible : column.visible; // eslint-disable-next-line no-param-reassign, max-lines
126
-
127
- column.isUserColumn = column.isUserColumn || isUserColumn; // eslint-disable-next-line no-param-reassign
128
-
129
- column.headerHookEffects = [];
130
- return column;
131
- };
132
- }
133
-
134
- export { appendCellFormatter, appendHeaderFormatter, initColumnDefinition as default, mergeClassNameToColumnHeader };
@@ -1,194 +0,0 @@
1
- import _defineProperty from '@babel/runtime/helpers/esm/defineProperty';
2
- import _objectWithoutProperties from '@babel/runtime/helpers/esm/objectWithoutProperties';
3
- import 'core-js/modules/web.dom-collections.iterator.js';
4
- import 'core-js/modules/esnext.async-iterator.map.js';
5
- import 'core-js/modules/esnext.iterator.map.js';
6
- import 'core-js/modules/esnext.async-iterator.for-each.js';
7
- import 'core-js/modules/esnext.iterator.constructor.js';
8
- import 'core-js/modules/esnext.iterator.for-each.js';
9
- import 'core-js/modules/esnext.async-iterator.reduce.js';
10
- import 'core-js/modules/esnext.iterator.reduce.js';
11
- import 'core-js/modules/esnext.async-iterator.filter.js';
12
- import 'core-js/modules/esnext.iterator.filter.js';
13
- import { useDerivedStateFromProps, compose, cloneDeep, usePrevious, isObject, isEqual, setRef } from '@elliemae/ds-utilities';
14
- import { useRef, useState, useMemo } from 'react';
15
- import { v4 } from 'uuid';
16
- import * as resolve from 'table-resolver';
17
- import initColumnDefinition from './initColumnDefinition.js';
18
- import { applyDecorators, decorateColumns, reducePropsGetter } from '../createDataInstance/utils.js';
19
- import VolatileRowsListener from './VolatileRowsListener.js';
20
- import { isInternetExplorer } from '../utils.js';
21
-
22
- const _excluded = ["uuid", "plugins", "rows", "columns", "renderers"];
23
-
24
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
25
-
26
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
27
- const IS_INTERNET_EXPLORER = isInternetExplorer(); // TODO: Reuse createDataInstance for the grid the same
28
- // way as the list does ex: packages/ds-shared/src/useDataList/useDataList.js
29
- // eslint-disable-next-line max-statements
30
-
31
- function useDataGrid(_ref) {
32
- let {
33
- uuid: uuidProp,
34
- plugins: pluginsFromProps,
35
- rows,
36
- columns,
37
- renderers = {}
38
- } = _ref,
39
- props = _objectWithoutProperties(_ref, _excluded);
40
-
41
- const plugins = pluginsFromProps;
42
- const instance = useRef();
43
- const tableRef = useRef();
44
- const headerRef = useRef();
45
- const bodyRef = useRef();
46
- const bodyInnerRef = useRef();
47
- const [uuid] = useState(uuidProp || (() => v4()));
48
- const [hasScroll, setHasScroll] = useState(false);
49
- const [isRowDragging, setIsRowDragging] = useState(false);
50
- const isScrolling = useRef();
51
- const shouldRefocus = useRef(); // todo: we probably need a plugin for focus related stuff
52
-
53
- const [RowsObserver] = useState(() => new VolatileRowsListener()); // todo move this with rows composition
54
-
55
- const [originalRows, updateRows] = useDerivedStateFromProps(rows, {
56
- onUpdate: resolve.resolve({
57
- columns,
58
- method: extra => compose(resolve.byFunction('valueTransformation')(extra), resolve.nested(extra))
59
- }),
60
- updateOnStateChange: true
61
- });
62
- instance.current = {
63
- decoratedRenderers: cloneDeep(renderers),
64
- decoratedColumns: columns,
65
- columns,
66
- rows,
67
- composedRows: originalRows,
68
- getRowProps: [],
69
- getHeaderRowProps: [],
70
- getBodyProps: [],
71
- getTableProps: [],
72
- effects: [],
73
- uuid,
74
- props,
75
- refs: {
76
- table: tableRef,
77
- body: bodyRef,
78
- header: headerRef,
79
- innerBody: bodyInnerRef
80
- },
81
- state: {
82
- hasScroll
83
- },
84
- actions: {
85
- updateRows
86
- },
87
- updateRows,
88
- // eslint-disable-next-line no-return-assign
89
- enableEvents: () => document.body.style.pointerEvents = IS_INTERNET_EXPLORER ? '' : null,
90
- // eslint-disable-next-line no-return-assign
91
- disableEvents: () => document.body.style.pointerEvents = 'none',
92
- observeRows: observer => RowsObserver.observe(observer),
93
- hotKeys: {},
94
- shouldRefocus,
95
- isScrolling,
96
- setHasScroll,
97
- setIsRowDragging,
98
- isRowDragging,
99
- plugins
100
- };
101
-
102
- instance.current.getState = () => instance.current.state;
103
-
104
- instance.current.getInstance = () => instance.current;
105
-
106
- const defaultDecorators = {
107
- decorateGrid: [],
108
- registerStateHook: [],
109
- registerHotKeys: [],
110
- decorateColumn: [],
111
- decorateColumns: [cols => cols.map(col => initColumnDefinition({
112
- useTextTruncation: col.useTextTruncation,
113
- wrapText: props.wrapText,
114
- normalize: props.normalizeDataKeys
115
- })(col))],
116
- decorateRenderers: [],
117
- getRowProps: [],
118
- getHeaderRowProps: [],
119
- getBodyProps: [],
120
- getTableProps: [],
121
- getHeaderProps: [],
122
- composeRows: []
123
- };
124
- const decorators = useMemo(() => {
125
- let nextDecorators = defaultDecorators; // eslint-disable-next-line no-return-assign
126
-
127
- plugins.forEach(plugin => nextDecorators = plugin(nextDecorators));
128
- return nextDecorators;
129
- }, [plugins]);
130
- instance.current = decorators.decorateGrid.reduce((nextInstance, decorator) => _objectSpread(_objectSpread({}, nextInstance), decorator(instance.current)), instance.current);
131
- instance.current = decorators.registerStateHook.reduce((nextInstance, decorator) => {
132
- const {
133
- state,
134
- actions
135
- } = decorator(instance.current);
136
- return _objectSpread(_objectSpread({}, nextInstance), {}, {
137
- state: _objectSpread(_objectSpread({}, nextInstance.state), state),
138
- actions: _objectSpread(_objectSpread({}, nextInstance.actions), actions)
139
- });
140
- }, instance.current);
141
-
142
- const reduceHotKey = (nextInstance, _ref2) => {
143
- let {
144
- key,
145
- handler,
146
- options
147
- } = _ref2;
148
- return _objectSpread(_objectSpread({}, nextInstance), {}, {
149
- hotKeys: _objectSpread(_objectSpread({}, nextInstance.hotKeys), {}, {
150
- [key]: {
151
- handler,
152
- options
153
- }
154
- })
155
- });
156
- };
157
-
158
- instance.current = decorators.registerHotKeys.reduce((nextInstance, decorator) => {
159
- const hotKeys = decorator(nextInstance);
160
-
161
- if (Array.isArray(hotKeys)) {
162
- return hotKeys.reduce(reduceHotKey, nextInstance);
163
- }
164
-
165
- return reduceHotKey(nextInstance, hotKeys);
166
- }, instance.current);
167
- instance.current.decoratedRenderers = applyDecorators(instance.current.decoratedRenderers, decorators.decorateRenderers, instance.current);
168
- instance.current.decoratedColumns = useMemo(() => {
169
- const visibleColumns = cloneDeep(columns).filter(column => typeof column.visible === 'undefined' || column.visible);
170
- return visibleColumns.length ? decorateColumns(visibleColumns, decorators, instance.current) : [];
171
- }, [columns]);
172
- instance.current.getBodyProps = reducePropsGetter(decorators.getBodyProps, instance.current);
173
- instance.current.getHeaderProps = reducePropsGetter(decorators.getHeaderProps, instance.current);
174
- instance.current.getRowProps = reducePropsGetter(decorators.getRowProps, instance.current);
175
- instance.current.getHeaderRowProps = reducePropsGetter(decorators.getHeaderRowProps, instance.current);
176
- instance.current.getTableProps = reducePropsGetter(decorators.getTableProps, instance.current);
177
- instance.current.composedRows = decorators.composeRows.reduce((nextRows, getter) => getter(nextRows, instance.current), instance.current.composedRows);
178
- RowsObserver.notify(instance.current.composedRows);
179
- const currentShouldRefocus = instance.current.shouldRefocus.current;
180
- const prevState = usePrevious(instance.current.state);
181
-
182
- if (isObject(currentShouldRefocus) && currentShouldRefocus.forced) {
183
- instance.current.shouldRefocus.current = currentShouldRefocus.value;
184
- } else {
185
- instance.current.shouldRefocus.current = !isEqual(prevState, instance.current.state);
186
- }
187
-
188
- if (props.instanceRef) setRef(props.instanceRef, instance.current);
189
- return _objectSpread(_objectSpread({}, instance.current), {}, {
190
- decorators
191
- });
192
- }
193
-
194
- export { useDataGrid as default };
@@ -1 +0,0 @@
1
- export { default } from './useDataList.js';
@@ -1,27 +0,0 @@
1
- const defaultStrategy = () => {
2
- throw Error('Implement an iterator strategy for record iterator');
3
- };
4
-
5
- function recordIterator(records) {
6
- let strategy = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultStrategy;
7
- let decorators = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
8
- let instance = arguments.length > 3 ? arguments[3] : undefined;
9
- const nextRows = [];
10
- strategy({
11
- data: records,
12
- cb: row => {
13
- let nextRow = row; // eslint-disable-next-line no-loops/no-loops,no-plusplus
14
-
15
- for (let i = 0; i < decorators.length; i++) {
16
- nextRow = decorators[i](nextRow, instance);
17
- if (!nextRow) break;
18
- }
19
-
20
- if (nextRow) nextRows.push(nextRow);
21
- },
22
- instance
23
- });
24
- return nextRows;
25
- }
26
-
27
- export { recordIterator };
@@ -1,90 +0,0 @@
1
- import 'core-js/modules/esnext.async-iterator.filter.js';
2
- import 'core-js/modules/esnext.iterator.filter.js';
3
- import 'core-js/modules/esnext.async-iterator.for-each.js';
4
- import 'core-js/modules/esnext.iterator.for-each.js';
5
- import _defineProperty from '@babel/runtime/helpers/esm/defineProperty';
6
- import _objectWithoutProperties from '@babel/runtime/helpers/esm/objectWithoutProperties';
7
- import 'core-js/modules/web.dom-collections.iterator.js';
8
- import 'core-js/modules/esnext.async-iterator.reduce.js';
9
- import 'core-js/modules/esnext.iterator.constructor.js';
10
- import 'core-js/modules/esnext.iterator.reduce.js';
11
- import { useRef, useMemo } from 'react';
12
- import { setRef } from '@elliemae/ds-utilities';
13
- import get from 'lodash/get';
14
- import { reducePropsGetter, composeFormatters } from '../createDataInstance/utils.js';
15
- import { recordIterator } from './recordIterator.js';
16
- import createDataInstanceRef from '../createDataInstance/createInstanceRef.js';
17
-
18
- const _excluded = ["data", "plugins", "renderers", "itemRenderer", "customDecorators"];
19
-
20
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
21
-
22
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
23
- const getItemLabel = function (record) {
24
- let nameKey = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'name';
25
- return get(record, ['data', nameKey]);
26
- };
27
- const getItemChildren = function (record) {
28
- let childrenKey = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'children';
29
- return get(record, ['data', childrenKey]);
30
- };
31
- const listRenderers = {
32
- list: 'ul',
33
- item: 'li'
34
- }; // todo: check if a plugin is a LIST plugin rather than GRID
35
-
36
- function useDataList(_ref) {
37
- let {
38
- data = [],
39
- plugins = [],
40
- renderers = listRenderers,
41
- itemRenderer = [],
42
- customDecorators
43
- } = _ref,
44
- props = _objectWithoutProperties(_ref, _excluded);
45
-
46
- const listRef = useRef();
47
- const {
48
- instance,
49
- decorators
50
- } = createDataInstanceRef(_objectSpread({
51
- data,
52
- renderers,
53
- plugins,
54
- customDecorators: _objectSpread(_objectSpread({}, customDecorators), {}, {
55
- recordIterator,
56
- getListProps: [],
57
- getItemProps: [],
58
- itemRenderer: [...itemRenderer],
59
- // components reduce to compose item content
60
- record: [],
61
- records: []
62
- })
63
- }, props));
64
-
65
- instance.current.getListRef = () => listRef;
66
-
67
- instance.current.setListRef = ref => {
68
- listRef.current = ref;
69
- };
70
-
71
- instance.current.getItemLabel = record => getItemLabel(record, props.nameKey);
72
-
73
- instance.current.getItemChildren = record => getItemChildren(record, props.childrenKey);
74
-
75
- instance.current.decorators = decorators;
76
- instance.current.getListProps = reducePropsGetter(decorators.getListProps, instance.current);
77
- instance.current.getItemProps = reducePropsGetter(decorators.getItemProps, instance.current);
78
- instance.current.itemRenderer = composeFormatters(instance.current.decorators.itemRenderer, instance.current);
79
- instance.current.records = useMemo(() => {
80
- // record iterator TREE / Simple
81
- let nextRecords = recordIterator(data, instance.current.decorators.recordIterator, decorators.record, instance.current); // compose all records
82
-
83
- nextRecords = decorators.records.reduce((nextRows, getter) => getter(nextRows, instance.current), nextRecords);
84
- return nextRecords;
85
- });
86
- if (props.instanceRef) setRef(props.instanceRef, instance.current);
87
- return instance.current;
88
- }
89
-
90
- export { useDataList as default, getItemChildren, getItemLabel };
package/esm/utils.js DELETED
@@ -1,95 +0,0 @@
1
- import 'core-js/modules/esnext.async-iterator.for-each.js';
2
- import 'core-js/modules/esnext.iterator.for-each.js';
3
- import _defineProperty from '@babel/runtime/helpers/esm/defineProperty';
4
- import 'core-js/modules/esnext.async-iterator.map.js';
5
- import 'core-js/modules/esnext.iterator.map.js';
6
- import 'core-js/modules/esnext.async-iterator.filter.js';
7
- import 'core-js/modules/esnext.iterator.constructor.js';
8
- import 'core-js/modules/esnext.iterator.filter.js';
9
-
10
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
11
-
12
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
13
-
14
- /* eslint-disable no-cond-assign */
15
- const objectType = obj => Object.prototype.toString.call(obj).slice(8, -1);
16
- const isDefined = param => typeof param !== 'undefined';
17
- const isUndefined = param => typeof param === 'undefined';
18
- const isFunction = param => typeof param === 'function';
19
- const isNumber = param => typeof param === 'number' && !isNaN(param); // eslint-disable-line
20
-
21
- const isString = str => objectType(str) === 'String';
22
- const isArray = arr => objectType(arr) === 'Array';
23
- const closest = (target, selector) => {
24
- // closest(e.target, '.field')
25
- while (target) {
26
- // eslint-disable-line
27
- if (target.matches && target.matches(selector)) return target;
28
- if (target.msMatchesSelector && target.msMatchesSelector(selector)) return target; // eslint-disable-next-line no-param-reassign
29
-
30
- target = target.parentNode;
31
- }
32
-
33
- return null;
34
- };
35
- const getOffsetRect = elem => {
36
- // (1)
37
- const box = elem.getBoundingClientRect();
38
- const {
39
- body,
40
- documentElement
41
- } = document; // (2)
42
-
43
- const scrollTop = window.pageYOffset || documentElement.scrollTop || body.scrollTop;
44
- const scrollLeft = window.pageXOffset || documentElement.scrollLeft || body.scrollLeft; // (3)
45
-
46
- const clientTop = documentElement.clientTop || body.clientTop || 0;
47
- const clientLeft = documentElement.clientLeft || body.clientLeft || 0; // (4)
48
-
49
- const top = box.top + scrollTop - clientTop;
50
- const left = box.left + scrollLeft - clientLeft;
51
- return {
52
- top: Math.round(top),
53
- left: Math.round(left)
54
- };
55
- };
56
- const getTotalScroll = elem => {
57
- let top = 0;
58
- let left = 0; // eslint-disable-next-line no-param-reassign
59
-
60
- while (elem = elem.parentNode) {
61
- top += elem.scrollTop || 0;
62
- left += elem.scrollLeft || 0;
63
- }
64
-
65
- return {
66
- top,
67
- left
68
- };
69
- };
70
- const getTransformProps = (x, y) => ({
71
- transform: "translate(".concat(x, "px, ").concat(y, "px)")
72
- });
73
- const listWithChildren = (list, childrenProp) => list.map(item => _objectSpread(_objectSpread({}, item), {}, {
74
- [childrenProp]: item[childrenProp] ? listWithChildren(item[childrenProp], childrenProp) : []
75
- }));
76
- const getAllNonEmptyNodesIds = (items, childrenProp) => {
77
- let childrenIds = [];
78
- const ids = items.filter(item => item[childrenProp].length).map(item => {
79
- childrenIds = childrenIds.concat(getAllNonEmptyNodesIds(item[childrenProp], childrenProp));
80
- return item.id;
81
- });
82
- return ids.concat(childrenIds);
83
- };
84
- const isInternetExplorer = () => {
85
- const ua = window.navigator.userAgent;
86
- const msie = ua.indexOf('MSIE '); // If Internet Explorer, return version number
87
-
88
- if (msie > 0 || !!navigator.userAgent.match(/Trident.*rv:11\./)) {
89
- return true;
90
- }
91
-
92
- return false;
93
- };
94
-
95
- export { closest, getAllNonEmptyNodesIds, getOffsetRect, getTotalScroll, getTransformProps, isArray, isDefined, isFunction, isInternetExplorer, isNumber, isString, isUndefined, listWithChildren, objectType };