@data-client/core 0.1.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 (308) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +71 -0
  3. package/dist/index.js +1643 -0
  4. package/dist/index.umd.min.js +1 -0
  5. package/dist/next.js +461 -0
  6. package/dist/package.json +1 -0
  7. package/legacy/actionTypes.js +12 -0
  8. package/legacy/compatibleActions.js +2 -0
  9. package/legacy/controller/BaseController.js +289 -0
  10. package/legacy/controller/Controller.js +20 -0
  11. package/legacy/controller/createFetch.js +42 -0
  12. package/legacy/controller/createInvalidate.js +12 -0
  13. package/legacy/controller/createInvalidateAll.js +8 -0
  14. package/legacy/controller/createOptimistic.js +33 -0
  15. package/legacy/controller/createReceive.js +36 -0
  16. package/legacy/controller/createReset.js +8 -0
  17. package/legacy/controller/createSubscription.js +30 -0
  18. package/legacy/controller/types.js +2 -0
  19. package/legacy/endpoint/index.js +2 -0
  20. package/legacy/endpoint/shapes.js +2 -0
  21. package/legacy/endpoint/types.js +2 -0
  22. package/legacy/fsa.js +2 -0
  23. package/legacy/index.js +22 -0
  24. package/legacy/internal.js +4 -0
  25. package/legacy/legacyActions.js +2 -0
  26. package/legacy/manager/ConnectionListener.js +2 -0
  27. package/legacy/manager/DefaultConnectionListener.js +40 -0
  28. package/legacy/manager/DevtoolsManager.js +73 -0
  29. package/legacy/manager/LogoutManager.js +34 -0
  30. package/legacy/manager/NetworkManager.js +291 -0
  31. package/legacy/manager/PollingSubscription.js +159 -0
  32. package/legacy/manager/SubscriptionManager.js +117 -0
  33. package/legacy/manager/applyManager.js +23 -0
  34. package/legacy/manager/devtoolsTypes.js +2 -0
  35. package/legacy/manager/index.js +6 -0
  36. package/legacy/middlewareTypes.js +2 -0
  37. package/legacy/newActions.js +2 -0
  38. package/legacy/next/Controller.js +24 -0
  39. package/legacy/next/index.js +3 -0
  40. package/legacy/previousActions.js +2 -0
  41. package/legacy/state/RIC.js +3 -0
  42. package/legacy/state/applyUpdatersToResults.js +4 -0
  43. package/legacy/state/legacy-actions/createFetch.js +62 -0
  44. package/legacy/state/legacy-actions/createReceive.js +37 -0
  45. package/legacy/state/legacy-actions/createReceiveError.js +28 -0
  46. package/legacy/state/legacy-actions/index.js +4 -0
  47. package/legacy/state/reducer/createReducer.js +54 -0
  48. package/legacy/state/reducer/fetchReducer.js +32 -0
  49. package/legacy/state/reducer/invalidateReducer.js +28 -0
  50. package/legacy/state/reducer/setReducer.js +113 -0
  51. package/legacy/state/reducerInstance.js +9 -0
  52. package/legacy/state/selectMeta.js +4 -0
  53. package/legacy/types.js +8 -0
  54. package/lib/actionTypes.d.ts +11 -0
  55. package/lib/actionTypes.d.ts.map +1 -0
  56. package/lib/actionTypes.js +12 -0
  57. package/lib/compatibleActions.d.ts +47 -0
  58. package/lib/compatibleActions.d.ts.map +1 -0
  59. package/lib/compatibleActions.js +2 -0
  60. package/lib/controller/BaseController.d.ts +128 -0
  61. package/lib/controller/BaseController.d.ts.map +1 -0
  62. package/lib/controller/BaseController.js +289 -0
  63. package/lib/controller/Controller.d.ts +14 -0
  64. package/lib/controller/Controller.d.ts.map +1 -0
  65. package/lib/controller/Controller.js +20 -0
  66. package/lib/controller/createFetch.d.ts +12 -0
  67. package/lib/controller/createFetch.d.ts.map +1 -0
  68. package/lib/controller/createFetch.js +42 -0
  69. package/lib/controller/createInvalidate.d.ts +6 -0
  70. package/lib/controller/createInvalidate.d.ts.map +1 -0
  71. package/lib/controller/createInvalidate.js +12 -0
  72. package/lib/controller/createInvalidateAll.d.ts +3 -0
  73. package/lib/controller/createInvalidateAll.d.ts.map +1 -0
  74. package/lib/controller/createInvalidateAll.js +8 -0
  75. package/lib/controller/createOptimistic.d.ts +10 -0
  76. package/lib/controller/createOptimistic.d.ts.map +1 -0
  77. package/lib/controller/createOptimistic.js +33 -0
  78. package/lib/controller/createReceive.d.ts +20 -0
  79. package/lib/controller/createReceive.d.ts.map +1 -0
  80. package/lib/controller/createReceive.js +36 -0
  81. package/lib/controller/createReset.d.ts +3 -0
  82. package/lib/controller/createReset.d.ts.map +1 -0
  83. package/lib/controller/createReset.js +8 -0
  84. package/lib/controller/createSubscription.d.ts +9 -0
  85. package/lib/controller/createSubscription.d.ts.map +1 -0
  86. package/lib/controller/createSubscription.js +30 -0
  87. package/lib/controller/types.d.ts +6 -0
  88. package/lib/controller/types.d.ts.map +1 -0
  89. package/lib/controller/types.js +2 -0
  90. package/lib/endpoint/index.d.ts +3 -0
  91. package/lib/endpoint/index.d.ts.map +1 -0
  92. package/lib/endpoint/index.js +2 -0
  93. package/lib/endpoint/shapes.d.ts +25 -0
  94. package/lib/endpoint/shapes.d.ts.map +1 -0
  95. package/lib/endpoint/shapes.js +2 -0
  96. package/lib/endpoint/types.d.ts +45 -0
  97. package/lib/endpoint/types.d.ts.map +1 -0
  98. package/lib/endpoint/types.js +2 -0
  99. package/lib/fsa.d.ts +41 -0
  100. package/lib/fsa.d.ts.map +1 -0
  101. package/lib/fsa.js +2 -0
  102. package/lib/index.d.ts +19 -0
  103. package/lib/index.d.ts.map +1 -0
  104. package/lib/index.js +22 -0
  105. package/lib/internal.d.ts +4 -0
  106. package/lib/internal.d.ts.map +1 -0
  107. package/lib/internal.js +4 -0
  108. package/lib/legacyActions.d.ts +92 -0
  109. package/lib/legacyActions.d.ts.map +1 -0
  110. package/lib/legacyActions.js +2 -0
  111. package/lib/manager/ConnectionListener.d.ts +8 -0
  112. package/lib/manager/ConnectionListener.d.ts.map +1 -0
  113. package/lib/manager/ConnectionListener.js +2 -0
  114. package/lib/manager/DefaultConnectionListener.d.ts +20 -0
  115. package/lib/manager/DefaultConnectionListener.d.ts.map +1 -0
  116. package/lib/manager/DefaultConnectionListener.js +40 -0
  117. package/lib/manager/DevtoolsManager.d.ts +24 -0
  118. package/lib/manager/DevtoolsManager.d.ts.map +1 -0
  119. package/lib/manager/DevtoolsManager.js +74 -0
  120. package/lib/manager/LogoutManager.d.ts +25 -0
  121. package/lib/manager/LogoutManager.d.ts.map +1 -0
  122. package/lib/manager/LogoutManager.js +34 -0
  123. package/lib/manager/NetworkManager.d.ts +82 -0
  124. package/lib/manager/NetworkManager.d.ts.map +1 -0
  125. package/lib/manager/NetworkManager.js +295 -0
  126. package/lib/manager/PollingSubscription.d.ts +45 -0
  127. package/lib/manager/PollingSubscription.d.ts.map +1 -0
  128. package/lib/manager/PollingSubscription.js +159 -0
  129. package/lib/manager/SubscriptionManager.d.ts +55 -0
  130. package/lib/manager/SubscriptionManager.d.ts.map +1 -0
  131. package/lib/manager/SubscriptionManager.js +117 -0
  132. package/lib/manager/applyManager.d.ts +10 -0
  133. package/lib/manager/applyManager.d.ts.map +1 -0
  134. package/lib/manager/applyManager.js +23 -0
  135. package/lib/manager/devtoolsTypes.d.ts +205 -0
  136. package/lib/manager/devtoolsTypes.d.ts.map +1 -0
  137. package/lib/manager/devtoolsTypes.js +2 -0
  138. package/lib/manager/index.d.ts +8 -0
  139. package/lib/manager/index.d.ts.map +1 -0
  140. package/lib/manager/index.js +6 -0
  141. package/lib/middlewareTypes.d.ts +18 -0
  142. package/lib/middlewareTypes.d.ts.map +1 -0
  143. package/lib/middlewareTypes.js +2 -0
  144. package/lib/newActions.d.ts +85 -0
  145. package/lib/newActions.d.ts.map +1 -0
  146. package/lib/newActions.js +2 -0
  147. package/lib/next/Controller.d.ts +14 -0
  148. package/lib/next/Controller.d.ts.map +1 -0
  149. package/lib/next/Controller.js +24 -0
  150. package/lib/next/index.d.ts +3 -0
  151. package/lib/next/index.d.ts.map +1 -0
  152. package/lib/next/index.js +3 -0
  153. package/lib/previousActions.d.ts +91 -0
  154. package/lib/previousActions.d.ts.map +1 -0
  155. package/lib/previousActions.js +2 -0
  156. package/lib/state/RIC.d.ts +2 -0
  157. package/lib/state/RIC.js +3 -0
  158. package/lib/state/applyUpdatersToResults.d.ts +13 -0
  159. package/lib/state/applyUpdatersToResults.d.ts.map +1 -0
  160. package/lib/state/applyUpdatersToResults.js +7 -0
  161. package/lib/state/legacy-actions/createFetch.d.ts +19 -0
  162. package/lib/state/legacy-actions/createFetch.d.ts.map +1 -0
  163. package/lib/state/legacy-actions/createFetch.js +62 -0
  164. package/lib/state/legacy-actions/createReceive.d.ts +14 -0
  165. package/lib/state/legacy-actions/createReceive.d.ts.map +1 -0
  166. package/lib/state/legacy-actions/createReceive.js +37 -0
  167. package/lib/state/legacy-actions/createReceiveError.d.ts +9 -0
  168. package/lib/state/legacy-actions/createReceiveError.d.ts.map +1 -0
  169. package/lib/state/legacy-actions/createReceiveError.js +28 -0
  170. package/lib/state/legacy-actions/index.d.ts +4 -0
  171. package/lib/state/legacy-actions/index.d.ts.map +1 -0
  172. package/lib/state/legacy-actions/index.js +4 -0
  173. package/lib/state/reducer/createReducer.d.ts +7 -0
  174. package/lib/state/reducer/createReducer.d.ts.map +1 -0
  175. package/lib/state/reducer/createReducer.js +55 -0
  176. package/lib/state/reducer/fetchReducer.d.ts +4 -0
  177. package/lib/state/reducer/fetchReducer.d.ts.map +1 -0
  178. package/lib/state/reducer/fetchReducer.js +34 -0
  179. package/lib/state/reducer/invalidateReducer.d.ts +37 -0
  180. package/lib/state/reducer/invalidateReducer.d.ts.map +1 -0
  181. package/lib/state/reducer/invalidateReducer.js +34 -0
  182. package/lib/state/reducer/setReducer.d.ts +40 -0
  183. package/lib/state/reducer/setReducer.d.ts.map +1 -0
  184. package/lib/state/reducer/setReducer.js +119 -0
  185. package/lib/state/reducerInstance.d.ts +7 -0
  186. package/lib/state/reducerInstance.d.ts.map +1 -0
  187. package/lib/state/reducerInstance.js +9 -0
  188. package/lib/state/selectMeta.d.ts +3 -0
  189. package/lib/state/selectMeta.d.ts.map +1 -0
  190. package/lib/state/selectMeta.js +4 -0
  191. package/lib/types.d.ts +71 -0
  192. package/lib/types.d.ts.map +1 -0
  193. package/lib/types.js +8 -0
  194. package/node.mjs +1 -0
  195. package/package.json +127 -0
  196. package/src/actionTypes.ts +11 -0
  197. package/src/compatibleActions.ts +96 -0
  198. package/src/controller/BaseController.ts +508 -0
  199. package/src/controller/Controller.ts +32 -0
  200. package/src/controller/__tests__/Controller.ts +29 -0
  201. package/src/controller/__tests__/__snapshots__/getResponse.ts.snap +35 -0
  202. package/src/controller/__tests__/getResponse.ts +182 -0
  203. package/src/controller/createFetch.ts +54 -0
  204. package/src/controller/createInvalidate.ts +16 -0
  205. package/src/controller/createInvalidateAll.ts +11 -0
  206. package/src/controller/createOptimistic.ts +47 -0
  207. package/src/controller/createReceive.ts +85 -0
  208. package/src/controller/createReset.ts +9 -0
  209. package/src/controller/createSubscription.ts +39 -0
  210. package/src/controller/types.ts +22 -0
  211. package/src/endpoint/index.ts +14 -0
  212. package/src/endpoint/shapes.ts +53 -0
  213. package/src/endpoint/types.ts +72 -0
  214. package/src/fsa.ts +99 -0
  215. package/src/index.ts +61 -0
  216. package/src/internal.ts +3 -0
  217. package/src/legacyActions.ts +163 -0
  218. package/src/manager/ConnectionListener.ts +7 -0
  219. package/src/manager/DefaultConnectionListener.ts +54 -0
  220. package/src/manager/DevtoolsManager.ts +99 -0
  221. package/src/manager/LogoutManager.ts +57 -0
  222. package/src/manager/NetworkManager.ts +346 -0
  223. package/src/manager/PollingSubscription.ts +190 -0
  224. package/src/manager/SubscriptionManager.ts +156 -0
  225. package/src/manager/__tests__/__snapshots__/pollingSubscription-endpoint.ts.snap +49 -0
  226. package/src/manager/__tests__/__snapshots__/pollingSubscription.ts.snap +43 -0
  227. package/src/manager/__tests__/logoutManager.ts +112 -0
  228. package/src/manager/__tests__/manager.ts +44 -0
  229. package/src/manager/__tests__/networkManager-legacy.ts +394 -0
  230. package/src/manager/__tests__/networkManager.ts +426 -0
  231. package/src/manager/__tests__/pollingSubscription-endpoint.ts +423 -0
  232. package/src/manager/__tests__/pollingSubscription.ts +313 -0
  233. package/src/manager/__tests__/subscriptionManager.ts +208 -0
  234. package/src/manager/applyManager.ts +33 -0
  235. package/src/manager/devtoolsTypes.ts +210 -0
  236. package/src/manager/index.ts +7 -0
  237. package/src/middlewareTypes.ts +49 -0
  238. package/src/newActions.ts +140 -0
  239. package/src/next/Controller.ts +39 -0
  240. package/src/next/index.ts +2 -0
  241. package/src/package.json +1 -0
  242. package/src/previousActions.ts +159 -0
  243. package/src/state/RIC.d.ts +2 -0
  244. package/src/state/RIC.js +5 -0
  245. package/src/state/__tests__/RIC.web.ts +16 -0
  246. package/src/state/__tests__/__snapshots__/reducer.ts.snap +56 -0
  247. package/src/state/__tests__/applyUpdatersToResults.ts +40 -0
  248. package/src/state/__tests__/reducer.ts +868 -0
  249. package/src/state/applyUpdatersToResults.ts +29 -0
  250. package/src/state/legacy-actions/createFetch.ts +95 -0
  251. package/src/state/legacy-actions/createReceive.ts +68 -0
  252. package/src/state/legacy-actions/createReceiveError.ts +43 -0
  253. package/src/state/legacy-actions/index.ts +3 -0
  254. package/src/state/reducer/createReducer.ts +80 -0
  255. package/src/state/reducer/fetchReducer.ts +48 -0
  256. package/src/state/reducer/invalidateReducer.ts +39 -0
  257. package/src/state/reducer/setReducer.ts +157 -0
  258. package/src/state/reducerInstance.ts +14 -0
  259. package/src/state/selectMeta.ts +8 -0
  260. package/src/types.ts +125 -0
  261. package/ts3.4/actionTypes.d.ts +11 -0
  262. package/ts3.4/compatibleActions.d.ts +47 -0
  263. package/ts3.4/controller/BaseController.d.ts +170 -0
  264. package/ts3.4/controller/Controller.d.ts +14 -0
  265. package/ts3.4/controller/createFetch.d.ts +14 -0
  266. package/ts3.4/controller/createInvalidate.d.ts +8 -0
  267. package/ts3.4/controller/createInvalidateAll.d.ts +3 -0
  268. package/ts3.4/controller/createOptimistic.d.ts +12 -0
  269. package/ts3.4/controller/createReceive.d.ts +24 -0
  270. package/ts3.4/controller/createReset.d.ts +3 -0
  271. package/ts3.4/controller/createSubscription.d.ts +13 -0
  272. package/ts3.4/controller/types.d.ts +6 -0
  273. package/ts3.4/endpoint/index.d.ts +3 -0
  274. package/ts3.4/endpoint/shapes.d.ts +25 -0
  275. package/ts3.4/endpoint/types.d.ts +45 -0
  276. package/ts3.4/fsa.d.ts +41 -0
  277. package/ts3.4/index.d.ts +22 -0
  278. package/ts3.4/internal.d.ts +4 -0
  279. package/ts3.4/legacyActions.d.ts +95 -0
  280. package/ts3.4/manager/ConnectionListener.d.ts +8 -0
  281. package/ts3.4/manager/DefaultConnectionListener.d.ts +20 -0
  282. package/ts3.4/manager/DevtoolsManager.d.ts +24 -0
  283. package/ts3.4/manager/LogoutManager.d.ts +25 -0
  284. package/ts3.4/manager/NetworkManager.d.ts +82 -0
  285. package/ts3.4/manager/PollingSubscription.d.ts +45 -0
  286. package/ts3.4/manager/SubscriptionManager.d.ts +55 -0
  287. package/ts3.4/manager/applyManager.d.ts +10 -0
  288. package/ts3.4/manager/devtoolsTypes.d.ts +205 -0
  289. package/ts3.4/manager/index.d.ts +8 -0
  290. package/ts3.4/middlewareTypes.d.ts +18 -0
  291. package/ts3.4/newActions.d.ts +88 -0
  292. package/ts3.4/next/Controller.d.ts +14 -0
  293. package/ts3.4/next/index.d.ts +3 -0
  294. package/ts3.4/previousActions.d.ts +94 -0
  295. package/ts3.4/state/RIC.d.ts +2 -0
  296. package/ts3.4/state/applyUpdatersToResults.d.ts +13 -0
  297. package/ts3.4/state/legacy-actions/createFetch.d.ts +19 -0
  298. package/ts3.4/state/legacy-actions/createReceive.d.ts +14 -0
  299. package/ts3.4/state/legacy-actions/createReceiveError.d.ts +9 -0
  300. package/ts3.4/state/legacy-actions/index.d.ts +4 -0
  301. package/ts3.4/state/reducer/createReducer.d.ts +7 -0
  302. package/ts3.4/state/reducer/fetchReducer.d.ts +4 -0
  303. package/ts3.4/state/reducer/invalidateReducer.d.ts +37 -0
  304. package/ts3.4/state/reducer/setReducer.d.ts +40 -0
  305. package/ts3.4/state/reducerInstance.d.ts +7 -0
  306. package/ts3.4/state/selectMeta.d.ts +3 -0
  307. package/ts3.4/types.d.ts +73 -0
  308. package/typescript.svg +8 -0
