@data-client/core 0.12.3 → 0.13.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 (92) hide show
  1. package/README.md +1 -1
  2. package/dist/index.js +89 -15
  3. package/dist/index.umd.min.js +1 -1
  4. package/legacy/actionTypes.js +2 -1
  5. package/legacy/actions.js +1 -1
  6. package/legacy/controller/Controller.js +21 -7
  7. package/legacy/controller/createSet.js +7 -11
  8. package/legacy/controller/createSetResponse.js +32 -0
  9. package/legacy/index.js +2 -1
  10. package/legacy/manager/DevtoolsManager.js +5 -5
  11. package/legacy/manager/LogoutManager.js +3 -3
  12. package/legacy/manager/NetworkManager.js +5 -5
  13. package/legacy/manager/PollingSubscription.js +1 -1
  14. package/legacy/manager/SubscriptionManager.js +1 -1
  15. package/legacy/next/index.js +1 -1
  16. package/legacy/state/reducer/createReducer.js +6 -3
  17. package/legacy/state/reducer/fetchReducer.js +1 -1
  18. package/legacy/state/reducer/setReducer.js +7 -85
  19. package/legacy/state/reducer/setResponseReducer.js +107 -0
  20. package/legacy/types.js +1 -1
  21. package/lib/actionTypes.d.ts +1 -0
  22. package/lib/actionTypes.d.ts.map +1 -1
  23. package/lib/actionTypes.js +2 -1
  24. package/lib/actions.d.ts +23 -11
  25. package/lib/actions.d.ts.map +1 -1
  26. package/lib/actions.js +1 -1
  27. package/lib/controller/Controller.d.ts +7 -2
  28. package/lib/controller/Controller.d.ts.map +1 -1
  29. package/lib/controller/Controller.js +21 -7
  30. package/lib/controller/createSet.d.ts +5 -17
  31. package/lib/controller/createSet.d.ts.map +1 -1
  32. package/lib/controller/createSet.js +7 -11
  33. package/lib/controller/createSetResponse.d.ts +20 -0
  34. package/lib/controller/createSetResponse.d.ts.map +1 -0
  35. package/lib/controller/createSetResponse.js +32 -0
  36. package/lib/index.d.ts +1 -0
  37. package/lib/index.d.ts.map +1 -1
  38. package/lib/index.js +2 -1
  39. package/lib/manager/DevtoolsManager.d.ts.map +1 -1
  40. package/lib/manager/DevtoolsManager.js +5 -3
  41. package/lib/manager/LogoutManager.js +3 -3
  42. package/lib/manager/NetworkManager.d.ts +2 -2
  43. package/lib/manager/NetworkManager.d.ts.map +1 -1
  44. package/lib/manager/NetworkManager.js +5 -5
  45. package/lib/manager/PollingSubscription.js +1 -1
  46. package/lib/manager/SubscriptionManager.js +1 -1
  47. package/lib/next/index.js +1 -1
  48. package/lib/state/reducer/createReducer.d.ts.map +1 -1
  49. package/lib/state/reducer/createReducer.js +6 -3
  50. package/lib/state/reducer/expireReducer.d.ts +1 -1
  51. package/lib/state/reducer/fetchReducer.js +1 -1
  52. package/lib/state/reducer/invalidateReducer.d.ts +1 -1
  53. package/lib/state/reducer/setReducer.d.ts +2 -3
  54. package/lib/state/reducer/setReducer.d.ts.map +1 -1
  55. package/lib/state/reducer/setReducer.js +7 -90
  56. package/lib/state/reducer/setResponseReducer.d.ts +4 -0
  57. package/lib/state/reducer/setResponseReducer.d.ts.map +1 -0
  58. package/lib/state/reducer/setResponseReducer.js +112 -0
  59. package/lib/types.d.ts +2 -4
  60. package/lib/types.d.ts.map +1 -1
  61. package/lib/types.js +1 -1
  62. package/package.json +1 -1
  63. package/src/actionTypes.ts +1 -0
  64. package/src/actions.ts +29 -10
  65. package/src/controller/Controller.ts +25 -8
  66. package/src/controller/createSet.ts +11 -51
  67. package/src/controller/createSetResponse.ts +79 -0
  68. package/src/index.ts +1 -0
  69. package/src/manager/DevtoolsManager.ts +4 -2
  70. package/src/manager/LogoutManager.ts +2 -2
  71. package/src/manager/NetworkManager.ts +6 -6
  72. package/src/manager/__tests__/logoutManager.ts +5 -5
  73. package/src/manager/__tests__/networkManager.ts +6 -6
  74. package/src/manager/__tests__/subscriptionManager.ts +2 -2
  75. package/src/state/__tests__/reducer.ts +64 -25
  76. package/src/state/reducer/createReducer.ts +6 -1
  77. package/src/state/reducer/fetchReducer.ts +2 -2
  78. package/src/state/reducer/setReducer.ts +9 -121
  79. package/src/state/reducer/setResponseReducer.ts +151 -0
  80. package/src/types.ts +6 -5
  81. package/ts3.4/actionTypes.d.ts +1 -0
  82. package/ts3.4/actions.d.ts +23 -11
  83. package/ts3.4/controller/Controller.d.ts +10 -2
  84. package/ts3.4/controller/createSet.d.ts +5 -19
  85. package/ts3.4/controller/createSetResponse.d.ts +24 -0
  86. package/ts3.4/index.d.ts +1 -0
  87. package/ts3.4/manager/NetworkManager.d.ts +2 -2
  88. package/ts3.4/state/reducer/expireReducer.d.ts +1 -1
  89. package/ts3.4/state/reducer/invalidateReducer.d.ts +1 -1
  90. package/ts3.4/state/reducer/setReducer.d.ts +2 -3
  91. package/ts3.4/state/reducer/setResponseReducer.d.ts +4 -0
  92. package/ts3.4/types.d.ts +2 -4
