@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.
- package/data_client_logo_and_text.svg +50 -0
- package/dist/index.js +66 -92
- package/dist/index.umd.min.js +1 -1
- package/dist/next.js +0 -447
- package/legacy/actionTypes.js +11 -13
- package/legacy/actions.js +2 -0
- package/legacy/controller/Controller.js +26 -42
- package/legacy/controller/createSet.js +3 -2
- package/legacy/controller/ensurePojo.js +7 -0
- package/legacy/index.js +2 -2
- package/legacy/internal.js +2 -2
- package/legacy/manager/DevtoolsManager.js +3 -3
- package/legacy/manager/NetworkManager.js +11 -11
- package/legacy/manager/SubscriptionManager.js +6 -6
- package/legacy/manager/applyManager.js +2 -9
- package/legacy/middlewareTypes.js +1 -1
- package/legacy/next/index.js +2 -3
- package/legacy/state/reducer/fetchReducer.js +5 -5
- package/legacy/state/reducer/setReducer.js +2 -2
- package/legacy/types.js +3 -4
- package/lib/actionTypes.d.ts +10 -12
- package/lib/actionTypes.d.ts.map +1 -1
- package/lib/actionTypes.js +11 -13
- package/lib/{newActions.d.ts → actions.d.ts} +1 -3
- package/lib/actions.d.ts.map +1 -0
- package/lib/actions.js +2 -0
- package/lib/controller/Controller.d.ts +20 -33
- package/lib/controller/Controller.d.ts.map +1 -1
- package/lib/controller/Controller.js +26 -42
- package/lib/controller/createSet.d.ts.map +1 -1
- package/lib/controller/createSet.js +3 -2
- package/lib/controller/ensurePojo.d.ts +3 -0
- package/lib/controller/ensurePojo.d.ts.map +1 -0
- package/lib/controller/ensurePojo.js +7 -0
- package/lib/index.d.ts +1 -1
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +2 -2
- package/lib/internal.d.ts +1 -1
- package/lib/internal.d.ts.map +1 -1
- package/lib/internal.js +2 -2
- package/lib/manager/DevtoolsManager.js +3 -3
- package/lib/manager/NetworkManager.d.ts +6 -6
- package/lib/manager/NetworkManager.d.ts.map +1 -1
- package/lib/manager/NetworkManager.js +11 -11
- package/lib/manager/SubscriptionManager.d.ts +5 -5
- package/lib/manager/SubscriptionManager.js +6 -6
- package/lib/manager/applyManager.d.ts.map +1 -1
- package/lib/manager/applyManager.js +2 -9
- package/lib/middlewareTypes.d.ts +2 -5
- package/lib/middlewareTypes.d.ts.map +1 -1
- package/lib/middlewareTypes.js +1 -1
- package/lib/next/index.d.ts +0 -2
- package/lib/next/index.d.ts.map +1 -1
- package/lib/next/index.js +2 -3
- package/lib/state/reducer/expireReducer.d.ts +1 -1
- package/lib/state/reducer/fetchReducer.js +5 -5
- package/lib/state/reducer/invalidateReducer.d.ts +1 -1
- package/lib/state/reducer/setReducer.d.ts +2 -2
- package/lib/state/reducer/setReducer.d.ts.map +1 -1
- package/lib/state/reducer/setReducer.js +2 -2
- package/lib/types.d.ts +3 -4
- package/lib/types.d.ts.map +1 -1
- package/lib/types.js +3 -4
- package/package.json +3 -3
- package/src/actionTypes.ts +10 -12
- package/src/{newActions.ts → actions.ts} +1 -6
- package/src/controller/Controller.ts +27 -55
- package/src/controller/createSet.ts +2 -1
- package/src/controller/ensurePojo.ts +11 -0
- package/src/index.ts +1 -1
- package/src/internal.ts +1 -1
- package/src/manager/DevtoolsManager.ts +2 -2
- package/src/manager/NetworkManager.ts +10 -10
- package/src/manager/SubscriptionManager.ts +5 -5
- package/src/manager/__tests__/__snapshots__/pollingSubscription.ts.snap +2 -2
- package/src/manager/__tests__/logoutManager.ts +2 -2
- package/src/manager/__tests__/manager.ts +1 -1
- package/src/manager/__tests__/networkManager.ts +13 -16
- package/src/manager/applyManager.ts +1 -6
- package/src/middlewareTypes.ts +4 -9
- package/src/next/index.ts +0 -2
- package/src/state/__tests__/__snapshots__/reducer.ts.snap +1 -1
- package/src/state/__tests__/reducer.ts +27 -9
- package/src/state/reducer/fetchReducer.ts +5 -5
- package/src/state/reducer/setReducer.ts +5 -5
- package/src/types.ts +3 -4
- package/ts3.4/actionTypes.d.ts +10 -12
- package/ts3.4/{newActions.d.ts → actions.d.ts} +1 -3
- package/ts3.4/controller/Controller.d.ts +20 -39
- package/ts3.4/controller/ensurePojo.d.ts +3 -0
- package/ts3.4/index.d.ts +1 -1
- package/ts3.4/internal.d.ts +1 -1
- package/ts3.4/manager/NetworkManager.d.ts +6 -6
- package/ts3.4/manager/SubscriptionManager.d.ts +5 -5
- package/ts3.4/middlewareTypes.d.ts +2 -5
- package/ts3.4/next/index.d.ts +0 -2
- package/ts3.4/state/reducer/expireReducer.d.ts +1 -1
- package/ts3.4/state/reducer/invalidateReducer.d.ts +1 -1
- package/ts3.4/state/reducer/setReducer.d.ts +2 -2
- package/ts3.4/types.d.ts +3 -5
- package/legacy/fsa.js +0 -2
- package/legacy/newActions.js +0 -2
- package/lib/fsa.d.ts +0 -41
- package/lib/fsa.d.ts.map +0 -1
- package/lib/fsa.js +0 -2
- package/lib/newActions.d.ts.map +0 -1
- package/lib/newActions.js +0 -2
- package/src/fsa.ts +0 -99
- 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
|
|
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
|
|
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 *
|
|
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;
|
package/lib/types.d.ts.map
CHANGED
|
@@ -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,
|
|
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
|
-
|
|
2
|
-
export {
|
|
3
|
-
|
|
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.
|
|
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
|
-
"./
|
|
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": "
|
|
123
|
+
"@data-client/normalizr": "workspace:^",
|
|
124
124
|
"flux-standard-action": "^2.1.1"
|
|
125
125
|
},
|
|
126
126
|
"devDependencies": {
|
package/src/actionTypes.ts
CHANGED
|
@@ -1,12 +1,10 @@
|
|
|
1
|
-
export const FETCH_TYPE = '
|
|
2
|
-
|
|
3
|
-
export const
|
|
4
|
-
export const
|
|
5
|
-
export const
|
|
6
|
-
export const
|
|
7
|
-
export const
|
|
8
|
-
export const
|
|
9
|
-
export const
|
|
10
|
-
export 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
|
-
/*
|
|
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
|
|
60
|
-
* @see https://
|
|
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
|
|
67
|
+
* Dispatches an action to Reactive Data Client reducer.
|
|
67
68
|
*
|
|
68
|
-
* @see https://
|
|
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://
|
|
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
|
|
98
|
-
* @see https://
|
|
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://
|
|
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://
|
|
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
|
|
177
|
-
* @see https://
|
|
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://
|
|
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://
|
|
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://
|
|
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://
|
|
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://
|
|
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://
|
|
335
|
-
* @see https://
|
|
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://
|
|
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://
|
|
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
|
|
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://
|
|
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://
|
|
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://
|
|
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
|
|
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
|
@@ -7,7 +7,7 @@ export type { DevToolsConfig };
|
|
|
7
7
|
|
|
8
8
|
const HASINTL = typeof Intl !== 'undefined';
|
|
9
9
|
const DEFAULT_CONFIG = {
|
|
10
|
-
name: `
|
|
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
|
-
'
|
|
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
|
|
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.
|
|
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.
|
|
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 '
|
|
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
|
|
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
|
|
227
|
+
/** Called when middleware intercepts a set action.
|
|
228
228
|
*
|
|
229
|
-
* Will resolve the promise associated with
|
|
229
|
+
* Will resolve the promise associated with set key.
|
|
230
230
|
*/
|
|
231
|
-
protected
|
|
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 '
|
|
248
|
+
* Intercepts 'rdc/fetch' actions to start requests.
|
|
249
249
|
*
|
|
250
|
-
* Resolve/rejects a request when matching '
|
|
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
|
|
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 '
|
|
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 '
|
|
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 '
|
|
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 '
|
|
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": "
|
|
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": "
|
|
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
|
|
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
|
|
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-
|
|
7
|
+
it('middlewares should compose with non-data-client middlewares', () => {
|
|
8
8
|
type AnotherAction = {
|
|
9
9
|
type: 'BOB';
|
|
10
10
|
payload: any;
|