@data-client/core 0.4.2 → 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 (109) hide show
  1. package/data_client_logo_and_text.svg +50 -0
  2. package/dist/index.js +66 -92
  3. package/dist/index.umd.min.js +1 -1
  4. package/dist/next.js +0 -447
  5. package/legacy/actionTypes.js +11 -13
  6. package/legacy/actions.js +2 -0
  7. package/legacy/controller/Controller.js +26 -42
  8. package/legacy/controller/createSet.js +3 -2
  9. package/legacy/controller/ensurePojo.js +7 -0
  10. package/legacy/index.js +2 -2
  11. package/legacy/internal.js +2 -2
  12. package/legacy/manager/DevtoolsManager.js +3 -3
  13. package/legacy/manager/NetworkManager.js +11 -11
  14. package/legacy/manager/SubscriptionManager.js +6 -6
  15. package/legacy/manager/applyManager.js +2 -9
  16. package/legacy/middlewareTypes.js +1 -1
  17. package/legacy/next/index.js +2 -3
  18. package/legacy/state/reducer/fetchReducer.js +5 -5
  19. package/legacy/state/reducer/setReducer.js +2 -2
  20. package/legacy/types.js +3 -4
  21. package/lib/actionTypes.d.ts +10 -12
  22. package/lib/actionTypes.d.ts.map +1 -1
  23. package/lib/actionTypes.js +11 -13
  24. package/lib/{newActions.d.ts → actions.d.ts} +1 -3
  25. package/lib/actions.d.ts.map +1 -0
  26. package/lib/actions.js +2 -0
  27. package/lib/controller/Controller.d.ts +20 -33
  28. package/lib/controller/Controller.d.ts.map +1 -1
  29. package/lib/controller/Controller.js +26 -42
  30. package/lib/controller/createSet.d.ts.map +1 -1
  31. package/lib/controller/createSet.js +3 -2
  32. package/lib/controller/ensurePojo.d.ts +3 -0
  33. package/lib/controller/ensurePojo.d.ts.map +1 -0
  34. package/lib/controller/ensurePojo.js +7 -0
  35. package/lib/index.d.ts +1 -1
  36. package/lib/index.d.ts.map +1 -1
  37. package/lib/index.js +2 -2
  38. package/lib/internal.d.ts +1 -1
  39. package/lib/internal.d.ts.map +1 -1
  40. package/lib/internal.js +2 -2
  41. package/lib/manager/DevtoolsManager.js +3 -3
  42. package/lib/manager/NetworkManager.d.ts +6 -6
  43. package/lib/manager/NetworkManager.d.ts.map +1 -1
  44. package/lib/manager/NetworkManager.js +11 -11
  45. package/lib/manager/SubscriptionManager.d.ts +5 -5
  46. package/lib/manager/SubscriptionManager.js +6 -6
  47. package/lib/manager/applyManager.d.ts.map +1 -1
  48. package/lib/manager/applyManager.js +2 -9
  49. package/lib/middlewareTypes.d.ts +2 -5
  50. package/lib/middlewareTypes.d.ts.map +1 -1
  51. package/lib/middlewareTypes.js +1 -1
  52. package/lib/next/index.d.ts +0 -2
  53. package/lib/next/index.d.ts.map +1 -1
  54. package/lib/next/index.js +2 -3
  55. package/lib/state/reducer/expireReducer.d.ts +1 -1
  56. package/lib/state/reducer/fetchReducer.js +5 -5
  57. package/lib/state/reducer/invalidateReducer.d.ts +1 -1
  58. package/lib/state/reducer/setReducer.d.ts +2 -2
  59. package/lib/state/reducer/setReducer.d.ts.map +1 -1
  60. package/lib/state/reducer/setReducer.js +2 -2
  61. package/lib/types.d.ts +3 -4
  62. package/lib/types.d.ts.map +1 -1
  63. package/lib/types.js +3 -4
  64. package/package.json +3 -3
  65. package/src/actionTypes.ts +10 -12
  66. package/src/{newActions.ts → actions.ts} +1 -6
  67. package/src/controller/Controller.ts +27 -55
  68. package/src/controller/createSet.ts +2 -1
  69. package/src/controller/ensurePojo.ts +11 -0
  70. package/src/index.ts +1 -1
  71. package/src/internal.ts +1 -1
  72. package/src/manager/DevtoolsManager.ts +2 -2
  73. package/src/manager/NetworkManager.ts +10 -10
  74. package/src/manager/SubscriptionManager.ts +5 -5
  75. package/src/manager/__tests__/__snapshots__/pollingSubscription.ts.snap +2 -2
  76. package/src/manager/__tests__/logoutManager.ts +2 -2
  77. package/src/manager/__tests__/manager.ts +1 -1
  78. package/src/manager/__tests__/networkManager.ts +13 -16
  79. package/src/manager/applyManager.ts +1 -6
  80. package/src/middlewareTypes.ts +4 -9
  81. package/src/next/index.ts +0 -2
  82. package/src/state/__tests__/__snapshots__/reducer.ts.snap +1 -1
  83. package/src/state/__tests__/reducer.ts +27 -9
  84. package/src/state/reducer/fetchReducer.ts +5 -5
  85. package/src/state/reducer/setReducer.ts +5 -5
  86. package/src/types.ts +3 -4
  87. package/ts3.4/actionTypes.d.ts +10 -12
  88. package/ts3.4/{newActions.d.ts → actions.d.ts} +1 -3
  89. package/ts3.4/controller/Controller.d.ts +20 -39
  90. package/ts3.4/controller/ensurePojo.d.ts +3 -0
  91. package/ts3.4/index.d.ts +1 -1
  92. package/ts3.4/internal.d.ts +1 -1
  93. package/ts3.4/manager/NetworkManager.d.ts +6 -6
  94. package/ts3.4/manager/SubscriptionManager.d.ts +5 -5
  95. package/ts3.4/middlewareTypes.d.ts +2 -5
  96. package/ts3.4/next/index.d.ts +0 -2
  97. package/ts3.4/state/reducer/expireReducer.d.ts +1 -1
  98. package/ts3.4/state/reducer/invalidateReducer.d.ts +1 -1
  99. package/ts3.4/state/reducer/setReducer.d.ts +2 -2
  100. package/ts3.4/types.d.ts +3 -5
  101. package/legacy/fsa.js +0 -2
  102. package/legacy/newActions.js +0 -2
  103. package/lib/fsa.d.ts +0 -41
  104. package/lib/fsa.d.ts.map +0 -1
  105. package/lib/fsa.js +0 -2
  106. package/lib/newActions.d.ts.map +0 -1
  107. package/lib/newActions.js +0 -2
  108. package/src/fsa.ts +0 -99
  109. package/ts3.4/fsa.d.ts +0 -41
