@gravity-ui/data-source 0.6.1 → 0.8.0

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 (278) hide show
  1. package/README.md +752 -15
  2. package/build/cjs/core/index.d.ts +3 -1
  3. package/build/cjs/core/index.js +7 -0
  4. package/build/cjs/core/index.js.map +1 -1
  5. package/build/cjs/core/types/DataManager.d.ts +5 -0
  6. package/build/cjs/core/types/DataManager.js.map +1 -1
  7. package/build/cjs/core/types/DataSource.d.ts +15 -19
  8. package/build/cjs/core/types/DataSource.js.map +1 -1
  9. package/build/cjs/core/types/Normalizer.d.ts +29 -0
  10. package/build/cjs/core/types/Normalizer.js +6 -0
  11. package/build/cjs/core/types/Normalizer.js.map +1 -0
  12. package/build/cjs/core/utils/__tests__/composeFullKey.test.js +34 -0
  13. package/build/cjs/core/utils/__tests__/composeFullKey.test.js.map +1 -0
  14. package/build/cjs/core/utils/__tests__/composeKey.test.js +32 -0
  15. package/build/cjs/core/utils/__tests__/composeKey.test.js.map +1 -0
  16. package/build/cjs/core/utils/__tests__/getError.test.js +31 -0
  17. package/build/cjs/core/utils/__tests__/getError.test.js.map +1 -0
  18. package/build/cjs/core/utils/__tests__/getStatus.test.js +49 -0
  19. package/build/cjs/core/utils/__tests__/getStatus.test.js.map +1 -0
  20. package/build/cjs/core/utils/__tests__/hasTag.test.js +31 -0
  21. package/build/cjs/core/utils/__tests__/hasTag.test.js.map +1 -0
  22. package/build/cjs/core/utils/__tests__/mergeStatuses.test.js +25 -0
  23. package/build/cjs/core/utils/__tests__/mergeStatuses.test.js.map +1 -0
  24. package/build/cjs/core/utils/__tests__/skipContext.test.js +70 -0
  25. package/build/cjs/core/utils/__tests__/skipContext.test.js.map +1 -0
  26. package/build/cjs/core/utils/__tests__/withCancellation.test.js +106 -0
  27. package/build/cjs/core/utils/__tests__/withCancellation.test.js.map +1 -0
  28. package/build/cjs/core/utils/__tests__/withCatch.test.js +208 -0
  29. package/build/cjs/core/utils/__tests__/withCatch.test.js.map +1 -0
  30. package/build/cjs/core/utils/withCatch.d.ts +26 -0
  31. package/build/cjs/core/utils/withCatch.js +37 -0
  32. package/build/cjs/core/utils/withCatch.js.map +1 -0
  33. package/build/cjs/react/DataManagerProvider.d.ts +7 -0
  34. package/build/cjs/react/DataManagerProvider.js +19 -0
  35. package/build/cjs/react/DataManagerProvider.js.map +1 -0
  36. package/build/cjs/react/__tests__/DataManagerContext.test.js +47 -0
  37. package/build/cjs/react/__tests__/DataManagerContext.test.js.map +1 -0
  38. package/build/cjs/react/__tests__/withDataManager.test.js +61 -0
  39. package/build/cjs/react/__tests__/withDataManager.test.js.map +1 -0
  40. package/build/cjs/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js +187 -0
  41. package/build/cjs/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js.map +1 -0
  42. package/build/cjs/react/components/DataLoader/__tests__/DataLoader.test.js +119 -0
  43. package/build/cjs/react/components/DataLoader/__tests__/DataLoader.test.js.map +1 -0
  44. package/build/cjs/react/index.d.ts +2 -0
  45. package/build/cjs/react/index.js +8 -0
  46. package/build/cjs/react/index.js.map +1 -1
  47. package/build/cjs/react/withDataManager.d.ts +1 -1
  48. package/build/cjs/react/withDataManager.js +3 -3
  49. package/build/cjs/react/withDataManager.js.map +1 -1
  50. package/build/cjs/react-query/ClientDataManager.d.ts +11 -2
  51. package/build/cjs/react-query/ClientDataManager.js +76 -9
  52. package/build/cjs/react-query/ClientDataManager.js.map +1 -1
  53. package/build/cjs/react-query/DataSourceProvider.d.ts +7 -0
  54. package/build/cjs/react-query/DataSourceProvider.js +35 -0
  55. package/build/cjs/react-query/DataSourceProvider.js.map +1 -0
  56. package/build/cjs/react-query/__tests__/createQueryNormalizer.test.js +177 -0
  57. package/build/cjs/react-query/__tests__/createQueryNormalizer.test.js.map +1 -0
  58. package/build/cjs/react-query/__tests__/normalizationEdgeCases.test.js +100 -0
  59. package/build/cjs/react-query/__tests__/normalizationEdgeCases.test.js.map +1 -0
  60. package/build/cjs/react-query/__tests__/subscriptions.test.js +1180 -0
  61. package/build/cjs/react-query/__tests__/subscriptions.test.js.map +1 -0
  62. package/build/cjs/react-query/__tests__/threeLevelIntegration.test.js +514 -0
  63. package/build/cjs/react-query/__tests__/threeLevelIntegration.test.js.map +1 -0
  64. package/build/cjs/react-query/__tests__/updateQueriesFromMutationData.test.js +229 -0
  65. package/build/cjs/react-query/__tests__/updateQueriesFromMutationData.test.js.map +1 -0
  66. package/build/cjs/react-query/constants.d.ts +2 -0
  67. package/build/cjs/react-query/constants.js +9 -0
  68. package/build/cjs/react-query/constants.js.map +1 -0
  69. package/build/cjs/react-query/hooks/__tests__/useQueryContext.test.js +55 -0
  70. package/build/cjs/react-query/hooks/__tests__/useQueryContext.test.js.map +1 -0
  71. package/build/cjs/react-query/hooks/__tests__/useQueryData.refetch.test.js +195 -0
  72. package/build/cjs/react-query/hooks/__tests__/useQueryData.refetch.test.js.map +1 -0
  73. package/build/cjs/react-query/hooks/__tests__/useQueryData.test.js +97 -0
  74. package/build/cjs/react-query/hooks/__tests__/useQueryData.test.js.map +1 -0
  75. package/build/cjs/react-query/hooks/__tests__/useQueryResponses.test.js +77 -0
  76. package/build/cjs/react-query/hooks/__tests__/useQueryResponses.test.js.map +1 -0
  77. package/build/cjs/react-query/hooks/__tests__/useRefetchAll.test.js +79 -0
  78. package/build/cjs/react-query/hooks/__tests__/useRefetchAll.test.js.map +1 -0
  79. package/build/cjs/react-query/hooks/__tests__/useRefetchErrored.test.js +117 -0
  80. package/build/cjs/react-query/hooks/__tests__/useRefetchErrored.test.js.map +1 -0
  81. package/build/cjs/react-query/hooks/__tests__/useRefetchInterval.test.js +156 -0
  82. package/build/cjs/react-query/hooks/__tests__/useRefetchInterval.test.js.map +1 -0
  83. package/build/cjs/react-query/hooks/useRefetchInterval.d.ts +1 -1
  84. package/build/cjs/react-query/impl/infinite/factory.d.ts +1 -1
  85. package/build/cjs/react-query/impl/infinite/factory.js.map +1 -1
  86. package/build/cjs/react-query/impl/infinite/hooks.js +4 -1
  87. package/build/cjs/react-query/impl/infinite/hooks.js.map +1 -1
  88. package/build/cjs/react-query/impl/infinite/types.d.ts +9 -9
  89. package/build/cjs/react-query/impl/infinite/types.js.map +1 -1
  90. package/build/cjs/react-query/impl/infinite/utils.js +11 -22
  91. package/build/cjs/react-query/impl/infinite/utils.js.map +1 -1
  92. package/build/cjs/react-query/impl/plain/factory.d.ts +1 -1
  93. package/build/cjs/react-query/impl/plain/factory.js.map +1 -1
  94. package/build/cjs/react-query/impl/plain/hooks.js +4 -1
  95. package/build/cjs/react-query/impl/plain/hooks.js.map +1 -1
  96. package/build/cjs/react-query/impl/plain/types.d.ts +6 -6
  97. package/build/cjs/react-query/impl/plain/types.js.map +1 -1
  98. package/build/cjs/react-query/impl/plain/utils.js +12 -23
  99. package/build/cjs/react-query/impl/plain/utils.js.map +1 -1
  100. package/build/cjs/react-query/index.d.ts +2 -0
  101. package/build/cjs/react-query/index.js +7 -0
  102. package/build/cjs/react-query/index.js.map +1 -1
  103. package/build/cjs/react-query/types/normalizer.d.ts +21 -0
  104. package/build/cjs/react-query/types/normalizer.js +6 -0
  105. package/build/cjs/react-query/types/normalizer.js.map +1 -0
  106. package/build/cjs/react-query/types/options.d.ts +12 -0
  107. package/build/cjs/react-query/types/options.js.map +1 -1
  108. package/build/cjs/react-query/utils/__tests__/formatNullableValue.test.js +27 -0
  109. package/build/cjs/react-query/utils/__tests__/formatNullableValue.test.js.map +1 -0
  110. package/build/cjs/react-query/utils/__tests__/getProgressiveRefetch.test.js +76 -0
  111. package/build/cjs/react-query/utils/__tests__/getProgressiveRefetch.test.js.map +1 -0
  112. package/build/cjs/react-query/utils/__tests__/normalizeStatus.test.js +30 -0
  113. package/build/cjs/react-query/utils/__tests__/normalizeStatus.test.js.map +1 -0
  114. package/build/cjs/react-query/utils/__tests__/notReachable.test.js +35 -0
  115. package/build/cjs/react-query/utils/__tests__/notReachable.test.js.map +1 -0
  116. package/build/cjs/react-query/utils/__tests__/parseNullableValue.test.js +27 -0
  117. package/build/cjs/react-query/utils/__tests__/parseNullableValue.test.js.map +1 -0
  118. package/build/cjs/react-query/utils/formatNullableValue.d.ts +2 -0
  119. package/build/cjs/react-query/utils/formatNullableValue.js +17 -0
  120. package/build/cjs/react-query/utils/formatNullableValue.js.map +1 -0
  121. package/build/cjs/react-query/utils/getProgressiveRefetch.d.ts +2 -2
  122. package/build/cjs/react-query/utils/normalize.d.ts +22 -0
  123. package/build/cjs/react-query/utils/normalize.js +150 -0
  124. package/build/cjs/react-query/utils/normalize.js.map +1 -0
  125. package/build/cjs/react-query/utils/parseNullableValue.d.ts +2 -0
  126. package/build/cjs/react-query/utils/parseNullableValue.js +17 -0
  127. package/build/cjs/react-query/utils/parseNullableValue.js.map +1 -0
  128. package/build/cjs/react-query/utils/warn.d.ts +1 -0
  129. package/build/cjs/react-query/utils/warn.js +15 -0
  130. package/build/cjs/react-query/utils/warn.js.map +1 -0
  131. package/build/cjs/react-query/utils/warnDisabledRefetch.d.ts +1 -0
  132. package/build/cjs/react-query/utils/warnDisabledRefetch.js +11 -0
  133. package/build/cjs/react-query/utils/warnDisabledRefetch.js.map +1 -0
  134. package/build/cjs/setupTests.d.ts +1 -0
  135. package/build/cjs/setupTests.js +4 -0
  136. package/build/cjs/setupTests.js.map +1 -0
  137. package/build/esm/core/index.d.ts +3 -1
  138. package/build/esm/core/index.js +1 -0
  139. package/build/esm/core/index.js.map +1 -1
  140. package/build/esm/core/types/DataManager.d.ts +5 -0
  141. package/build/esm/core/types/DataManager.js.map +1 -1
  142. package/build/esm/core/types/DataSource.d.ts +15 -19
  143. package/build/esm/core/types/DataSource.js.map +1 -1
  144. package/build/esm/core/types/Normalizer.d.ts +29 -0
  145. package/build/esm/core/types/Normalizer.js +2 -0
  146. package/build/esm/core/types/Normalizer.js.map +1 -0
  147. package/build/esm/core/utils/__tests__/composeFullKey.test.js +32 -0
  148. package/build/esm/core/utils/__tests__/composeFullKey.test.js.map +1 -0
  149. package/build/esm/core/utils/__tests__/composeKey.test.js +30 -0
  150. package/build/esm/core/utils/__tests__/composeKey.test.js.map +1 -0
  151. package/build/esm/core/utils/__tests__/getError.test.js +29 -0
  152. package/build/esm/core/utils/__tests__/getError.test.js.map +1 -0
  153. package/build/esm/core/utils/__tests__/getStatus.test.js +47 -0
  154. package/build/esm/core/utils/__tests__/getStatus.test.js.map +1 -0
  155. package/build/esm/core/utils/__tests__/hasTag.test.js +29 -0
  156. package/build/esm/core/utils/__tests__/hasTag.test.js.map +1 -0
  157. package/build/esm/core/utils/__tests__/mergeStatuses.test.js +23 -0
  158. package/build/esm/core/utils/__tests__/mergeStatuses.test.js.map +1 -0
  159. package/build/esm/core/utils/__tests__/skipContext.test.js +67 -0
  160. package/build/esm/core/utils/__tests__/skipContext.test.js.map +1 -0
  161. package/build/esm/core/utils/__tests__/withCancellation.test.js +104 -0
  162. package/build/esm/core/utils/__tests__/withCancellation.test.js.map +1 -0
  163. package/build/esm/core/utils/__tests__/withCatch.test.js +205 -0
  164. package/build/esm/core/utils/__tests__/withCatch.test.js.map +1 -0
  165. package/build/esm/core/utils/withCatch.d.ts +26 -0
  166. package/build/esm/core/utils/withCatch.js +31 -0
  167. package/build/esm/core/utils/withCatch.js.map +1 -0
  168. package/build/esm/react/DataManagerProvider.d.ts +7 -0
  169. package/build/esm/react/DataManagerProvider.js +12 -0
  170. package/build/esm/react/DataManagerProvider.js.map +1 -0
  171. package/build/esm/react/__tests__/DataManagerContext.test.js +44 -0
  172. package/build/esm/react/__tests__/DataManagerContext.test.js.map +1 -0
  173. package/build/esm/react/__tests__/withDataManager.test.js +58 -0
  174. package/build/esm/react/__tests__/withDataManager.test.js.map +1 -0
  175. package/build/esm/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js +184 -0
  176. package/build/esm/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js.map +1 -0
  177. package/build/esm/react/components/DataLoader/__tests__/DataLoader.test.js +116 -0
  178. package/build/esm/react/components/DataLoader/__tests__/DataLoader.test.js.map +1 -0
  179. package/build/esm/react/index.d.ts +2 -0
  180. package/build/esm/react/index.js +1 -0
  181. package/build/esm/react/index.js.map +1 -1
  182. package/build/esm/react/withDataManager.d.ts +1 -1
  183. package/build/esm/react/withDataManager.js +3 -3
  184. package/build/esm/react/withDataManager.js.map +1 -1
  185. package/build/esm/react-query/ClientDataManager.d.ts +11 -2
  186. package/build/esm/react-query/ClientDataManager.js +70 -3
  187. package/build/esm/react-query/ClientDataManager.js.map +1 -1
  188. package/build/esm/react-query/DataSourceProvider.d.ts +7 -0
  189. package/build/esm/react-query/DataSourceProvider.js +28 -0
  190. package/build/esm/react-query/DataSourceProvider.js.map +1 -0
  191. package/build/esm/react-query/__tests__/createQueryNormalizer.test.js +174 -0
  192. package/build/esm/react-query/__tests__/createQueryNormalizer.test.js.map +1 -0
  193. package/build/esm/react-query/__tests__/normalizationEdgeCases.test.js +98 -0
  194. package/build/esm/react-query/__tests__/normalizationEdgeCases.test.js.map +1 -0
  195. package/build/esm/react-query/__tests__/subscriptions.test.js +1176 -0
  196. package/build/esm/react-query/__tests__/subscriptions.test.js.map +1 -0
  197. package/build/esm/react-query/__tests__/threeLevelIntegration.test.js +511 -0
  198. package/build/esm/react-query/__tests__/threeLevelIntegration.test.js.map +1 -0
  199. package/build/esm/react-query/__tests__/updateQueriesFromMutationData.test.js +227 -0
  200. package/build/esm/react-query/__tests__/updateQueriesFromMutationData.test.js.map +1 -0
  201. package/build/esm/react-query/constants.d.ts +2 -0
  202. package/build/esm/react-query/constants.js +3 -0
  203. package/build/esm/react-query/constants.js.map +1 -0
  204. package/build/esm/react-query/hooks/__tests__/useQueryContext.test.js +52 -0
  205. package/build/esm/react-query/hooks/__tests__/useQueryContext.test.js.map +1 -0
  206. package/build/esm/react-query/hooks/__tests__/useQueryData.refetch.test.js +192 -0
  207. package/build/esm/react-query/hooks/__tests__/useQueryData.refetch.test.js.map +1 -0
  208. package/build/esm/react-query/hooks/__tests__/useQueryData.test.js +95 -0
  209. package/build/esm/react-query/hooks/__tests__/useQueryData.test.js.map +1 -0
  210. package/build/esm/react-query/hooks/__tests__/useQueryResponses.test.js +74 -0
  211. package/build/esm/react-query/hooks/__tests__/useQueryResponses.test.js.map +1 -0
  212. package/build/esm/react-query/hooks/__tests__/useRefetchAll.test.js +77 -0
  213. package/build/esm/react-query/hooks/__tests__/useRefetchAll.test.js.map +1 -0
  214. package/build/esm/react-query/hooks/__tests__/useRefetchErrored.test.js +115 -0
  215. package/build/esm/react-query/hooks/__tests__/useRefetchErrored.test.js.map +1 -0
  216. package/build/esm/react-query/hooks/__tests__/useRefetchInterval.test.js +154 -0
  217. package/build/esm/react-query/hooks/__tests__/useRefetchInterval.test.js.map +1 -0
  218. package/build/esm/react-query/hooks/useRefetchInterval.d.ts +1 -1
  219. package/build/esm/react-query/impl/infinite/factory.d.ts +1 -1
  220. package/build/esm/react-query/impl/infinite/factory.js.map +1 -1
  221. package/build/esm/react-query/impl/infinite/hooks.js +5 -2
  222. package/build/esm/react-query/impl/infinite/hooks.js.map +1 -1
  223. package/build/esm/react-query/impl/infinite/types.d.ts +9 -9
  224. package/build/esm/react-query/impl/infinite/types.js.map +1 -1
  225. package/build/esm/react-query/impl/infinite/utils.js +9 -20
  226. package/build/esm/react-query/impl/infinite/utils.js.map +1 -1
  227. package/build/esm/react-query/impl/plain/factory.d.ts +1 -1
  228. package/build/esm/react-query/impl/plain/factory.js.map +1 -1
  229. package/build/esm/react-query/impl/plain/hooks.js +5 -2
  230. package/build/esm/react-query/impl/plain/hooks.js.map +1 -1
  231. package/build/esm/react-query/impl/plain/types.d.ts +6 -6
  232. package/build/esm/react-query/impl/plain/types.js.map +1 -1
  233. package/build/esm/react-query/impl/plain/utils.js +10 -21
  234. package/build/esm/react-query/impl/plain/utils.js.map +1 -1
  235. package/build/esm/react-query/index.d.ts +2 -0
  236. package/build/esm/react-query/index.js +1 -0
  237. package/build/esm/react-query/index.js.map +1 -1
  238. package/build/esm/react-query/types/normalizer.d.ts +21 -0
  239. package/build/esm/react-query/types/normalizer.js +2 -0
  240. package/build/esm/react-query/types/normalizer.js.map +1 -0
  241. package/build/esm/react-query/types/options.d.ts +12 -0
  242. package/build/esm/react-query/types/options.js.map +1 -1
  243. package/build/esm/react-query/utils/__tests__/formatNullableValue.test.js +25 -0
  244. package/build/esm/react-query/utils/__tests__/formatNullableValue.test.js.map +1 -0
  245. package/build/esm/react-query/utils/__tests__/getProgressiveRefetch.test.js +74 -0
  246. package/build/esm/react-query/utils/__tests__/getProgressiveRefetch.test.js.map +1 -0
  247. package/build/esm/react-query/utils/__tests__/normalizeStatus.test.js +28 -0
  248. package/build/esm/react-query/utils/__tests__/normalizeStatus.test.js.map +1 -0
  249. package/build/esm/react-query/utils/__tests__/notReachable.test.js +33 -0
  250. package/build/esm/react-query/utils/__tests__/notReachable.test.js.map +1 -0
  251. package/build/esm/react-query/utils/__tests__/parseNullableValue.test.js +25 -0
  252. package/build/esm/react-query/utils/__tests__/parseNullableValue.test.js.map +1 -0
  253. package/build/esm/react-query/utils/formatNullableValue.d.ts +2 -0
  254. package/build/esm/react-query/utils/formatNullableValue.js +11 -0
  255. package/build/esm/react-query/utils/formatNullableValue.js.map +1 -0
  256. package/build/esm/react-query/utils/getProgressiveRefetch.d.ts +2 -2
  257. package/build/esm/react-query/utils/normalize.d.ts +22 -0
  258. package/build/esm/react-query/utils/normalize.js +143 -0
  259. package/build/esm/react-query/utils/normalize.js.map +1 -0
  260. package/build/esm/react-query/utils/parseNullableValue.d.ts +2 -0
  261. package/build/esm/react-query/utils/parseNullableValue.js +11 -0
  262. package/build/esm/react-query/utils/parseNullableValue.js.map +1 -0
  263. package/build/esm/react-query/utils/warn.d.ts +1 -0
  264. package/build/esm/react-query/utils/warn.js +9 -0
  265. package/build/esm/react-query/utils/warn.js.map +1 -0
  266. package/build/esm/react-query/utils/warnDisabledRefetch.d.ts +1 -0
  267. package/build/esm/react-query/utils/warnDisabledRefetch.js +5 -0
  268. package/build/esm/react-query/utils/warnDisabledRefetch.js.map +1 -0
  269. package/build/esm/setupTests.d.ts +1 -0
  270. package/build/esm/setupTests.js +2 -0
  271. package/build/esm/setupTests.js.map +1 -0
  272. package/package.json +18 -13
  273. package/build/cjs/react-query/impl/utils.d.ts +0 -4
  274. package/build/cjs/react-query/impl/utils.js +0 -27
  275. package/build/cjs/react-query/impl/utils.js.map +0 -1
  276. package/build/esm/react-query/impl/utils.d.ts +0 -4
  277. package/build/esm/react-query/impl/utils.js +0 -21
  278. package/build/esm/react-query/impl/utils.js.map +0 -1