@@ -0,0 +1,112 @@
1
+ import { normalize } from '@data-client/normalizr';
2
+ import { OPTIMISTIC_TYPE } from '../../actionTypes.js';
3
+ import AbortOptimistic from '../../controller/AbortOptimistic.js';
4
+ export function setResponseReducer(state, action, controller) {
5
+ if (action.error) {
6
+ return reduceError(state, action, action.payload);
7
+ }
8
+ try {
9
+ var _state$meta$action$me;
10
+ let payload;
11
+ // for true set's payload is contained in action
12
+ if (action.type === OPTIMISTIC_TYPE) {
13
+ // this should never happen
14
+ /* istanbul ignore if */
15
+ if (!action.endpoint.getOptimisticResponse) return state;
16
+ try {
17
+ // compute optimistic response based on current state
18
+ payload = action.endpoint.getOptimisticResponse.call(action.endpoint, controller.snapshot(state, action.meta.fetchedAt), ...action.meta.args);
19
+ } catch (e) {
20
+ // AbortOptimistic means 'do nothing', otherwise we count the exception as endpoint failure
21
+ if (e.constructor === AbortOptimistic) {
22
+ return state;
23
+ }
24
+ throw e;
25
+ }
26
+ } else {
27
+ payload = action.payload;
28
+ }
29
+ const {
30
+ result,
31
+ entities,
32
+ indexes,
33
+ entityMeta
34
+ } = normalize(payload, action.endpoint.schema, action.meta.args, state.entities, state.indexes, state.entityMeta, action.meta);
35
+ const endpoints = {
36
+ ...state.endpoints,
37
+ [action.meta.key]: result
38
+ };
39
+ try {
40
+ if (action.endpoint.update) {
41
+ const updaters = action.endpoint.update(result, ...action.meta.args);
42
+ Object.keys(updaters).forEach(key => {
43
+ endpoints[key] = updaters[key](endpoints[key]);
44
+ });
45
+ }
46
+ // no reason to completely fail because of user-code error
47
+ // integrity of this state update is still guaranteed
48
+ } catch (error) {
49
+ console.error(`The following error occured during Endpoint.update() for ${action.meta.key}`);
50
+ console.error(error);
51
+ }
52
+ return {
53
+ entities,
54
+ indexes,
55
+ endpoints,
56
+ entityMeta,
57
+ meta: {
58
+ ...state.meta,
59
+ [action.meta.key]: {
60
+ date: action.meta.date,
61
+ expiresAt: action.meta.expiresAt,
62
+ prevExpiresAt: (_state$meta$action$me = state.meta[action.meta.key]) == null ? void 0 : _state$meta$action$me.expiresAt
63
+ }
64
+ },
65
+ optimistic: filterOptimistic(state, action),
66
+ lastReset: state.lastReset
67
+ };
68
+ // reducer must update the state, so in case of processing errors we simply compute the endpoints inline
69
+ } catch (error) {
70
+ if (typeof error === 'object') {
71
+ error.message = `Error processing ${action.meta.key}\n\nFull Schema: ${JSON.stringify(action.endpoint.schema, undefined, 2)}\n\nError:\n${error.message}`;
72
+ if ('payload' in action) error.payload = action.payload;
73
+ error.status = 400;
74
+ }
75
+
76
+ // this is not always bubbled up, so let's double sure this doesn't fail silently
77
+ /* istanbul ignore else */
78
+ if (process.env.NODE_ENV !== 'production') {
79
+ console.error(error);
80
+ }
81
+ return reduceError(state, action, error);
82
+ }
83
+ }
84
+ function reduceError(state, action, error) {
85
+ if (error.name === 'AbortError') {
86
+ // In case we abort simply undo the optimistic update and act like no fetch even occured
87
+ // We still want those watching promises from fetch directly to observed the abort, but we don't want to
88
+ // Trigger errors in this case. This means theoretically improperly built abortes useResource() could suspend forever.
89
+ return {
90
+ ...state,
91
+ optimistic: filterOptimistic(state, action)
92
+ };
93
+ }
94
+ return {
95
+ ...state,
96
+ meta: {
97
+ ...state.meta,
98
+ [action.meta.key]: {
99
+ date: action.meta.date,
100
+ error,
101
+ expiresAt: action.meta.expiresAt,
102
+ errorPolicy: action.endpoint.errorPolicy == null ? void 0 : action.endpoint.errorPolicy(error)
103
+ }
104
+ },
105
+ optimistic: filterOptimistic(state, action)
106
+ };
107
+ }
108
+ /** Filter all requests with same serialization that did not start after the resolving request */
109
+ function filterOptimistic(state, resolvingAction) {
110
+ return state.optimistic.filter(optimisticAction => optimisticAction.meta.key !== resolvingAction.meta.key || (optimisticAction.type === OPTIMISTIC_TYPE ? optimisticAction.meta.fetchedAt !== resolvingAction.meta.fetchedAt : optimisticAction.meta.date > resolvingAction.meta.date));
111
+ }
112
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["normalize","OPTIMISTIC_TYPE","AbortOptimistic","setResponseReducer","state","action","controller","error","reduceError","payload","_state$meta$action$me","type","endpoint","getOptimisticResponse","call","snapshot","meta","fetchedAt","args","e","constructor","result","entities","indexes","entityMeta","schema","endpoints","key","update","updaters","Object","keys","forEach","console","date","expiresAt","prevExpiresAt","optimistic","filterOptimistic","lastReset","message","JSON","stringify","undefined","status","process","env","NODE_ENV","name","errorPolicy","resolvingAction","filter","optimisticAction"],"sources":["../../../src/state/reducer/setResponseReducer.ts"],"sourcesContent":["import { normalize } from '@data-client/normalizr';\n\nimport { OPTIMISTIC_TYPE } from '../../actionTypes.js';\nimport AbortOptimistic from '../../controller/AbortOptimistic.js';\nimport type Controller from '../../controller/Controller.js';\nimport type {\n  State,\n  SetResponseAction,\n  OptimisticAction,\n} from '../../types.js';\n\nexport function setResponseReducer(\n  state: State<unknown>,\n  action: OptimisticAction | SetResponseAction,\n  controller: Controller,\n) {\n  if (action.error) {\n    return reduceError(state, action, action.payload);\n  }\n  try {\n    let payload: any;\n    // for true set's payload is contained in action\n    if (action.type === OPTIMISTIC_TYPE) {\n      // this should never happen\n      /* istanbul ignore if */\n      if (!action.endpoint.getOptimisticResponse) return state;\n      try {\n        // compute optimistic response based on current state\n        payload = action.endpoint.getOptimisticResponse.call(\n          action.endpoint,\n          controller.snapshot(state, action.meta.fetchedAt),\n          ...action.meta.args,\n        );\n      } catch (e: any) {\n        // AbortOptimistic means 'do nothing', otherwise we count the exception as endpoint failure\n        if (e.constructor === AbortOptimistic) {\n          return state;\n        }\n        throw e;\n      }\n    } else {\n      payload = action.payload;\n    }\n    const { result, entities, indexes, entityMeta } = normalize(\n      payload,\n      action.endpoint.schema,\n      action.meta.args as any,\n      state.entities,\n      state.indexes,\n      state.entityMeta,\n      action.meta,\n    );\n    const endpoints: Record<string, unknown> = {\n      ...state.endpoints,\n      [action.meta.key]: result,\n    };\n    try {\n      if (action.endpoint.update) {\n        const updaters = action.endpoint.update(result, ...action.meta.args);\n        Object.keys(updaters).forEach(key => {\n          endpoints[key] = updaters[key](endpoints[key]);\n        });\n      }\n      // no reason to completely fail because of user-code error\n      // integrity of this state update is still guaranteed\n    } catch (error) {\n      console.error(\n        `The following error occured during Endpoint.update() for ${action.meta.key}`,\n      );\n      console.error(error);\n    }\n    return {\n      entities,\n      indexes,\n      endpoints,\n      entityMeta,\n      meta: {\n        ...state.meta,\n        [action.meta.key]: {\n          date: action.meta.date,\n          expiresAt: action.meta.expiresAt,\n          prevExpiresAt: state.meta[action.meta.key]?.expiresAt,\n        },\n      },\n      optimistic: filterOptimistic(state, action),\n      lastReset: state.lastReset,\n    };\n    // reducer must update the state, so in case of processing errors we simply compute the endpoints inline\n  } catch (error: any) {\n    if (typeof error === 'object') {\n      error.message = `Error processing ${\n        action.meta.key\n      }\\n\\nFull Schema: ${JSON.stringify(\n        action.endpoint.schema,\n        undefined,\n        2,\n      )}\\n\\nError:\\n${error.message}`;\n      if ('payload' in action) error.payload = action.payload;\n      error.status = 400;\n    }\n\n    // this is not always bubbled up, so let's double sure this doesn't fail silently\n    /* istanbul ignore else */\n    if (process.env.NODE_ENV !== 'production') {\n      console.error(error);\n    }\n    return reduceError(state, action, error);\n  }\n}\n\nfunction reduceError(\n  state: State<unknown>,\n  action: SetResponseAction | OptimisticAction,\n  error: any,\n): State<unknown> {\n  if (error.name === 'AbortError') {\n    // In case we abort simply undo the optimistic update and act like no fetch even occured\n    // We still want those watching promises from fetch directly to observed the abort, but we don't want to\n    // Trigger errors in this case. This means theoretically improperly built abortes useResource() could suspend forever.\n    return {\n      ...state,\n      optimistic: filterOptimistic(state, action),\n    };\n  }\n  return {\n    ...state,\n    meta: {\n      ...state.meta,\n      [action.meta.key]: {\n        date: action.meta.date,\n        error,\n        expiresAt: action.meta.expiresAt,\n        errorPolicy: action.endpoint.errorPolicy?.(error),\n      },\n    },\n    optimistic: filterOptimistic(state, action),\n  };\n}\n/** Filter all requests with same serialization that did not start after the resolving request */\nfunction filterOptimistic(\n  state: State<unknown>,\n  resolvingAction: SetResponseAction | OptimisticAction,\n) {\n  return state.optimistic.filter(\n    optimisticAction =>\n      optimisticAction.meta.key !== resolvingAction.meta.key ||\n      (optimisticAction.type === OPTIMISTIC_TYPE ?\n        optimisticAction.meta.fetchedAt !== resolvingAction.meta.fetchedAt\n      : optimisticAction.meta.date > resolvingAction.meta.date),\n  );\n}\n"],"mappings":"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","ignoreList":[]}
package/lib/types.d.ts CHANGED
@@ -1,11 +1,9 @@
1
1
  import { NormalizedIndex } from '@data-client/normalizr';