@@ -7,7 +7,7 @@ export function setReducer(state, action, controller) {
7
7
  try {
8
8
  var _state$meta$action$me;
9
9
  let payload;
10
- // for true receives payload is contained in action
10
+ // for true set's payload is contained in action
11
11
  if (action.type === OPTIMISTIC_TYPE) {
12
12
  // this should never happen
13
13
  if (!action.endpoint.getOptimisticResponse) return state;
@@ -108,4 +108,4 @@ function reduceError(state, action, error) {
108
108
  function filterOptimistic(state, resolvingAction) {
109
109
  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));
110
110
  }
111
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["normalize","OPTIMISTIC_TYPE","setReducer","state","action","controller","error","reduceError","payload","_state$meta$action$me","type","endpoint","getOptimisticResponse","call","snapshot","meta","fetchedAt","args","e","_e$constructor","constructor","name","result","entities","indexes","entityMeta","schema","results","key","update","updaters","Object","keys","forEach","console","date","expiresAt","prevExpiresAt","optimistic","filterOptimistic","lastReset","message","JSON","stringify","undefined","status","process","env","NODE_ENV","errorPolicy","resolvingAction","filter","optimisticAction"],"sources":["../../../src/state/reducer/setReducer.ts"],"sourcesContent":["import { normalize } from '@data-client/normalizr';\n\nimport { OPTIMISTIC_TYPE } from '../../actionTypes.js';\nimport type Controller from '../../controller/Controller.js';\nimport type { State, ReceiveAction, OptimisticAction } from '../../types.js';\n\nexport function setReducer(\n  state: State<unknown>,\n  action: OptimisticAction | ReceiveAction,\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 receives payload is contained in action\n    if (action.type === OPTIMISTIC_TYPE) {\n      // this should never happen\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?.name === '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 results = {\n      ...state.results,\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          results[key] = updaters[key](results[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      results,\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 results 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: ReceiveAction | 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: ReceiveAction | 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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"}
111
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["normalize","OPTIMISTIC_TYPE","setReducer","state","action","controller","error","reduceError","payload","_state$meta$action$me","type","endpoint","getOptimisticResponse","call","snapshot","meta","fetchedAt","args","e","_e$constructor","constructor","name","result","entities","indexes","entityMeta","schema","results","key","update","updaters","Object","keys","forEach","console","date","expiresAt","prevExpiresAt","optimistic","filterOptimistic","lastReset","message","JSON","stringify","undefined","status","process","env","NODE_ENV","errorPolicy","resolvingAction","filter","optimisticAction"],"sources":["../../../src/state/reducer/setReducer.ts"],"sourcesContent":["import { normalize } from '@data-client/normalizr';\n\nimport { OPTIMISTIC_TYPE } from '../../actionTypes.js';\nimport type Controller from '../../controller/Controller.js';\nimport type { State, SetAction, OptimisticAction } from '../../types.js';\n\nexport function setReducer(\n  state: State<unknown>,\n  action: OptimisticAction | SetAction,\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      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?.name === '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 results = {\n      ...state.results,\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          results[key] = updaters[key](results[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      results,\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 results 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: SetAction | 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: SetAction | 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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"}
package/lib/types.d.ts CHANGED
@@ -1,11 +1,11 @@
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';
4
5
  import { SET_TYPE } from './actionTypes.js';
5
6
  import type { Dispatch, Middleware, MiddlewareAPI } from './middlewareTypes.js';
6
- import type { ActionTypes, SetAction, OptimisticAction } from './newActions.js';
7
7
  export type { AbstractInstanceType, UpdateFunction };
8
- export type ReceiveTypes = typeof SET_TYPE;
8
+ export type SetTypes = typeof SET_TYPE;
9
9
  export type PK = string;
10
10
  export interface State<T> {
11
11
  readonly entities: {
@@ -39,8 +39,7 @@ export interface State<T> {
39
39
  readonly optimistic: (SetAction | OptimisticAction)[];
40
40
  readonly lastReset: number;
41
41
  }
42
- export * as newActions from './newActions.js';
43
- export * from './newActions.js';
42
+ export * from './actions.js';
44
43
  export interface Manager<Actions = ActionTypes> {
45
44
  getMiddleware(): Middleware<Actions>;
46
45
  cleanup(): void;
@@ -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,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAChF,OAAO,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAEhF,YAAY,EAAE,oBAAoB,EAAE,cAAc,EAAE,CAAC;AAErD,MAAM,MAAM,YAAY,GAAG,OAAO,QAAQ,CAAC;AAE3C,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,OAAO,EAAE;QAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,SAAS,CAAA;KAAE,CAAC;IAC9E,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,OAAO,KAAK,UAAU,MAAM,iBAAiB,CAAC;AAC9C,cAAc,iBAAiB,CAAC;AAEhC,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,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,OAAO,EAAE;QAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,SAAS,CAAA;KAAE,CAAC;IAC9E,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"}
package/lib/types.js CHANGED
@@ -1,4 +1,3 @@
1
- import * as _newActions from './newActions.js';
2
- export { _newActions as newActions };
3
- export * from './newActions.js';
4
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbmV3QWN0aW9ucyIsIm5ld0FjdGlvbnMiXSwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTm9ybWFsaXplZEluZGV4IH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5pbXBvcnQgdHlwZSB7XG4gIFVwZGF0ZUZ1bmN0aW9uLFxuICBBYnN0cmFjdEluc3RhbmNlVHlwZSxcbn0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5pbXBvcnQgdHlwZSB7IEVycm9yVHlwZXMgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgU0VUX1RZUEUgfSBmcm9tICcuL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgRGlzcGF0Y2gsIE1pZGRsZXdhcmUsIE1pZGRsZXdhcmVBUEkgfSBmcm9tICcuL21pZGRsZXdhcmVUeXBlcy5qcyc7XG5pbXBvcnQgdHlwZSB7IEFjdGlvblR5cGVzLCBTZXRBY3Rpb24sIE9wdGltaXN0aWNBY3Rpb24gfSBmcm9tICcuL25ld0FjdGlvbnMuanMnO1xuXG5leHBvcnQgdHlwZSB7IEFic3RyYWN0SW5zdGFuY2VUeXBlLCBVcGRhdGVGdW5jdGlvbiB9O1xuXG5leHBvcnQgdHlwZSBSZWNlaXZlVHlwZXMgPSB0eXBlb2YgU0VUX1RZUEU7XG5cbmV4cG9ydCB0eXBlIFBLID0gc3RyaW5nO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN0YXRlPFQ+IHtcbiAgcmVhZG9ubHkgZW50aXRpZXM6IHtcbiAgICByZWFkb25seSBbZW50aXR5S2V5OiBzdHJpbmddOiB7IHJlYWRvbmx5IFtwazogc3RyaW5nXTogVCB9IHwgdW5kZWZpbmVkO1xuICB9O1xuICByZWFkb25seSBpbmRleGVzOiBOb3JtYWxpemVkSW5kZXg7XG4gIHJlYWRvbmx5IHJlc3VsdHM6IHsgcmVhZG9ubHkgW2tleTogc3RyaW5nXTogdW5rbm93biB8IFBLW10gfCBQSyB8IHVuZGVmaW5lZCB9O1xuICByZWFkb25seSBtZXRhOiB7XG4gICAgcmVhZG9ubHkgW2tleTogc3RyaW5nXToge1xuICAgICAgcmVhZG9ubHkgZGF0ZTogbnVtYmVyO1xuICAgICAgcmVhZG9ubHkgZXJyb3I/OiBFcnJvclR5cGVzO1xuICAgICAgcmVhZG9ubHkgZXhwaXJlc0F0OiBudW1iZXI7XG4gICAgICByZWFkb25seSBwcmV2RXhwaXJlc0F0PzogbnVtYmVyO1xuICAgICAgcmVhZG9ubHkgaW52YWxpZGF0ZWQ/OiBib29sZWFuO1xuICAgICAgcmVhZG9ubHkgZXJyb3JQb2xpY3k/OiAnaGFyZCcgfCAnc29mdCcgfCB1bmRlZmluZWQ7XG4gICAgfTtcbiAgfTtcbiAgcmVhZG9ubHkgZW50aXR5TWV0YToge1xuICAgIHJlYWRvbmx5IFtlbnRpdHlLZXk6IHN0cmluZ106IHtcbiAgICAgIHJlYWRvbmx5IFtwazogc3RyaW5nXToge1xuICAgICAgICByZWFkb25seSBkYXRlOiBudW1iZXI7XG4gICAgICAgIHJlYWRvbmx5IGV4cGlyZXNBdDogbnVtYmVyO1xuICAgICAgICByZWFkb25seSBmZXRjaGVkQXQ6IG51bWJlcjtcbiAgICAgIH07XG4gICAgfTtcbiAgfTtcbiAgcmVhZG9ubHkgb3B0aW1pc3RpYzogKFNldEFjdGlvbiB8IE9wdGltaXN0aWNBY3Rpb24pW107XG4gIHJlYWRvbmx5IGxhc3RSZXNldDogbnVtYmVyO1xufVxuXG5leHBvcnQgKiBhcyBuZXdBY3Rpb25zIGZyb20gJy4vbmV3QWN0aW9ucy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL25ld0FjdGlvbnMuanMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1hbmFnZXI8QWN0aW9ucyA9IEFjdGlvblR5cGVzPiB7XG4gIGdldE1pZGRsZXdhcmUoKTogTWlkZGxld2FyZTxBY3Rpb25zPjtcbiAgY2xlYW51cCgpOiB2b2lkO1xuICBpbml0PzogKHN0YXRlOiBTdGF0ZTxhbnk+KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgdHlwZSB7IERpc3BhdGNoLCBNaWRkbGV3YXJlLCBNaWRkbGV3YXJlQVBJIH07XG4iXSwibWFwcGluZ3MiOiI2QkE4QzRCLGlCQUFpQjtBQUFBLFNBQUFBLFdBQUEsSUFBakNDLFVBQVU7QUFDdEIsY0FBYyxpQkFBaUIifQ==
1
+ export * from './actions.js';
2
+ export {};
3
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL3R5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5vcm1hbGl6ZWRJbmRleCB9IGZyb20gJ0BkYXRhLWNsaWVudC9ub3JtYWxpenInO1xuaW1wb3J0IHR5cGUge1xuICBVcGRhdGVGdW5jdGlvbixcbiAgQWJzdHJhY3RJbnN0YW5jZVR5cGUsXG59IGZyb20gJ0BkYXRhLWNsaWVudC9ub3JtYWxpenInO1xuaW1wb3J0IHR5cGUgeyBFcnJvclR5cGVzIH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB0eXBlIHsgQWN0aW9uVHlwZXMsIFNldEFjdGlvbiwgT3B0aW1pc3RpY0FjdGlvbiB9IGZyb20gJy4vYWN0aW9ucy5qcyc7XG5pbXBvcnQgeyBTRVRfVFlQRSB9IGZyb20gJy4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgTWlkZGxld2FyZSwgTWlkZGxld2FyZUFQSSB9IGZyb20gJy4vbWlkZGxld2FyZVR5cGVzLmpzJztcblxuZXhwb3J0IHR5cGUgeyBBYnN0cmFjdEluc3RhbmNlVHlwZSwgVXBkYXRlRnVuY3Rpb24gfTtcblxuZXhwb3J0IHR5cGUgU2V0VHlwZXMgPSB0eXBlb2YgU0VUX1RZUEU7XG5cbmV4cG9ydCB0eXBlIFBLID0gc3RyaW5nO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN0YXRlPFQ+IHtcbiAgcmVhZG9ubHkgZW50aXRpZXM6IHtcbiAgICByZWFkb25seSBbZW50aXR5S2V5OiBzdHJpbmddOiB7IHJlYWRvbmx5IFtwazogc3RyaW5nXTogVCB9IHwgdW5kZWZpbmVkO1xuICB9O1xuICByZWFkb25seSBpbmRleGVzOiBOb3JtYWxpemVkSW5kZXg7XG4gIHJlYWRvbmx5IHJlc3VsdHM6IHsgcmVhZG9ubHkgW2tleTogc3RyaW5nXTogdW5rbm93biB8IFBLW10gfCBQSyB8IHVuZGVmaW5lZCB9O1xuICByZWFkb25seSBtZXRhOiB7XG4gICAgcmVhZG9ubHkgW2tleTogc3RyaW5nXToge1xuICAgICAgcmVhZG9ubHkgZGF0ZTogbnVtYmVyO1xuICAgICAgcmVhZG9ubHkgZXJyb3I/OiBFcnJvclR5cGVzO1xuICAgICAgcmVhZG9ubHkgZXhwaXJlc0F0OiBudW1iZXI7XG4gICAgICByZWFkb25seSBwcmV2RXhwaXJlc0F0PzogbnVtYmVyO1xuICAgICAgcmVhZG9ubHkgaW52YWxpZGF0ZWQ/OiBib29sZWFuO1xuICAgICAgcmVhZG9ubHkgZXJyb3JQb2xpY3k/OiAnaGFyZCcgfCAnc29mdCcgfCB1bmRlZmluZWQ7XG4gICAgfTtcbiAgfTtcbiAgcmVhZG9ubHkgZW50aXR5TWV0YToge1xuICAgIHJlYWRvbmx5IFtlbnRpdHlLZXk6IHN0cmluZ106IHtcbiAgICAgIHJlYWRvbmx5IFtwazogc3RyaW5nXToge1xuICAgICAgICByZWFkb25seSBkYXRlOiBudW1iZXI7XG4gICAgICAgIHJlYWRvbmx5IGV4cGlyZXNBdDogbnVtYmVyO1xuICAgICAgICByZWFkb25seSBmZXRjaGVkQXQ6IG51bWJlcjtcbiAgICAgIH07XG4gICAgfTtcbiAgfTtcbiAgcmVhZG9ubHkgb3B0aW1pc3RpYzogKFNldEFjdGlvbiB8IE9wdGltaXN0aWNBY3Rpb24pW107XG4gIHJlYWRvbmx5IGxhc3RSZXNldDogbnVtYmVyO1xufVxuXG5leHBvcnQgKiBmcm9tICcuL2FjdGlvbnMuanMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1hbmFnZXI8QWN0aW9ucyA9IEFjdGlvblR5cGVzPiB7XG4gIGdldE1pZGRsZXdhcmUoKTogTWlkZGxld2FyZTxBY3Rpb25zPjtcbiAgY2xlYW51cCgpOiB2b2lkO1xuICBpbml0PzogKHN0YXRlOiBTdGF0ZTxhbnk+KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgdHlwZSB7IERpc3BhdGNoLCBNaWRkbGV3YXJlLCBNaWRkbGV3YXJlQVBJIH07XG4iXSwibWFwcGluZ3MiOiJBQThDQSxjQUFjLGNBQWM7QUFBQyJ9
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@data-client/core",
3
- "version": "0.4.2",
3
+ "version": "0.8.0",
4
4
  "description": "High performance reactive framework for async data.",
5
5
  "sideEffects": false,
6
6
  "main": "dist/index.js",
@@ -60,7 +60,7 @@
60
60
  "LICENSE",
61
61
  "README.md",
62
62
  "./typescript.svg",
63
- "./rest_hooks_logo_and_text.svg"
63
+ "./data_client_logo_and_text.svg"
64
64
  ],
65
65
  "scripts": {
66
66
  "build:lib": "NODE_ENV=production BROWSERSLIST_ENV='2020' yarn g:babel --out-dir lib",
@@ -120,7 +120,7 @@
120
120
  },
121
121
  "dependencies": {
122
122
  "@babel/runtime": "^7.17.0",
123
- "@data-client/normalizr": "^0.2.2",
123
+ "@data-client/normalizr": "workspace:^",
124
124
  "flux-standard-action": "^2.1.1"
125
125
  },
126
126
  "devDependencies": {
@@ -1,12 +1,10 @@
1
- export const FETCH_TYPE = 'rest-hooks/fetch' as const;
2
- /** @deprecated use SET_TYPE instead */
3
- export const RECEIVE_TYPE = 'rest-hooks/receive' as const;
4
- export const SET_TYPE = RECEIVE_TYPE;
5
- export const OPTIMISTIC_TYPE = 'rest-hooks/optimistic' as const;
6
- export const RESET_TYPE = 'rest-hooks/reset' as const;
7
- export const SUBSCRIBE_TYPE = 'rest-hooks/subscribe' as const;
8
- export const UNSUBSCRIBE_TYPE = 'rest-hook/unsubscribe' as const;
9
- export const INVALIDATE_TYPE = 'rest-hooks/invalidate' as const;
10
- export const INVALIDATEALL_TYPE = 'rest-hooks/invalidateall' as const;
11
- export const EXPIREALL_TYPE = 'rest-hooks/expireall' as const;
12
- export const GC_TYPE = 'rest-hooks/gc' as const;
1
+ export const FETCH_TYPE = 'rdc/fetch' as const;
2
+ export const SET_TYPE = 'rdc/set' as const;
3
+ export const OPTIMISTIC_TYPE = 'rdc/optimistic' as const;
4
+ export const RESET_TYPE = 'rdc/reset' as const;
5
+ export const SUBSCRIBE_TYPE = 'rdc/subscribe' as const;
6
+ export const UNSUBSCRIBE_TYPE = 'rdc/unsubscribe' as const;
7
+ export const INVALIDATE_TYPE = 'rdc/invalidate' as const;
8
+ export const INVALIDATEALL_TYPE = 'rdc/invalidateall' as const;
9
+ export const EXPIREALL_TYPE = 'rdc/expireall' as const;
10
+ export const GC_TYPE = 'rdc/gc' as const;
@@ -25,7 +25,7 @@ type EndpointDefault = EndpointInterface & {
25
25
  update?: EndpointUpdateFunction<EndpointInterface>;
26
26
  };
27
27
 
28
- /* RECEIVE */
28
+ /* SET */
29
29
  export interface SetMeta {
30
30
  args: readonly any[];
31
31
  key: string;
@@ -55,11 +55,6 @@ export type SetAction<E extends EndpointAndUpdate<E> = EndpointDefault> =
55
55
  | SetActionSuccess<E>
56
56
  | SetActionError<E>;
57
57
 
58
- // TODO(breaking): Remove - legacy name compatibility
59
- /** @deprecated use SetAction instead */
60
- export type ReceiveAction<E extends EndpointAndUpdate<E> = EndpointDefault> =
61
- SetAction<E>;
62
-
63
58
  /* FETCH */
64
59
  export interface FetchMeta {
65
60
  args: readonly any[];
@@ -29,6 +29,7 @@ import {
29
29
  createUnsubscription,
30
30
  createSubscription,
31
31
  } from './createSubscription.js';
32
+ import ensurePojo from './ensurePojo.js';
32
33
  import type { EndpointUpdateFunction } from './types.js';
33
34
  import { initialState } from '../state/reducer/createReducer.js';
34
35
  import selectMeta from '../state/selectMeta.js';
@@ -56,16 +57,16 @@ const unsetState = (): State<unknown> => {
56
57
  };
57
58
 
58
59
  /**
59
- * Imperative control of Rest Hooks store
60
- * @see https://resthooks.io/docs/api/Controller
60
+ * Imperative control of Reactive Data Client store
61
+ * @see https://dataclient.io/docs/api/Controller
61
62
  */
62
63
  export default class Controller<
63
64
  D extends GenericDispatch = DataClientDispatch,
64
65
  > {
65
66
  /**
66
- * Dispatches an action to Rest Hooks reducer.
67
+ * Dispatches an action to Reactive Data Client reducer.
67
68
  *
68
- * @see https://resthooks.io/docs/api/Controller#dispatch
69
+ * @see https://dataclient.io/docs/api/Controller#dispatch
69
70
  */
70
71
  declare readonly dispatch: D;
71
72
  /**
@@ -73,7 +74,7 @@ export default class Controller<
73
74
  *
74
75
  * This can be useful for imperative use-cases like event handlers.
75
76
  * This should *not* be used to render; instead useSuspense() or useCache()
76
- * @see https://resthooks.io/docs/api/Controller#getState
77
+ * @see https://dataclient.io/docs/api/Controller#getState
77
78
  */
78
79
  declare readonly getState: () => State<unknown>;
79
80
  declare readonly globalCache: DenormalizeCache;
@@ -94,8 +95,8 @@ export default class Controller<
94
95
  /*************** Action Dispatchers ***************/
95
96
 
96
97
  /**
97
- * Fetches the endpoint with given args, updating the Rest Hooks cache with the response or error upon completion.
98
- * @see https://resthooks.io/docs/api/Controller#fetch
98
+ * Fetches the endpoint with given args, updating the Reactive Data Client cache with the response or error upon completion.
99
+ * @see https://dataclient.io/docs/api/Controller#fetch
99
100
  */
100
101
  fetch = <
101
102
  E extends EndpointInterface & { update?: EndpointUpdateFunction<E> },
@@ -142,7 +143,7 @@ export default class Controller<
142
143
 
143
144
  /**
144
145
  * Forces refetching and suspense on useSuspense with the same Endpoint and parameters.
145
- * @see https://resthooks.io/docs/api/Controller#invalidate
146
+ * @see https://dataclient.io/docs/api/Controller#invalidate
146
147
  */
147
148
  invalidate = <E extends EndpointInterface>(
148
149
  endpoint: E,
@@ -158,7 +159,7 @@ export default class Controller<
158
159
 
159
160
  /**
160
161
  * Forces refetching and suspense on useSuspense on all matching endpoint result keys.
161
- * @see https://resthooks.io/docs/api/Controller#invalidateAll
162
+ * @see https://dataclient.io/docs/api/Controller#invalidateAll
162
163
  * @returns Promise that resolves when invalidation is commited.
163
164
  */
164
165
  invalidateAll = (options: { testKey: (key: string) => boolean }) =>
@@ -173,14 +174,14 @@ export default class Controller<
173
174
  this.dispatch(createExpireAll((key: string) => options.testKey(key)));
174
175
 
175
176
  /**
176
- * Resets the entire Rest Hooks cache. All inflight requests will not resolve.
177
- * @see https://resthooks.io/docs/api/Controller#resetEntireStore
177
+ * Resets the entire Reactive Data Client cache. All inflight requests will not resolve.
178
+ * @see https://dataclient.io/docs/api/Controller#resetEntireStore
178
179
  */
179
180
  resetEntireStore = (): Promise<void> => this.dispatch(createReset());
180
181
 
181
182
  /**
182
183
  * Stores response in cache for given Endpoint and args.
183
- * @see https://resthooks.io/docs/api/Controller#set
184
+ * @see https://dataclient.io/docs/api/Controller#set
184
185
  */
185
186
  setResponse = <
186
187
  E extends EndpointInterface & {
@@ -198,24 +199,9 @@ export default class Controller<
198
199
  return this.dispatch(action);
199
200
  };
200
201
 
201
- /**
202
- * @deprecated use https://resthooks.io/docs/api/Controller#setResponse instead
203
- */
204
- /* istanbul ignore next */ receive = <
205
- E extends EndpointInterface & {
206
- update?: EndpointUpdateFunction<E>;
207
- },
208
- >(
209
- endpoint: E,
210
- ...rest: readonly [...Parameters<E>, any]
211
- ): Promise<void> => {
212
- /* istanbul ignore next */
213
- return this.setResponse(endpoint, ...rest);
214
- };
215
-
216
202
  /**
217
203
  * Stores the result of Endpoint and args as the error provided.
218
- * @see https://resthooks.io/docs/api/Controller#setError
204
+ * @see https://dataclient.io/docs/api/Controller#setError
219
205
  */
220
206
  setError = <
221
207
  E extends EndpointInterface & {
@@ -234,25 +220,9 @@ export default class Controller<
234
220
  return this.dispatch(action);
235
221
  };
236
222
 
237
- /**
238
- * Another name for setError
239
- * @deprecated use https://resthooks.io/docs/api/Controller#setError instead
240
- */
241
- /* istanbul ignore next */ receiveError = <
242
- E extends EndpointInterface & {
243
- update?: EndpointUpdateFunction<E>;
244
- },
245
- >(
246
- endpoint: E,
247
- ...rest: readonly [...Parameters<E>, Error]
248
- ): Promise<void> => {
249
- /* istanbul ignore next */
250
- return this.setError(endpoint, ...rest);
251
- };
252
-
253
223
  /**
254
224
  * Resolves an inflight fetch. `fetchedAt` should `fetch`'s `createdAt`
255
- * @see https://resthooks.io/docs/api/Controller#resolve
225
+ * @see https://dataclient.io/docs/api/Controller#resolve
256
226
  */
257
227
  resolve = <
258
228
  E extends EndpointInterface & {
@@ -279,7 +249,7 @@ export default class Controller<
279
249
 
280
250
  /**
281
251
  * Marks a new subscription to a given Endpoint.
282
- * @see https://resthooks.io/docs/api/Controller#subscribe
252
+ * @see https://dataclient.io/docs/api/Controller#subscribe
283
253
  */
284
254
  subscribe = <
285
255
  E extends EndpointInterface<
@@ -301,7 +271,7 @@ export default class Controller<
301
271
 
302
272
  /**
303
273
  * Marks completion of subscription to a given Endpoint.
304
- * @see https://resthooks.io/docs/api/Controller#unsubscribe
274
+ * @see https://dataclient.io/docs/api/Controller#unsubscribe
305
275
  */
306
276
  unsubscribe = <
307
277
  E extends EndpointInterface<
@@ -331,8 +301,8 @@ export default class Controller<
331
301
  */
332
302
 
333
303
  /**
334
- * Gets a snapshot (https://resthooks.io/docs/api/Snapshot)
335
- * @see https://resthooks.io/docs/api/Controller#snapshot
304
+ * Gets a snapshot (https://dataclient.io/docs/api/Snapshot)
305
+ * @see https://dataclient.io/docs/api/Controller#snapshot
336
306
  */
337
307
  snapshot = (state: State<unknown>, fetchedAt?: number): SnapshotInterface => {
338
308
  return new Snapshot(this, state, fetchedAt);
@@ -340,7 +310,7 @@ export default class Controller<
340
310
 
341
311
  /**
342
312
  * Gets the error, if any, for a given endpoint. Returns undefined for no errors.
343
- * @see https://resthooks.io/docs/api/Controller#getError
313
+ * @see https://dataclient.io/docs/api/Controller#getError
344
314
  */
345
315
  getError = <
346
316
  E extends Pick<EndpointInterface, 'key'>,
@@ -365,7 +335,7 @@ export default class Controller<
365
335
 
366
336
  /**
367
337
  * Gets the (globally referentially stable) response for a given endpoint/args pair from state given.
368
- * @see https://resthooks.io/docs/api/Controller#getResponse
338
+ * @see https://dataclient.io/docs/api/Controller#getResponse
369
339
  */
370
340
  getResponse = <
371
341
  E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,
@@ -380,7 +350,9 @@ export default class Controller<
380
350
  } => {
381
351
  const state = rest[rest.length - 1] as State<unknown>;
382
352
  // this is typescript generics breaking
383
- const args: any = rest.slice(0, rest.length - 1) as Parameters<E['key']>;
353
+ const args: any = rest
354
+ .slice(0, rest.length - 1)
355
+ .map(ensurePojo) as Parameters<E['key']>;
384
356
  const isActive = args.length !== 1 || args[0] !== null;
385
357
  const key = isActive ? endpoint.key(...args) : '';
386
358
  const cacheResults = isActive ? state.results[key] : undefined;
@@ -447,7 +419,7 @@ export default class Controller<
447
419
  expiresAt = entityExpiresAt(paths, state.entityMeta);
448
420
  }
449
421
 
450
- // https://resthooks.io/docs/concepts/expiry-policy#expiry-status
422
+ // https://dataclient.io/docs/concepts/expiry-policy#expiry-status
451
423
  // we don't track the difference between stale or fresh because that is tied to triggering
452
424
  // conditions
453
425
  const expiryStatus =
@@ -517,7 +489,7 @@ class Snapshot<T = unknown> implements SnapshotInterface {
517
489
  }
518
490
 
519
491
  /*************** Data Access ***************/
520
- /** @see https://resthooks.io/docs/api/Snapshot#getResponse */
492
+ /** @see https://dataclient.io/docs/api/Snapshot#getResponse */
521
493
  getResponse = <
522
494
  E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,
523
495
  Args extends readonly [...Parameters<E['key']>],
@@ -532,7 +504,7 @@ class Snapshot<T = unknown> implements SnapshotInterface {
532
504
  return this.controller.getResponse(endpoint, ...args, this.state);
533
505
  };
534
506
 
535
- /** @see https://resthooks.io/docs/api/Snapshot#getError */
507
+ /** @see https://dataclient.io/docs/api/Snapshot#getError */
536
508
  getError = <
537
509
  E extends Pick<EndpointInterface, 'key'>,
538
510
  Args extends readonly [...Parameters<E['key']>],
@@ -1,5 +1,6 @@
1
1
  import type { EndpointInterface, ResolveType } from '@data-client/normalizr';
2
2
 
3
+ import ensurePojo from './ensurePojo.js';
3
4
  import { EndpointUpdateFunction } from './types.js';
4
5
  import { SET_TYPE } from '../actionTypes.js';
5
6
  import type { SetAction, SetMeta } from '../types.js';
@@ -59,7 +60,7 @@ export default function createSet<
59
60
  }
60
61
  const now = Date.now();
61
62
  const meta: SetMeta = {
62
- args,
63
+ args: args.map(ensurePojo),
63
64
  fetchedAt: fetchedAt ?? now,
64
65
  date: now,
65
66
  expiresAt: now + expiryLength,
@@ -0,0 +1,11 @@
1
+ export const ensurePojo =
2
+ // FormData doesn't exist in node
3
+ /* istanbul ignore else we don't run coverage when we test node*/
4
+ typeof FormData !== 'undefined'
5
+ ? (body: any) =>
6
+ body instanceof FormData
7
+ ? Object.fromEntries((body as any).entries())
8
+ : body
9
+ : /* istanbul ignore next */
10
+ (body: any) => body;
11
+ export default ensurePojo;
package/src/index.ts CHANGED
@@ -38,7 +38,7 @@ export type {
38
38
  GenericDispatch,
39
39
  } from './controller/Controller.js';
40
40
  export { default as createFetch } from './controller/createFetch.js';
41
- export { default as createReceive } from './controller/createSet.js';
41
+ export { default as createSet } from './controller/createSet.js';
42
42
 
43
43
  export * from './controller/types.js';
44
44
  export * as actionTypes from './actionTypes.js';
package/src/internal.ts CHANGED
@@ -1,3 +1,3 @@
1
- export { inferResults, DELETED, INVALID } from '@data-client/normalizr';
1
+ export { inferResults, INVALID } from '@data-client/normalizr';
2
2
  export { default as RIC } from './state/RIC.js';
3
3
  export { initialState } from './state/reducer/createReducer.js';
@@ -7,7 +7,7 @@ export type { DevToolsConfig };
7
7
 
8
8
  const HASINTL = typeof Intl !== 'undefined';
9
9
  const DEFAULT_CONFIG = {
10
- name: `Rest Hooks: ${globalThis.document?.title}`,
10
+ name: `RDC: ${globalThis.document?.title}`,
11
11
  autoPause: true,
12
12
  serialize: {
13
13
  options: undefined,
@@ -70,7 +70,7 @@ export default class DevToolsManager implements Manager {
70
70
  action,
71
71
  state.optimistic.reduce(reducer, state),
72
72
  undefined,
73
- 'REST_HOOKS',
73
+ 'RDC',
74
74
  );
75
75
  });
76
76
  return ret;
@@ -61,7 +61,7 @@ export default class NetworkManager implements Manager {
61
61
  }
62
62
  return Promise.resolve();
63
63
  case SET_TYPE:
64
- // only receive after new state is computed
64
+ // only set after new state is computed
65
65
  return next(action).then(() => {
66
66
  if (action.meta.key in this.fetched) {
67
67
  // Note: meta *must* be set by reducer so this should be safe
@@ -69,7 +69,7 @@ export default class NetworkManager implements Manager {
69
69
  controller.getState().meta[action.meta.key]?.error;
70
70
  // processing errors result in state meta having error, so we should reject the promise
71
71
  if (error) {
72
- this.handleReceive(
72
+ this.handleSet(
73
73
  createSet(action.endpoint, {
74
74
  args: action.meta.args as any,
75
75
  response: error,
@@ -78,7 +78,7 @@ export default class NetworkManager implements Manager {
78
78
  }),
79
79
  );
80
80
  } else {
81
- this.handleReceive(action);
81
+ this.handleSet(action);
82
82
  }
83
83
  }
84
84
  });
@@ -145,7 +145,7 @@ export default class NetworkManager implements Manager {
145
145
  return this.controller.getState().lastReset;
146
146
  }
147
147
 
148
- /** Called when middleware intercepts 'rest-hooks/fetch' action.
148
+ /** Called when middleware intercepts 'rdc/fetch' action.
149
149
  *
150
150
  * Will then start a promise for a key and potentially start the network
151
151
  * fetch.
@@ -171,7 +171,7 @@ export default class NetworkManager implements Manager {
171
171
  reject(error);
172
172
  throw error;
173
173
  });
174
- // schedule non-throttled resolutions in a microtask before receive
174
+ // schedule non-throttled resolutions in a microtask before set
175
175
  // this enables users awaiting their fetch to trigger any react updates needed to deal
176
176
  // with upcoming changes because of the fetch (for instance avoiding suspense if something is deleted)
177
177
  if (!throttle) {
@@ -224,11 +224,11 @@ export default class NetworkManager implements Manager {
224
224
  }
225
225
  }
226
226
 
227
- /** Called when middleware intercepts a receive action.
227
+ /** Called when middleware intercepts a set action.
228
228
  *
229
- * Will resolve the promise associated with receive key.
229
+ * Will resolve the promise associated with set key.
230
230
  */
231
- protected handleReceive(action: SetAction) {
231
+ protected handleSet(action: SetAction) {
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;
@@ -245,9 +245,9 @@ export default class NetworkManager implements Manager {
245
245
 
246
246
  /** Attaches NetworkManager to store
247
247
  *
248
- * Intercepts 'rest-hooks/fetch' actions to start requests.
248
+ * Intercepts 'rdc/fetch' actions to start requests.
249
249
  *
250
- * Resolve/rejects a request when matching 'rest-hooks/receive' event
250
+ * Resolve/rejects a request when matching 'rdc/set' event
251
251
  * is seen.
252
252
  */
253
253
  getMiddleware() {
@@ -25,7 +25,7 @@ export interface SubscriptionConstructable {
25
25
  ): Subscription;
26
26
  }
27
27
 
28
- /** Handles subscription actions -> fetch or receive actions
28
+ /** Handles subscription actions -> fetch or set actions
29
29
  *
30
30
  * Constructor takes a SubscriptionConstructable class to control how
31
31
  * subscriptions are handled. (e.g., polling, websockets)
@@ -75,7 +75,7 @@ export default class SubscriptionManager<S extends SubscriptionConstructable>
75
75
  }
76
76
  }
77
77
 
78
- /** Called when middleware intercepts 'rest-hooks/subscribe' action.
78
+ /** Called when middleware intercepts 'rdc/subscribe' action.
79
79
  *
80
80
  */
81
81
  protected handleSubscribe(action: SubscribeAction) {
@@ -92,7 +92,7 @@ export default class SubscriptionManager<S extends SubscriptionConstructable>
92
92
  }
93
93
  }
94
94
 
95
- /** Called when middleware intercepts 'rest-hooks/unsubscribe' action.
95
+ /** Called when middleware intercepts 'rdc/unsubscribe' action.
96
96
  *
97
97
  */
98
98
  protected handleUnsubscribe(action: UnsubscribeAction) {
@@ -112,10 +112,10 @@ export default class SubscriptionManager<S extends SubscriptionConstructable>
112
112
 
113
113
  /** Attaches Manager to store
114
114
  *
115
- * Intercepts 'rest-hooks/subscribe'/'rest-hooks/unsubscribe' to register resources that
115
+ * Intercepts 'rdc/subscribe'/'rest-hordc/ribe' to register resources that
116
116
  * need to be kept up to date.
117
117
  *
118
- * Will possibly dispatch 'rest-hooks/fetch' or 'rest-hooks/receive' to keep resources fresh
118
+ * Will possibly dispatch 'rdc/fetch' or 'rest-hordc/' to keep resources fresh
119
119
  *
120
120
  */
121
121
  getMiddleware() {
@@ -20,7 +20,7 @@ exports[`PollingSubscription fresh data should call after period 1`] = `
20
20
  "throttle": true,
21
21
  },
22
22
  "payload": [Function],
23
- "type": "rest-hooks/fetch",
23
+ "type": "rdc/fetch",
24
24
  },
25
25
  ]
26
26
  `;
@@ -39,7 +39,7 @@ exports[`PollingSubscription fresh data should call after period 2`] = `
39
39
  "throttle": true,
40
40
  },
41
41
  "payload": [Function],
42
- "type": "rest-hooks/fetch",
42
+ "type": "rdc/fetch",
43
43
  },
44
44
  ]
45
45
  `;
@@ -43,7 +43,7 @@ describe('LogoutManager', () => {
43
43
  controller: { value: controller },
44
44
  },
45
45
  );
46
- it('should ignore non-error receive', async () => {
46
+ it('should ignore non-error set', async () => {
47
47
  const action = createSet(CoolerArticleResource.get, {
48
48
  args: [{ id: 5 }],
49
49
  response: { id: 5, title: 'hi' },
@@ -52,7 +52,7 @@ describe('LogoutManager', () => {
52
52
 
53
53
  expect(dispatch.mock.calls.length).toBe(0);
54
54
  });
55
- it('should ignore non-401 receive', async () => {
55
+ it('should ignore non-401 set', async () => {
56
56
  const error: any = new Error('network failed');
57
57
  error.status = 404;
58
58
  const action = createSet(CoolerArticleResource.get, {
@@ -4,7 +4,7 @@ import { ActionTypes } from '../../types';
4
4
  import NetworkManager from '../NetworkManager';
5
5
 
6
6
  const middleware: Middleware = new NetworkManager().getMiddleware();
7
- it('middlewares should compose with non-rest-hooks middlewares', () => {
7
+ it('middlewares should compose with non-data-client middlewares', () => {
8
8
  type AnotherAction = {
9
9
  type: 'BOB';
10
10
  payload: any;