@@ -0,0 +1,187 @@
1
+ "use strict";
2
+
3
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
4
+ var _react = _interopRequireDefault(require("react"));
5
+ var _react2 = require("@testing-library/react");
6
+ var _DataInfiniteLoader = require("../DataInfiniteLoader");
7
+ var _jsxRuntime = require("react/jsx-runtime");
8
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
9
+ var MockLoadingView = function MockLoadingView() {
10
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
11
+ "data-testid": "loading-view",
12
+ children: "Loading..."
13
+ });
14
+ };
15
+ var MockErrorView = function MockErrorView(_ref) {
16
+ var error = _ref.error,
17
+ action = _ref.action;
18
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
19
+ "data-testid": "error-view",
20
+ children: [error ? "Error: ".concat(error.message) : 'No error', action ? /*#__PURE__*/(0, _jsxRuntime.jsx)("button", {
21
+ "data-testid": "error-action",
22
+ onClick: action.handler,
23
+ children: action.children || 'Retry'
24
+ }) : null]
25
+ });
26
+ };
27
+ var MockMoreView = function MockMoreView(_ref2) {
28
+ var isLoading = _ref2.isLoading,
29
+ onClick = _ref2.onClick;
30
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
31
+ "data-testid": "more-view",
32
+ children: isLoading ? /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
33
+ "data-testid": "more-view-loading",
34
+ children: "Loading more..."
35
+ }) : /*#__PURE__*/(0, _jsxRuntime.jsx)("button", {
36
+ "data-testid": "more-view-button",
37
+ onClick: onClick,
38
+ children: "Load more"
39
+ })
40
+ });
41
+ };
42
+ describe('DataInfiniteLoader', function () {
43
+ var renderDataInfiniteLoader = function renderDataInfiniteLoader() {
44
+ var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
45
+ var fetchNextPage = jest.fn();
46
+ var defaultProps = {
47
+ status: 'success',
48
+ error: null,
49
+ hasNextPage: true,
50
+ fetchNextPage: fetchNextPage,
51
+ isFetchingNextPage: false,
52
+ LoadingView: MockLoadingView,
53
+ ErrorView: MockErrorView,
54
+ MoreView: MockMoreView,
55
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
56
+ "data-testid": "content",
57
+ children: "Content"
58
+ })
59
+ };
60
+ return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, (0, _react2.render)(/*#__PURE__*/(0, _jsxRuntime.jsx)(_DataInfiniteLoader.DataInfiniteLoader, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, defaultProps), props)))), {}, {
61
+ fetchNextPage: fetchNextPage
62
+ });
63
+ };
64
+ it('should render children and MoreView when status is success and hasNextPage is true', function () {
65
+ renderDataInfiniteLoader({
66
+ status: 'success',
67
+ hasNextPage: true
68
+ });
69
+ expect(_react2.screen.getByTestId('content')).toBeInTheDocument();
70
+ expect(_react2.screen.getByTestId('more-view')).toBeInTheDocument();
71
+ expect(_react2.screen.queryByTestId('loading-view')).not.toBeInTheDocument();
72
+ expect(_react2.screen.queryByTestId('error-view')).not.toBeInTheDocument();
73
+ });
74
+ it('should render only children when status is success and hasNextPage is false', function () {
75
+ renderDataInfiniteLoader({
76
+ status: 'success',
77
+ hasNextPage: false
78
+ });
79
+ expect(_react2.screen.getByTestId('content')).toBeInTheDocument();
80
+ expect(_react2.screen.queryByTestId('more-view')).not.toBeInTheDocument();
81
+ expect(_react2.screen.queryByTestId('loading-view')).not.toBeInTheDocument();
82
+ expect(_react2.screen.queryByTestId('error-view')).not.toBeInTheDocument();
83
+ });
84
+ it('should render LoadingView when status is loading', function () {
85
+ renderDataInfiniteLoader({
86
+ status: 'loading'
87
+ });
88
+ expect(_react2.screen.getByTestId('loading-view')).toBeInTheDocument();
89
+ expect(_react2.screen.queryByTestId('content')).not.toBeInTheDocument();
90
+ expect(_react2.screen.queryByTestId('more-view')).not.toBeInTheDocument();
91
+ expect(_react2.screen.queryByTestId('error-view')).not.toBeInTheDocument();
92
+ });
93
+ it('should render ErrorView when status is error', function () {
94
+ var error = new Error('Test error');
95
+ renderDataInfiniteLoader({
96
+ status: 'error',
97
+ error: error
98
+ });
99
+ expect(_react2.screen.getByTestId('error-view')).toBeInTheDocument();
100
+ expect(_react2.screen.queryByTestId('content')).not.toBeInTheDocument();
101
+ expect(_react2.screen.queryByTestId('more-view')).not.toBeInTheDocument();
102
+ expect(_react2.screen.queryByTestId('loading-view')).not.toBeInTheDocument();
103
+ expect(_react2.screen.getByText(/Test error/)).toBeInTheDocument();
104
+ });
105
+ it('should call fetchNextPage when clicking on load more button', function () {
106
+ var _renderDataInfiniteLo = renderDataInfiniteLoader({
107
+ status: 'success',
108
+ hasNextPage: true,
109
+ isFetchingNextPage: false
110
+ }),
111
+ fetchNextPage = _renderDataInfiniteLo.fetchNextPage;
112
+ _react2.fireEvent.click(_react2.screen.getByTestId('more-view-button'));
113
+ expect(fetchNextPage).toHaveBeenCalledTimes(1);
114
+ });
115
+ it('should show loading state in MoreView when isFetchingNextPage is true', function () {
116
+ renderDataInfiniteLoader({
117
+ status: 'success',
118
+ hasNextPage: true,
119
+ isFetchingNextPage: true
120
+ });
121
+ expect(_react2.screen.getByTestId('more-view-loading')).toBeInTheDocument();
122
+ expect(_react2.screen.queryByTestId('more-view-button')).not.toBeInTheDocument();
123
+ });
124
+ it('should pass errorAction to ErrorView', function () {
125
+ var error = new Error('Test error');
126
+ var errorAction = jest.fn();
127
+ renderDataInfiniteLoader({
128
+ status: 'error',
129
+ error: error,
130
+ errorAction: errorAction
131
+ });
132
+ expect(_react2.screen.getByTestId('error-action')).toBeInTheDocument();
133
+ });
134
+ it('should pass errorAction with custom children to ErrorView', function () {
135
+ var error = new Error('Test error');
136
+ var errorAction = {
137
+ handler: jest.fn(),
138
+ children: 'Custom action'
139
+ };
140
+ renderDataInfiniteLoader({
141
+ status: 'error',
142
+ error: error,
143
+ errorAction: errorAction
144
+ });
145
+ expect(_react2.screen.getByText('Custom action')).toBeInTheDocument();
146
+ });
147
+ it('should pass loadingViewProps to LoadingView', function () {
148
+ var LoadingView = jest.fn(MockLoadingView);
149
+ var loadingViewProps = {
150
+ customProp: 'test'
151
+ };
152
+ renderDataInfiniteLoader({
153
+ status: 'loading',
154
+ LoadingView: LoadingView,
155
+ loadingViewProps: loadingViewProps
156
+ });
157
+ expect(LoadingView).toHaveBeenCalledWith(expect.objectContaining(loadingViewProps), undefined);
158
+ });
159
+ it('should pass errorViewProps to ErrorView', function () {
160
+ var ErrorView = jest.fn(MockErrorView);
161
+ var errorViewProps = {
162
+ customProp: 'test'
163
+ };
164
+ var error = new Error('Test error');
165
+ renderDataInfiniteLoader({
166
+ status: 'error',
167
+ error: error,
168
+ ErrorView: ErrorView,
169
+ errorViewProps: errorViewProps
170
+ });
171
+ expect(ErrorView).toHaveBeenCalledWith(expect.objectContaining(errorViewProps), undefined);
172
+ });
173
+ it('should pass moreViewProps to MoreView', function () {
174
+ var MoreView = jest.fn(MockMoreView);
175
+ var moreViewProps = {
176
+ customProp: 'test'
177
+ };
178
+ renderDataInfiniteLoader({
179
+ status: 'success',
180
+ hasNextPage: true,
181
+ MoreView: MoreView,
182
+ moreViewProps: moreViewProps
183
+ });
184
+ expect(MoreView).toHaveBeenCalledWith(expect.objectContaining(moreViewProps), undefined);
185
+ });
186
+ });
187
+ // #sourceMappingURL=DataInfiniteLoader.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_react","_interopRequireDefault","require","_react2","_DataInfiniteLoader","_jsxRuntime","e","__esModule","default","MockLoadingView","_jsx","children","MockErrorView","_ref","error","action","_jsxs","concat","message","onClick","handler","MockMoreView","_ref2","isLoading","describe","renderDataInfiniteLoader","props","arguments","length","undefined","fetchNextPage","jest","fn","defaultProps","status","hasNextPage","isFetchingNextPage","LoadingView","ErrorView","MoreView","_objectSpread","render","DataInfiniteLoader","it","expect","screen","getByTestId","toBeInTheDocument","queryByTestId","not","Error","getByText","_renderDataInfiniteLo","fireEvent","click","toHaveBeenCalledTimes","errorAction","loadingViewProps","customProp","toHaveBeenCalledWith","objectContaining","errorViewProps","moreViewProps"],"sources":["DataInfiniteLoader.test.tsx"],"sourcesContent":["import React from 'react';\n\nimport {fireEvent, render, screen} from '@testing-library/react';\n\nimport type {ErrorViewProps} from '../../types';\nimport {DataInfiniteLoader} from '../DataInfiniteLoader';\nimport type {DataInfiniteLoaderProps, MoreViewProps} from '../types';\n\nconst MockLoadingView = () => <div data-testid=\"loading-view\">Loading...</div>;\nconst MockErrorView: React.FC<ErrorViewProps<Error>> = ({error, action}) => (\n <div data-testid=\"error-view\">\n {error ? `Error: ${error.message}` : 'No error'}\n {action ? (\n <button data-testid=\"error-action\" onClick={action.handler}>\n {action.children || 'Retry'}\n </button>\n ) : null}\n </div>\n);\nconst MockMoreView: React.FC<MoreViewProps> = ({isLoading, onClick}) => (\n <div data-testid=\"more-view\">\n {isLoading ? (\n <span data-testid=\"more-view-loading\">Loading more...</span>\n ) : (\n <button data-testid=\"more-view-button\" onClick={onClick}>\n Load more\n </button>\n )}\n </div>\n);\n\ndescribe('DataInfiniteLoader', () => {\n const renderDataInfiniteLoader = (props: Partial<DataInfiniteLoaderProps<Error>> = {}) => {\n const fetchNextPage = jest.fn();\n const defaultProps: DataInfiniteLoaderProps<Error> = {\n status: 'success',\n error: null,\n hasNextPage: true,\n fetchNextPage,\n isFetchingNextPage: false,\n LoadingView: MockLoadingView,\n ErrorView: MockErrorView,\n MoreView: MockMoreView,\n children: <div data-testid=\"content\">Content</div>,\n };\n\n return {\n ...render(<DataInfiniteLoader {...defaultProps} {...props} />),\n fetchNextPage,\n };\n };\n\n it('should render children and MoreView when status is success and hasNextPage is true', () => {\n renderDataInfiniteLoader({status: 'success', hasNextPage: true});\n expect(screen.getByTestId('content')).toBeInTheDocument();\n expect(screen.getByTestId('more-view')).toBeInTheDocument();\n expect(screen.queryByTestId('loading-view')).not.toBeInTheDocument();\n expect(screen.queryByTestId('error-view')).not.toBeInTheDocument();\n });\n\n it('should render only children when status is success and hasNextPage is false', () => {\n renderDataInfiniteLoader({status: 'success', hasNextPage: false});\n expect(screen.getByTestId('content')).toBeInTheDocument();\n expect(screen.queryByTestId('more-view')).not.toBeInTheDocument();\n expect(screen.queryByTestId('loading-view')).not.toBeInTheDocument();\n expect(screen.queryByTestId('error-view')).not.toBeInTheDocument();\n });\n\n it('should render LoadingView when status is loading', () => {\n renderDataInfiniteLoader({status: 'loading'});\n expect(screen.getByTestId('loading-view')).toBeInTheDocument();\n expect(screen.queryByTestId('content')).not.toBeInTheDocument();\n expect(screen.queryByTestId('more-view')).not.toBeInTheDocument();\n expect(screen.queryByTestId('error-view')).not.toBeInTheDocument();\n });\n\n it('should render ErrorView when status is error', () => {\n const error = new Error('Test error');\n renderDataInfiniteLoader({status: 'error', error});\n expect(screen.getByTestId('error-view')).toBeInTheDocument();\n expect(screen.queryByTestId('content')).not.toBeInTheDocument();\n expect(screen.queryByTestId('more-view')).not.toBeInTheDocument();\n expect(screen.queryByTestId('loading-view')).not.toBeInTheDocument();\n expect(screen.getByText(/Test error/)).toBeInTheDocument();\n });\n\n it('should call fetchNextPage when clicking on load more button', () => {\n const {fetchNextPage} = renderDataInfiniteLoader({\n status: 'success',\n hasNextPage: true,\n isFetchingNextPage: false,\n });\n fireEvent.click(screen.getByTestId('more-view-button'));\n expect(fetchNextPage).toHaveBeenCalledTimes(1);\n });\n\n it('should show loading state in MoreView when isFetchingNextPage is true', () => {\n renderDataInfiniteLoader({\n status: 'success',\n hasNextPage: true,\n isFetchingNextPage: true,\n });\n expect(screen.getByTestId('more-view-loading')).toBeInTheDocument();\n expect(screen.queryByTestId('more-view-button')).not.toBeInTheDocument();\n });\n\n it('should pass errorAction to ErrorView', () => {\n const error = new Error('Test error');\n const errorAction = jest.fn();\n renderDataInfiniteLoader({\n status: 'error',\n error,\n errorAction,\n });\n expect(screen.getByTestId('error-action')).toBeInTheDocument();\n });\n\n it('should pass errorAction with custom children to ErrorView', () => {\n const error = new Error('Test error');\n const errorAction = {\n handler: jest.fn(),\n children: 'Custom action',\n };\n renderDataInfiniteLoader({\n status: 'error',\n error,\n errorAction,\n });\n expect(screen.getByText('Custom action')).toBeInTheDocument();\n });\n\n it('should pass loadingViewProps to LoadingView', () => {\n const LoadingView = jest.fn(MockLoadingView);\n const loadingViewProps = {customProp: 'test'};\n renderDataInfiniteLoader({\n status: 'loading',\n LoadingView,\n loadingViewProps,\n });\n expect(LoadingView).toHaveBeenCalledWith(\n expect.objectContaining(loadingViewProps),\n undefined,\n );\n });\n\n it('should pass errorViewProps to ErrorView', () => {\n const ErrorView = jest.fn(MockErrorView);\n const errorViewProps = {customProp: 'test'};\n const error = new Error('Test error');\n renderDataInfiniteLoader({\n status: 'error',\n error,\n ErrorView,\n errorViewProps,\n });\n expect(ErrorView).toHaveBeenCalledWith(expect.objectContaining(errorViewProps), undefined);\n });\n\n it('should pass moreViewProps to MoreView', () => {\n const MoreView = jest.fn(MockMoreView);\n const moreViewProps = {customProp: 'test'};\n renderDataInfiniteLoader({\n status: 'success',\n hasNextPage: true,\n MoreView,\n moreViewProps,\n });\n expect(MoreView).toHaveBeenCalledWith(expect.objectContaining(moreViewProps), undefined);\n });\n});\n"],"mappings":";;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,IAAAC,OAAA,GAAAD,OAAA;AAGA,IAAAE,mBAAA,GAAAF,OAAA;AAAyD,IAAAG,WAAA,GAAAH,OAAA;AAAA,SAAAD,uBAAAK,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAGzD,IAAMG,eAAe,GAAG,SAAlBA,eAAeA,CAAA;EAAA,oBAAS,IAAAC,eAAA;IAAK,eAAY,cAAc;IAAAC,QAAA,EAAC;EAAU,CAAK,CAAC;AAAA;AAC9E,IAAMC,aAA8C,GAAG,SAAjDA,aAA8CA,CAAAC,IAAA;EAAA,IAAKC,KAAK,GAAAD,IAAA,CAALC,KAAK;IAAEC,MAAM,GAAAF,IAAA,CAANE,MAAM;EAAA,oBAClE,IAAAC,gBAAA;IAAK,eAAY,YAAY;IAAAL,QAAA,GACxBG,KAAK,aAAAG,MAAA,CAAaH,KAAK,CAACI,OAAO,IAAK,UAAU,EAC9CH,MAAM,gBACH,IAAAL,eAAA;MAAQ,eAAY,cAAc;MAACS,OAAO,EAAEJ,MAAM,CAACK,OAAQ;MAAAT,QAAA,EACtDI,MAAM,CAACJ,QAAQ,IAAI;IAAO,CACvB,CAAC,GACT,IAAI;EAAA,CACP,CAAC;AAAA,CACT;AACD,IAAMU,YAAqC,GAAG,SAAxCA,YAAqCA,CAAAC,KAAA;EAAA,IAAKC,SAAS,GAAAD,KAAA,CAATC,SAAS;IAAEJ,OAAO,GAAAG,KAAA,CAAPH,OAAO;EAAA,oBAC9D,IAAAT,eAAA;IAAK,eAAY,WAAW;IAAAC,QAAA,EACvBY,SAAS,gBACN,IAAAb,eAAA;MAAM,eAAY,mBAAmB;MAAAC,QAAA,EAAC;IAAe,CAAM,CAAC,gBAE5D,IAAAD,eAAA;MAAQ,eAAY,kBAAkB;MAACS,OAAO,EAAEA,OAAQ;MAAAR,QAAA,EAAC;IAEzD,CAAQ;EACX,CACA,CAAC;AAAA,CACT;AAEDa,QAAQ,CAAC,oBAAoB,EAAE,YAAM;EACjC,IAAMC,wBAAwB,GAAG,SAA3BA,wBAAwBA,CAAA,EAA4D;IAAA,IAAxDC,KAA8C,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;IACjF,IAAMG,aAAa,GAAGC,IAAI,CAACC,EAAE,CAAC,CAAC;IAC/B,IAAMC,YAA4C,GAAG;MACjDC,MAAM,EAAE,SAAS;MACjBpB,KAAK,EAAE,IAAI;MACXqB,WAAW,EAAE,IAAI;MACjBL,aAAa,EAAbA,aAAa;MACbM,kBAAkB,EAAE,KAAK;MACzBC,WAAW,EAAE5B,eAAe;MAC5B6B,SAAS,EAAE1B,aAAa;MACxB2B,QAAQ,EAAElB,YAAY;MACtBV,QAAQ,eAAE,IAAAD,eAAA;QAAK,eAAY,SAAS;QAAAC,QAAA,EAAC;MAAO,CAAK;IACrD,CAAC;IAED,WAAA6B,sBAAA,MAAAA,sBAAA,MACO,IAAAC,cAAM,eAAC,IAAA/B,eAAA,EAACgC,sCAAkB,MAAAF,sBAAA,MAAAA,sBAAA,MAAKP,YAAY,GAAMP,KAAK,CAAG,CAAC,CAAC;MAC9DI,aAAa,EAAbA;IAAa;EAErB,CAAC;EAEDa,EAAE,CAAC,oFAAoF,EAAE,YAAM;IAC3FlB,wBAAwB,CAAC;MAACS,MAAM,EAAE,SAAS;MAAEC,WAAW,EAAE;IAAI,CAAC,CAAC;IAChES,MAAM,CAACC,cAAM,CAACC,WAAW,CAAC,SAAS,CAAC,CAAC,CAACC,iBAAiB,CAAC,CAAC;IACzDH,MAAM,CAACC,cAAM,CAACC,WAAW,CAAC,WAAW,CAAC,CAAC,CAACC,iBAAiB,CAAC,CAAC;IAC3DH,MAAM,CAACC,cAAM,CAACG,aAAa,CAAC,cAAc,CAAC,CAAC,CAACC,GAAG,CAACF,iBAAiB,CAAC,CAAC;IACpEH,MAAM,CAACC,cAAM,CAACG,aAAa,CAAC,YAAY,CAAC,CAAC,CAACC,GAAG,CAACF,iBAAiB,CAAC,CAAC;EACtE,CAAC,CAAC;EAEFJ,EAAE,CAAC,6EAA6E,EAAE,YAAM;IACpFlB,wBAAwB,CAAC;MAACS,MAAM,EAAE,SAAS;MAAEC,WAAW,EAAE;IAAK,CAAC,CAAC;IACjES,MAAM,CAACC,cAAM,CAACC,WAAW,CAAC,SAAS,CAAC,CAAC,CAACC,iBAAiB,CAAC,CAAC;IACzDH,MAAM,CAACC,cAAM,CAACG,aAAa,CAAC,WAAW,CAAC,CAAC,CAACC,GAAG,CAACF,iBAAiB,CAAC,CAAC;IACjEH,MAAM,CAACC,cAAM,CAACG,aAAa,CAAC,cAAc,CAAC,CAAC,CAACC,GAAG,CAACF,iBAAiB,CAAC,CAAC;IACpEH,MAAM,CAACC,cAAM,CAACG,aAAa,CAAC,YAAY,CAAC,CAAC,CAACC,GAAG,CAACF,iBAAiB,CAAC,CAAC;EACtE,CAAC,CAAC;EAEFJ,EAAE,CAAC,kDAAkD,EAAE,YAAM;IACzDlB,wBAAwB,CAAC;MAACS,MAAM,EAAE;IAAS,CAAC,CAAC;IAC7CU,MAAM,CAACC,cAAM,CAACC,WAAW,CAAC,cAAc,CAAC,CAAC,CAACC,iBAAiB,CAAC,CAAC;IAC9DH,MAAM,CAACC,cAAM,CAACG,aAAa,CAAC,SAAS,CAAC,CAAC,CAACC,GAAG,CAACF,iBAAiB,CAAC,CAAC;IAC/DH,MAAM,CAACC,cAAM,CAACG,aAAa,CAAC,WAAW,CAAC,CAAC,CAACC,GAAG,CAACF,iBAAiB,CAAC,CAAC;IACjEH,MAAM,CAACC,cAAM,CAACG,aAAa,CAAC,YAAY,CAAC,CAAC,CAACC,GAAG,CAACF,iBAAiB,CAAC,CAAC;EACtE,CAAC,CAAC;EAEFJ,EAAE,CAAC,8CAA8C,EAAE,YAAM;IACrD,IAAM7B,KAAK,GAAG,IAAIoC,KAAK,CAAC,YAAY,CAAC;IACrCzB,wBAAwB,CAAC;MAACS,MAAM,EAAE,OAAO;MAAEpB,KAAK,EAALA;IAAK,CAAC,CAAC;IAClD8B,MAAM,CAACC,cAAM,CAACC,WAAW,CAAC,YAAY,CAAC,CAAC,CAACC,iBAAiB,CAAC,CAAC;IAC5DH,MAAM,CAACC,cAAM,CAACG,aAAa,CAAC,SAAS,CAAC,CAAC,CAACC,GAAG,CAACF,iBAAiB,CAAC,CAAC;IAC/DH,MAAM,CAACC,cAAM,CAACG,aAAa,CAAC,WAAW,CAAC,CAAC,CAACC,GAAG,CAACF,iBAAiB,CAAC,CAAC;IACjEH,MAAM,CAACC,cAAM,CAACG,aAAa,CAAC,cAAc,CAAC,CAAC,CAACC,GAAG,CAACF,iBAAiB,CAAC,CAAC;IACpEH,MAAM,CAACC,cAAM,CAACM,SAAS,CAAC,YAAY,CAAC,CAAC,CAACJ,iBAAiB,CAAC,CAAC;EAC9D,CAAC,CAAC;EAEFJ,EAAE,CAAC,6DAA6D,EAAE,YAAM;IACpE,IAAAS,qBAAA,GAAwB3B,wBAAwB,CAAC;QAC7CS,MAAM,EAAE,SAAS;QACjBC,WAAW,EAAE,IAAI;QACjBC,kBAAkB,EAAE;MACxB,CAAC,CAAC;MAJKN,aAAa,GAAAsB,qBAAA,CAAbtB,aAAa;IAKpBuB,iBAAS,CAACC,KAAK,CAACT,cAAM,CAACC,WAAW,CAAC,kBAAkB,CAAC,CAAC;IACvDF,MAAM,CAACd,aAAa,CAAC,CAACyB,qBAAqB,CAAC,CAAC,CAAC;EAClD,CAAC,CAAC;EAEFZ,EAAE,CAAC,uEAAuE,EAAE,YAAM;IAC9ElB,wBAAwB,CAAC;MACrBS,MAAM,EAAE,SAAS;MACjBC,WAAW,EAAE,IAAI;MACjBC,kBAAkB,EAAE;IACxB,CAAC,CAAC;IACFQ,MAAM,CAACC,cAAM,CAACC,WAAW,CAAC,mBAAmB,CAAC,CAAC,CAACC,iBAAiB,CAAC,CAAC;IACnEH,MAAM,CAACC,cAAM,CAACG,aAAa,CAAC,kBAAkB,CAAC,CAAC,CAACC,GAAG,CAACF,iBAAiB,CAAC,CAAC;EAC5E,CAAC,CAAC;EAEFJ,EAAE,CAAC,sCAAsC,EAAE,YAAM;IAC7C,IAAM7B,KAAK,GAAG,IAAIoC,KAAK,CAAC,YAAY,CAAC;IACrC,IAAMM,WAAW,GAAGzB,IAAI,CAACC,EAAE,CAAC,CAAC;IAC7BP,wBAAwB,CAAC;MACrBS,MAAM,EAAE,OAAO;MACfpB,KAAK,EAALA,KAAK;MACL0C,WAAW,EAAXA;IACJ,CAAC,CAAC;IACFZ,MAAM,CAACC,cAAM,CAACC,WAAW,CAAC,cAAc,CAAC,CAAC,CAACC,iBAAiB,CAAC,CAAC;EAClE,CAAC,CAAC;EAEFJ,EAAE,CAAC,2DAA2D,EAAE,YAAM;IAClE,IAAM7B,KAAK,GAAG,IAAIoC,KAAK,CAAC,YAAY,CAAC;IACrC,IAAMM,WAAW,GAAG;MAChBpC,OAAO,EAAEW,IAAI,CAACC,EAAE,CAAC,CAAC;MAClBrB,QAAQ,EAAE;IACd,CAAC;IACDc,wBAAwB,CAAC;MACrBS,MAAM,EAAE,OAAO;MACfpB,KAAK,EAALA,KAAK;MACL0C,WAAW,EAAXA;IACJ,CAAC,CAAC;IACFZ,MAAM,CAACC,cAAM,CAACM,SAAS,CAAC,eAAe,CAAC,CAAC,CAACJ,iBAAiB,CAAC,CAAC;EACjE,CAAC,CAAC;EAEFJ,EAAE,CAAC,6CAA6C,EAAE,YAAM;IACpD,IAAMN,WAAW,GAAGN,IAAI,CAACC,EAAE,CAACvB,eAAe,CAAC;IAC5C,IAAMgD,gBAAgB,GAAG;MAACC,UAAU,EAAE;IAAM,CAAC;IAC7CjC,wBAAwB,CAAC;MACrBS,MAAM,EAAE,SAAS;MACjBG,WAAW,EAAXA,WAAW;MACXoB,gBAAgB,EAAhBA;IACJ,CAAC,CAAC;IACFb,MAAM,CAACP,WAAW,CAAC,CAACsB,oBAAoB,CACpCf,MAAM,CAACgB,gBAAgB,CAACH,gBAAgB,CAAC,EACzC5B,SACJ,CAAC;EACL,CAAC,CAAC;EAEFc,EAAE,CAAC,yCAAyC,EAAE,YAAM;IAChD,IAAML,SAAS,GAAGP,IAAI,CAACC,EAAE,CAACpB,aAAa,CAAC;IACxC,IAAMiD,cAAc,GAAG;MAACH,UAAU,EAAE;IAAM,CAAC;IAC3C,IAAM5C,KAAK,GAAG,IAAIoC,KAAK,CAAC,YAAY,CAAC;IACrCzB,wBAAwB,CAAC;MACrBS,MAAM,EAAE,OAAO;MACfpB,KAAK,EAALA,KAAK;MACLwB,SAAS,EAATA,SAAS;MACTuB,cAAc,EAAdA;IACJ,CAAC,CAAC;IACFjB,MAAM,CAACN,SAAS,CAAC,CAACqB,oBAAoB,CAACf,MAAM,CAACgB,gBAAgB,CAACC,cAAc,CAAC,EAAEhC,SAAS,CAAC;EAC9F,CAAC,CAAC;EAEFc,EAAE,CAAC,uCAAuC,EAAE,YAAM;IAC9C,IAAMJ,QAAQ,GAAGR,IAAI,CAACC,EAAE,CAACX,YAAY,CAAC;IACtC,IAAMyC,aAAa,GAAG;MAACJ,UAAU,EAAE;IAAM,CAAC;IAC1CjC,wBAAwB,CAAC;MACrBS,MAAM,EAAE,SAAS;MACjBC,WAAW,EAAE,IAAI;MACjBI,QAAQ,EAARA,QAAQ;MACRuB,aAAa,EAAbA;IACJ,CAAC,CAAC;IACFlB,MAAM,CAACL,QAAQ,CAAC,CAACoB,oBAAoB,CAACf,MAAM,CAACgB,gBAAgB,CAACE,aAAa,CAAC,EAAEjC,SAAS,CAAC;EAC5F,CAAC,CAAC;AACN,CAAC,CAAC","ignoreList":[]}
@@ -0,0 +1,119 @@
1
+ "use strict";
2
+
3
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
4
+ var _react = _interopRequireDefault(require("react"));
5
+ var _react2 = require("@testing-library/react");
6
+ var _DataLoader = require("../DataLoader");
7
+ var _jsxRuntime = require("react/jsx-runtime");
8
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
9
+ var MockLoadingView = function MockLoadingView() {
10
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
11
+ "data-testid": "loading-view",
12
+ children: "Loading..."
13
+ });
14
+ };
15
+ var MockErrorView = function MockErrorView(_ref) {
16
+ var error = _ref.error,
17
+ action = _ref.action;
18
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
19
+ "data-testid": "error-view",
20
+ children: [error ? "Error: ".concat(error.message) : 'No error', action ? /*#__PURE__*/(0, _jsxRuntime.jsx)("button", {
21
+ "data-testid": "error-action",
22
+ onClick: action.handler,
23
+ children: action.children || 'Retry'
24
+ }) : null]
25
+ });
26
+ };
27
+ describe('DataLoader', function () {
28
+ var renderDataLoader = function renderDataLoader() {
29
+ var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
30
+ var defaultProps = {
31
+ status: 'success',
32
+ error: null,
33
+ LoadingView: MockLoadingView,
34
+ ErrorView: MockErrorView,
35
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
36
+ "data-testid": "content",
37
+ children: "Content"
38
+ })
39
+ };
40
+ return (0, _react2.render)(/*#__PURE__*/(0, _jsxRuntime.jsx)(_DataLoader.DataLoader, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, defaultProps), props)));
41
+ };
42
+ it('should render children when status is success', function () {
43
+ renderDataLoader({
44
+ status: 'success'
45
+ });
46
+ expect(_react2.screen.getByTestId('content')).toBeInTheDocument();
47
+ expect(_react2.screen.queryByTestId('loading-view')).not.toBeInTheDocument();
48
+ expect(_react2.screen.queryByTestId('error-view')).not.toBeInTheDocument();
49
+ });
50
+ it('should render LoadingView when status is loading', function () {
51
+ renderDataLoader({
52
+ status: 'loading'
53
+ });
54
+ expect(_react2.screen.getByTestId('loading-view')).toBeInTheDocument();
55
+ expect(_react2.screen.queryByTestId('content')).not.toBeInTheDocument();
56
+ expect(_react2.screen.queryByTestId('error-view')).not.toBeInTheDocument();
57
+ });
58
+ it('should render ErrorView when status is error', function () {
59
+ var error = new Error('Test error');
60
+ renderDataLoader({
61
+ status: 'error',
62
+ error: error
63
+ });
64
+ expect(_react2.screen.getByTestId('error-view')).toBeInTheDocument();
65
+ expect(_react2.screen.queryByTestId('content')).not.toBeInTheDocument();
66
+ expect(_react2.screen.queryByTestId('loading-view')).not.toBeInTheDocument();
67
+ expect(_react2.screen.getByText(/Test error/)).toBeInTheDocument();
68
+ });
69
+ it('should pass errorAction to ErrorView', function () {
70
+ var error = new Error('Test error');
71
+ var errorAction = jest.fn();
72
+ renderDataLoader({
73
+ status: 'error',
74
+ error: error,
75
+ errorAction: errorAction
76
+ });
77
+ expect(_react2.screen.getByTestId('error-action')).toBeInTheDocument();
78
+ });
79
+ it('should pass errorAction with custom children to ErrorView', function () {
80
+ var error = new Error('Test error');
81
+ var errorAction = {
82
+ handler: jest.fn(),
83
+ children: 'Custom action'
84
+ };
85
+ renderDataLoader({
86
+ status: 'error',
87
+ error: error,
88
+ errorAction: errorAction
89
+ });
90
+ expect(_react2.screen.getByText('Custom action')).toBeInTheDocument();
91
+ });
92
+ it('should pass loadingViewProps to LoadingView', function () {
93
+ var LoadingView = jest.fn(MockLoadingView);
94
+ var loadingViewProps = {
95
+ customProp: 'test'
96
+ };
97
+ renderDataLoader({
98
+ status: 'loading',
99
+ LoadingView: LoadingView,
100
+ loadingViewProps: loadingViewProps
101
+ });
102
+ expect(LoadingView).toHaveBeenCalledWith(expect.objectContaining(loadingViewProps), undefined);
103
+ });
104
+ it('should pass errorViewProps to ErrorView', function () {
105
+ var ErrorView = jest.fn(MockErrorView);
106
+ var errorViewProps = {
107
+ customProp: 'test'
108
+ };
109
+ var error = new Error('Test error');
110
+ renderDataLoader({
111
+ status: 'error',
112
+ error: error,
113
+ ErrorView: ErrorView,
114
+ errorViewProps: errorViewProps
115
+ });
116
+ expect(ErrorView).toHaveBeenCalledWith(expect.objectContaining(errorViewProps), undefined);
117
+ });
118
+ });
119
+ // #sourceMappingURL=DataLoader.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_react","_interopRequireDefault","require","_react2","_DataLoader","_jsxRuntime","e","__esModule","default","MockLoadingView","_jsx","children","MockErrorView","_ref","error","action","_jsxs","concat","message","onClick","handler","describe","renderDataLoader","props","arguments","length","undefined","defaultProps","status","LoadingView","ErrorView","render","DataLoader","_objectSpread","it","expect","screen","getByTestId","toBeInTheDocument","queryByTestId","not","Error","getByText","errorAction","jest","fn","loadingViewProps","customProp","toHaveBeenCalledWith","objectContaining","errorViewProps"],"sources":["DataLoader.test.tsx"],"sourcesContent":["import React from 'react';\n\nimport {render, screen} from '@testing-library/react';\n\nimport type {ErrorViewProps} from '../../types';\nimport {DataLoader} from '../DataLoader';\nimport type {DataLoaderProps} from '../types';\n\nconst MockLoadingView = () => <div data-testid=\"loading-view\">Loading...</div>;\nconst MockErrorView: React.FC<ErrorViewProps<Error>> = ({error, action}) => (\n <div data-testid=\"error-view\">\n {error ? `Error: ${error.message}` : 'No error'}\n {action ? (\n <button data-testid=\"error-action\" onClick={action.handler}>\n {action.children || 'Retry'}\n </button>\n ) : null}\n </div>\n);\n\ndescribe('DataLoader', () => {\n const renderDataLoader = (props: Partial<DataLoaderProps<Error>> = {}) => {\n const defaultProps: DataLoaderProps<Error> = {\n status: 'success',\n error: null,\n LoadingView: MockLoadingView,\n ErrorView: MockErrorView,\n children: <div data-testid=\"content\">Content</div>,\n };\n\n return render(<DataLoader {...defaultProps} {...props} />);\n };\n\n it('should render children when status is success', () => {\n renderDataLoader({status: 'success'});\n expect(screen.getByTestId('content')).toBeInTheDocument();\n expect(screen.queryByTestId('loading-view')).not.toBeInTheDocument();\n expect(screen.queryByTestId('error-view')).not.toBeInTheDocument();\n });\n\n it('should render LoadingView when status is loading', () => {\n renderDataLoader({status: 'loading'});\n expect(screen.getByTestId('loading-view')).toBeInTheDocument();\n expect(screen.queryByTestId('content')).not.toBeInTheDocument();\n expect(screen.queryByTestId('error-view')).not.toBeInTheDocument();\n });\n\n it('should render ErrorView when status is error', () => {\n const error = new Error('Test error');\n renderDataLoader({status: 'error', error});\n expect(screen.getByTestId('error-view')).toBeInTheDocument();\n expect(screen.queryByTestId('content')).not.toBeInTheDocument();\n expect(screen.queryByTestId('loading-view')).not.toBeInTheDocument();\n expect(screen.getByText(/Test error/)).toBeInTheDocument();\n });\n\n it('should pass errorAction to ErrorView', () => {\n const error = new Error('Test error');\n const errorAction = jest.fn();\n renderDataLoader({\n status: 'error',\n error,\n errorAction,\n });\n expect(screen.getByTestId('error-action')).toBeInTheDocument();\n });\n\n it('should pass errorAction with custom children to ErrorView', () => {\n const error = new Error('Test error');\n const errorAction = {\n handler: jest.fn(),\n children: 'Custom action',\n };\n renderDataLoader({\n status: 'error',\n error,\n errorAction,\n });\n expect(screen.getByText('Custom action')).toBeInTheDocument();\n });\n\n it('should pass loadingViewProps to LoadingView', () => {\n const LoadingView = jest.fn(MockLoadingView);\n const loadingViewProps = {customProp: 'test'};\n renderDataLoader({\n status: 'loading',\n LoadingView,\n loadingViewProps,\n });\n expect(LoadingView).toHaveBeenCalledWith(\n expect.objectContaining(loadingViewProps),\n undefined,\n );\n });\n\n it('should pass errorViewProps to ErrorView', () => {\n const ErrorView = jest.fn(MockErrorView);\n const errorViewProps = {customProp: 'test'};\n const error = new Error('Test error');\n renderDataLoader({\n status: 'error',\n error,\n ErrorView,\n errorViewProps,\n });\n expect(ErrorView).toHaveBeenCalledWith(expect.objectContaining(errorViewProps), undefined);\n });\n});\n"],"mappings":"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","ignoreList":[]}
@@ -1,4 +1,6 @@
1
1
  export { DataManagerContext, useDataManager } from './DataManagerContext';
