@elliemae/ds-shared 3.0.0-next.0 → 3.0.0-next.4

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 +116 -107
  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
@@ -0,0 +1,3 @@
1
+ import * as React from "react";
2
+ export * from "react-spring/web";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/react-spring/index.tsx"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "export * from 'react-spring/web';\n"],
5
+ "mappings": "AAAA;ACAA;",
6
+ "names": []
7
+ }
@@ -0,0 +1,3 @@
1
+ import * as React from "react";
2
+ export * from "react-spring/renderprops";
3
+ //# sourceMappingURL=renderprops.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/react-spring/renderprops.tsx"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "export * from 'react-spring/renderprops';\n"],
5
+ "mappings": "AAAA;ACAA;",
6
+ "names": []
7
+ }
@@ -0,0 +1,99 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ import * as React from "react";
21
+ import React2, { useMemo, useRef, useState, useEffect, memo } from "react";
22
+ import { DSPopover } from "@elliemae/ds-popper";
23
+ import { useOnClickOutside } from "@elliemae/ds-utilities";
24
+ const ToolbarContext = React2.createContext();
25
+ const { Provider } = ToolbarContext;
26
+ const useScrollListener = (callback, dependencies) => {
27
+ useEffect(() => {
28
+ window.addEventListener("scroll", callback, true);
29
+ return () => {
30
+ window.removeEventListener("scroll", callback, true);
31
+ };
32
+ }, [dependencies]);
33
+ };
34
+ const noop = () => null;
35
+ const ToolbarProvider = memo(({ delay = 200, children, onHide = noop, onShow = noop }) => {
36
+ const showTimer = useRef();
37
+ const hideTimer = useRef();
38
+ const toolbarRef = useRef();
39
+ const [tooltipState, setTooltipState] = useState({});
40
+ const show = (state) => {
41
+ if (state.reference === tooltipState.reference)
42
+ clearTimeout(hideTimer.current);
43
+ showTimer.current = setTimeout(() => setTooltipState(__spreadProps(__spreadValues({}, state), {
44
+ visible: true
45
+ })), delay);
46
+ onShow();
47
+ };
48
+ const hide = (e, force) => {
49
+ if (!force)
50
+ clearTimeout(showTimer.current);
51
+ hideTimer.current = setTimeout(() => setTooltipState((prevState) => __spreadProps(__spreadValues({}, prevState), {
52
+ visible: false
53
+ })), 100);
54
+ onHide(tooltipState, e);
55
+ };
56
+ useScrollListener((e) => hide(e, true), tooltipState.visible);
57
+ useOnClickOutside(toolbarRef, () => hide());
58
+ const keyDownHandler = (e) => {
59
+ if (e.key === "Escape") {
60
+ hide(e);
61
+ }
62
+ };
63
+ useEffect(() => {
64
+ window.addEventListener("keydown", keyDownHandler);
65
+ return () => {
66
+ window.removeEventListener("keydown", keyDownHandler);
67
+ };
68
+ });
69
+ const value = useMemo(() => ({
70
+ state: tooltipState,
71
+ show,
72
+ hide
73
+ }), [tooltipState.reference]);
74
+ return /* @__PURE__ */ React2.createElement(Provider, {
75
+ value
76
+ }, children, /* @__PURE__ */ React2.createElement(DSPopover, __spreadProps(__spreadValues({
77
+ boundaries: "scrollParent"
78
+ }, tooltipState.options || {}), {
79
+ content: tooltipState.renderer,
80
+ placement: "left",
81
+ referenceEl: tooltipState.reference,
82
+ renderer: ({ as: Component, style, children: Content }) => /* @__PURE__ */ React2.createElement("div", {
83
+ ref: toolbarRef,
84
+ onMouseEnter: (e) => show(tooltipState, e),
85
+ onMouseLeave: hide
86
+ }, /* @__PURE__ */ React2.createElement(Component, {
87
+ style
88
+ }, Content)),
89
+ style: tooltipState.style,
90
+ visible: tooltipState.visible
91
+ })));
92
+ });
93
+ var ToolbarProvider_default = ToolbarProvider;
94
+ export {
95
+ ToolbarContext,
96
+ ToolbarProvider,
97
+ ToolbarProvider_default as default
98
+ };
99
+ //# sourceMappingURL=ToolbarProvider.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/toolbar/ToolbarProvider.tsx"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import React, { useMemo, useRef, useState, useEffect, memo } from 'react';\nimport { DSPopover } from '@elliemae/ds-popper';\nimport { useOnClickOutside } from '@elliemae/ds-utilities';\n\nexport const ToolbarContext = React.createContext();\n\nconst { Provider } = ToolbarContext;\n\nconst useScrollListener = (callback, dependencies) => {\n useEffect(() => {\n window.addEventListener('scroll', callback, true);\n return () => {\n window.removeEventListener('scroll', callback, true);\n };\n }, [dependencies]);\n};\n\nconst noop = () => null;\nconst ToolbarProvider = memo(({ delay = 200, children, onHide = noop, onShow = noop }) => {\n const showTimer = useRef();\n const hideTimer = useRef();\n const toolbarRef = useRef();\n const [tooltipState, setTooltipState] = useState({});\n\n const show = (state) => {\n if (state.reference === tooltipState.reference) clearTimeout(hideTimer.current);\n showTimer.current = setTimeout(\n () =>\n setTooltipState({\n ...state,\n visible: true,\n }),\n delay,\n );\n onShow();\n };\n\n const hide = (e, force) => {\n if (!force) clearTimeout(showTimer.current);\n hideTimer.current = setTimeout(\n () =>\n setTooltipState((prevState) => ({\n ...prevState,\n visible: false,\n })),\n 100,\n );\n onHide(tooltipState, e);\n };\n\n useScrollListener((e) => hide(e, true), tooltipState.visible);\n useOnClickOutside(toolbarRef, () => hide());\n\n const keyDownHandler = (e) => {\n if (e.key === 'Escape') {\n hide(e);\n }\n };\n\n useEffect(() => {\n window.addEventListener('keydown', keyDownHandler);\n return () => {\n window.removeEventListener('keydown', keyDownHandler);\n };\n });\n\n const value = useMemo(\n () => ({\n state: tooltipState,\n show,\n hide,\n }),\n [tooltipState.reference],\n );\n\n return (\n <Provider value={value}>\n {children}\n <DSPopover\n boundaries=\"scrollParent\"\n {...(tooltipState.options || {})}\n content={tooltipState.renderer}\n placement=\"left\"\n referenceEl={tooltipState.reference}\n renderer={({ as: Component, style, children: Content }) => (\n <div ref={toolbarRef} onMouseEnter={(e) => show(tooltipState, e)} onMouseLeave={hide}>\n <Component style={style}>{Content}</Component>\n </div>\n )}\n style={tooltipState.style}\n visible={tooltipState.visible}\n />\n </Provider>\n );\n});\n\nexport { ToolbarProvider };\nexport default ToolbarProvider;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;AAAA;ACAA;AACA;AACA;AAEO,MAAM,iBAAiB,OAAM;AAEpC,MAAM,EAAE,aAAa;AAErB,MAAM,oBAAoB,CAAC,UAAU,iBAAiB;AACpD,YAAU,MAAM;AACd,WAAO,iBAAiB,UAAU,UAAU;AAC5C,WAAO,MAAM;AACX,aAAO,oBAAoB,UAAU,UAAU;AAAA;AAAA,KAEhD,CAAC;AAAA;AAGN,MAAM,OAAO,MAAM;AACnB,MAAM,kBAAkB,KAAK,CAAC,EAAE,QAAQ,KAAK,UAAU,SAAS,MAAM,SAAS,WAAW;AACxF,QAAM,YAAY;AAClB,QAAM,YAAY;AAClB,QAAM,aAAa;AACnB,QAAM,CAAC,cAAc,mBAAmB,SAAS;AAEjD,QAAM,OAAO,CAAC,UAAU;AACtB,QAAI,MAAM,cAAc,aAAa;AAAW,mBAAa,UAAU;AACvE,cAAU,UAAU,WAClB,MACE,gBAAgB,iCACX,QADW;AAAA,MAEd,SAAS;AAAA,SAEb;AAEF;AAAA;AAGF,QAAM,OAAO,CAAC,GAAG,UAAU;AACzB,QAAI,CAAC;AAAO,mBAAa,UAAU;AACnC,cAAU,UAAU,WAClB,MACE,gBAAgB,CAAC,cAAe,iCAC3B,YAD2B;AAAA,MAE9B,SAAS;AAAA,SAEb;AAEF,WAAO,cAAc;AAAA;AAGvB,oBAAkB,CAAC,MAAM,KAAK,GAAG,OAAO,aAAa;AACrD,oBAAkB,YAAY,MAAM;AAEpC,QAAM,iBAAiB,CAAC,MAAM;AAC5B,QAAI,EAAE,QAAQ,UAAU;AACtB,WAAK;AAAA;AAAA;AAIT,YAAU,MAAM;AACd,WAAO,iBAAiB,WAAW;AACnC,WAAO,MAAM;AACX,aAAO,oBAAoB,WAAW;AAAA;AAAA;AAI1C,QAAM,QAAQ,QACZ,MAAO;AAAA,IACL,OAAO;AAAA,IACP;AAAA,IACA;AAAA,MAEF,CAAC,aAAa;AAGhB,SACE,qCAAC,UAAD;AAAA,IAAU;AAAA,KACP,UACD,qCAAC,WAAD;AAAA,IACE,YAAW;AAAA,KACN,aAAa,WAAW,KAF/B;AAAA,IAGE,SAAS,aAAa;AAAA,IACtB,WAAU;AAAA,IACV,aAAa,aAAa;AAAA,IAC1B,UAAU,CAAC,EAAE,IAAI,WAAW,OAAO,UAAU,cAC3C,qCAAC,OAAD;AAAA,MAAK,KAAK;AAAA,MAAY,cAAc,CAAC,MAAM,KAAK,cAAc;AAAA,MAAI,cAAc;AAAA,OAC9E,qCAAC,WAAD;AAAA,MAAW;AAAA,OAAe;AAAA,IAG9B,OAAO,aAAa;AAAA,IACpB,SAAS,aAAa;AAAA;AAAA;AAO9B,IAAO,0BAAQ;",
6
+ "names": []
7
+ }
@@ -0,0 +1,20 @@
1
+ import * as React from "react";
2
+ import { safeCall } from "@elliemae/ds-utilities";
3
+ class VolatileRowsListener {
4
+ constructor() {
5
+ this.observers = [];
6
+ }
7
+ observe(listener) {
8
+ this.observers.push(listener);
9
+ }
10
+ notify(nextRows) {
11
+ this.observers.forEach((observer) => safeCall(observer, nextRows));
12
+ this.observers = [];
13
+ }
14
+ }
15
+ var VolatileRowsListener_default = VolatileRowsListener;
16
+ export {
17
+ VolatileRowsListener,
18
+ VolatileRowsListener_default as default
19
+ };
20
+ //# sourceMappingURL=VolatileRowsListener.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/useDataGrid/VolatileRowsListener.tsx"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import { safeCall } from '@elliemae/ds-utilities';\n\nclass VolatileRowsListener {\n observers = [];\n\n observe(listener) {\n this.observers.push(listener);\n }\n\n notify(nextRows) {\n this.observers.forEach(observer => safeCall(observer, nextRows));\n this.observers = [];\n }\n}\n\nexport { VolatileRowsListener };\nexport default VolatileRowsListener;\n"],
5
+ "mappings": "AAAA;ACAA;AAEA,2BAA2B;AAAA,EAA3B,cAFA;AAGE,qBAAY;AAAA;AAAA,EAEZ,QAAQ,UAAU;AAChB,SAAK,UAAU,KAAK;AAAA;AAAA,EAGtB,OAAO,UAAU;AACf,SAAK,UAAU,QAAQ,cAAY,SAAS,UAAU;AACtD,SAAK,YAAY;AAAA;AAAA;AAKrB,IAAO,+BAAQ;",
6
+ "names": []
7
+ }
@@ -0,0 +1,7 @@
1
+ import * as React from "react";
2
+ import { default as default2, default as default3 } from "./useDataGrid";
3
+ export {
4
+ default2 as default,
5
+ default3 as useDataGrid
6
+ };
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/useDataGrid/index.tsx"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "export { default, default as useDataGrid } from './useDataGrid';\n"],
5
+ "mappings": "AAAA;ACAA;",
6
+ "names": []
7
+ }
@@ -0,0 +1,126 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ import * as React from "react";
21
+ import React2 from "react";
22
+ import { v4 as uuidv4 } from "uuid";
23
+ import {
24
+ get,
25
+ curry,
26
+ set,
27
+ cloneDeep,
28
+ isFunction
29
+ } from "@elliemae/ds-utilities";
30
+ const appendHeaderFormatter = curry((formatter, column) => __spreadProps(__spreadValues({}, column), {
31
+ header: __spreadProps(__spreadValues({}, column.header), {
32
+ formatters: [...get(column, "header.formatters", []), formatter]
33
+ })
34
+ }));
35
+ const appendCellFormatter = curry((formatter, column, path = "formatters") => {
36
+ const nextColumn = cloneDeep(column);
37
+ const formatters = get(nextColumn, ["cell", path], []);
38
+ const scrollingFormatters = get(nextColumn, "cell.scrollingFormatters", []);
39
+ if (Array.isArray(formatter)) {
40
+ if (formatter[1])
41
+ scrollingFormatters.push(formatter[1]);
42
+ formatters.push(formatter[0]);
43
+ } else {
44
+ formatters.push(formatter);
45
+ scrollingFormatters.push(formatter);
46
+ }
47
+ set(nextColumn, ["cell", path], formatters);
48
+ set(nextColumn, "cell.scrollingFormatters", scrollingFormatters);
49
+ return nextColumn;
50
+ });
51
+ const defaultColumnDefinitionOptions = {
52
+ normalize: false,
53
+ useTextTruncation: true,
54
+ isUserColumn: true,
55
+ visible: true
56
+ };
57
+ const mergeClassNameToColumnHeader = curry((className, column) => {
58
+ const headerProps = get(column, ["header", "props"], {});
59
+ const headerClassName = headerProps.className || "";
60
+ return __spreadProps(__spreadValues({}, column), {
61
+ header: __spreadProps(__spreadValues({}, column.header), {
62
+ props: __spreadProps(__spreadValues({}, headerProps), {
63
+ className: `${headerClassName} ${className}`
64
+ })
65
+ })
66
+ });
67
+ });
68
+ const initColumnDefinition = (options = {}) => {
69
+ return (column) => {
70
+ if (column.type === "number") {
71
+ column.cellStyle = {
72
+ textAlign: "right"
73
+ };
74
+ }
75
+ const { useTextTruncation = true, isUserColumn, visible, normalize } = __spreadValues(__spreadValues({}, defaultColumnDefinitionOptions), options);
76
+ if (normalize) {
77
+ column.originalProperty = column.property;
78
+ column.property = column.property.replace(/\s+/g, "");
79
+ }
80
+ column.props = __spreadProps(__spreadValues({}, column.props), {
81
+ style: {}
82
+ });
83
+ column.header = __spreadProps(__spreadValues({}, column.header), {
84
+ label: column.label,
85
+ formatters: [...get(column, ["header", "formatters"], [])],
86
+ props: {
87
+ style: column.headerStyle || {}
88
+ }
89
+ });
90
+ if (useTextTruncation && !(isFunction(column.customHeaderRenderer) || column.header.formatters.length)) {
91
+ column.header.formatters.push((value) => /* @__PURE__ */ React2.createElement("span", {
92
+ className: "cell-value"
93
+ }, value));
94
+ }
95
+ column.cell = __spreadProps(__spreadValues({}, column.cell), {
96
+ transforms: [],
97
+ formatters: [...get(column, ["cell", "formatters"], [])],
98
+ scrollingFormatters: [...get(column, ["cell", "formatters"], [])],
99
+ props: {
100
+ style: column.cellStyle || {}
101
+ }
102
+ });
103
+ if (useTextTruncation && !(isFunction(column.customRenderer) || column.cell.formatters.length)) {
104
+ column.cell.formatters.push((value) => /* @__PURE__ */ React2.createElement("span", {
105
+ className: "cell-value",
106
+ style: {
107
+ justifyContent: column.type === "number" ? "flex-end" : "flex-start"
108
+ }
109
+ }, value));
110
+ }
111
+ column.uuid = column.uuid || uuidv4();
112
+ column.visible = column.visible === void 0 ? visible : column.visible;
113
+ column.isUserColumn = column.isUserColumn || isUserColumn;
114
+ column.headerHookEffects = [];
115
+ return column;
116
+ };
117
+ };
118
+ var initColumnDefinition_default = initColumnDefinition;
119
+ export {
120
+ appendCellFormatter,
121
+ appendHeaderFormatter,
122
+ initColumnDefinition_default as default,
123
+ initColumnDefinition,
124
+ mergeClassNameToColumnHeader
125
+ };
126
+ //# sourceMappingURL=initColumnDefinition.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/useDataGrid/initColumnDefinition.tsx"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable max-lines */\n/* eslint-disable react/display-name */\nimport React from 'react';\nimport { v4 as uuidv4 } from 'uuid';\nimport {\n get,\n curry,\n set,\n cloneDeep,\n isFunction,\n} from '@elliemae/ds-utilities';\n\n// TODO: use lenses to access nested fields\n\nexport const appendHeaderFormatter = curry((formatter, column) => ({\n ...column,\n header: {\n ...column.header,\n formatters: [...get(column, 'header.formatters', []), formatter],\n },\n}));\n\nexport const appendCellFormatter = curry(\n (formatter, column, path = 'formatters') => {\n const nextColumn = cloneDeep(column);\n const formatters = get(nextColumn, ['cell', path], []);\n const scrollingFormatters = get(nextColumn, 'cell.scrollingFormatters', []);\n if (Array.isArray(formatter)) {\n if (formatter[1]) scrollingFormatters.push(formatter[1]);\n formatters.push(formatter[0]);\n } else {\n formatters.push(formatter);\n scrollingFormatters.push(formatter);\n }\n set(nextColumn, ['cell', path], formatters);\n set(nextColumn, 'cell.scrollingFormatters', scrollingFormatters);\n return nextColumn;\n },\n);\n\nconst defaultColumnDefinitionOptions = {\n normalize: false,\n useTextTruncation: true,\n isUserColumn: true,\n visible: true,\n};\n\nexport const mergeClassNameToColumnHeader = curry((className, column) => {\n const headerProps = get(column, ['header', 'props'], {});\n const headerClassName = headerProps.className || '';\n return {\n ...column,\n header: {\n ...column.header,\n props: {\n ...headerProps,\n className: `${headerClassName} ${className}`,\n },\n },\n };\n});\n\nexport const initColumnDefinition = (options = {}) => {\n // eslint-disable-next-line complexity\n return (column) => {\n // todo: clean this\n if (column.type === 'number') {\n // eslint-disable-next-line no-param-reassign\n column.cellStyle = {\n textAlign: 'right',\n };\n }\n const { useTextTruncation = true, isUserColumn, visible, normalize } = {\n ...defaultColumnDefinitionOptions,\n ...options,\n };\n\n if (normalize) {\n // eslint-disable-next-line no-param-reassign\n column.originalProperty = column.property;\n // eslint-disable-next-line no-param-reassign\n column.property = column.property.replace(/\\s+/g, '');\n }\n\n // eslint-disable-next-line no-param-reassign\n column.props = {\n ...column.props,\n style: {},\n };\n // eslint-disable-next-line no-param-reassign\n column.header = {\n ...column.header,\n label: column.label,\n formatters: [...get(column, ['header', 'formatters'], [])],\n props: {\n style: column.headerStyle || {},\n },\n };\n if (\n useTextTruncation &&\n !(\n isFunction(column.customHeaderRenderer) ||\n column.header.formatters.length\n )\n ) {\n column.header.formatters.push((value) => (\n <span className=\"cell-value\">{value}</span>\n ));\n }\n\n // eslint-disable-next-line no-param-reassign\n column.cell = {\n ...column.cell,\n transforms: [],\n formatters: [...get(column, ['cell', 'formatters'], [])],\n scrollingFormatters: [...get(column, ['cell', 'formatters'], [])],\n props: {\n style: column.cellStyle || {},\n },\n };\n\n if (\n useTextTruncation &&\n !(isFunction(column.customRenderer) || column.cell.formatters.length)\n ) {\n column.cell.formatters.push((value) => (\n <span\n className=\"cell-value\"\n style={{\n justifyContent:\n column.type === 'number' ? 'flex-end' : 'flex-start',\n }}\n >\n {value}\n </span>\n ));\n }\n // eslint-disable-next-line no-param-reassign\n column.uuid = column.uuid || uuidv4();\n // eslint-disable-next-line no-param-reassign\n column.visible = column.visible === undefined ? visible : column.visible;\n // eslint-disable-next-line no-param-reassign, max-lines\n column.isUserColumn = column.isUserColumn || isUserColumn;\n // eslint-disable-next-line no-param-reassign\n column.headerHookEffects = [];\n return column;\n };\n};\n\nexport default initColumnDefinition;\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,201 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ var __objRest = (source, exclude) => {
21
+ var target = {};
22
+ for (var prop in source)
23
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
24
+ target[prop] = source[prop];
25
+ if (source != null && __getOwnPropSymbols)
26
+ for (var prop of __getOwnPropSymbols(source)) {
27
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
28
+ target[prop] = source[prop];
29
+ }
30
+ return target;
31
+ };
32
+ import * as React from "react";
33
+ import {
34
+ cloneDeep,
35
+ compose,
36
+ isEqual,
37
+ isObject,
38
+ setRef,
39
+ usePrevious,
40
+ useDerivedStateFromProps
41
+ } from "@elliemae/ds-utilities";
42
+ import { useMemo, useRef, useState } from "react";
43
+ import { v4 as uuidv4 } from "uuid";
44
+ import * as resolve from "table-resolver";
45
+ import { initColumnDefinition } from "./initColumnDefinition";
46
+ import {
47
+ applyDecorators,
48
+ decorateColumns,
49
+ reducePropsGetter
50
+ } from "../createDataInstance/utils";
51
+ import { VolatileRowsListener } from "./VolatileRowsListener";
52
+ import { isInternetExplorer } from "../utils";
53
+ const IS_INTERNET_EXPLORER = isInternetExplorer();
54
+ const useDataGrid = (_a) => {
55
+ var _b = _a, {
56
+ uuid: uuidProp,
57
+ plugins: pluginsFromProps,
58
+ rows,
59
+ columns,
60
+ renderers = {}
61
+ } = _b, props = __objRest(_b, [
62
+ "uuid",
63
+ "plugins",
64
+ "rows",
65
+ "columns",
66
+ "renderers"
67
+ ]);
68
+ const plugins = pluginsFromProps;
69
+ const instance = useRef();
70
+ const tableRef = useRef();
71
+ const headerRef = useRef();
72
+ const bodyRef = useRef();
73
+ const bodyInnerRef = useRef();
74
+ const [uuid] = useState(uuidProp || (() => uuidv4()));
75
+ const [hasScroll, setHasScroll] = useState(false);
76
+ const [isRowDragging, setIsRowDragging] = useState(false);
77
+ const isScrolling = useRef();
78
+ const shouldRefocus = useRef();
79
+ const [RowsObserver] = useState(() => new VolatileRowsListener());
80
+ const [originalRows, updateRows] = useDerivedStateFromProps(rows, {
81
+ onUpdate: resolve.resolve({
82
+ columns,
83
+ method: (extra) => compose(resolve.byFunction("valueTransformation")(extra), resolve.nested(extra))
84
+ }),
85
+ updateOnStateChange: true
86
+ });
87
+ instance.current = {
88
+ decoratedRenderers: cloneDeep(renderers),
89
+ decoratedColumns: columns,
90
+ columns,
91
+ rows,
92
+ composedRows: originalRows,
93
+ getRowProps: [],
94
+ getHeaderRowProps: [],
95
+ getBodyProps: [],
96
+ getTableProps: [],
97
+ effects: [],
98
+ uuid,
99
+ props,
100
+ refs: {
101
+ table: tableRef,
102
+ body: bodyRef,
103
+ header: headerRef,
104
+ innerBody: bodyInnerRef
105
+ },
106
+ state: {
107
+ hasScroll
108
+ },
109
+ actions: {
110
+ updateRows
111
+ },
112
+ updateRows,
113
+ enableEvents: () => document.body.style.pointerEvents = IS_INTERNET_EXPLORER ? "" : null,
114
+ disableEvents: () => document.body.style.pointerEvents = "none",
115
+ observeRows: (observer) => RowsObserver.observe(observer),
116
+ hotKeys: {},
117
+ shouldRefocus,
118
+ isScrolling,
119
+ setHasScroll,
120
+ setIsRowDragging,
121
+ isRowDragging,
122
+ plugins
123
+ };
124
+ instance.current.getState = () => instance.current.state;
125
+ instance.current.getInstance = () => instance.current;
126
+ const defaultDecorators = {
127
+ decorateGrid: [],
128
+ registerStateHook: [],
129
+ registerHotKeys: [],
130
+ decorateColumn: [],
131
+ decorateColumns: [
132
+ (cols) => cols.map((col) => initColumnDefinition({
133
+ useTextTruncation: col.useTextTruncation,
134
+ wrapText: props.wrapText,
135
+ normalize: props.normalizeDataKeys
136
+ })(col))
137
+ ],
138
+ decorateRenderers: [],
139
+ getRowProps: [],
140
+ getHeaderRowProps: [],
141
+ getBodyProps: [],
142
+ getTableProps: [],
143
+ getHeaderProps: [],
144
+ composeRows: []
145
+ };
146
+ const decorators = useMemo(() => {
147
+ let nextDecorators = defaultDecorators;
148
+ plugins.forEach((plugin) => nextDecorators = plugin(nextDecorators));
149
+ return nextDecorators;
150
+ }, [plugins]);
151
+ instance.current = decorators.decorateGrid.reduce((nextInstance, decorator) => __spreadValues(__spreadValues({}, nextInstance), decorator(instance.current)), instance.current);
152
+ instance.current = decorators.registerStateHook.reduce((nextInstance, decorator) => {
153
+ const { state, actions } = decorator(instance.current);
154
+ return __spreadProps(__spreadValues({}, nextInstance), {
155
+ state: __spreadValues(__spreadValues({}, nextInstance.state), state),
156
+ actions: __spreadValues(__spreadValues({}, nextInstance.actions), actions)
157
+ });
158
+ }, instance.current);
159
+ const reduceHotKey = (nextInstance, { key, handler, options }) => __spreadProps(__spreadValues({}, nextInstance), {
160
+ hotKeys: __spreadProps(__spreadValues({}, nextInstance.hotKeys), {
161
+ [key]: { handler, options }
162
+ })
163
+ });
164
+ instance.current = decorators.registerHotKeys.reduce((nextInstance, decorator) => {
165
+ const hotKeys = decorator(nextInstance);
166
+ if (Array.isArray(hotKeys)) {
167
+ return hotKeys.reduce(reduceHotKey, nextInstance);
168
+ }
169
+ return reduceHotKey(nextInstance, hotKeys);
170
+ }, instance.current);
171
+ instance.current.decoratedRenderers = applyDecorators(instance.current.decoratedRenderers, decorators.decorateRenderers, instance.current);
172
+ instance.current.decoratedColumns = useMemo(() => {
173
+ const visibleColumns = cloneDeep(columns).filter((column) => typeof column.visible === "undefined" || column.visible);
174
+ return visibleColumns.length ? decorateColumns(visibleColumns, decorators, instance.current) : [];
175
+ }, [columns]);
176
+ instance.current.getBodyProps = reducePropsGetter(decorators.getBodyProps, instance.current);
177
+ instance.current.getHeaderProps = reducePropsGetter(decorators.getHeaderProps, instance.current);
178
+ instance.current.getRowProps = reducePropsGetter(decorators.getRowProps, instance.current);
179
+ instance.current.getHeaderRowProps = reducePropsGetter(decorators.getHeaderRowProps, instance.current);
180
+ instance.current.getTableProps = reducePropsGetter(decorators.getTableProps, instance.current);
181
+ instance.current.composedRows = decorators.composeRows.reduce((nextRows, getter) => getter(nextRows, instance.current), instance.current.composedRows);
182
+ RowsObserver.notify(instance.current.composedRows);
183
+ const currentShouldRefocus = instance.current.shouldRefocus.current;
184
+ const prevState = usePrevious(instance.current.state);
185
+ if (isObject(currentShouldRefocus) && currentShouldRefocus.forced) {
186
+ instance.current.shouldRefocus.current = currentShouldRefocus.value;
187
+ } else {
188
+ instance.current.shouldRefocus.current = !isEqual(prevState, instance.current.state);
189
+ }
190
+ if (props.instanceRef)
191
+ setRef(props.instanceRef, instance.current);
192
+ return __spreadProps(__spreadValues({}, instance.current), {
193
+ decorators
194
+ });
195
+ };
196
+ var useDataGrid_default = useDataGrid;
197
+ export {
198
+ useDataGrid_default as default,
199
+ useDataGrid
200
+ };
201
+ //# sourceMappingURL=useDataGrid.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/useDataGrid/useDataGrid.tsx"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable max-lines */\nimport {\n cloneDeep,\n compose,\n isEqual,\n isObject,\n setRef, \n usePrevious, \n useDerivedStateFromProps \n} from '@elliemae/ds-utilities';\nimport { useMemo, useRef, useState } from 'react';\nimport { v4 as uuidv4 } from 'uuid';\nimport * as resolve from 'table-resolver';\nimport { initColumnDefinition } from './initColumnDefinition';\nimport {\n applyDecorators,\n decorateColumns,\n reducePropsGetter,\n} from '../createDataInstance/utils';\nimport { VolatileRowsListener } from './VolatileRowsListener';\nimport { isInternetExplorer } from '../utils';\n\nconst IS_INTERNET_EXPLORER = isInternetExplorer();\n\n// TODO: Reuse createDataInstance for the grid the same\n// way as the list does ex: packages/ds-shared/src/useDataList/useDataList.js\n// eslint-disable-next-line max-statements\nexport const useDataGrid = ({\n uuid: uuidProp,\n plugins: pluginsFromProps,\n rows,\n columns,\n renderers = {},\n ...props\n}) => {\n const plugins = pluginsFromProps;\n const instance = useRef();\n const tableRef = useRef();\n const headerRef = useRef();\n const bodyRef = useRef();\n const bodyInnerRef = useRef();\n const [uuid] = useState(uuidProp || (() => uuidv4()));\n const [hasScroll, setHasScroll] = useState(false);\n const [isRowDragging, setIsRowDragging] = useState(false);\n const isScrolling = useRef();\n const shouldRefocus = useRef(); // todo: we probably need a plugin for focus related stuff\n const [RowsObserver] = useState(() => new VolatileRowsListener());\n\n // todo move this with rows composition\n const [originalRows, updateRows] = useDerivedStateFromProps(rows, {\n onUpdate: resolve.resolve({\n columns,\n method: (extra) =>\n compose(\n resolve.byFunction('valueTransformation')(extra),\n resolve.nested(extra),\n ),\n }),\n updateOnStateChange: true,\n });\n\n instance.current = {\n decoratedRenderers: cloneDeep(renderers),\n decoratedColumns: columns,\n columns,\n rows,\n composedRows: originalRows,\n getRowProps: [],\n getHeaderRowProps: [],\n getBodyProps: [],\n getTableProps: [],\n effects: [],\n uuid,\n props,\n refs: {\n table: tableRef,\n body: bodyRef,\n header: headerRef,\n innerBody: bodyInnerRef,\n },\n state: {\n hasScroll,\n },\n actions: {\n updateRows,\n },\n updateRows,\n // eslint-disable-next-line no-return-assign\n enableEvents: () =>\n (document.body.style.pointerEvents = IS_INTERNET_EXPLORER ? '' : null),\n // eslint-disable-next-line no-return-assign\n disableEvents: () => (document.body.style.pointerEvents = 'none'),\n observeRows: (observer) => RowsObserver.observe(observer),\n hotKeys: {},\n shouldRefocus,\n isScrolling,\n setHasScroll,\n setIsRowDragging,\n isRowDragging,\n plugins,\n };\n instance.current.getState = () => instance.current.state;\n instance.current.getInstance = () => instance.current;\n\n const defaultDecorators = {\n decorateGrid: [],\n registerStateHook: [],\n registerHotKeys: [],\n decorateColumn: [],\n decorateColumns: [\n (cols) =>\n cols.map((col) =>\n initColumnDefinition({\n useTextTruncation: col.useTextTruncation,\n wrapText: props.wrapText,\n normalize: props.normalizeDataKeys,\n })(col),\n ),\n ],\n decorateRenderers: [],\n getRowProps: [],\n getHeaderRowProps: [],\n getBodyProps: [],\n getTableProps: [],\n getHeaderProps: [],\n composeRows: [],\n };\n\n const decorators = useMemo(() => {\n let nextDecorators = defaultDecorators;\n // eslint-disable-next-line no-return-assign\n plugins.forEach((plugin) => (nextDecorators = plugin(nextDecorators)));\n return nextDecorators;\n }, [plugins]);\n\n instance.current = decorators.decorateGrid.reduce(\n (nextInstance, decorator) => ({\n ...nextInstance,\n ...decorator(instance.current),\n }),\n instance.current,\n );\n\n instance.current = decorators.registerStateHook.reduce(\n (nextInstance, decorator) => {\n const { state, actions } = decorator(instance.current);\n return {\n ...nextInstance,\n state: {\n ...nextInstance.state,\n ...state,\n },\n actions: {\n ...nextInstance.actions,\n ...actions,\n },\n };\n },\n instance.current,\n );\n\n const reduceHotKey = (nextInstance, { key, handler, options }) => ({\n ...nextInstance,\n hotKeys: {\n ...nextInstance.hotKeys,\n [key]: { handler, options },\n },\n });\n instance.current = decorators.registerHotKeys.reduce(\n (nextInstance, decorator) => {\n const hotKeys = decorator(nextInstance);\n if (Array.isArray(hotKeys)) {\n return hotKeys.reduce(reduceHotKey, nextInstance);\n }\n return reduceHotKey(nextInstance, hotKeys);\n },\n instance.current,\n );\n\n instance.current.decoratedRenderers = applyDecorators(\n instance.current.decoratedRenderers,\n decorators.decorateRenderers,\n instance.current,\n );\n\n instance.current.decoratedColumns = useMemo(() => {\n const visibleColumns = cloneDeep(columns).filter(\n (column) => typeof column.visible === 'undefined' || column.visible,\n );\n return visibleColumns.length\n ? decorateColumns(visibleColumns, decorators, instance.current)\n : [];\n }, [columns]);\n\n instance.current.getBodyProps = reducePropsGetter(\n decorators.getBodyProps,\n instance.current,\n );\n instance.current.getHeaderProps = reducePropsGetter(\n decorators.getHeaderProps,\n instance.current,\n );\n instance.current.getRowProps = reducePropsGetter(\n decorators.getRowProps,\n instance.current,\n );\n instance.current.getHeaderRowProps = reducePropsGetter(\n decorators.getHeaderRowProps,\n instance.current,\n );\n instance.current.getTableProps = reducePropsGetter(\n decorators.getTableProps,\n instance.current,\n );\n\n instance.current.composedRows = decorators.composeRows.reduce(\n (nextRows, getter) => getter(nextRows, instance.current),\n instance.current.composedRows,\n );\n\n RowsObserver.notify(instance.current.composedRows);\n\n const currentShouldRefocus = instance.current.shouldRefocus.current;\n const prevState = usePrevious(instance.current.state);\n if (isObject(currentShouldRefocus) && currentShouldRefocus.forced) {\n instance.current.shouldRefocus.current = currentShouldRefocus.value;\n } else {\n instance.current.shouldRefocus.current = !isEqual(\n prevState,\n instance.current.state,\n );\n }\n\n if (props.instanceRef) setRef(props.instanceRef, instance.current);\n\n return {\n ...instance.current,\n decorators,\n };\n};\n\nexport default useDataGrid;\n\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,7 @@
1
+ import * as React from "react";
2
+ import { default as default2, default as default3 } from "./useDataList";
3
+ export {
4
+ default2 as default,
5
+ default3 as useDataList
6
+ };
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/useDataList/index.tsx"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "export { default, default as useDataList } from './useDataList';\n"],
5
+ "mappings": "AAAA;ACAA;",
6
+ "names": []
7
+ }
@@ -0,0 +1,26 @@
1
+ import * as React from "react";
2
+ const defaultStrategy = () => {
3
+ throw Error("Implement an iterator strategy for record iterator");
4
+ };
5
+ function recordIterator(records, strategy = defaultStrategy, decorators = [], instance) {
6
+ const nextRows = [];
7
+ strategy({
8
+ data: records,
9
+ cb: (row) => {
10
+ let nextRow = row;
11
+ for (let i = 0; i < decorators.length; i++) {
12
+ nextRow = decorators[i](nextRow, instance);
13
+ if (!nextRow)
14
+ break;
15
+ }
16
+ if (nextRow)
17
+ nextRows.push(nextRow);
18
+ },
19
+ instance
20
+ });
21
+ return nextRows;
22
+ }
23
+ export {
24
+ recordIterator
25
+ };
26
+ //# sourceMappingURL=recordIterator.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/useDataList/recordIterator.tsx"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "const defaultStrategy = () => {\n throw Error('Implement an iterator strategy for record iterator');\n};\n\nexport function recordIterator(\n records,\n strategy = defaultStrategy,\n decorators = [],\n instance,\n) {\n const nextRows = [];\n\n strategy({\n data: records,\n cb: row => {\n let nextRow = row;\n\n // eslint-disable-next-line no-loops/no-loops,no-plusplus\n for (let i = 0; i < decorators.length; i++) {\n nextRow = decorators[i](nextRow, instance);\n if (!nextRow) break;\n }\n\n if (nextRow) nextRows.push(nextRow);\n },\n instance,\n });\n\n return nextRows;\n}\n"],
5
+ "mappings": "AAAA;ACAA,MAAM,kBAAkB,MAAM;AAC5B,QAAM,MAAM;AAAA;AAGP,wBACL,SACA,WAAW,iBACX,aAAa,IACb,UACA;AACA,QAAM,WAAW;AAEjB,WAAS;AAAA,IACP,MAAM;AAAA,IACN,IAAI,SAAO;AACT,UAAI,UAAU;AAGd,eAAS,IAAI,GAAG,IAAI,WAAW,QAAQ,KAAK;AAC1C,kBAAU,WAAW,GAAG,SAAS;AACjC,YAAI,CAAC;AAAS;AAAA;AAGhB,UAAI;AAAS,iBAAS,KAAK;AAAA;AAAA,IAE7B;AAAA;AAGF,SAAO;AAAA;",
6
+ "names": []
7
+ }