2
2
  import type { UpdateFunction, AbstractInstanceType } from '@data-client/normalizr';
3
3
  import type { ErrorTypes } from '@data-client/normalizr';
4
- import type { ActionTypes, SetAction, OptimisticAction } from './actions.js';
5
- import { SET_TYPE } from './actionTypes.js';
4
+ import type { ActionTypes, SetResponseAction, OptimisticAction } from './actions.js';
6
5
  import type { Dispatch, Middleware, MiddlewareAPI } from './middlewareTypes.js';
7
6
  export type { AbstractInstanceType, UpdateFunction };
8
- export type SetTypes = typeof SET_TYPE;
9
7
  export type PK = string;
10
8
  export interface State<T> {
11
9
  readonly entities: {
@@ -36,7 +34,7 @@ export interface State<T> {
36
34
  };
37
35
  };
38
36
  };
39
- readonly optimistic: (SetAction | OptimisticAction)[];
37
+ readonly optimistic: (SetResponseAction | OptimisticAction)[];
40
38
  readonly lastReset: number;
41
39
  }
42
40
  export * from './actions.js';
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,KAAK,EACV,cAAc,EACd,oBAAoB,EACrB,MAAM,wBAAwB,CAAC;AAChC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEzD,OAAO,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAC7E,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAEhF,YAAY,EAAE,oBAAoB,EAAE,cAAc,EAAE,CAAC;AAErD,MAAM,MAAM,QAAQ,GAAG,OAAO,QAAQ,CAAC;AAEvC,MAAM,MAAM,EAAE,GAAG,MAAM,CAAC;AAExB,MAAM,WAAW,KAAK,CAAC,CAAC;IACtB,QAAQ,CAAC,QAAQ,EAAE;QACjB,QAAQ,EAAE,SAAS,EAAE,MAAM,GAAG;YAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,GAAG,CAAC,CAAA;SAAE,GAAG,SAAS,CAAC;KACxE,CAAC;IACF,QAAQ,CAAC,OAAO,EAAE,eAAe,CAAC;IAClC,QAAQ,CAAC,SAAS,EAAE;QAClB,QAAQ,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,SAAS,CAAC;KACzD,CAAC;IACF,QAAQ,CAAC,IAAI,EAAE;QACb,QAAQ,EAAE,GAAG,EAAE,MAAM,GAAG;YACtB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;YACtB,QAAQ,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC;YAC5B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;YAC3B,QAAQ,CAAC,aAAa,CAAC,EAAE,MAAM,CAAC;YAChC,QAAQ,CAAC,WAAW,CAAC,EAAE,OAAO,CAAC;YAC/B,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC;SACpD,CAAC;KACH,CAAC;IACF,QAAQ,CAAC,UAAU,EAAE;QACnB,QAAQ,EAAE,SAAS,EAAE,MAAM,GAAG;YAC5B,QAAQ,EAAE,EAAE,EAAE,MAAM,GAAG;gBACrB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;gBACtB,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;gBAC3B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;aAC5B,CAAC;SACH,CAAC;KACH,CAAC;IACF,QAAQ,CAAC,UAAU,EAAE,CAAC,SAAS,GAAG,gBAAgB,CAAC,EAAE,CAAC;IACtD,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;CAC5B;AAED,cAAc,cAAc,CAAC;AAE7B,MAAM,WAAW,OAAO,CAAC,OAAO,GAAG,WAAW;IAC5C,aAAa,IAAI,UAAU,CAAC,OAAO,CAAC,CAAC;IACrC,OAAO,IAAI,IAAI,CAAC;IAChB,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC;CACpC;AAED,YAAY,EAAE,QAAQ,EAAE,UAAU,EAAE,aAAa,EAAE,CAAC"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,KAAK,EACV,cAAc,EACd,oBAAoB,EACrB,MAAM,wBAAwB,CAAC;AAChC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEzD,OAAO,KAAK,EACV,WAAW,EACX,iBAAiB,EACjB,gBAAgB,EACjB,MAAM,cAAc,CAAC;AACtB,OAAO,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAEhF,YAAY,EAAE,oBAAoB,EAAE,cAAc,EAAE,CAAC;AAErD,MAAM,MAAM,EAAE,GAAG,MAAM,CAAC;AAExB,MAAM,WAAW,KAAK,CAAC,CAAC;IACtB,QAAQ,CAAC,QAAQ,EAAE;QACjB,QAAQ,EAAE,SAAS,EAAE,MAAM,GAAG;YAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,GAAG,CAAC,CAAA;SAAE,GAAG,SAAS,CAAC;KACxE,CAAC;IACF,QAAQ,CAAC,OAAO,EAAE,eAAe,CAAC;IAClC,QAAQ,CAAC,SAAS,EAAE;QAClB,QAAQ,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,SAAS,CAAC;KACzD,CAAC;IACF,QAAQ,CAAC,IAAI,EAAE;QACb,QAAQ,EAAE,GAAG,EAAE,MAAM,GAAG;YACtB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;YACtB,QAAQ,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC;YAC5B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;YAC3B,QAAQ,CAAC,aAAa,CAAC,EAAE,MAAM,CAAC;YAChC,QAAQ,CAAC,WAAW,CAAC,EAAE,OAAO,CAAC;YAC/B,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC;SACpD,CAAC;KACH,CAAC;IACF,QAAQ,CAAC,UAAU,EAAE;QACnB,QAAQ,EAAE,SAAS,EAAE,MAAM,GAAG;YAC5B,QAAQ,EAAE,EAAE,EAAE,MAAM,GAAG;gBACrB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;gBACtB,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;gBAC3B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;aAC5B,CAAC;SACH,CAAC;KACH,CAAC;IACF,QAAQ,CAAC,UAAU,EAAE,CAAC,iBAAiB,GAAG,gBAAgB,CAAC,EAAE,CAAC;IAC9D,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;CAC5B;AAED,cAAc,cAAc,CAAC;AAE7B,MAAM,WAAW,OAAO,CAAC,OAAO,GAAG,WAAW;IAC5C,aAAa,IAAI,UAAU,CAAC,OAAO,CAAC,CAAC;IACrC,OAAO,IAAI,IAAI,CAAC;IAChB,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC;CACpC;AAED,YAAY,EAAE,QAAQ,EAAE,UAAU,EAAE,aAAa,EAAE,CAAC"}
package/lib/types.js CHANGED
@@ -1,3 +1,3 @@
1
1
  export * from './actions.js';