2
+ export { DataManagerProvider } from './DataManagerProvider';
3
+ export type { DataManagerProviderProps } from './DataManagerProvider';
2
4
  export type { WithDataManagerProps } from './withDataManager';
3
5
  export { withDataManager } from './withDataManager';
4
6
  export type { ErrorAction, ErrorViewProps } from './components/types';
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  var _exportNames = {
7
7
  DataManagerContext: true,
8
8
  useDataManager: true,
9
+ DataManagerProvider: true,
9
10
  withDataManager: true
10
11
  };
11
12
  Object.defineProperty(exports, "DataManagerContext", {
@@ -14,6 +15,12 @@ Object.defineProperty(exports, "DataManagerContext", {
14
15
  return _DataManagerContext.DataManagerContext;
15
16
  }
16
17
  });
18
+ Object.defineProperty(exports, "DataManagerProvider", {
19
+ enumerable: true,
20
+ get: function () {
21
+ return _DataManagerProvider.DataManagerProvider;
22
+ }
23
+ });
17
24
  Object.defineProperty(exports, "useDataManager", {
18
25
  enumerable: true,
19
26
  get: function () {
@@ -27,6 +34,7 @@ Object.defineProperty(exports, "withDataManager", {
27
34
  }
28
35
  });
29
36
  var _DataManagerContext = require("./DataManagerContext");
37
+ var _DataManagerProvider = require("./DataManagerProvider");
30
38
  var _withDataManager = require("./withDataManager");
31
39
  var _DataLoader = require("./components/DataLoader");
32
40
  Object.keys(_DataLoader).forEach(function (key) {
@@ -1 +1 @@
1
- {"version":3,"names":["_DataManagerContext","require","_withDataManager","_DataLoader","Object","keys","forEach","key","prototype","hasOwnProperty","call","_exportNames","exports","defineProperty","enumerable","get","_DataInfiniteLoader"],"sources":["index.ts"],"sourcesContent":["export {DataManagerContext, useDataManager} from './DataManagerContext';\n\nexport type {WithDataManagerProps} from './withDataManager';\nexport {withDataManager} from './withDataManager';\n\nexport type {ErrorAction, ErrorViewProps} from './components/types';\nexport * from './components/DataLoader';\nexport * from './components/DataInfiniteLoader';\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,IAAAA,mBAAA,GAAAC,OAAA;AAGA,IAAAC,gBAAA,GAAAD,OAAA;AAGA,IAAAE,WAAA,GAAAF,OAAA;AAAAG,MAAA,CAAAC,IAAA,CAAAF,WAAA,EAAAG,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAC,YAAA,EAAAJ,GAAA;EAAA,IAAAA,GAAA,IAAAK,OAAA,IAAAA,OAAA,CAAAL,GAAA,MAAAJ,WAAA,CAAAI,GAAA;EAAAH,MAAA,CAAAS,cAAA,CAAAD,OAAA,EAAAL,GAAA;IAAAO,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAZ,WAAA,CAAAI,GAAA;IAAA;EAAA;AAAA;AACA,IAAAS,mBAAA,GAAAf,OAAA;AAAAG,MAAA,CAAAC,IAAA,CAAAW,mBAAA,EAAAV,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAC,YAAA,EAAAJ,GAAA;EAAA,IAAAA,GAAA,IAAAK,OAAA,IAAAA,OAAA,CAAAL,GAAA,MAAAS,mBAAA,CAAAT,GAAA;EAAAH,MAAA,CAAAS,cAAA,CAAAD,OAAA,EAAAL,GAAA;IAAAO,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAC,mBAAA,CAAAT,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}
1
+ {"version":3,"names":["_DataManagerContext","require","_DataManagerProvider","_withDataManager","_DataLoader","Object","keys","forEach","key","prototype","hasOwnProperty","call","_exportNames","exports","defineProperty","enumerable","get","_DataInfiniteLoader"],"sources":["index.ts"],"sourcesContent":["export {DataManagerContext, useDataManager} from './DataManagerContext';\nexport {DataManagerProvider} from './DataManagerProvider';\nexport type {DataManagerProviderProps} from './DataManagerProvider';\n\nexport type {WithDataManagerProps} from './withDataManager';\nexport {withDataManager} from './withDataManager';\n\nexport type {ErrorAction, ErrorViewProps} from './components/types';\nexport * from './components/DataLoader';\nexport * from './components/DataInfiniteLoader';\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,IAAAA,mBAAA,GAAAC,OAAA;AACA,IAAAC,oBAAA,GAAAD,OAAA;AAIA,IAAAE,gBAAA,GAAAF,OAAA;AAGA,IAAAG,WAAA,GAAAH,OAAA;AAAAI,MAAA,CAAAC,IAAA,CAAAF,WAAA,EAAAG,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAC,YAAA,EAAAJ,GAAA;EAAA,IAAAA,GAAA,IAAAK,OAAA,IAAAA,OAAA,CAAAL,GAAA,MAAAJ,WAAA,CAAAI,GAAA;EAAAH,MAAA,CAAAS,cAAA,CAAAD,OAAA,EAAAL,GAAA;IAAAO,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAZ,WAAA,CAAAI,GAAA;IAAA;EAAA;AAAA;AACA,IAAAS,mBAAA,GAAAhB,OAAA;AAAAI,MAAA,CAAAC,IAAA,CAAAW,mBAAA,EAAAV,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAC,YAAA,EAAAJ,GAAA;EAAA,IAAAA,GAAA,IAAAK,OAAA,IAAAA,OAAA,CAAAL,GAAA,MAAAS,mBAAA,CAAAT,GAAA;EAAAH,MAAA,CAAAS,cAAA,CAAAD,OAAA,EAAAL,GAAA;IAAAO,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAC,mBAAA,CAAAT,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}
@@ -3,4 +3,4 @@ import type { DataManager } from '../core';
3
3
  export interface WithDataManagerProps {
4
4
  dataManager: DataManager;
5
5
  }
6
- export declare const withDataManager: <T extends WithDataManagerProps>(WrappedComponent: React.ComponentType<WithDataManagerProps>) => React.FC<T>;
6
+ export declare const withDataManager: <T>(Component: React.ComponentType<T & WithDataManagerProps>) => React.FC<T>;
@@ -9,14 +9,14 @@ var _react = _interopRequireDefault(require("react"));
9
9
  var _DataManagerContext = require("./DataManagerContext");
10
10
  var _jsxRuntime = require("react/jsx-runtime");
11
11
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
12
- var withDataManager = exports.withDataManager = function withDataManager(WrappedComponent) {
12
+ var withDataManager = exports.withDataManager = function withDataManager(Component) {
13
13
  var ComponentWithDataManager = function ComponentWithDataManager(props) {
14
14
  var dataManager = (0, _DataManagerContext.useDataManager)();
15
- return /*#__PURE__*/(0, _jsxRuntime.jsx)(WrappedComponent, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, props), {}, {
15
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(Component, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, props), {}, {
16
16
  dataManager: dataManager
17
17
  }));
18
18
  };
19
- ComponentWithDataManager.displayName = "WithDataManager".concat(WrappedComponent.displayName || WrappedComponent.name || 'Component');
19
+ ComponentWithDataManager.displayName = "WithDataManager".concat(Component.displayName || Component.name || 'Component');
20
20
  return ComponentWithDataManager;
21
21
  };
22
22
  // #sourceMappingURL=withDataManager.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["_react","_interopRequireDefault","require","_DataManagerContext","_jsxRuntime","e","__esModule","default","withDataManager","exports","WrappedComponent","ComponentWithDataManager","props","dataManager","useDataManager","_jsx","_objectSpread","displayName","concat","name"],"sources":["withDataManager.tsx"],"sourcesContent":["import React from 'react';\n\nimport type {DataManager} from '../core';\n\nimport {useDataManager} from './DataManagerContext';\n\nexport interface WithDataManagerProps {\n dataManager: DataManager;\n}\n\nexport const withDataManager = <T extends WithDataManagerProps>(\n WrappedComponent: React.ComponentType<WithDataManagerProps>,\n) => {\n const ComponentWithDataManager: React.FC<T> = (props) => {\n const dataManager = useDataManager();\n\n return <WrappedComponent {...props} dataManager={dataManager} />;\n };\n\n ComponentWithDataManager.displayName = `WithDataManager${\n WrappedComponent.displayName || WrappedComponent.name || 'Component'\n }`;\n\n return ComponentWithDataManager;\n};\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAIA,IAAAC,mBAAA,GAAAD,OAAA;AAAoD,IAAAE,WAAA,GAAAF,OAAA;AAAA,SAAAD,uBAAAI,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAM7C,IAAMG,eAAe,GAAAC,OAAA,CAAAD,eAAA,GAAG,SAAlBA,eAAeA,CACxBE,gBAA2D,EAC1D;EACD,IAAMC,wBAAqC,GAAG,SAAxCA,wBAAqCA,CAAIC,KAAK,EAAK;IACrD,IAAMC,WAAW,GAAG,IAAAC,kCAAc,EAAC,CAAC;IAEpC,oBAAO,IAAAC,eAAA,EAACL,gBAAgB,MAAAM,sBAAA,MAAAA,sBAAA,MAAKJ,KAAK;MAAEC,WAAW,EAAEA;IAAY,EAAE,CAAC;EACpE,CAAC;EAEDF,wBAAwB,CAACM,WAAW,qBAAAC,MAAA,CAChCR,gBAAgB,CAACO,WAAW,IAAIP,gBAAgB,CAACS,IAAI,IAAI,WAAW,CACtE;EAEF,OAAOR,wBAAwB;AACnC,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["_react","_interopRequireDefault","require","_DataManagerContext","_jsxRuntime","e","__esModule","default","withDataManager","exports","Component","ComponentWithDataManager","props","dataManager","useDataManager","_jsx","_objectSpread","displayName","concat","name"],"sources":["withDataManager.tsx"],"sourcesContent":["import React from 'react';\n\nimport type {DataManager} from '../core';\n\nimport {useDataManager} from './DataManagerContext';\n\nexport interface WithDataManagerProps {\n dataManager: DataManager;\n}\n\nexport const withDataManager = <T,>(Component: React.ComponentType<T & WithDataManagerProps>) => {\n const ComponentWithDataManager: React.FC<T> = (props) => {\n const dataManager = useDataManager();\n\n return <Component {...props} dataManager={dataManager} />;\n };\n\n ComponentWithDataManager.displayName = `WithDataManager${\n Component.displayName || Component.name || 'Component'\n }`;\n\n return ComponentWithDataManager;\n};\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAIA,IAAAC,mBAAA,GAAAD,OAAA;AAAoD,IAAAE,WAAA,GAAAF,OAAA;AAAA,SAAAD,uBAAAI,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAM7C,IAAMG,eAAe,GAAAC,OAAA,CAAAD,eAAA,GAAG,SAAlBA,eAAeA,CAAQE,SAAwD,EAAK;EAC7F,IAAMC,wBAAqC,GAAG,SAAxCA,wBAAqCA,CAAIC,KAAK,EAAK;IACrD,IAAMC,WAAW,GAAG,IAAAC,kCAAc,EAAC,CAAC;IAEpC,oBAAO,IAAAC,eAAA,EAACL,SAAS,MAAAM,sBAAA,MAAAA,sBAAA,MAAKJ,KAAK;MAAEC,WAAW,EAAEA;IAAY,EAAE,CAAC;EAC7D,CAAC;EAEDF,wBAAwB,CAACM,WAAW,qBAAAC,MAAA,CAChCR,SAAS,CAACO,WAAW,IAAIP,SAAS,CAACS,IAAI,IAAI,WAAW,CACxD;EAEF,OAAOR,wBAAwB;AACnC,CAAC","ignoreList":[]}
@@ -1,11 +1,19 @@
1
+ import type { Data } from '@normy/core';
1
2
  import type { InvalidateQueryFilters, QueryClientConfig } from '@tanstack/react-query';
2
3
  import { QueryClient } from '@tanstack/react-query';
3
- import { type AnyDataSource, type DataManager, type DataSourceParams, type DataSourceTag } from '../core';
4
+ import { type AnyDataSource, type DataManager, type DataSourceParams, type DataSourceTag, type Normalizer, type NormalizerConfig } from '../core';
4
5
  import type { InvalidateOptions, InvalidateRepeatOptions } from '../core/types/DataManagerOptions';
5
- export type ClientDataManagerConfig = QueryClientConfig;
6
+ import type { QueryNormalizer } from './types/normalizer';
7
+ export interface ClientDataManagerConfig extends QueryClientConfig {
8
+ normalizerConfig?: NormalizerConfig | boolean;
9
+ }
6
10
  export declare class ClientDataManager implements DataManager {
7
11
  readonly queryClient: QueryClient;
12
+ readonly normalizer?: Normalizer | undefined;
13
+ readonly queryNormalizer?: QueryNormalizer | undefined;
8
14
  constructor(config?: ClientDataManagerConfig);
15
+ optimisticUpdate(mutationData: Data): void;
16
+ invalidateData(data: Data): void;
9
17
  invalidateTag(tag: DataSourceTag, invalidateOptions?: InvalidateOptions): Promise<void>;
10
18
  invalidateTags(tags: DataSourceTag[], invalidateOptions?: InvalidateOptions): Promise<void>;
11
19
  invalidateSource<TDataSource extends AnyDataSource>(dataSource: TDataSource, invalidateOptions?: InvalidateOptions): Promise<void>;
@@ -15,4 +23,5 @@ export declare class ClientDataManager implements DataManager {
15
23
  invalidateSourceTags<TDataSource extends AnyDataSource>(dataSource: TDataSource, params: DataSourceParams<TDataSource>, invalidateOptions?: InvalidateOptions): Promise<void>;
16
24
  protected invalidateQueries(filters: InvalidateQueryFilters, invalidateOptions?: InvalidateOptions): Promise<void>;
17
25
  protected repeatInvalidate(invalidate: () => Promise<void>, repeat?: InvalidateRepeatOptions): void;
26
+ private createNormalize;
18
27
  }
@@ -7,15 +7,21 @@ exports.ClientDataManager = void 0;
7
7
  var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
8
8
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
9
9
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
10
+ var _core = require("@normy/core");
10
11
  var _reactQuery = require("@tanstack/react-query");
11
- var _core = require("../core");
12
+ var _core2 = require("../core");
13
+ var _normalize = require("./utils/normalize");
12
14
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
13
15
  var ClientDataManager = exports.ClientDataManager = /*#__PURE__*/function () {
14
16
  function ClientDataManager() {
15
- var _config$defaultOption, _config$defaultOption2;
17
+ var _config$defaultOption,
18
+ _config$defaultOption2,
19
+ _this = this;
16
20
  var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
17
21
  (0, _classCallCheck2.default)(this, ClientDataManager);
18
22
  this.queryClient = void 0;
23
+ this.normalizer = void 0;
24
+ this.queryNormalizer = void 0;
19
25
  this.queryClient = new _reactQuery.QueryClient((0, _objectSpread2.default)((0, _objectSpread2.default)({}, config), {}, {
20
26
  defaultOptions: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, config.defaultOptions), {}, {
21
27
  queries: (0, _objectSpread2.default)({
@@ -26,14 +32,64 @@ var ClientDataManager = exports.ClientDataManager = /*#__PURE__*/function () {
26
32
  }, (_config$defaultOption2 = config.defaultOptions) === null || _config$defaultOption2 === void 0 ? void 0 : _config$defaultOption2.mutations)
27
33
  })
28
34
  }));
35
+ this.normalizer = this.createNormalize(config.normalizerConfig);
36
+ this.queryNormalizer = (0, _normalize.createQueryNormalizer)(this.normalizer, this.queryClient, config.normalizerConfig, function (data) {
37
+ return _this.optimisticUpdate(data);
38
+ }, function (data) {
39
+ return _this.invalidateData(data);
40
+ });
29
41
  }
30
42
  return (0, _createClass2.default)(ClientDataManager, [{
43
+ key: "optimisticUpdate",
44
+ value: function optimisticUpdate(mutationData) {
45
+ var _this2 = this;
46
+ if (!this.normalizer) {
47
+ return;
48
+ }
49
+ var queriesToUpdate = this.normalizer.getQueriesToUpdate(mutationData);
50
+ queriesToUpdate.forEach(function (query) {
51
+ var queryKey = JSON.parse(query.queryKey);
52
+ var cachedQuery = _this2.queryClient.getQueryCache().find({
53
+ queryKey: queryKey
54
+ });
55
+ var dataUpdatedAt = cachedQuery === null || cachedQuery === void 0 ? void 0 : cachedQuery.state.dataUpdatedAt;
56
+ var isInvalidated = cachedQuery === null || cachedQuery === void 0 ? void 0 : cachedQuery.state.isInvalidated;
57
+ var error = cachedQuery === null || cachedQuery === void 0 ? void 0 : cachedQuery.state.error;
58
+ var status = cachedQuery === null || cachedQuery === void 0 ? void 0 : cachedQuery.state.status;
59
+ _this2.queryClient.setQueryData(queryKey, function () {
60
+ return query.data;
61
+ }, {
62
+ updatedAt: dataUpdatedAt
63
+ });
64
+ cachedQuery === null || cachedQuery === void 0 || cachedQuery.setState({
65
+ isInvalidated: isInvalidated,
66
+ error: error,
67
+ status: status
68
+ });
69
+ });
70
+ }
71
+ }, {
72
+ key: "invalidateData",
73
+ value: function invalidateData(data) {
74
+ var _this3 = this;
75
+ if (!this.normalizer) {
76
+ return;
77
+ }
78
+ var queriesToUpdate = this.normalizer.getQueriesToUpdate(data);
79
+ queriesToUpdate.forEach(function (query) {
80
+ var queryKey = JSON.parse(query.queryKey);
81
+ _this3.queryClient.invalidateQueries({
82
+ queryKey: queryKey
83
+ });
84
+ });
85
+ }
86
+ }, {
31
87
  key: "invalidateTag",
32
88
  value: function invalidateTag(tag, invalidateOptions) {
33
89
  return this.invalidateQueries({
34
90
  predicate: function predicate(_ref) {
35
91
  var queryKey = _ref.queryKey;
36
- return (0, _core.hasTag)(queryKey, tag);
92
+ return (0, _core2.hasTag)(queryKey, tag);
37
93
  }
38
94
  }, invalidateOptions);
39
95
  }
@@ -44,7 +100,7 @@ var ClientDataManager = exports.ClientDataManager = /*#__PURE__*/function () {
44
100
  predicate: function predicate(_ref2) {
45
101
  var queryKey = _ref2.queryKey;
46
102
  return tags.every(function (tag) {
47
- return (0, _core.hasTag)(queryKey, tag);
103
+ return (0, _core2.hasTag)(queryKey, tag);
48
104
  });
49
105
  }
50
106
  }, invalidateOptions);
@@ -69,7 +125,7 @@ var ClientDataManager = exports.ClientDataManager = /*#__PURE__*/function () {
69
125
  key: "invalidateParams",
70
126
  value: function invalidateParams(dataSource, params, invalidateOptions) {
71
127
  return this.invalidateQueries({
72
- queryKey: (0, _core.composeFullKey)(dataSource, params),
128
+ queryKey: (0, _core2.composeFullKey)(dataSource, params),
73
129
  exact: true
74
130
  }, invalidateOptions);
75
131
  }
@@ -77,7 +133,7 @@ var ClientDataManager = exports.ClientDataManager = /*#__PURE__*/function () {
77
133
  key: "resetParams",
78
134
  value: function resetParams(dataSource, params) {
79
135
  return this.queryClient.resetQueries({
80
- queryKey: (0, _core.composeFullKey)(dataSource, params),
136
+ queryKey: (0, _core2.composeFullKey)(dataSource, params),
81
137
  exact: true
82
138
  });
83
139
  }
@@ -86,15 +142,15 @@ var ClientDataManager = exports.ClientDataManager = /*#__PURE__*/function () {
86
142
  value: function invalidateSourceTags(dataSource, params, invalidateOptions) {
87
143
  return this.invalidateQueries({
88
144
  // Last element is a full key
89
- queryKey: (0, _core.composeFullKey)(dataSource, params).slice(0, -1)
145
+ queryKey: (0, _core2.composeFullKey)(dataSource, params).slice(0, -1)
90
146
  }, invalidateOptions);
91
147
  }
92
148
  }, {
93
149
  key: "invalidateQueries",
94
150
  value: function invalidateQueries(filters, invalidateOptions) {
95
- var _this = this;
151
+ var _this4 = this;
96
152
  var invalidate = function invalidate() {
97
- return _this.queryClient.invalidateQueries(filters);
153
+ return _this4.queryClient.invalidateQueries(filters);
98
154
  };
99
155
  this.repeatInvalidate(invalidate, invalidateOptions === null || invalidateOptions === void 0 ? void 0 : invalidateOptions.repeat);
100
156
  return invalidate();
@@ -109,6 +165,17 @@ var ClientDataManager = exports.ClientDataManager = /*#__PURE__*/function () {
109
165
  setTimeout(invalidate, repeat.interval * i);
110
166
  }
111
167
  }
168
+ }, {
169
+ key: "createNormalize",
170
+ value: function createNormalize(config) {
171
+ if (!config) {
172
+ return undefined;
173
+ }
174
+ if (config === true) {
175
+ return (0, _core.createNormalizer)({});
176
+ }
177
+ return (0, _core.createNormalizer)(config);
178
+ }
112
179
  }]);
113
180
  }();
114
181
  // #sourceMappingURL=ClientDataManager.js.map