@@ -0,0 +1,45 @@
1
+ import type { Schema } from '@data-client/normalizr';
2
+ import ConnectionListener from './ConnectionListener.js';
3
+ import { Subscription, SubscriptionInit } from './SubscriptionManager.js';
4
+ import type { State, Dispatch } from '../types.js';
5
+ /**
6
+ * PollingSubscription keeps a given resource updated by
7
+ * dispatching a fetch at a rate equal to the minimum update
8
+ * interval requested.
9
+ *
10
+ * @see https://resthooks.io/docs/api/PollingSubscription
11
+ */
12
+ export default class PollingSubscription implements Subscription {
13
+ protected readonly schema: Schema | undefined;
14
+ protected readonly fetch: () => Promise<any>;
15
+ protected readonly key: string;
16
+ protected frequency: number;
17
+ protected frequencyHistogram: Map<number, number>;
18
+ protected dispatch: Dispatch<any>;
19
+ protected getState: () => State<unknown>;
20
+ protected intervalId?: ReturnType<typeof setInterval>;
21
+ protected lastIntervalId?: ReturnType<typeof setInterval>;
22
+ protected startId?: ReturnType<typeof setTimeout>;
23
+ private connectionListener;
24
+ constructor({ key, schema, fetch, frequency, getState }: SubscriptionInit, dispatch: Dispatch<any>, connectionListener?: ConnectionListener);
25
+ /** Subscribe to a frequency */
26
+ add(frequency?: number): void;
27
+ /** Unsubscribe from a frequency */
28
+ remove(frequency?: number): boolean;
29
+ /** Cleanup means clearing out background interval. */
30
+ cleanup(): void;
31
+ /** Trigger request for latest resource */
32
+ protected update(): void;
33
+ /** What happens when browser goes offline */
34
+ protected offlineListener: () => void;
35
+ /** What happens when browser comes online */
36
+ protected onlineListener: () => void;
37
+ /** Run polling process with current frequency
38
+ *
39
+ * Will clean up old poll interval on next run
40
+ */
41
+ protected run(): void;
42
+ /** Last fetch time */
43
+ protected lastFetchTime(): number;
44
+ }
45
+ //# sourceMappingURL=PollingSubscription.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PollingSubscription.d.ts","sourceRoot":"","sources":["../../src/manager/PollingSubscription.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAqB,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAExE,OAAO,kBAAkB,MAAM,yBAAyB,CAAC;AAEzD,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAE1E,OAAO,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEnD;;;;;;GAMG;AACH,MAAM,CAAC,OAAO,OAAO,mBAAoB,YAAW,YAAY;IAC9D,mBAA2B,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;IACtD,mBAA2B,KAAK,EAAE,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC;IACrD,mBAA2B,GAAG,EAAE,MAAM,CAAC;IACvC,UAAkB,SAAS,EAAE,MAAM,CAAC;IACpC,SAAS,CAAC,kBAAkB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAa;IAC9D,UAAkB,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC;IAC1C,UAAkB,QAAQ,EAAE,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC;IACjD,UAAkB,UAAU,CAAC,EAAE,UAAU,CAAC,OAAO,WAAW,CAAC,CAAC;IAC9D,UAAkB,cAAc,CAAC,EAAE,UAAU,CAAC,OAAO,WAAW,CAAC,CAAC;IAClE,UAAkB,OAAO,CAAC,EAAE,UAAU,CAAC,OAAO,UAAU,CAAC,CAAC;IAC1D,QAAgB,kBAAkB,CAAqB;gBAGrD,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,gBAAgB,EAC7D,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC,EACvB,kBAAkB,CAAC,EAAE,kBAAkB;IAsBzC,+BAA+B;IAC/B,GAAG,CAAC,SAAS,CAAC,EAAE,MAAM;IAkBtB,mCAAmC;IACnC,MAAM,CAAC,SAAS,CAAC,EAAE,MAAM;IAgCzB,sDAAsD;IACtD,OAAO;IAiBP,0CAA0C;IAC1C,SAAS,CAAC,MAAM;IAahB,6CAA6C;IAC7C,SAAS,CAAC,eAAe,aAIvB;IAEF,6CAA6C;IAC7C,SAAS,CAAC,cAAc,aAetB;IAEF;;;OAGG;IACH,SAAS,CAAC,GAAG;IAmBb,sBAAsB;IACtB,SAAS,CAAC,aAAa;CAGxB"}
@@ -0,0 +1,159 @@
1
+ import DefaultConnectionListener from './DefaultConnectionListener.js';
2
+ import createFetch from '../controller/createFetch.js';
3
+ /**
4
+ * PollingSubscription keeps a given resource updated by
5
+ * dispatching a fetch at a rate equal to the minimum update
6
+ * interval requested.
7
+ *
8
+ * @see https://resthooks.io/docs/api/PollingSubscription
9
+ */
10
+ export default class PollingSubscription {
11
+ constructor({
12
+ key,
13
+ schema,
14
+ fetch,
15
+ frequency,
16
+ getState
17
+ }, dispatch, connectionListener) {
18
+ this.frequencyHistogram = new Map();
19
+ /** What happens when browser goes offline */
20
+ this.offlineListener = () => {
21
+ // this clears existing listeners, so no need to clear offline listener
22
+ this.cleanup();
23
+ this.connectionListener.addOnlineListener(this.onlineListener);
24
+ };
25
+ /** What happens when browser comes online */
26
+ this.onlineListener = () => {
27
+ this.connectionListener.removeOnlineListener(this.onlineListener);
28
+ const now = Date.now();
29
+ this.startId = setTimeout(() => {
30
+ if (this.startId) {
31
+ delete this.startId;
32
+ this.update();
33
+ this.run();
34
+ } else if (process.env.NODE_ENV !== 'production') {
35
+ console.warn(`Poll setTimeout for ${this.key} still running, but timeoutId deleted`);
36
+ }
37
+ }, Math.max(0, this.lastFetchTime() - now + this.frequency));
38
+ this.connectionListener.addOfflineListener(this.offlineListener);
39
+ };
40
+ if (frequency === undefined) throw new Error('frequency needed for polling subscription');
41
+ this.schema = schema;
42
+ this.fetch = fetch;
43
+ this.frequency = frequency;
44
+ this.key = key;
45
+ this.frequencyHistogram.set(this.frequency, 1);
46
+ this.dispatch = dispatch;
47
+ this.getState = getState;
48
+ this.connectionListener = connectionListener || new DefaultConnectionListener();
49
+
50
+ // Kickstart running since this is initialized after the online notif is sent
51
+ if (this.connectionListener.isOnline()) {
52
+ this.onlineListener();
53
+ } else {
54
+ this.offlineListener();
55
+ }
56
+ }
57
+
58
+ /** Subscribe to a frequency */
59
+ add(frequency) {
60
+ if (frequency === undefined) return;
61
+ if (this.frequencyHistogram.has(frequency)) {
62
+ this.frequencyHistogram.set(frequency, this.frequencyHistogram.get(frequency) + 1);
63
+ } else {
64
+ this.frequencyHistogram.set(frequency, 1);
65
+
66
+ // new min so restart service
67
+ if (frequency < this.frequency) {
68
+ this.frequency = frequency;
69
+ this.run();
70
+ }
71
+ }
72
+ }
73
+
74
+ /** Unsubscribe from a frequency */
75
+ remove(frequency) {
76
+ if (frequency === undefined) return false;
77
+ if (this.frequencyHistogram.has(frequency)) {
78
+ this.frequencyHistogram.set(frequency, this.frequencyHistogram.get(frequency) - 1);
79
+ if (this.frequencyHistogram.get(frequency) < 1) {
80
+ this.frequencyHistogram.delete(frequency);
81
+
82
+ // nothing subscribed to this anymore...it is invalid
83
+ if (this.frequencyHistogram.size === 0) {
84
+ this.cleanup();
85
+ return true;
86
+ }
87
+
88
+ // this was the min, so find the next size
89
+ if (frequency <= this.frequency) {
90
+ this.frequency = Math.min(...this.frequencyHistogram.keys());
91
+ this.run();
92
+ }
93
+ }
94
+ } /* istanbul ignore next */else if (process.env.NODE_ENV !== 'production') {
95
+ console.error(`Mismatched remove: ${frequency} is not subscribed for ${this.key}`);
96
+ }
97
+ return false;
98
+ }
99
+
100
+ /** Cleanup means clearing out background interval. */
101
+ cleanup() {
102
+ if (this.intervalId) {
103
+ clearInterval(this.intervalId);
104
+ delete this.intervalId;
105
+ }
106
+ if (this.lastIntervalId) {
107
+ clearInterval(this.lastIntervalId);
108
+ delete this.lastIntervalId;
109
+ }
110
+ if (this.startId) {
111
+ clearTimeout(this.startId);
112
+ delete this.startId;
113
+ }
114
+ this.connectionListener.removeOnlineListener(this.onlineListener);
115
+ this.connectionListener.removeOfflineListener(this.offlineListener);
116
+ }
117
+
118
+ /** Trigger request for latest resource */
119
+ update() {
120
+ const endpoint = () => this.fetch();
121
+ endpoint.schema = this.schema;
122
+ endpoint.key = () => this.key;
123
+ endpoint.dataExpiryLength = this.frequency / 2;
124
+ endpoint.errorExpiryLength = this.frequency / 10;
125
+ endpoint.errorPolicy = () => 'soft';
126
+ const action = createFetch(endpoint, {
127
+ args: []
128
+ });
129
+ // stop any errors here from bubbling
130
+ action.meta.promise.catch(e => null);
131
+ this.dispatch(action);
132
+ }
133
+ /** Run polling process with current frequency
134
+ *
135
+ * Will clean up old poll interval on next run
136
+ */
137
+ run() {
138
+ if (this.startId) return;
139
+ if (this.intervalId) this.lastIntervalId = this.intervalId;
140
+ this.intervalId = setInterval(() => {
141
+ // since we don't know how long into the last poll it was before resetting
142
+ // we wait til the next fetch to clear old intervals
143
+ if (this.lastIntervalId) {
144
+ clearInterval(this.lastIntervalId);
145
+ delete this.lastIntervalId;
146
+ }
147
+ if (this.intervalId) this.update();else if (process.env.NODE_ENV !== 'production') {
148
+ console.warn(`Poll intervalId for ${this.key} still running, but intervalId deleted`);
149
+ }
150
+ }, this.frequency);
151
+ }
152
+
153
+ /** Last fetch time */
154
+ lastFetchTime() {
155
+ var _this$getState$meta$t, _this$getState$meta$t2;
156
+ return (_this$getState$meta$t = (_this$getState$meta$t2 = this.getState().meta[this.key]) == null ? void 0 : _this$getState$meta$t2.date) != null ? _this$getState$meta$t : 0;
157
+ }
158
+ }
159
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DefaultConnectionListener","createFetch","PollingSubscription","constructor","key","schema","fetch","frequency","getState","dispatch","connectionListener","frequencyHistogram","Map","offlineListener","cleanup","addOnlineListener","onlineListener","removeOnlineListener","now","Date","startId","setTimeout","update","run","process","env","NODE_ENV","console","warn","Math","max","lastFetchTime","addOfflineListener","undefined","Error","set","isOnline","add","has","get","remove","delete","size","min","keys","error","intervalId","clearInterval","lastIntervalId","clearTimeout","removeOfflineListener","endpoint","dataExpiryLength","errorExpiryLength","errorPolicy","action","args","meta","promise","catch","e","setInterval","_this$getState$meta$t","_this$getState$meta$t2","date"],"sources":["../../src/manager/PollingSubscription.ts"],"sourcesContent":["import type { EndpointInterface, Schema } from '@data-client/normalizr';\n\nimport ConnectionListener from './ConnectionListener.js';\nimport DefaultConnectionListener from './DefaultConnectionListener.js';\nimport { Subscription, SubscriptionInit } from './SubscriptionManager.js';\nimport createFetch from '../controller/createFetch.js';\nimport type { State, Dispatch } from '../types.js';\n\n/**\n * PollingSubscription keeps a given resource updated by\n * dispatching a fetch at a rate equal to the minimum update\n * interval requested.\n *\n * @see https://resthooks.io/docs/api/PollingSubscription\n */\nexport default class PollingSubscription implements Subscription {\n  protected declare readonly schema: Schema | undefined;\n  protected declare readonly fetch: () => Promise<any>;\n  protected declare readonly key: string;\n  protected declare frequency: number;\n  protected frequencyHistogram: Map<number, number> = new Map();\n  protected declare dispatch: Dispatch<any>;\n  protected declare getState: () => State<unknown>;\n  protected declare intervalId?: ReturnType<typeof setInterval>;\n  protected declare lastIntervalId?: ReturnType<typeof setInterval>;\n  protected declare startId?: ReturnType<typeof setTimeout>;\n  private declare connectionListener: ConnectionListener;\n\n  constructor(\n    { key, schema, fetch, frequency, getState }: SubscriptionInit,\n    dispatch: Dispatch<any>,\n    connectionListener?: ConnectionListener,\n  ) {\n    if (frequency === undefined)\n      throw new Error('frequency needed for polling subscription');\n    this.schema = schema;\n    this.fetch = fetch;\n    this.frequency = frequency;\n    this.key = key;\n    this.frequencyHistogram.set(this.frequency, 1);\n    this.dispatch = dispatch;\n    this.getState = getState;\n    this.connectionListener =\n      connectionListener || new DefaultConnectionListener();\n\n    // Kickstart running since this is initialized after the online notif is sent\n    if (this.connectionListener.isOnline()) {\n      this.onlineListener();\n    } else {\n      this.offlineListener();\n    }\n  }\n\n  /** Subscribe to a frequency */\n  add(frequency?: number) {\n    if (frequency === undefined) return;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) + 1,\n      );\n    } else {\n      this.frequencyHistogram.set(frequency, 1);\n\n      // new min so restart service\n      if (frequency < this.frequency) {\n        this.frequency = frequency;\n        this.run();\n      }\n    }\n  }\n\n  /** Unsubscribe from a frequency */\n  remove(frequency?: number) {\n    if (frequency === undefined) return false;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) - 1,\n      );\n      if ((this.frequencyHistogram.get(frequency) as number) < 1) {\n        this.frequencyHistogram.delete(frequency);\n\n        // nothing subscribed to this anymore...it is invalid\n        if (this.frequencyHistogram.size === 0) {\n          this.cleanup();\n          return true;\n        }\n\n        // this was the min, so find the next size\n        if (frequency <= this.frequency) {\n          this.frequency = Math.min(...this.frequencyHistogram.keys());\n          this.run();\n        }\n      }\n    } /* istanbul ignore next */ else if (\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.error(\n        `Mismatched remove: ${frequency} is not subscribed for ${this.key}`,\n      );\n    }\n    return false;\n  }\n\n  /** Cleanup means clearing out background interval. */\n  cleanup() {\n    if (this.intervalId) {\n      clearInterval(this.intervalId);\n      delete this.intervalId;\n    }\n    if (this.lastIntervalId) {\n      clearInterval(this.lastIntervalId);\n      delete this.lastIntervalId;\n    }\n    if (this.startId) {\n      clearTimeout(this.startId);\n      delete this.startId;\n    }\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    this.connectionListener.removeOfflineListener(this.offlineListener);\n  }\n\n  /** Trigger request for latest resource */\n  protected update() {\n    const endpoint: EndpointInterface = () => this.fetch();\n    (endpoint as any).schema = this.schema;\n    endpoint.key = () => this.key;\n    (endpoint as any).dataExpiryLength = this.frequency / 2;\n    (endpoint as any).errorExpiryLength = this.frequency / 10;\n    endpoint.errorPolicy = () => 'soft' as const;\n    const action = createFetch(endpoint, { args: [] });\n    // stop any errors here from bubbling\n    (action.meta.promise as Promise<any>).catch(e => null);\n    this.dispatch(action);\n  }\n\n  /** What happens when browser goes offline */\n  protected offlineListener = () => {\n    // this clears existing listeners, so no need to clear offline listener\n    this.cleanup();\n    this.connectionListener.addOnlineListener(this.onlineListener);\n  };\n\n  /** What happens when browser comes online */\n  protected onlineListener = () => {\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    const now = Date.now();\n    this.startId = setTimeout(() => {\n      if (this.startId) {\n        delete this.startId;\n        this.update();\n        this.run();\n      } else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll setTimeout for ${this.key} still running, but timeoutId deleted`,\n        );\n      }\n    }, Math.max(0, this.lastFetchTime() - now + this.frequency));\n    this.connectionListener.addOfflineListener(this.offlineListener);\n  };\n\n  /** Run polling process with current frequency\n   *\n   * Will clean up old poll interval on next run\n   */\n  protected run() {\n    if (this.startId) return;\n    if (this.intervalId) this.lastIntervalId = this.intervalId;\n    this.intervalId = setInterval(() => {\n      // since we don't know how long into the last poll it was before resetting\n      // we wait til the next fetch to clear old intervals\n      if (this.lastIntervalId) {\n        clearInterval(this.lastIntervalId);\n        delete this.lastIntervalId;\n      }\n      if (this.intervalId) this.update();\n      else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll intervalId for ${this.key} still running, but intervalId deleted`,\n        );\n      }\n    }, this.frequency);\n  }\n\n  /** Last fetch time */\n  protected lastFetchTime() {\n    return this.getState().meta[this.key]?.date ?? 0;\n  }\n}\n"],"mappings":"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"}
@@ -0,0 +1,55 @@
1
+ import type { Schema } from '@data-client/normalizr';
2
+ import type { Manager, State, Middleware, Dispatch, UnsubscribeAction, SubscribeAction } from '../types.js';
3
+ /** Properties sent to Subscription constructor */
4
+ export interface SubscriptionInit {
5
+ schema?: Schema | undefined;
6
+ fetch: () => Promise<any>;
7
+ key: string;
8
+ getState: () => State<unknown>;
9
+ frequency?: number | undefined;
10
+ }
11
+ /** Interface handling a single resource subscription */
12
+ export interface Subscription {
13
+ add(frequency?: number): void;
14
+ remove(frequency?: number): boolean;
15
+ cleanup(): void;
16
+ }
17
+ /** The static class that constructs Subscription */
18
+ export interface SubscriptionConstructable {
19
+ new (init: SubscriptionInit, dispatch: Dispatch<any>): Subscription;
20
+ }
21
+ /** Handles subscription actions -> fetch or receive actions
22
+ *
23
+ * Constructor takes a SubscriptionConstructable class to control how
24
+ * subscriptions are handled. (e.g., polling, websockets)
25
+ *
26
+ * @see https://resthooks.io/docs/api/SubscriptionManager
27
+ */
28
+ export default class SubscriptionManager<S extends SubscriptionConstructable> implements Manager {
29
+ protected subscriptions: {
30
+ [key: string]: InstanceType<S>;
31
+ };
32
+ protected readonly Subscription: S;
33
+ protected middleware: Middleware;
34
+ constructor(Subscription: S);
35
+ /** Ensures all subscriptions are cleaned up. */
36
+ cleanup(): void;
37
+ /** Called when middleware intercepts 'rest-hooks/subscribe' action.
38
+ *
39
+ */
40
+ protected handleSubscribe(action: SubscribeAction, dispatch: (action: any) => Promise<void>, getState: () => State<unknown>): void;
41
+ /** Called when middleware intercepts 'rest-hooks/unsubscribe' action.
42
+ *
43
+ */
44
+ protected handleUnsubscribe(action: UnsubscribeAction, dispatch: (action: any) => Promise<void>): void;
45
+ /** Attaches Manager to store
46
+ *
47
+ * Intercepts 'rest-hooks/subscribe'/'rest-hooks/unsubscribe' to register resources that
48
+ * need to be kept up to date.
49
+ *
50
+ * Will possibly dispatch 'rest-hooks/fetch' or 'rest-hooks/receive' to keep resources fresh
51
+ *
52
+ */
53
+ getMiddleware(): Middleware;
54
+ }
55
+ //# sourceMappingURL=SubscriptionManager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SubscriptionManager.d.ts","sourceRoot":"","sources":["../../src/manager/SubscriptionManager.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAGrD,OAAO,KAAK,EACV,OAAO,EACP,KAAK,EAEL,UAAU,EACV,QAAQ,EACR,iBAAiB,EACjB,eAAe,EAChB,MAAM,aAAa,CAAC;AAIrB,kDAAkD;AAClD,MAAM,WAAW,gBAAgB;IAC/B,MAAM,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC5B,KAAK,EAAE,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC;IAC1B,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC;IAC/B,SAAS,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CAChC;AAED,wDAAwD;AACxD,MAAM,WAAW,YAAY;IAC3B,GAAG,CAAC,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,MAAM,CAAC,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IACpC,OAAO,IAAI,IAAI,CAAC;CACjB;AAED,oDAAoD;AACpD,MAAM,WAAW,yBAAyB;IACxC,KAAK,IAAI,EAAE,gBAAgB,EAAE,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC,GAAG,YAAY,CAAC;CACrE;AAED;;;;;;GAMG;AACH,MAAM,CAAC,OAAO,OAAO,mBAAmB,CAAC,CAAC,SAAS,yBAAyB,CAC1E,YAAW,OAAO;IAElB,SAAS,CAAC,aAAa,EAAE;QACvB,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;KAChC,CAAM;IAEP,mBAA2B,YAAY,EAAE,CAAC,CAAC;IAC3C,UAAkB,UAAU,EAAE,UAAU,CAAC;gBAE7B,YAAY,EAAE,CAAC;IAwB3B,gDAAgD;IAChD,OAAO;IAMP;;OAEG;IACH,SAAS,CAAC,eAAe,CACvB,MAAM,EAAE,eAAe,EACvB,QAAQ,EAAE,CAAC,MAAM,EAAE,GAAG,KAAK,OAAO,CAAC,IAAI,CAAC,EACxC,QAAQ,EAAE,MAAM,KAAK,CAAC,OAAO,CAAC;IAiChC;;OAEG;IACH,SAAS,CAAC,iBAAiB,CACzB,MAAM,EAAE,iBAAiB,EACzB,QAAQ,EAAE,CAAC,MAAM,EAAE,GAAG,KAAK,OAAO,CAAC,IAAI,CAAC;IAgB1C;;;;;;;OAOG;IACH,aAAa;CAGd"}
@@ -0,0 +1,117 @@
1
+ import { SUBSCRIBE_TYPE, UNSUBSCRIBE_TYPE } from '../actionTypes.js';
2
+
3
+ /** Properties sent to Subscription constructor */
4
+
5
+ /** Interface handling a single resource subscription */
6
+
7
+ /** The static class that constructs Subscription */
8
+
9
+ /** Handles subscription actions -> fetch or receive actions
10
+ *
11
+ * Constructor takes a SubscriptionConstructable class to control how
12
+ * subscriptions are handled. (e.g., polling, websockets)
13
+ *
14
+ * @see https://resthooks.io/docs/api/SubscriptionManager
15
+ */
16
+ export default class SubscriptionManager {
17
+ constructor(Subscription) {
18
+ this.subscriptions = {};
19
+ this.Subscription = Subscription;
20
+ this.middleware = ({
21
+ dispatch,
22
+ getState
23
+ }) => {
24
+ return next => action => {
25
+ switch (action.type) {
26
+ case SUBSCRIBE_TYPE:
27
+ try {
28
+ this.handleSubscribe(action, dispatch, getState);
29
+ } catch (e) {
30
+ console.error(e);
31
+ }
32
+ return Promise.resolve();
33
+ case UNSUBSCRIBE_TYPE:
34
+ this.handleUnsubscribe(action, dispatch);
35
+ return Promise.resolve();
36
+ default:
37
+ return next(action);
38
+ }
39
+ };
40
+ };
41
+ }
42
+
43
+ /** Ensures all subscriptions are cleaned up. */
44
+ cleanup() {
45
+ for (const key in this.subscriptions) {
46
+ this.subscriptions[key].cleanup();
47
+ }
48
+ }
49
+
50
+ /** Called when middleware intercepts 'rest-hooks/subscribe' action.
51
+ *
52
+ */
53
+ handleSubscribe(action, dispatch, getState) {
54
+ let options;
55
+ if (action.endpoint) {
56
+ const {
57
+ endpoint
58
+ } = action;
59
+ const {
60
+ args
61
+ } = action.meta;
62
+ options = {
63
+ schema: endpoint.schema,
64
+ fetch: () => endpoint(...args),
65
+ frequency: endpoint.pollFrequency,
66
+ key: endpoint.key(...args),
67
+ getState
68
+ };
69
+ } else {
70
+ var _action$meta$options;
71
+ options = {
72
+ key: action.meta.key,
73
+ frequency: (_action$meta$options = action.meta.options) == null ? void 0 : _action$meta$options.pollFrequency,
74
+ schema: action.meta.schema,
75
+ fetch: action.meta.fetch,
76
+ getState
77
+ };
78
+ }
79
+ if (options.key in this.subscriptions) {
80
+ this.subscriptions[options.key].add(options.frequency);
81
+ } else {
82
+ this.subscriptions[options.key] = new this.Subscription(options, dispatch);
83
+ }
84
+ }
85
+
86
+ /** Called when middleware intercepts 'rest-hooks/unsubscribe' action.
87
+ *
88
+ */
89
+ handleUnsubscribe(action, dispatch) {
90
+ var _action$meta$options2;
91
+ const key = action.meta.key;
92
+ const frequency = (_action$meta$options2 = action.meta.options) == null ? void 0 : _action$meta$options2.pollFrequency;
93
+
94
+ /* istanbul ignore else */
95
+ if (key in this.subscriptions) {
96
+ const empty = this.subscriptions[key].remove(frequency);
97
+ if (empty) {
98
+ delete this.subscriptions[key];
99
+ }
100
+ } else if (process.env.NODE_ENV !== 'production') {
101
+ console.error(`Mismatched unsubscribe: ${key} is not subscribed`);
102
+ }
103
+ }
104
+
105
+ /** Attaches Manager to store
106
+ *
107
+ * Intercepts 'rest-hooks/subscribe'/'rest-hooks/unsubscribe' to register resources that
108
+ * need to be kept up to date.
109
+ *
110
+ * Will possibly dispatch 'rest-hooks/fetch' or 'rest-hooks/receive' to keep resources fresh
111
+ *
112
+ */
113
+ getMiddleware() {
114
+ return this.middleware;
115
+ }
116
+ }
117
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SUBSCRIBE_TYPE","UNSUBSCRIBE_TYPE","SubscriptionManager","constructor","Subscription","subscriptions","middleware","dispatch","getState","next","action","type","handleSubscribe","e","console","error","Promise","resolve","handleUnsubscribe","cleanup","key","options","endpoint","args","meta","schema","fetch","frequency","pollFrequency","_action$meta$options","add","_action$meta$options2","empty","remove","process","env","NODE_ENV","getMiddleware"],"sources":["../../src/manager/SubscriptionManager.ts"],"sourcesContent":["import type { Schema } from '@data-client/normalizr';\n\nimport { SUBSCRIBE_TYPE, UNSUBSCRIBE_TYPE } from '../actionTypes.js';\nimport type {\n  Manager,\n  State,\n  MiddlewareAPI,\n  Middleware,\n  Dispatch,\n  UnsubscribeAction,\n  SubscribeAction,\n} from '../types.js';\n\ntype Actions = UnsubscribeAction | SubscribeAction;\n\n/** Properties sent to Subscription constructor */\nexport interface SubscriptionInit {\n  schema?: Schema | undefined;\n  fetch: () => Promise<any>;\n  key: string;\n  getState: () => State<unknown>;\n  frequency?: number | undefined;\n}\n\n/** Interface handling a single resource subscription */\nexport interface Subscription {\n  add(frequency?: number): void;\n  remove(frequency?: number): boolean;\n  cleanup(): void;\n}\n\n/** The static class that constructs Subscription */\nexport interface SubscriptionConstructable {\n  new (init: SubscriptionInit, dispatch: Dispatch<any>): Subscription;\n}\n\n/** Handles subscription actions -> fetch or receive actions\n *\n * Constructor takes a SubscriptionConstructable class to control how\n * subscriptions are handled. (e.g., polling, websockets)\n *\n * @see https://resthooks.io/docs/api/SubscriptionManager\n */\nexport default class SubscriptionManager<S extends SubscriptionConstructable>\n  implements Manager\n{\n  protected subscriptions: {\n    [key: string]: InstanceType<S>;\n  } = {};\n\n  protected declare readonly Subscription: S;\n  protected declare middleware: Middleware;\n\n  constructor(Subscription: S) {\n    this.Subscription = Subscription;\n\n    this.middleware = <C extends MiddlewareAPI>({ dispatch, getState }: C) => {\n      return (next: C['dispatch']): C['dispatch'] =>\n        action => {\n          switch (action.type) {\n            case SUBSCRIBE_TYPE:\n              try {\n                this.handleSubscribe(action, dispatch, getState);\n              } catch (e) {\n                console.error(e);\n              }\n              return Promise.resolve();\n            case UNSUBSCRIBE_TYPE:\n              this.handleUnsubscribe(action, dispatch);\n              return Promise.resolve();\n            default:\n              return next(action);\n          }\n        };\n    };\n  }\n\n  /** Ensures all subscriptions are cleaned up. */\n  cleanup() {\n    for (const key in this.subscriptions) {\n      this.subscriptions[key].cleanup();\n    }\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/subscribe' action.\n   *\n   */\n  protected handleSubscribe(\n    action: SubscribeAction,\n    dispatch: (action: any) => Promise<void>,\n    getState: () => State<unknown>,\n  ) {\n    let options: SubscriptionInit;\n    if (action.endpoint) {\n      const { endpoint } = action;\n      const { args } = action.meta;\n      options = {\n        schema: endpoint.schema,\n        fetch: () => endpoint(...args),\n        frequency: endpoint.pollFrequency,\n        key: endpoint.key(...args),\n        getState,\n      };\n    } else {\n      options = {\n        key: action.meta.key,\n        frequency: action.meta.options?.pollFrequency,\n        schema: action.meta.schema,\n        fetch: action.meta.fetch,\n        getState,\n      };\n    }\n\n    if (options.key in this.subscriptions) {\n      this.subscriptions[options.key].add(options.frequency);\n    } else {\n      this.subscriptions[options.key] = new this.Subscription(\n        options,\n        dispatch,\n      ) as InstanceType<S>;\n    }\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/unsubscribe' action.\n   *\n   */\n  protected handleUnsubscribe(\n    action: UnsubscribeAction,\n    dispatch: (action: any) => Promise<void>,\n  ) {\n    const key = action.meta.key;\n    const frequency = action.meta.options?.pollFrequency;\n\n    /* istanbul ignore else */\n    if (key in this.subscriptions) {\n      const empty = this.subscriptions[key].remove(frequency);\n      if (empty) {\n        delete this.subscriptions[key];\n      }\n    } else if (process.env.NODE_ENV !== 'production') {\n      console.error(`Mismatched unsubscribe: ${key} is not subscribed`);\n    }\n  }\n\n  /** Attaches Manager to store\n   *\n   * Intercepts 'rest-hooks/subscribe'/'rest-hooks/unsubscribe' to register resources that\n   * need to be kept up to date.\n   *\n   * Will possibly dispatch 'rest-hooks/fetch' or 'rest-hooks/receive' to keep resources fresh\n   *\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n}\n"],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import type Controller from '../controller/Controller.js';
2
+ import type { Reducer, Dispatch, ReducerState } from '../middlewareTypes.js';
3
+ import { Manager } from '../types.js';
4
+ export default function applyManager(managers: Manager[], controller: Controller): Middleware[];
5
+ export interface MiddlewareAPI<R extends Reducer<any, any> = Reducer<any, any>> {
6
+ getState: () => ReducerState<R>;
7
+ dispatch: Dispatch<R>;
8
+ }
9
+ export type Middleware = <R extends Reducer<any, any>>({ dispatch, }: MiddlewareAPI<R>) => (next: Dispatch<R>) => Dispatch<R>;
10
+ //# sourceMappingURL=applyManager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"applyManager.d.ts","sourceRoot":"","sources":["../../src/manager/applyManager.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,UAAU,MAAM,6BAA6B,CAAC;AAC1D,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAC7E,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,MAAM,CAAC,OAAO,UAAU,YAAY,CAClC,QAAQ,EAAE,OAAO,EAAE,EACnB,UAAU,EAAE,UAAU,GACrB,UAAU,EAAE,CAcd;AAGD,MAAM,WAAW,aAAa,CAC5B,CAAC,SAAS,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC;IAE/C,QAAQ,EAAE,MAAM,YAAY,CAAC,CAAC,CAAC,CAAC;IAChC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;CACvB;AACD,MAAM,MAAM,UAAU,GAAG,CAAC,CAAC,SAAS,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EACrD,QAAQ,GACT,EAAE,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC"}
@@ -0,0 +1,23 @@
1
+ export default function applyManager(managers, controller) {
2
+ return managers.map(manager => {
3
+ const middleware = manager.getMiddleware();
4
+ return ({
5
+ dispatch,
6
+ getState
7
+ }) => {
8
+ controller.dispatch = dispatch;
9
+ controller.getState = getState;
10
+ // this is needed for backwards compatibility as we added 'controller' prop previously
11
+ const API = Object.create(controller, {
12
+ controller: {
13
+ value: controller
14
+ }
15
+ });
16
+ // controller is a superset of the middleware API
17
+ return middleware(API);
18
+ };
19
+ });
20
+ }
21
+
22
+ /* These should be compatible with redux */
23
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBseU1hbmFnZXIiLCJtYW5hZ2VycyIsImNvbnRyb2xsZXIiLCJtYXAiLCJtYW5hZ2VyIiwibWlkZGxld2FyZSIsImdldE1pZGRsZXdhcmUiLCJkaXNwYXRjaCIsImdldFN0YXRlIiwiQVBJIiwiT2JqZWN0IiwiY3JlYXRlIiwidmFsdWUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9hcHBseU1hbmFnZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgQ29udHJvbGxlciBmcm9tICcuLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBSZWR1Y2VyLCBEaXNwYXRjaCwgUmVkdWNlclN0YXRlIH0gZnJvbSAnLi4vbWlkZGxld2FyZVR5cGVzLmpzJztcbmltcG9ydCB7IE1hbmFnZXIgfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFwcGx5TWFuYWdlcihcbiAgbWFuYWdlcnM6IE1hbmFnZXJbXSxcbiAgY29udHJvbGxlcjogQ29udHJvbGxlcixcbik6IE1pZGRsZXdhcmVbXSB7XG4gIHJldHVybiBtYW5hZ2Vycy5tYXAobWFuYWdlciA9PiB7XG4gICAgY29uc3QgbWlkZGxld2FyZSA9IG1hbmFnZXIuZ2V0TWlkZGxld2FyZSgpO1xuICAgIHJldHVybiAoeyBkaXNwYXRjaCwgZ2V0U3RhdGUgfSkgPT4ge1xuICAgICAgKGNvbnRyb2xsZXIgYXMgYW55KS5kaXNwYXRjaCA9IGRpc3BhdGNoO1xuICAgICAgKGNvbnRyb2xsZXIgYXMgYW55KS5nZXRTdGF0ZSA9IGdldFN0YXRlO1xuICAgICAgLy8gdGhpcyBpcyBuZWVkZWQgZm9yIGJhY2t3YXJkcyBjb21wYXRpYmlsaXR5IGFzIHdlIGFkZGVkICdjb250cm9sbGVyJyBwcm9wIHByZXZpb3VzbHlcbiAgICAgIGNvbnN0IEFQSSA9IE9iamVjdC5jcmVhdGUoY29udHJvbGxlciwge1xuICAgICAgICBjb250cm9sbGVyOiB7IHZhbHVlOiBjb250cm9sbGVyIH0sXG4gICAgICB9KTtcbiAgICAgIC8vIGNvbnRyb2xsZXIgaXMgYSBzdXBlcnNldCBvZiB0aGUgbWlkZGxld2FyZSBBUElcbiAgICAgIHJldHVybiBtaWRkbGV3YXJlKEFQSSk7XG4gICAgfTtcbiAgfSk7XG59XG5cbi8qIFRoZXNlIHNob3VsZCBiZSBjb21wYXRpYmxlIHdpdGggcmVkdXggKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWlkZGxld2FyZUFQSTxcbiAgUiBleHRlbmRzIFJlZHVjZXI8YW55LCBhbnk+ID0gUmVkdWNlcjxhbnksIGFueT4sXG4+IHtcbiAgZ2V0U3RhdGU6ICgpID0+IFJlZHVjZXJTdGF0ZTxSPjtcbiAgZGlzcGF0Y2g6IERpc3BhdGNoPFI+O1xufVxuZXhwb3J0IHR5cGUgTWlkZGxld2FyZSA9IDxSIGV4dGVuZHMgUmVkdWNlcjxhbnksIGFueT4+KHtcbiAgZGlzcGF0Y2gsXG59OiBNaWRkbGV3YXJlQVBJPFI+KSA9PiAobmV4dDogRGlzcGF0Y2g8Uj4pID0+IERpc3BhdGNoPFI+O1xuIl0sIm1hcHBpbmdzIjoiQUFJQSxlQUFlLFNBQVNBLFlBQVlBLENBQ2xDQyxRQUFtQixFQUNuQkMsVUFBc0IsRUFDUjtFQUNkLE9BQU9ELFFBQVEsQ0FBQ0UsR0FBRyxDQUFDQyxPQUFPLElBQUk7SUFDN0IsTUFBTUMsVUFBVSxHQUFHRCxPQUFPLENBQUNFLGFBQWEsQ0FBQyxDQUFDO0lBQzFDLE9BQU8sQ0FBQztNQUFFQyxRQUFRO01BQUVDO0lBQVMsQ0FBQyxLQUFLO01BQ2hDTixVQUFVLENBQVNLLFFBQVEsR0FBR0EsUUFBUTtNQUN0Q0wsVUFBVSxDQUFTTSxRQUFRLEdBQUdBLFFBQVE7TUFDdkM7TUFDQSxNQUFNQyxHQUFHLEdBQUdDLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDVCxVQUFVLEVBQUU7UUFDcENBLFVBQVUsRUFBRTtVQUFFVSxLQUFLLEVBQUVWO1FBQVc7TUFDbEMsQ0FBQyxDQUFDO01BQ0Y7TUFDQSxPQUFPRyxVQUFVLENBQUNJLEdBQUcsQ0FBQztJQUN4QixDQUFDO0VBQ0gsQ0FBQyxDQUFDO0FBQ0o7O0FBRUEifQ==