2
2
  export {};
3
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL3R5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5vcm1hbGl6ZWRJbmRleCB9IGZyb20gJ0BkYXRhLWNsaWVudC9ub3JtYWxpenInO1xuaW1wb3J0IHR5cGUge1xuICBVcGRhdGVGdW5jdGlvbixcbiAgQWJzdHJhY3RJbnN0YW5jZVR5cGUsXG59IGZyb20gJ0BkYXRhLWNsaWVudC9ub3JtYWxpenInO1xuaW1wb3J0IHR5cGUgeyBFcnJvclR5cGVzIH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB0eXBlIHsgQWN0aW9uVHlwZXMsIFNldEFjdGlvbiwgT3B0aW1pc3RpY0FjdGlvbiB9IGZyb20gJy4vYWN0aW9ucy5qcyc7XG5pbXBvcnQgeyBTRVRfVFlQRSB9IGZyb20gJy4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgTWlkZGxld2FyZSwgTWlkZGxld2FyZUFQSSB9IGZyb20gJy4vbWlkZGxld2FyZVR5cGVzLmpzJztcblxuZXhwb3J0IHR5cGUgeyBBYnN0cmFjdEluc3RhbmNlVHlwZSwgVXBkYXRlRnVuY3Rpb24gfTtcblxuZXhwb3J0IHR5cGUgU2V0VHlwZXMgPSB0eXBlb2YgU0VUX1RZUEU7XG5cbmV4cG9ydCB0eXBlIFBLID0gc3RyaW5nO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN0YXRlPFQ+IHtcbiAgcmVhZG9ubHkgZW50aXRpZXM6IHtcbiAgICByZWFkb25seSBbZW50aXR5S2V5OiBzdHJpbmddOiB7IHJlYWRvbmx5IFtwazogc3RyaW5nXTogVCB9IHwgdW5kZWZpbmVkO1xuICB9O1xuICByZWFkb25seSBpbmRleGVzOiBOb3JtYWxpemVkSW5kZXg7XG4gIHJlYWRvbmx5IGVuZHBvaW50czoge1xuICAgIHJlYWRvbmx5IFtrZXk6IHN0cmluZ106IHVua25vd24gfCBQS1tdIHwgUEsgfCB1bmRlZmluZWQ7XG4gIH07XG4gIHJlYWRvbmx5IG1ldGE6IHtcbiAgICByZWFkb25seSBba2V5OiBzdHJpbmddOiB7XG4gICAgICByZWFkb25seSBkYXRlOiBudW1iZXI7XG4gICAgICByZWFkb25seSBlcnJvcj86IEVycm9yVHlwZXM7XG4gICAgICByZWFkb25seSBleHBpcmVzQXQ6IG51bWJlcjtcbiAgICAgIHJlYWRvbmx5IHByZXZFeHBpcmVzQXQ/OiBudW1iZXI7XG4gICAgICByZWFkb25seSBpbnZhbGlkYXRlZD86IGJvb2xlYW47XG4gICAgICByZWFkb25seSBlcnJvclBvbGljeT86ICdoYXJkJyB8ICdzb2Z0JyB8IHVuZGVmaW5lZDtcbiAgICB9O1xuICB9O1xuICByZWFkb25seSBlbnRpdHlNZXRhOiB7XG4gICAgcmVhZG9ubHkgW2VudGl0eUtleTogc3RyaW5nXToge1xuICAgICAgcmVhZG9ubHkgW3BrOiBzdHJpbmddOiB7XG4gICAgICAgIHJlYWRvbmx5IGRhdGU6IG51bWJlcjtcbiAgICAgICAgcmVhZG9ubHkgZXhwaXJlc0F0OiBudW1iZXI7XG4gICAgICAgIHJlYWRvbmx5IGZldGNoZWRBdDogbnVtYmVyO1xuICAgICAgfTtcbiAgICB9O1xuICB9O1xuICByZWFkb25seSBvcHRpbWlzdGljOiAoU2V0QWN0aW9uIHwgT3B0aW1pc3RpY0FjdGlvbilbXTtcbiAgcmVhZG9ubHkgbGFzdFJlc2V0OiBudW1iZXI7XG59XG5cbmV4cG9ydCAqIGZyb20gJy4vYWN0aW9ucy5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFuYWdlcjxBY3Rpb25zID0gQWN0aW9uVHlwZXM+IHtcbiAgZ2V0TWlkZGxld2FyZSgpOiBNaWRkbGV3YXJlPEFjdGlvbnM+O1xuICBjbGVhbnVwKCk6IHZvaWQ7XG4gIGluaXQ/OiAoc3RhdGU6IFN0YXRlPGFueT4pID0+IHZvaWQ7XG59XG5cbmV4cG9ydCB0eXBlIHsgRGlzcGF0Y2gsIE1pZGRsZXdhcmUsIE1pZGRsZXdhcmVBUEkgfTtcbiJdLCJtYXBwaW5ncyI6IkFBZ0RBLGNBQWMsY0FBYztBQUFDIiwiaWdub3JlTGlzdCI6W119
3
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL3R5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5vcm1hbGl6ZWRJbmRleCB9IGZyb20gJ0BkYXRhLWNsaWVudC9ub3JtYWxpenInO1xuaW1wb3J0IHR5cGUge1xuICBVcGRhdGVGdW5jdGlvbixcbiAgQWJzdHJhY3RJbnN0YW5jZVR5cGUsXG59IGZyb20gJ0BkYXRhLWNsaWVudC9ub3JtYWxpenInO1xuaW1wb3J0IHR5cGUgeyBFcnJvclR5cGVzIH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB0eXBlIHtcbiAgQWN0aW9uVHlwZXMsXG4gIFNldFJlc3BvbnNlQWN0aW9uLFxuICBPcHRpbWlzdGljQWN0aW9uLFxufSBmcm9tICcuL2FjdGlvbnMuanMnO1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgTWlkZGxld2FyZSwgTWlkZGxld2FyZUFQSSB9IGZyb20gJy4vbWlkZGxld2FyZVR5cGVzLmpzJztcblxuZXhwb3J0IHR5cGUgeyBBYnN0cmFjdEluc3RhbmNlVHlwZSwgVXBkYXRlRnVuY3Rpb24gfTtcblxuZXhwb3J0IHR5cGUgUEsgPSBzdHJpbmc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3RhdGU8VD4ge1xuICByZWFkb25seSBlbnRpdGllczoge1xuICAgIHJlYWRvbmx5IFtlbnRpdHlLZXk6IHN0cmluZ106IHsgcmVhZG9ubHkgW3BrOiBzdHJpbmddOiBUIH0gfCB1bmRlZmluZWQ7XG4gIH07XG4gIHJlYWRvbmx5IGluZGV4ZXM6IE5vcm1hbGl6ZWRJbmRleDtcbiAgcmVhZG9ubHkgZW5kcG9pbnRzOiB7XG4gICAgcmVhZG9ubHkgW2tleTogc3RyaW5nXTogdW5rbm93biB8IFBLW10gfCBQSyB8IHVuZGVmaW5lZDtcbiAgfTtcbiAgcmVhZG9ubHkgbWV0YToge1xuICAgIHJlYWRvbmx5IFtrZXk6IHN0cmluZ106IHtcbiAgICAgIHJlYWRvbmx5IGRhdGU6IG51bWJlcjtcbiAgICAgIHJlYWRvbmx5IGVycm9yPzogRXJyb3JUeXBlcztcbiAgICAgIHJlYWRvbmx5IGV4cGlyZXNBdDogbnVtYmVyO1xuICAgICAgcmVhZG9ubHkgcHJldkV4cGlyZXNBdD86IG51bWJlcjtcbiAgICAgIHJlYWRvbmx5IGludmFsaWRhdGVkPzogYm9vbGVhbjtcbiAgICAgIHJlYWRvbmx5IGVycm9yUG9saWN5PzogJ2hhcmQnIHwgJ3NvZnQnIHwgdW5kZWZpbmVkO1xuICAgIH07XG4gIH07XG4gIHJlYWRvbmx5IGVudGl0eU1ldGE6IHtcbiAgICByZWFkb25seSBbZW50aXR5S2V5OiBzdHJpbmddOiB7XG4gICAgICByZWFkb25seSBbcGs6IHN0cmluZ106IHtcbiAgICAgICAgcmVhZG9ubHkgZGF0ZTogbnVtYmVyO1xuICAgICAgICByZWFkb25seSBleHBpcmVzQXQ6IG51bWJlcjtcbiAgICAgICAgcmVhZG9ubHkgZmV0Y2hlZEF0OiBudW1iZXI7XG4gICAgICB9O1xuICAgIH07XG4gIH07XG4gIHJlYWRvbmx5IG9wdGltaXN0aWM6IChTZXRSZXNwb25zZUFjdGlvbiB8IE9wdGltaXN0aWNBY3Rpb24pW107XG4gIHJlYWRvbmx5IGxhc3RSZXNldDogbnVtYmVyO1xufVxuXG5leHBvcnQgKiBmcm9tICcuL2FjdGlvbnMuanMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1hbmFnZXI8QWN0aW9ucyA9IEFjdGlvblR5cGVzPiB7XG4gIGdldE1pZGRsZXdhcmUoKTogTWlkZGxld2FyZTxBY3Rpb25zPjtcbiAgY2xlYW51cCgpOiB2b2lkO1xuICBpbml0PzogKHN0YXRlOiBTdGF0ZTxhbnk+KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgdHlwZSB7IERpc3BhdGNoLCBNaWRkbGV3YXJlLCBNaWRkbGV3YXJlQVBJIH07XG4iXSwibWFwcGluZ3MiOiJBQWlEQSxjQUFjLGNBQWM7QUFBQyIsImlnbm9yZUxpc3QiOltdfQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@data-client/core",
3
- "version": "0.12.3",
3
+ "version": "0.13.0",
4
4
  "description": "High performance mutable data framework.",
