@data-client/core 0.14.13 → 0.14.16
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/dist/index.js +62 -40
- package/dist/index.umd.min.js +1 -1
- package/legacy/actionTypes.js +23 -12
- package/legacy/actions.js +1 -1
- package/legacy/controller/actions/createExpireAll.js +3 -3
- package/legacy/controller/actions/createFetch.js +3 -3
- package/legacy/controller/actions/createInvalidate.js +3 -3
- package/legacy/controller/actions/createInvalidateAll.js +3 -3
- package/legacy/controller/actions/createOptimistic.js +3 -3
- package/legacy/controller/actions/createReset.js +3 -3
- package/legacy/controller/actions/createSet.js +3 -3
- package/legacy/controller/actions/createSetResponse.js +3 -3
- package/legacy/controller/actions/createSubscription.js +4 -4
- package/legacy/manager/LogoutManager.js +3 -3
- package/legacy/manager/NetworkManager.js +6 -6
- package/legacy/manager/SubscriptionManager.js +4 -4
- package/legacy/state/reducer/createReducer.js +11 -11
- package/legacy/state/reducer/invalidateReducer.js +3 -3
- package/legacy/state/reducer/setResponseReducer.js +4 -4
- package/lib/actionTypes.d.ts +11 -0
- package/lib/actionTypes.d.ts.map +1 -1
- package/lib/actionTypes.js +23 -12
- package/lib/actions.d.ts +12 -12
- package/lib/actions.d.ts.map +1 -1
- package/lib/actions.js +1 -1
- package/lib/controller/actions/createExpireAll.js +3 -3
- package/lib/controller/actions/createFetch.js +3 -3
- package/lib/controller/actions/createInvalidate.js +3 -3
- package/lib/controller/actions/createInvalidateAll.js +3 -3
- package/lib/controller/actions/createOptimistic.js +3 -3
- package/lib/controller/actions/createReset.js +3 -3
- package/lib/controller/actions/createSet.js +3 -3
- package/lib/controller/actions/createSetResponse.js +3 -3
- package/lib/controller/actions/createSubscription.js +4 -4
- package/lib/manager/LogoutManager.js +3 -3
- package/lib/manager/NetworkManager.js +6 -6
- package/lib/manager/SubscriptionManager.js +4 -4
- package/lib/state/reducer/createReducer.js +11 -11
- package/lib/state/reducer/invalidateReducer.js +3 -3
- package/lib/state/reducer/setResponseReducer.js +4 -4
- package/package.json +2 -2
- package/src/actionTypes.ts +23 -11
- package/src/actions.ts +22 -22
- package/src/controller/actions/createExpireAll.ts +2 -2
- package/src/controller/actions/createFetch.ts +2 -2
- package/src/controller/actions/createInvalidate.ts +2 -2
- package/src/controller/actions/createInvalidateAll.ts +2 -2
- package/src/controller/actions/createOptimistic.ts +2 -2
- package/src/controller/actions/createReset.ts +2 -2
- package/src/controller/actions/createSet.ts +2 -2
- package/src/controller/actions/createSetResponse.ts +2 -2
- package/src/controller/actions/createSubscription.ts +3 -3
- package/src/manager/LogoutManager.ts +2 -2
- package/src/manager/NetworkManager.ts +5 -5
- package/src/manager/SubscriptionManager.ts +3 -3
- package/src/manager/__tests__/logoutManager.ts +3 -3
- package/src/manager/__tests__/networkManager.ts +6 -6
- package/src/manager/__tests__/subscriptionManager.ts +4 -4
- package/src/state/__tests__/reducer.ts +22 -22
- package/src/state/reducer/createReducer.ts +18 -18
- package/src/state/reducer/invalidateReducer.ts +2 -2
- package/src/state/reducer/setResponseReducer.ts +3 -3
- package/ts3.4/actionTypes.d.ts +11 -0
- package/ts3.4/actions.d.ts +12 -12
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { INVALIDATE } from '../../actionTypes.js';
|
|
2
2
|
export function invalidateReducer(state, action) {
|
|
3
3
|
const endpoints = {
|
|
4
4
|
...state.endpoints
|
|
@@ -16,7 +16,7 @@ export function invalidateReducer(state, action) {
|
|
|
16
16
|
delete itemMeta.error;
|
|
17
17
|
meta[key] = itemMeta;
|
|
18
18
|
};
|
|
19
|
-
if (action.type ===
|
|
19
|
+
if (action.type === INVALIDATE) {
|
|
20
20
|
invalidateKey(action.key);
|
|
21
21
|
} else {
|
|
22
22
|
Object.keys(endpoints).forEach(key => {
|
|
@@ -31,4 +31,4 @@ export function invalidateReducer(state, action) {
|
|
|
31
31
|
meta
|
|
32
32
|
};
|
|
33
33
|
}
|
|
34
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJJTlZBTElEQVRFIiwiaW52YWxpZGF0ZVJlZHVjZXIiLCJzdGF0ZSIsImFjdGlvbiIsImVuZHBvaW50cyIsIm1ldGEiLCJpbnZhbGlkYXRlS2V5Iiwia2V5IiwiaXRlbU1ldGEiLCJleHBpcmVzQXQiLCJpbnZhbGlkYXRlZCIsImVycm9yIiwidHlwZSIsIk9iamVjdCIsImtleXMiLCJmb3JFYWNoIiwidGVzdEtleSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zdGF0ZS9yZWR1Y2VyL2ludmFsaWRhdGVSZWR1Y2VyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElOVkFMSURBVEUgfSBmcm9tICcuLi8uLi9hY3Rpb25UeXBlcy5qcyc7XG5pbXBvcnQgdHlwZSB7XG4gIFN0YXRlLFxuICBJbnZhbGlkYXRlQWxsQWN0aW9uLFxuICBJbnZhbGlkYXRlQWN0aW9uLFxufSBmcm9tICcuLi8uLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBpbnZhbGlkYXRlUmVkdWNlcihcbiAgc3RhdGU6IFN0YXRlPHVua25vd24+LFxuICBhY3Rpb246IEludmFsaWRhdGVBY3Rpb24gfCBJbnZhbGlkYXRlQWxsQWN0aW9uLFxuKSB7XG4gIGNvbnN0IGVuZHBvaW50cyA9IHsgLi4uc3RhdGUuZW5kcG9pbnRzIH07XG4gIGNvbnN0IG1ldGEgPSB7IC4uLnN0YXRlLm1ldGEgfTtcbiAgY29uc3QgaW52YWxpZGF0ZUtleSA9IChrZXk6IHN0cmluZykgPT4ge1xuICAgIGRlbGV0ZSBlbmRwb2ludHNba2V5XTtcbiAgICBjb25zdCBpdGVtTWV0YSA9IHtcbiAgICAgIC4uLm1ldGFba2V5XSxcbiAgICAgIGV4cGlyZXNBdDogMCxcbiAgICAgIGludmFsaWRhdGVkOiB0cnVlLFxuICAgIH07XG4gICAgZGVsZXRlIGl0ZW1NZXRhLmVycm9yO1xuICAgIG1ldGFba2V5XSA9IGl0ZW1NZXRhO1xuICB9O1xuICBpZiAoYWN0aW9uLnR5cGUgPT09IElOVkFMSURBVEUpIHtcbiAgICBpbnZhbGlkYXRlS2V5KGFjdGlvbi5rZXkpO1xuICB9IGVsc2Uge1xuICAgIE9iamVjdC5rZXlzKGVuZHBvaW50cykuZm9yRWFjaChrZXkgPT4ge1xuICAgICAgaWYgKGFjdGlvbi50ZXN0S2V5KGtleSkpIHtcbiAgICAgICAgaW52YWxpZGF0ZUtleShrZXkpO1xuICAgICAgfVxuICAgIH0pO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICAuLi5zdGF0ZSxcbiAgICBlbmRwb2ludHMsXG4gICAgbWV0YSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsVUFBVSxRQUFRLHNCQUFzQjtBQU9qRCxPQUFPLFNBQVNDLGlCQUFpQkEsQ0FDL0JDLEtBQXFCLEVBQ3JCQyxNQUE4QyxFQUM5QztFQUNBLE1BQU1DLFNBQVMsR0FBRztJQUFFLEdBQUdGLEtBQUssQ0FBQ0U7RUFBVSxDQUFDO0VBQ3hDLE1BQU1DLElBQUksR0FBRztJQUFFLEdBQUdILEtBQUssQ0FBQ0c7RUFBSyxDQUFDO0VBQzlCLE1BQU1DLGFBQWEsR0FBSUMsR0FBVyxJQUFLO0lBQ3JDLE9BQU9ILFNBQVMsQ0FBQ0csR0FBRyxDQUFDO0lBQ3JCLE1BQU1DLFFBQVEsR0FBRztNQUNmLEdBQUdILElBQUksQ0FBQ0UsR0FBRyxDQUFDO01BQ1pFLFNBQVMsRUFBRSxDQUFDO01BQ1pDLFdBQVcsRUFBRTtJQUNmLENBQUM7SUFDRCxPQUFPRixRQUFRLENBQUNHLEtBQUs7SUFDckJOLElBQUksQ0FBQ0UsR0FBRyxDQUFDLEdBQUdDLFFBQVE7RUFDdEIsQ0FBQztFQUNELElBQUlMLE1BQU0sQ0FBQ1MsSUFBSSxLQUFLWixVQUFVLEVBQUU7SUFDOUJNLGFBQWEsQ0FBQ0gsTUFBTSxDQUFDSSxHQUFHLENBQUM7RUFDM0IsQ0FBQyxNQUFNO0lBQ0xNLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDVixTQUFTLENBQUMsQ0FBQ1csT0FBTyxDQUFDUixHQUFHLElBQUk7TUFDcEMsSUFBSUosTUFBTSxDQUFDYSxPQUFPLENBQUNULEdBQUcsQ0FBQyxFQUFFO1FBQ3ZCRCxhQUFhLENBQUNDLEdBQUcsQ0FBQztNQUNwQjtJQUNGLENBQUMsQ0FBQztFQUNKO0VBRUEsT0FBTztJQUNMLEdBQUdMLEtBQUs7SUFDUkUsU0FBUztJQUNUQztFQUNGLENBQUM7QUFDSCIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { normalize } from '@data-client/normalizr';
|
|
2
|
-
import {
|
|
2
|
+
import { OPTIMISTIC } from '../../actionTypes.js';
|
|
3
3
|
import AbortOptimistic from '../../controller/AbortOptimistic.js';
|
|
4
4
|
export function setResponseReducer(state, action, controller) {
|
|
5
5
|
if (action.error) {
|
|
@@ -9,7 +9,7 @@ export function setResponseReducer(state, action, controller) {
|
|
|
9
9
|
var _state$meta$action$ke;
|
|
10
10
|
let response;
|
|
11
11
|
// for true set's response is contained in action
|
|
12
|
-
if (action.type ===
|
|
12
|
+
if (action.type === OPTIMISTIC) {
|
|
13
13
|
// this should never happen
|
|
14
14
|
/* istanbul ignore if */
|
|
15
15
|
if (!action.endpoint.getOptimisticResponse) return state;
|
|
@@ -107,6 +107,6 @@ function reduceError(state, action, error) {
|
|
|
107
107
|
}
|
|
108
108
|
/** Filter all requests with same serialization that did not start after the resolving request */
|
|
109
109
|
function filterOptimistic(state, resolvingAction) {
|
|
110
|
-
return state.optimistic.filter(optimisticAction => optimisticAction.key !== resolvingAction.key || (optimisticAction.type ===
|
|
110
|
+
return state.optimistic.filter(optimisticAction => optimisticAction.key !== resolvingAction.key || (optimisticAction.type === OPTIMISTIC ? optimisticAction.meta.fetchedAt !== resolvingAction.meta.fetchedAt : optimisticAction.meta.date > resolvingAction.meta.date));
|
|
111
111
|
}
|
|
112
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["normalize","OPTIMISTIC_TYPE","AbortOptimistic","setResponseReducer","state","action","controller","error","reduceError","response","_state$meta$action$ke","type","endpoint","getOptimisticResponse","call","snapshot","meta","fetchedAt","args","e","constructor","result","entities","indexes","entityMeta","schema","endpoints","key","update","updaters","Object","keys","forEach","console","date","expiresAt","prevExpiresAt","optimistic","filterOptimistic","lastReset","message","JSON","stringify","undefined","status","process","env","NODE_ENV","name","errorPolicy","resolvingAction","filter","optimisticAction"],"sources":["../../../src/state/reducer/setResponseReducer.ts"],"sourcesContent":["import { normalize } from '@data-client/normalizr';\n\nimport { OPTIMISTIC_TYPE } from '../../actionTypes.js';\nimport AbortOptimistic from '../../controller/AbortOptimistic.js';\nimport type Controller from '../../controller/Controller.js';\nimport type {\n  State,\n  SetResponseAction,\n  OptimisticAction,\n} from '../../types.js';\n\nexport function setResponseReducer(\n  state: State<unknown>,\n  action: OptimisticAction | SetResponseAction,\n  controller: Controller,\n) {\n  if (action.error) {\n    return reduceError(state, action, action.response);\n  }\n  try {\n    let response: any;\n    // for true set's response is contained in action\n    if (action.type === OPTIMISTIC_TYPE) {\n      // this should never happen\n      /* istanbul ignore if */\n      if (!action.endpoint.getOptimisticResponse) return state;\n      try {\n        // compute optimistic response based on current state\n        response = action.endpoint.getOptimisticResponse.call(\n          action.endpoint,\n          controller.snapshot(state, action.meta.fetchedAt),\n          ...action.args,\n        );\n      } catch (e: any) {\n        // AbortOptimistic means 'do nothing', otherwise we count the exception as endpoint failure\n        if (e.constructor === AbortOptimistic) {\n          return state;\n        }\n        throw e;\n      }\n    } else {\n      response = action.response;\n    }\n    const { result, entities, indexes, entityMeta } = normalize(\n      action.endpoint.schema,\n      response,\n      action.args,\n      state,\n      action.meta,\n    );\n    const endpoints: Record<string, unknown> = {\n      ...state.endpoints,\n      [action.key]: result,\n    };\n    try {\n      if (action.endpoint.update) {\n        const updaters = action.endpoint.update(result, ...action.args);\n        Object.keys(updaters).forEach(key => {\n          endpoints[key] = updaters[key](endpoints[key]);\n        });\n      }\n      // no reason to completely fail because of user-code error\n      // integrity of this state update is still guaranteed\n    } catch (error) {\n      console.error(\n        `The following error occured during Endpoint.update() for ${action.key}`,\n      );\n      console.error(error);\n    }\n    return {\n      entities,\n      endpoints,\n      indexes,\n      meta: {\n        ...state.meta,\n        [action.key]: {\n          date: action.meta.date,\n          expiresAt: action.meta.expiresAt,\n          prevExpiresAt: state.meta[action.key]?.expiresAt,\n        },\n      },\n      entityMeta,\n      optimistic: filterOptimistic(state, action),\n      lastReset: state.lastReset,\n    };\n    // reducer must update the state, so in case of processing errors we simply compute the endpoints inline\n  } catch (error: any) {\n    if (typeof error === 'object') {\n      error.message = `Error processing ${\n        action.key\n      }\\n\\nFull Schema: ${JSON.stringify(\n        action.endpoint.schema,\n        undefined,\n        2,\n      )}\\n\\nError:\\n${error.message}`;\n      if ('response' in action) error.response = action.response;\n      error.status = 400;\n    }\n\n    // this is not always bubbled up, so let's double sure this doesn't fail silently\n    /* istanbul ignore else */\n    if (process.env.NODE_ENV !== 'production') {\n      console.error(error);\n    }\n    return reduceError(state, action, error);\n  }\n}\n\nfunction reduceError(\n  state: State<unknown>,\n  action: SetResponseAction | OptimisticAction,\n  error: any,\n): State<unknown> {\n  if (error.name === 'AbortError') {\n    // In case we abort simply undo the optimistic update and act like no fetch even occured\n    // We still want those watching promises from fetch directly to observed the abort, but we don't want to\n    // Trigger errors in this case. This means theoretically improperly built abortes useResource() could suspend forever.\n    return {\n      ...state,\n      optimistic: filterOptimistic(state, action),\n    };\n  }\n  return {\n    ...state,\n    meta: {\n      ...state.meta,\n      [action.key]: {\n        date: action.meta.date,\n        error,\n        expiresAt: action.meta.expiresAt,\n        errorPolicy: action.endpoint.errorPolicy?.(error),\n      },\n    },\n    optimistic: filterOptimistic(state, action),\n  };\n}\n/** Filter all requests with same serialization that did not start after the resolving request */\nfunction filterOptimistic(\n  state: State<unknown>,\n  resolvingAction: SetResponseAction | OptimisticAction,\n) {\n  return state.optimistic.filter(\n    optimisticAction =>\n      optimisticAction.key !== resolvingAction.key ||\n      (optimisticAction.type === OPTIMISTIC_TYPE ?\n        optimisticAction.meta.fetchedAt !== resolvingAction.meta.fetchedAt\n      : optimisticAction.meta.date > resolvingAction.meta.date),\n  );\n}\n"],"mappings":"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","ignoreList":[]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["normalize","OPTIMISTIC","AbortOptimistic","setResponseReducer","state","action","controller","error","reduceError","response","_state$meta$action$ke","type","endpoint","getOptimisticResponse","call","snapshot","meta","fetchedAt","args","e","constructor","result","entities","indexes","entityMeta","schema","endpoints","key","update","updaters","Object","keys","forEach","console","date","expiresAt","prevExpiresAt","optimistic","filterOptimistic","lastReset","message","JSON","stringify","undefined","status","process","env","NODE_ENV","name","errorPolicy","resolvingAction","filter","optimisticAction"],"sources":["../../../src/state/reducer/setResponseReducer.ts"],"sourcesContent":["import { normalize } from '@data-client/normalizr';\n\nimport { OPTIMISTIC } from '../../actionTypes.js';\nimport AbortOptimistic from '../../controller/AbortOptimistic.js';\nimport type Controller from '../../controller/Controller.js';\nimport type {\n  State,\n  SetResponseAction,\n  OptimisticAction,\n} from '../../types.js';\n\nexport function setResponseReducer(\n  state: State<unknown>,\n  action: OptimisticAction | SetResponseAction,\n  controller: Controller,\n) {\n  if (action.error) {\n    return reduceError(state, action, action.response);\n  }\n  try {\n    let response: any;\n    // for true set's response is contained in action\n    if (action.type === OPTIMISTIC) {\n      // this should never happen\n      /* istanbul ignore if */\n      if (!action.endpoint.getOptimisticResponse) return state;\n      try {\n        // compute optimistic response based on current state\n        response = action.endpoint.getOptimisticResponse.call(\n          action.endpoint,\n          controller.snapshot(state, action.meta.fetchedAt),\n          ...action.args,\n        );\n      } catch (e: any) {\n        // AbortOptimistic means 'do nothing', otherwise we count the exception as endpoint failure\n        if (e.constructor === AbortOptimistic) {\n          return state;\n        }\n        throw e;\n      }\n    } else {\n      response = action.response;\n    }\n    const { result, entities, indexes, entityMeta } = normalize(\n      action.endpoint.schema,\n      response,\n      action.args,\n      state,\n      action.meta,\n    );\n    const endpoints: Record<string, unknown> = {\n      ...state.endpoints,\n      [action.key]: result,\n    };\n    try {\n      if (action.endpoint.update) {\n        const updaters = action.endpoint.update(result, ...action.args);\n        Object.keys(updaters).forEach(key => {\n          endpoints[key] = updaters[key](endpoints[key]);\n        });\n      }\n      // no reason to completely fail because of user-code error\n      // integrity of this state update is still guaranteed\n    } catch (error) {\n      console.error(\n        `The following error occured during Endpoint.update() for ${action.key}`,\n      );\n      console.error(error);\n    }\n    return {\n      entities,\n      endpoints,\n      indexes,\n      meta: {\n        ...state.meta,\n        [action.key]: {\n          date: action.meta.date,\n          expiresAt: action.meta.expiresAt,\n          prevExpiresAt: state.meta[action.key]?.expiresAt,\n        },\n      },\n      entityMeta,\n      optimistic: filterOptimistic(state, action),\n      lastReset: state.lastReset,\n    };\n    // reducer must update the state, so in case of processing errors we simply compute the endpoints inline\n  } catch (error: any) {\n    if (typeof error === 'object') {\n      error.message = `Error processing ${\n        action.key\n      }\\n\\nFull Schema: ${JSON.stringify(\n        action.endpoint.schema,\n        undefined,\n        2,\n      )}\\n\\nError:\\n${error.message}`;\n      if ('response' in action) error.response = action.response;\n      error.status = 400;\n    }\n\n    // this is not always bubbled up, so let's double sure this doesn't fail silently\n    /* istanbul ignore else */\n    if (process.env.NODE_ENV !== 'production') {\n      console.error(error);\n    }\n    return reduceError(state, action, error);\n  }\n}\n\nfunction reduceError(\n  state: State<unknown>,\n  action: SetResponseAction | OptimisticAction,\n  error: any,\n): State<unknown> {\n  if (error.name === 'AbortError') {\n    // In case we abort simply undo the optimistic update and act like no fetch even occured\n    // We still want those watching promises from fetch directly to observed the abort, but we don't want to\n    // Trigger errors in this case. This means theoretically improperly built abortes useResource() could suspend forever.\n    return {\n      ...state,\n      optimistic: filterOptimistic(state, action),\n    };\n  }\n  return {\n    ...state,\n    meta: {\n      ...state.meta,\n      [action.key]: {\n        date: action.meta.date,\n        error,\n        expiresAt: action.meta.expiresAt,\n        errorPolicy: action.endpoint.errorPolicy?.(error),\n      },\n    },\n    optimistic: filterOptimistic(state, action),\n  };\n}\n/** Filter all requests with same serialization that did not start after the resolving request */\nfunction filterOptimistic(\n  state: State<unknown>,\n  resolvingAction: SetResponseAction | OptimisticAction,\n) {\n  return state.optimistic.filter(\n    optimisticAction =>\n      optimisticAction.key !== resolvingAction.key ||\n      (optimisticAction.type === OPTIMISTIC ?\n        optimisticAction.meta.fetchedAt !== resolvingAction.meta.fetchedAt\n      : optimisticAction.meta.date > resolvingAction.meta.date),\n  );\n}\n"],"mappings":"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","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@data-client/core",
|
|
3
|
-
"version": "0.14.
|
|
3
|
+
"version": "0.14.16",
|
|
4
4
|
"description": "Async State Management without the Management. REST, GraphQL, SSE, Websockets, Fetch",
|
|
5
5
|
"sideEffects": false,
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -121,7 +121,7 @@
|
|
|
121
121
|
},
|
|
122
122
|
"dependencies": {
|
|
123
123
|
"@babel/runtime": "^7.17.0",
|
|
124
|
-
"@data-client/normalizr": "^0.14.
|
|
124
|
+
"@data-client/normalizr": "^0.14.16",
|
|
125
125
|
"flux-standard-action": "^2.1.1"
|
|
126
126
|
},
|
|
127
127
|
"devDependencies": {
|
package/src/actionTypes.ts
CHANGED
|
@@ -1,11 +1,23 @@
|
|
|
1
|
-
export const
|
|
2
|
-
export const
|
|
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
|
|
1
|
+
export const FETCH = 'rdc/fetch' as const;
|
|
2
|
+
export const SET = 'rdc/set' as const;
|
|
3
|
+
export const SET_RESPONSE = 'rdc/setresponse' as const;
|
|
4
|
+
export const OPTIMISTIC = 'rdc/optimistic' as const;
|
|
5
|
+
export const RESET = 'rdc/reset' as const;
|
|
6
|
+
export const SUBSCRIBE = 'rdc/subscribe' as const;
|
|
7
|
+
export const UNSUBSCRIBE = 'rdc/unsubscribe' as const;
|
|
8
|
+
export const INVALIDATE = 'rdc/invalidate' as const;
|
|
9
|
+
export const INVALIDATEALL = 'rdc/invalidateall' as const;
|
|
10
|
+
export const EXPIREALL = 'rdc/expireall' as const;
|
|
11
|
+
export const GC = 'rdc/gc' as const;
|
|
12
|
+
|
|
13
|
+
export const FETCH_TYPE = FETCH;
|
|
14
|
+
export const SET_TYPE = SET;
|
|
15
|
+
export const SET_RESPONSE_TYPE = SET_RESPONSE;
|
|
16
|
+
export const OPTIMISTIC_TYPE = OPTIMISTIC;
|
|
17
|
+
export const RESET_TYPE = RESET;
|
|
18
|
+
export const SUBSCRIBE_TYPE = SUBSCRIBE;
|
|
19
|
+
export const UNSUBSCRIBE_TYPE = UNSUBSCRIBE;
|
|
20
|
+
export const INVALIDATE_TYPE = INVALIDATE;
|
|
21
|
+
export const INVALIDATEALL_TYPE = INVALIDATEALL;
|
|
22
|
+
export const EXPIREALL_TYPE = EXPIREALL;
|
|
23
|
+
export const GC_TYPE = GC;
|
package/src/actions.ts
CHANGED
|
@@ -7,17 +7,17 @@ import type {
|
|
|
7
7
|
} from '@data-client/normalizr';
|
|
8
8
|
|
|
9
9
|
import type {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
10
|
+
SET,
|
|
11
|
+
RESET,
|
|
12
|
+
FETCH,
|
|
13
|
+
SUBSCRIBE,
|
|
14
|
+
UNSUBSCRIBE,
|
|
15
|
+
INVALIDATE,
|
|
16
|
+
GC,
|
|
17
|
+
OPTIMISTIC,
|
|
18
|
+
INVALIDATEALL,
|
|
19
|
+
EXPIREALL,
|
|
20
|
+
SET_RESPONSE,
|
|
21
21
|
} from './actionTypes.js';
|
|
22
22
|
import type { EndpointUpdateFunction } from './controller/types.js';
|
|
23
23
|
|
|
@@ -37,7 +37,7 @@ export interface ActionMeta {
|
|
|
37
37
|
|
|
38
38
|
/** Action for Controller.set() */
|
|
39
39
|
export interface SetAction<S extends Queryable = any> {
|
|
40
|
-
type: typeof
|
|
40
|
+
type: typeof SET;
|
|
41
41
|
schema: S;
|
|
42
42
|
args: readonly any[];
|
|
43
43
|
meta: ActionMeta;
|
|
@@ -48,7 +48,7 @@ export interface SetAction<S extends Queryable = any> {
|
|
|
48
48
|
export interface SetResponseActionBase<
|
|
49
49
|
E extends EndpointAndUpdate<E> = EndpointDefault,
|
|
50
50
|
> {
|
|
51
|
-
type: typeof
|
|
51
|
+
type: typeof SET_RESPONSE;
|
|
52
52
|
endpoint: E;
|
|
53
53
|
args: readonly any[];
|
|
54
54
|
key: string;
|
|
@@ -81,7 +81,7 @@ export interface FetchMeta {
|
|
|
81
81
|
|
|
82
82
|
/** Action for Controller.fetch() */
|
|
83
83
|
export interface FetchAction<E extends EndpointAndUpdate<E> = EndpointDefault> {
|
|
84
|
-
type: typeof
|
|
84
|
+
type: typeof FETCH;
|
|
85
85
|
endpoint: E;
|
|
86
86
|
args: readonly [...Parameters<E>];
|
|
87
87
|
key: string;
|
|
@@ -93,7 +93,7 @@ export interface FetchAction<E extends EndpointAndUpdate<E> = EndpointDefault> {
|
|
|
93
93
|
export interface OptimisticAction<
|
|
94
94
|
E extends EndpointAndUpdate<E> = EndpointDefault,
|
|
95
95
|
> {
|
|
96
|
-
type: typeof
|
|
96
|
+
type: typeof OPTIMISTIC;
|
|
97
97
|
endpoint: E;
|
|
98
98
|
args: readonly any[];
|
|
99
99
|
key: string;
|
|
@@ -106,7 +106,7 @@ export interface OptimisticAction<
|
|
|
106
106
|
export interface SubscribeAction<
|
|
107
107
|
E extends EndpointAndUpdate<E> = EndpointDefault,
|
|
108
108
|
> {
|
|
109
|
-
type: typeof
|
|
109
|
+
type: typeof SUBSCRIBE;
|
|
110
110
|
endpoint: E;
|
|
111
111
|
args: readonly any[];
|
|
112
112
|
key: string;
|
|
@@ -116,7 +116,7 @@ export interface SubscribeAction<
|
|
|
116
116
|
export interface UnsubscribeAction<
|
|
117
117
|
E extends EndpointAndUpdate<E> = EndpointDefault,
|
|
118
118
|
> {
|
|
119
|
-
type: typeof
|
|
119
|
+
type: typeof UNSUBSCRIBE;
|
|
120
120
|
endpoint: E;
|
|
121
121
|
args: readonly any[];
|
|
122
122
|
key: string;
|
|
@@ -124,30 +124,30 @@ export interface UnsubscribeAction<
|
|
|
124
124
|
|
|
125
125
|
/* EXPIRY */
|
|
126
126
|
export interface ExpireAllAction {
|
|
127
|
-
type: typeof
|
|
127
|
+
type: typeof EXPIREALL;
|
|
128
128
|
testKey: (key: string) => boolean;
|
|
129
129
|
}
|
|
130
130
|
|
|
131
131
|
/* INVALIDATE */
|
|
132
132
|
export interface InvalidateAllAction {
|
|
133
|
-
type: typeof
|
|
133
|
+
type: typeof INVALIDATEALL;
|
|
134
134
|
testKey: (key: string) => boolean;
|
|
135
135
|
}
|
|
136
136
|
|
|
137
137
|
export interface InvalidateAction {
|
|
138
|
-
type: typeof
|
|
138
|
+
type: typeof INVALIDATE;
|
|
139
139
|
key: string;
|
|
140
140
|
}
|
|
141
141
|
|
|
142
142
|
/* RESET */
|
|
143
143
|
export interface ResetAction {
|
|
144
|
-
type: typeof
|
|
144
|
+
type: typeof RESET;
|
|
145
145
|
date: number;
|
|
146
146
|
}
|
|
147
147
|
|
|
148
148
|
/* GC */
|
|
149
149
|
export interface GCAction {
|
|
150
|
-
type: typeof
|
|
150
|
+
type: typeof GC;
|
|
151
151
|
entities: [string, string][];
|
|
152
152
|
endpoints: string[];
|
|
153
153
|
}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { EXPIREALL } from '../../actionTypes.js';
|
|
2
2
|
import type { ExpireAllAction } from '../../types.js';
|
|
3
3
|
|
|
4
4
|
export function createExpireAll(
|
|
5
5
|
testKey: (key: string) => boolean,
|
|
6
6
|
): ExpireAllAction {
|
|
7
7
|
return {
|
|
8
|
-
type:
|
|
8
|
+
type: EXPIREALL,
|
|
9
9
|
testKey,
|
|
10
10
|
};
|
|
11
11
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { EndpointInterface, NI } from '@data-client/normalizr';
|
|
2
2
|
|
|
3
|
-
import {
|
|
3
|
+
import { FETCH } from '../../actionTypes.js';
|
|
4
4
|
import type { FetchAction, FetchMeta } from '../../types.js';
|
|
5
5
|
import { EndpointUpdateFunction } from '../types.js';
|
|
6
6
|
|
|
@@ -26,7 +26,7 @@ export function createFetch<
|
|
|
26
26
|
};
|
|
27
27
|
|
|
28
28
|
return {
|
|
29
|
-
type:
|
|
29
|
+
type: FETCH,
|
|
30
30
|
key: endpoint.key(...args),
|
|
31
31
|
args,
|
|
32
32
|
endpoint,
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { EndpointInterface } from '@data-client/normalizr';
|
|
2
2
|
|
|
3
|
-
import {
|
|
3
|
+
import { INVALIDATE } from '../../actionTypes.js';
|
|
4
4
|
import type { InvalidateAction } from '../../types.js';
|
|
5
5
|
|
|
6
6
|
export function createInvalidate<E extends EndpointInterface>(
|
|
@@ -8,7 +8,7 @@ export function createInvalidate<E extends EndpointInterface>(
|
|
|
8
8
|
{ args }: { args: readonly [...Parameters<E>] },
|
|
9
9
|
): InvalidateAction {
|
|
10
10
|
return {
|
|
11
|
-
type:
|
|
11
|
+
type: INVALIDATE,
|
|
12
12
|
key: endpoint.key(...args),
|
|
13
13
|
};
|
|
14
14
|
}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { INVALIDATEALL } from '../../actionTypes.js';
|
|
2
2
|
import type { InvalidateAllAction } from '../../types.js';
|
|
3
3
|
|
|
4
4
|
export function createInvalidateAll(
|
|
5
5
|
testKey: (key: string) => boolean,
|
|
6
6
|
): InvalidateAllAction {
|
|
7
7
|
return {
|
|
8
|
-
type:
|
|
8
|
+
type: INVALIDATEALL,
|
|
9
9
|
testKey,
|
|
10
10
|
};
|
|
11
11
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { EndpointInterface } from '@data-client/normalizr';
|
|
2
2
|
|
|
3
3
|
import { createMeta } from './createMeta.js';
|
|
4
|
-
import {
|
|
4
|
+
import { OPTIMISTIC } from '../../actionTypes.js';
|
|
5
5
|
import type { OptimisticAction } from '../../types.js';
|
|
6
6
|
import type { EndpointUpdateFunction } from '../types.js';
|
|
7
7
|
|
|
@@ -23,7 +23,7 @@ export function createOptimistic<
|
|
|
23
23
|
}
|
|
24
24
|
|
|
25
25
|
return {
|
|
26
|
-
type:
|
|
26
|
+
type: OPTIMISTIC,
|
|
27
27
|
key: endpoint.key(...args),
|
|
28
28
|
args,
|
|
29
29
|
endpoint,
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { RESET } from '../../actionTypes.js';
|
|
2
2
|
import type { ResetAction } from '../../types.js';
|
|
3
3
|
|
|
4
4
|
export function createReset(): ResetAction {
|
|
5
5
|
return {
|
|
6
|
-
type:
|
|
6
|
+
type: RESET,
|
|
7
7
|
date: Date.now(),
|
|
8
8
|
};
|
|
9
9
|
}
|
|
@@ -5,7 +5,7 @@ import type {
|
|
|
5
5
|
} from '@data-client/normalizr';
|
|
6
6
|
|
|
7
7
|
import { createMeta } from './createMeta.js';
|
|
8
|
-
import {
|
|
8
|
+
import { SET } from '../../actionTypes.js';
|
|
9
9
|
import type { SetAction } from '../../types.js';
|
|
10
10
|
import ensurePojo from '../ensurePojo.js';
|
|
11
11
|
|
|
@@ -22,7 +22,7 @@ export function createSet<S extends Queryable>(
|
|
|
22
22
|
},
|
|
23
23
|
): SetAction<S> {
|
|
24
24
|
return {
|
|
25
|
-
type:
|
|
25
|
+
type: SET,
|
|
26
26
|
value,
|
|
27
27
|
args: args.map(ensurePojo) as SchemaArgs<S>,
|
|
28
28
|
schema,
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { EndpointInterface, ResolveType } from '@data-client/normalizr';
|
|
2
2
|
|
|
3
3
|
import { createMeta } from './createMeta.js';
|
|
4
|
-
import {
|
|
4
|
+
import { SET_RESPONSE } from '../../actionTypes.js';
|
|
5
5
|
import type { SetResponseAction } from '../../types.js';
|
|
6
6
|
import ensurePojo from '../ensurePojo.js';
|
|
7
7
|
import { EndpointUpdateFunction } from '../types.js';
|
|
@@ -62,7 +62,7 @@ export function createSetResponse<
|
|
|
62
62
|
}
|
|
63
63
|
|
|
64
64
|
return {
|
|
65
|
-
type:
|
|
65
|
+
type: SET_RESPONSE,
|
|
66
66
|
key: endpoint.key(...args),
|
|
67
67
|
response,
|
|
68
68
|
args: args.map(ensurePojo),
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { EndpointInterface } from '@data-client/normalizr';
|
|
2
2
|
|
|
3
|
-
import {
|
|
3
|
+
import { SUBSCRIBE, UNSUBSCRIBE } from '../../actionTypes.js';
|
|
4
4
|
import type { SubscribeAction, UnsubscribeAction } from '../../types.js';
|
|
5
5
|
|
|
6
6
|
export function createSubscription<E extends EndpointInterface>(
|
|
@@ -8,7 +8,7 @@ export function createSubscription<E extends EndpointInterface>(
|
|
|
8
8
|
{ args }: { args: readonly [...Parameters<E>] },
|
|
9
9
|
): SubscribeAction<E> {
|
|
10
10
|
return {
|
|
11
|
-
type:
|
|
11
|
+
type: SUBSCRIBE,
|
|
12
12
|
endpoint,
|
|
13
13
|
args,
|
|
14
14
|
key: endpoint.key(...args),
|
|
@@ -20,7 +20,7 @@ export function createUnsubscription<E extends EndpointInterface>(
|
|
|
20
20
|
{ args }: { args: readonly [...Parameters<E>] },
|
|
21
21
|
): UnsubscribeAction<E> {
|
|
22
22
|
return {
|
|
23
|
-
type:
|
|
23
|
+
type: UNSUBSCRIBE,
|
|
24
24
|
key: endpoint.key(...args),
|
|
25
25
|
args,
|
|
26
26
|
endpoint,
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { SET_RESPONSE } from '../actionTypes.js';
|
|
2
2
|
import type Controller from '../controller/Controller.js';
|
|
3
3
|
import { UnknownError } from '../index.js';
|
|
4
4
|
import type { Manager, Middleware } from '../types.js';
|
|
@@ -16,7 +16,7 @@ export default class LogoutManager implements Manager {
|
|
|
16
16
|
middleware: Middleware = controller => next => async action => {
|
|
17
17
|
await next(action);
|
|
18
18
|
if (
|
|
19
|
-
action.type ===
|
|
19
|
+
action.type === SET_RESPONSE &&
|
|
20
20
|
action.error &&
|
|
21
21
|
this.shouldLogout(action.response)
|
|
22
22
|
) {
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { SET_RESPONSE, FETCH, RESET } from '../actionTypes.js';
|
|
2
2
|
import { createSetResponse } from '../controller/actions/index.js';
|
|
3
3
|
import Controller from '../controller/Controller.js';
|
|
4
4
|
import type {
|
|
@@ -46,7 +46,7 @@ export default class NetworkManager implements Manager {
|
|
|
46
46
|
this.controller = controller;
|
|
47
47
|
return next => action => {
|
|
48
48
|
switch (action.type) {
|
|
49
|
-
case
|
|
49
|
+
case FETCH:
|
|
50
50
|
this.handleFetch(action);
|
|
51
51
|
// This is the only case that causes any state change
|
|
52
52
|
// It's important to intercept other fetches as we don't want to trigger reducers during
|
|
@@ -58,7 +58,7 @@ export default class NetworkManager implements Manager {
|
|
|
58
58
|
return next(action);
|
|
59
59
|
}
|
|
60
60
|
return Promise.resolve();
|
|
61
|
-
case
|
|
61
|
+
case SET_RESPONSE:
|
|
62
62
|
// only set after new state is computed
|
|
63
63
|
return next(action).then(() => {
|
|
64
64
|
if (action.key in this.fetched) {
|
|
@@ -79,7 +79,7 @@ export default class NetworkManager implements Manager {
|
|
|
79
79
|
}
|
|
80
80
|
}
|
|
81
81
|
});
|
|
82
|
-
case
|
|
82
|
+
case RESET: {
|
|
83
83
|
const rejectors = { ...this.rejectors };
|
|
84
84
|
|
|
85
85
|
this.clearAll();
|
|
@@ -112,7 +112,7 @@ export default class NetworkManager implements Manager {
|
|
|
112
112
|
/** Used by DevtoolsManager to determine whether to log an action */
|
|
113
113
|
skipLogging(action: ActionTypes) {
|
|
114
114
|
/* istanbul ignore next */
|
|
115
|
-
return action.type ===
|
|
115
|
+
return action.type === FETCH && action.key in this.fetched;
|
|
116
116
|
}
|
|
117
117
|
|
|
118
118
|
allSettled() {
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { SUBSCRIBE, UNSUBSCRIBE } from '../actionTypes.js';
|
|
2
2
|
import Controller from '../controller/Controller.js';
|
|
3
3
|
import type {
|
|
4
4
|
Manager,
|
|
@@ -51,14 +51,14 @@ export default class SubscriptionManager<
|
|
|
51
51
|
this.controller = controller;
|
|
52
52
|
return next => action => {
|
|
53
53
|
switch (action.type) {
|
|
54
|
-
case
|
|
54
|
+
case SUBSCRIBE:
|
|
55
55
|
try {
|
|
56
56
|
this.handleSubscribe(action);
|
|
57
57
|
} catch (e) {
|
|
58
58
|
console.error(e);
|
|
59
59
|
}
|
|
60
60
|
return Promise.resolve();
|
|
61
|
-
case
|
|
61
|
+
case UNSUBSCRIBE:
|
|
62
62
|
this.handleUnsubscribe(action);
|
|
63
63
|
return Promise.resolve();
|
|
64
64
|
default:
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { CoolerArticleResource } from '__tests__/new';
|
|
2
2
|
|
|
3
3
|
import { Controller, initialState } from '../..';
|
|
4
|
-
import {
|
|
4
|
+
import { FETCH, RESET } from '../../actionTypes';
|
|
5
5
|
import { createSetResponse } from '../../controller/actions';
|
|
6
6
|
import LogoutManager from '../LogoutManager.js';
|
|
7
7
|
|
|
@@ -73,7 +73,7 @@ describe('LogoutManager', () => {
|
|
|
73
73
|
await manager.middleware(API)(next)(action);
|
|
74
74
|
|
|
75
75
|
expect(dispatch.mock.calls.length).toBe(1);
|
|
76
|
-
expect(dispatch.mock.calls[0][0]?.type).toBe(
|
|
76
|
+
expect(dispatch.mock.calls[0][0]?.type).toBe(RESET);
|
|
77
77
|
});
|
|
78
78
|
|
|
79
79
|
it('should call custom handleLogout', async () => {
|
|
@@ -97,7 +97,7 @@ describe('LogoutManager', () => {
|
|
|
97
97
|
});
|
|
98
98
|
|
|
99
99
|
it('should let other actions pass through', async () => {
|
|
100
|
-
const action = { type:
|
|
100
|
+
const action = { type: FETCH };
|
|
101
101
|
next.mockReset();
|
|
102
102
|
|
|
103
103
|
await manager.middleware(API)(next)(action as any);
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Endpoint } from '@data-client/endpoint';
|
|
2
2
|
import { Article, ArticleResource } from '__tests__/new';
|
|
3
3
|
|
|
4
|
-
import {
|
|
4
|
+
import { SET_RESPONSE } from '../../actionTypes';
|
|
5
5
|
import { createFetch } from '../../controller/actions';
|
|
6
6
|
import Controller from '../../controller/Controller';
|
|
7
7
|
import NetworkManager from '../../manager/NetworkManager';
|
|
@@ -159,7 +159,7 @@ describe('NetworkManager', () => {
|
|
|
159
159
|
await new Promise(resolve => setTimeout(resolve, 0));
|
|
160
160
|
|
|
161
161
|
const action: SetResponseAction = {
|
|
162
|
-
type:
|
|
162
|
+
type: SET_RESPONSE,
|
|
163
163
|
endpoint: fetchResolveAction.endpoint,
|
|
164
164
|
response,
|
|
165
165
|
args: fetchResolveAction.args,
|
|
@@ -195,7 +195,7 @@ describe('NetworkManager', () => {
|
|
|
195
195
|
await new Promise(resolve => setTimeout(resolve, 0));
|
|
196
196
|
|
|
197
197
|
const action: SetResponseAction = {
|
|
198
|
-
type:
|
|
198
|
+
type: SET_RESPONSE,
|
|
199
199
|
endpoint: fetchSetWithUpdatersAction.endpoint,
|
|
200
200
|
response,
|
|
201
201
|
args: fetchSetWithUpdatersAction.args,
|
|
@@ -231,7 +231,7 @@ describe('NetworkManager', () => {
|
|
|
231
231
|
await new Promise(resolve => setTimeout(resolve, 0));
|
|
232
232
|
|
|
233
233
|
const action: SetResponseAction = {
|
|
234
|
-
type:
|
|
234
|
+
type: SET_RESPONSE,
|
|
235
235
|
endpoint: fetchRpcWithUpdatersAction.endpoint,
|
|
236
236
|
response,
|
|
237
237
|
args: fetchRpcWithUpdatersAction.args,
|
|
@@ -267,7 +267,7 @@ describe('NetworkManager', () => {
|
|
|
267
267
|
// mutations resolve before dispatch, so we must wait for next tick to see set
|
|
268
268
|
await new Promise(resolve => setTimeout(resolve, 0));
|
|
269
269
|
expect(dispatch).toHaveBeenCalledWith({
|
|
270
|
-
type:
|
|
270
|
+
type: SET_RESPONSE,
|
|
271
271
|
endpoint: fetchRpcWithUpdatersAndOptimisticAction.endpoint,
|
|
272
272
|
response,
|
|
273
273
|
args: fetchRpcWithUpdatersAndOptimisticAction.args,
|
|
@@ -338,7 +338,7 @@ describe('NetworkManager', () => {
|
|
|
338
338
|
} catch (error) {
|
|
339
339
|
expect(next).not.toHaveBeenCalled();
|
|
340
340
|
expect(dispatch).toHaveBeenCalledWith({
|
|
341
|
-
type:
|
|
341
|
+
type: SET_RESPONSE,
|
|
342
342
|
response: error,
|
|
343
343
|
key: fetchRejectAction.key,
|
|
344
344
|
meta: {
|
|
@@ -4,7 +4,7 @@ import { actionTypes, Controller, initialState } from '../..';
|
|
|
4
4
|
import { SubscribeAction, UnsubscribeAction } from '../../types';
|
|
5
5
|
import SubscriptionManager, { Subscription } from '../SubscriptionManager.js';
|
|
6
6
|
|
|
7
|
-
const {
|
|
7
|
+
const { UNSUBSCRIBE, SUBSCRIBE, SET_RESPONSE } = actionTypes;
|
|
8
8
|
|
|
9
9
|
function onError(e: any) {
|
|
10
10
|
e.preventDefault();
|
|
@@ -55,7 +55,7 @@ describe('SubscriptionManager', () => {
|
|
|
55
55
|
() => Promise.reject(new Error('Failed'))
|
|
56
56
|
: () => Promise.resolve(response);
|
|
57
57
|
return {
|
|
58
|
-
type:
|
|
58
|
+
type: SUBSCRIBE,
|
|
59
59
|
endpoint: PollingArticleResource.get.extend({ fetch }),
|
|
60
60
|
args: [{ id: response.id }],
|
|
61
61
|
key: PollingArticleResource.get.key({ id: response.id }),
|
|
@@ -65,7 +65,7 @@ describe('SubscriptionManager', () => {
|
|
|
65
65
|
response: Record<string, any>,
|
|
66
66
|
): UnsubscribeAction {
|
|
67
67
|
return {
|
|
68
|
-
type:
|
|
68
|
+
type: UNSUBSCRIBE,
|
|
69
69
|
endpoint: PollingArticleResource.get,
|
|
70
70
|
key: PollingArticleResource.get.key({ id: response.id }),
|
|
71
71
|
args: [{ id: response.id }],
|
|
@@ -185,7 +185,7 @@ describe('SubscriptionManager', () => {
|
|
|
185
185
|
});
|
|
186
186
|
|
|
187
187
|
it('should let other actions pass through', () => {
|
|
188
|
-
const action = { type:
|
|
188
|
+
const action = { type: SET_RESPONSE };
|
|
189
189
|
next.mockReset();
|
|
190
190
|
|
|
191
191
|
manager.middleware(API)(next)(action as any);
|