5
5
  "sideEffects": false,
6
6
  "main": "dist/index.js",
@@ -1,5 +1,6 @@
1
1
  export const FETCH_TYPE = 'rdc/fetch' as const;
2
2
  export const SET_TYPE = 'rdc/set' as const;
3
+ export const SET_RESPONSE_TYPE = 'rdc/setresponse' as const;
3
4
  export const OPTIMISTIC_TYPE = 'rdc/optimistic' as const;
4
5
  export const RESET_TYPE = 'rdc/reset' as const;
5
6
  export const SUBSCRIBE_TYPE = 'rdc/subscribe' as const;
package/src/actions.ts CHANGED
@@ -1,5 +1,7 @@
1
1
  import type {
2
+ Denormalize,
2
3
  EndpointInterface,
4
+ Queryable,
3
5
  ResolveType,
4
6
  UnknownError,
5
7
  } from '@data-client/normalizr';
@@ -15,6 +17,7 @@ import type {
15
17
  OPTIMISTIC_TYPE,
16
18
  INVALIDATEALL_TYPE,
17
19
  EXPIREALL_TYPE,
20
+ SET_RESPONSE_TYPE,
18
21
  } from './actionTypes.js';
19
22
  import type { EndpointUpdateFunction } from './controller/types.js';
20
23
 
@@ -27,33 +30,48 @@ type EndpointDefault = EndpointInterface & {
27
30
 
28
31
  /* SET */
29
32
  export interface SetMeta {
33
+ args: readonly any[];
34
+ fetchedAt: number;
35
+ date: number;
36
+ expiresAt: number;
37
+ }
38
+
39
+ export interface SetAction<S extends Queryable = any> {
40
+ type: typeof SET_TYPE;
41
+ schema: S;
42
+ meta: SetMeta;
43
+ value: Denormalize<S>;
44
+ }
45
+
46
+ /* setResponse */
47
+ export interface SetResponseMeta {
30
48
  args: readonly any[];
31
49
  key: string;
32
50
  fetchedAt: number;
33
51
  date: number;
34
52
  expiresAt: number;
35
53
  }
36
- export interface SetActionSuccess<
54
+ export interface SetResponseActionSuccess<
37
55
  E extends EndpointAndUpdate<E> = EndpointDefault,
38
56
  > {
39
- type: typeof SET_TYPE;
57
+ type: typeof SET_RESPONSE_TYPE;
40
58
  endpoint: E;
41
- meta: SetMeta;
59
+ meta: SetResponseMeta;
42
60
  payload: ResolveType<E>;
43
61
  error?: false;
44
62
  }
45
- export interface SetActionError<
63
+ export interface SetResponseActionError<
46
64
  E extends EndpointAndUpdate<E> = EndpointDefault,
47
65
  > {
48
- type: typeof SET_TYPE;
66
+ type: typeof SET_RESPONSE_TYPE;
49
67
  endpoint: E;
50
- meta: SetMeta;
68
+ meta: SetResponseMeta;
51
69
  payload: UnknownError;
52
70
  error: true;
53
71
  }
54
- export type SetAction<E extends EndpointAndUpdate<E> = EndpointDefault> =
55
- | SetActionSuccess<E>
56
- | SetActionError<E>;
72
+ export type SetResponseAction<
73
+ E extends EndpointAndUpdate<E> = EndpointDefault,
74
+ > = SetResponseActionSuccess<E> | SetResponseActionError<E>;
57
75
 
58
76
  /* FETCH */
59
77
  export interface FetchMeta<A extends readonly any[] = readonly any[]> {
@@ -81,7 +99,7 @@ export interface OptimisticAction<
81
99
  > {
82
100
  type: typeof OPTIMISTIC_TYPE;
83
101
  endpoint: E;
84
- meta: SetMeta;
102
+ meta: SetResponseMeta;
85
103
  error?: false;
86
104
  }
87
105
 
@@ -144,6 +162,7 @@ export type ActionTypes =
144
162
  | FetchAction
145
163
  | OptimisticAction
146
164
  | SetAction
165
+ | SetResponseAction
147
166
  | SubscribeAction
148
167
  | UnsubscribeAction
149
168
  | InvalidateAction
@@ -5,7 +5,6 @@ import type {
5
5
  Denormalize,
6
6
  Queryable,
7
7
  SchemaArgs,
8
- NI,
9
8
  } from '@data-client/normalizr';
10
9
  import {
11
10
  ExpiryStatus,
@@ -27,6 +26,7 @@ import createInvalidate from './createInvalidate.js';
27
26
  import createInvalidateAll from './createInvalidateAll.js';
28
27
  import createReset from './createReset.js';
29
28
  import createSet from './createSet.js';
29
+ import createSetResponse from './createSetResponse.js';
30
30
  import {
31
31
  createUnsubscription,
32
32
  createSubscription,
@@ -53,7 +53,7 @@ const unsetDispatch = (action: unknown): Promise<void> => {
53
53
  );
54
54
  };
55
55
  const unsetState = (): State<unknown> => {
56
- // This is only the value until it is set by the CacheProvider
56
+ // This is only the value until it is set by the DataProvider
57
57
  /* istanbul ignore next */
58
58
  return initialState;
59
59
  };
@@ -183,9 +183,26 @@ export default class Controller<
183
183
  resetEntireStore = (): Promise<void> => this.dispatch(createReset());
184
184
 
185
185
  /**
186
- * Stores response in cache for given Endpoint and args.
186
+ * Sets value for the Queryable and args.
187
187
  * @see https://dataclient.io/docs/api/Controller#set
188
188
  */
189
+ set = <S extends Queryable>(
190
+ schema: S,
191
+ ...rest: readonly [...SchemaArgs<S>, any]
192
+ ): Promise<void> => {
193
+ const value: Denormalize<S> = rest[rest.length - 1];
194
+ const action = createSet(schema, {
195
+ args: rest.slice(0, rest.length - 1) as SchemaArgs<S>,
196
+ value,
197
+ });
198
+ // TODO: reject with error if this fails in reducer
199
+ return this.dispatch(action);
200
+ };
201
+
202
+ /**
203
+ * Sets response for the Endpoint and args.
204
+ * @see https://dataclient.io/docs/api/Controller#setResponse
205
+ */
189
206
  setResponse = <
190
207
  E extends EndpointInterface & {
191
208
  update?: EndpointUpdateFunction<E>;
@@ -195,7 +212,7 @@ export default class Controller<
195
212
  ...rest: readonly [...Parameters<E>, any]
196
213
  ): Promise<void> => {
197
214
  const response: ResolveType<E> = rest[rest.length - 1];
198
- const action = createSet(endpoint, {
215
+ const action = createSetResponse(endpoint, {
199
216
  args: rest.slice(0, rest.length - 1) as Parameters<E>,
200
217
  response,
201
218
  });
@@ -203,7 +220,7 @@ export default class Controller<
203
220
  };
204
221
 
205
222
  /**
206
- * Stores the result of Endpoint and args as the error provided.
223
+ * Sets an error response for the Endpoint and args.
207
224
  * @see https://dataclient.io/docs/api/Controller#setError
208
225
  */
209
226
  setError = <
@@ -215,7 +232,7 @@ export default class Controller<
215
232
  ...rest: readonly [...Parameters<E>, Error]
216
233
  ): Promise<void> => {
217
234
  const response: Error = rest[rest.length - 1];
218
- const action = createSet(endpoint, {
235
+ const action = createSetResponse(endpoint, {
219
236
  args: rest.slice(0, rest.length - 1) as Parameters<E>,
220
237
  response,
221
238
  error: true,
@@ -247,7 +264,7 @@ export default class Controller<
247
264
  error?: false | undefined;
248
265
  },
249
266
  ): Promise<void> => {
250
- return this.dispatch(createSet(endpoint, meta as any));
267
+ return this.dispatch(createSetResponse(endpoint, meta as any));
251
268
  };
252
269
 
253
270
  /**
@@ -526,7 +543,7 @@ function entityExpiresAt(
526
543
  readonly [pk: string]: {
527
544
  readonly date: number;
528
545
  readonly expiresAt: number;
529
- readonly fetchedAt: number; // This is only the value until it is set by the CacheProvider
546
+ readonly fetchedAt: number; // This is only the value until it is set by the DataProvider
530
547
  };
531
548
  };
532
549
  },
@@ -1,60 +1,22 @@
1
- import type { EndpointInterface, ResolveType } from '@data-client/normalizr';
1
+ import type { Queryable, SchemaArgs } from '@data-client/normalizr';
2
2
 
3
3
  import ensurePojo from './ensurePojo.js';
4
- import { EndpointUpdateFunction } from './types.js';
5
4
  import { SET_TYPE } from '../actionTypes.js';
6
5
  import type { SetAction, SetMeta } from '../types.js';
7
6
 
8
- export default function createSet<
9
- E extends EndpointInterface & {
10
- update?: EndpointUpdateFunction<E>;
11
- },
12
- >(
13
- endpoint: E,
14
- options: {
15
- args: readonly [...Parameters<E>];
16
- response: Error;
17
- fetchedAt?: number;
18
- error: true;
19
- },
20
- ): SetAction<E>;
21
-
22
- export default function createSet<
23
- E extends EndpointInterface & {
24
- update?: EndpointUpdateFunction<E>;
25
- },
26
- >(
27
- endpoint: E,
28
- options: {
29
- args: readonly [...Parameters<E>];
30
- response: ResolveType<E>;
31
- fetchedAt?: number;
32
- error?: false;
33
- },
34
- ): SetAction<E>;
35
-
36
- export default function createSet<
37
- E extends EndpointInterface & {
38
- update?: EndpointUpdateFunction<E>;
39
- },
40
- >(
41
- endpoint: E,
7
+ export default function createSet<S extends Queryable>(
8
+ schema: S,
42
9
  {
43
10
  args,
44
11
  fetchedAt,
45
- response,
46
- error = false,
12
+ value,
47
13
  }: {
48
- args: readonly [...Parameters<E>];
49
- response: any;
14
+ args: readonly [...SchemaArgs<S>];
15
+ value: any;
50
16
  fetchedAt?: number;
51
- error?: boolean;
52
17
  },
53
- ): SetAction<E> {
54
- const expiryLength: number =
55
- error ?
56
- endpoint.errorExpiryLength ?? 1000
57
- : endpoint.dataExpiryLength ?? 60000;
18
+ ): SetAction<S> {
19
+ const expiryLength: number = 60000;
58
20
  /* istanbul ignore next */
59
21
  if (process.env.NODE_ENV === 'development' && expiryLength < 0) {
60
22
  throw new Error('Negative expiry length are not allowed.');
@@ -65,15 +27,13 @@ export default function createSet<
65
27
  fetchedAt: fetchedAt ?? now,
66
28
  date: now,
67
29
  expiresAt: now + expiryLength,
68
- key: endpoint.key(...args),
69
30
  };
70
31
 
71
- const action: SetAction<E> = {
32
+ const action: SetAction<S> = {
72
33
  type: SET_TYPE,
73
- payload: response,
74
- endpoint: endpoint,
34
+ value,
35
+ schema,
75
36
  meta,
76
37
  };
77
- if (error) (action as any).error = true;
78
38
  return action;
79
39
  }
@@ -0,0 +1,79 @@
1
+ import type { EndpointInterface, ResolveType } from '@data-client/normalizr';
2
+
3
+ import ensurePojo from './ensurePojo.js';
4
+ import { EndpointUpdateFunction } from './types.js';
5
+ import { SET_RESPONSE_TYPE } from '../actionTypes.js';
6
+ import type { SetResponseAction, SetResponseMeta } from '../types.js';
7
+
8
+ export default function createSetResponse<
9
+ E extends EndpointInterface & {
10
+ update?: EndpointUpdateFunction<E>;
11
+ },
12
+ >(
13
+ endpoint: E,
14
+ options: {
15
+ args: readonly [...Parameters<E>];
16
+ response: Error;
17
+ fetchedAt?: number;
18
+ error: true;
19
+ },
20
+ ): SetResponseAction<E>;
21
+
22
+ export default function createSetResponse<
23
+ E extends EndpointInterface & {
24
+ update?: EndpointUpdateFunction<E>;
25
+ },
26
+ >(
27
+ endpoint: E,
28
+ options: {
29
+ args: readonly [...Parameters<E>];
30
+ response: ResolveType<E>;
31
+ fetchedAt?: number;
32
+ error?: false;
33
+ },
34
+ ): SetResponseAction<E>;
35
+
36
+ export default function createSetResponse<
37
+ E extends EndpointInterface & {
38
+ update?: EndpointUpdateFunction<E>;
39
+ },
40
+ >(
41
+ endpoint: E,
42
+ {
43
+ args,
44
+ fetchedAt,
45
+ response,
46
+ error = false,
47
+ }: {
48
+ args: readonly [...Parameters<E>];
49
+ response: any;
50
+ fetchedAt?: number;
51
+ error?: boolean;
52
+ },
53
+ ): SetResponseAction<E> {
54
+ const expiryLength: number =
55
+ error ?
56
+ endpoint.errorExpiryLength ?? 1000
57
+ : endpoint.dataExpiryLength ?? 60000;
58
+ /* istanbul ignore next */
59
+ if (process.env.NODE_ENV === 'development' && expiryLength < 0) {
60
+ throw new Error('Negative expiry length are not allowed.');
61
+ }
62
+ const now = Date.now();
63
+ const meta: SetResponseMeta = {
64
+ args: args.map(ensurePojo),
65
+ fetchedAt: fetchedAt ?? now,
66
+ date: now,
67
+ expiresAt: now + expiryLength,
68
+ key: endpoint.key(...args),
69
+ };
70
+
71
+ const action: SetResponseAction<E> = {
72
+ type: SET_RESPONSE_TYPE,
73
+ payload: response,
74
+ endpoint: endpoint,
75
+ meta,
76
+ };
77
+ if (error) (action as any).error = true;
78
+ return action;
79
+ }
package/src/index.ts CHANGED
@@ -41,6 +41,7 @@ export type {
41
41
  } from './controller/Controller.js';
42
42
  export { default as createFetch } from './controller/createFetch.js';
43
43
  export { default as createSet } from './controller/createSet.js';
44
+ export { default as createSetResponse } from './controller/createSetResponse.js';
44
45
 
45
46
  export * from './controller/types.js';
46
47
  export * as actionTypes from './actionTypes.js';
@@ -94,8 +94,10 @@ export default class DevToolsManager implements Manager {
94
94
  (window as any).__REDUX_DEVTOOLS_EXTENSION__ &&
95
95
  (window as any).__REDUX_DEVTOOLS_EXTENSION__.connect({
96
96
  ...DEFAULT_CONFIG,
97
- config,
97
+ ...config,
98
98
  });
99
+ // we cut it in half so we should double so we don't lose
100
+ if (config?.maxAge) this.maxBufferLength = config.maxAge * 2;
99
101
  if (process.env.NODE_ENV !== 'production' && this.devTools) {
100
102
  this.devTools.subscribe((msg: any) => {
101
103
  switch (msg.type) {
@@ -150,7 +152,7 @@ export default class DevToolsManager implements Manager {
150
152
 
151
153
  handleAction(action: any, state: any) {
152
154
  if (this.started) {
153
- this.devTools.send(action, state, undefined, 'RDC');
155
+ this.devTools.send(action, state);
154
156
  } else {
155
157
  // avoid this getting too big in case this is long running
156
158
  // we cut in half so we aren't constantly reallocating
@@ -1,4 +1,4 @@
1
- import { SET_TYPE } from '../actionTypes.js';
1
+ import { SET_RESPONSE_TYPE } from '../actionTypes.js';
2
2
  import Controller from '../controller/Controller.js';
3
3
  import { UnknownError } from '../index.js';
4
4
  import { ActionTypes, Manager } from '../types.js';
@@ -16,7 +16,7 @@ export default class LogoutManager implements Manager {
16
16
  this.middleware = controller => next => async action => {
17
17
  await next(action);
18
18
  if (
19
- action.type === SET_TYPE &&
19
+ action.type === SET_RESPONSE_TYPE &&
20
20
  action.error &&
21
21
  this.shouldLogout(action.payload)
22
22
  ) {
@@ -1,6 +1,6 @@
1
- import { SET_TYPE, FETCH_TYPE, RESET_TYPE } from '../actionTypes.js';
1
+ import { SET_RESPONSE_TYPE, FETCH_TYPE, RESET_TYPE } from '../actionTypes.js';
2
2
  import Controller from '../controller/Controller.js';
3
- import createSet from '../controller/createSet.js';
3
+ import createSetResponse from '../controller/createSetResponse.js';
4
4
  import RIC from '../state/RIC.js';
5
5
  import type {
6
6
  FetchAction,
@@ -8,7 +8,7 @@ import type {
8
8
  ActionTypes,
9
9
  MiddlewareAPI,
10
10
  Middleware,
11
- SetAction,
11
+ SetResponseAction,
12
12
  } from '../types.js';
13
13
 
14
14
  export class ResetError extends Error {
@@ -60,7 +60,7 @@ export default class NetworkManager implements Manager {
60
60
  return next(action);
61
61
  }
62
62
  return Promise.resolve();
63
- case SET_TYPE:
63
+ case SET_RESPONSE_TYPE:
64
64
  // only set after new state is computed
65
65
  return next(action).then(() => {
66
66
  if (action.meta.key in this.fetched) {
@@ -70,7 +70,7 @@ export default class NetworkManager implements Manager {
70
70
  // processing errors result in state meta having error, so we should reject the promise
71
71
  if (error) {
72
72
  this.handleSet(
73
- createSet(action.endpoint, {
73
+ createSetResponse(action.endpoint, {
74
74
  args: action.meta.args,
75
75
  response: error,
76
76
  fetchedAt: action.meta.fetchedAt,
@@ -228,7 +228,7 @@ export default class NetworkManager implements Manager {
228
228
  *
229
229
  * Will resolve the promise associated with set key.
230
230
  */
231
- protected handleSet(action: SetAction) {
231
+ protected handleSet(action: SetResponseAction) {
232
232
  // this can still turn out to be untrue since this is async
233
233
  if (action.meta.key in this.fetched) {
234
234
  let promiseHandler: (value?: any) => void;