@data-client/core 0.12.3 → 0.13.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (92) hide show
  1. package/README.md +1 -1
  2. package/dist/index.js +89 -15
  3. package/dist/index.umd.min.js +1 -1
  4. package/legacy/actionTypes.js +2 -1
  5. package/legacy/actions.js +1 -1
  6. package/legacy/controller/Controller.js +21 -7
  7. package/legacy/controller/createSet.js +7 -11
  8. package/legacy/controller/createSetResponse.js +32 -0
  9. package/legacy/index.js +2 -1
  10. package/legacy/manager/DevtoolsManager.js +5 -5
  11. package/legacy/manager/LogoutManager.js +3 -3
  12. package/legacy/manager/NetworkManager.js +5 -5
  13. package/legacy/manager/PollingSubscription.js +1 -1
  14. package/legacy/manager/SubscriptionManager.js +1 -1
  15. package/legacy/next/index.js +1 -1
  16. package/legacy/state/reducer/createReducer.js +6 -3
  17. package/legacy/state/reducer/fetchReducer.js +1 -1
  18. package/legacy/state/reducer/setReducer.js +7 -85
  19. package/legacy/state/reducer/setResponseReducer.js +107 -0
  20. package/legacy/types.js +1 -1
  21. package/lib/actionTypes.d.ts +1 -0
  22. package/lib/actionTypes.d.ts.map +1 -1
  23. package/lib/actionTypes.js +2 -1
  24. package/lib/actions.d.ts +23 -11
  25. package/lib/actions.d.ts.map +1 -1
  26. package/lib/actions.js +1 -1
  27. package/lib/controller/Controller.d.ts +7 -2
  28. package/lib/controller/Controller.d.ts.map +1 -1
  29. package/lib/controller/Controller.js +21 -7
  30. package/lib/controller/createSet.d.ts +5 -17
  31. package/lib/controller/createSet.d.ts.map +1 -1
  32. package/lib/controller/createSet.js +7 -11
  33. package/lib/controller/createSetResponse.d.ts +20 -0
  34. package/lib/controller/createSetResponse.d.ts.map +1 -0
  35. package/lib/controller/createSetResponse.js +32 -0
  36. package/lib/index.d.ts +1 -0
  37. package/lib/index.d.ts.map +1 -1
  38. package/lib/index.js +2 -1
  39. package/lib/manager/DevtoolsManager.d.ts.map +1 -1
  40. package/lib/manager/DevtoolsManager.js +5 -3
  41. package/lib/manager/LogoutManager.js +3 -3
  42. package/lib/manager/NetworkManager.d.ts +2 -2
  43. package/lib/manager/NetworkManager.d.ts.map +1 -1
  44. package/lib/manager/NetworkManager.js +5 -5
  45. package/lib/manager/PollingSubscription.js +1 -1
  46. package/lib/manager/SubscriptionManager.js +1 -1
  47. package/lib/next/index.js +1 -1
  48. package/lib/state/reducer/createReducer.d.ts.map +1 -1
  49. package/lib/state/reducer/createReducer.js +6 -3
  50. package/lib/state/reducer/expireReducer.d.ts +1 -1
  51. package/lib/state/reducer/fetchReducer.js +1 -1
  52. package/lib/state/reducer/invalidateReducer.d.ts +1 -1
  53. package/lib/state/reducer/setReducer.d.ts +2 -3
  54. package/lib/state/reducer/setReducer.d.ts.map +1 -1
  55. package/lib/state/reducer/setReducer.js +7 -90
  56. package/lib/state/reducer/setResponseReducer.d.ts +4 -0
  57. package/lib/state/reducer/setResponseReducer.d.ts.map +1 -0
  58. package/lib/state/reducer/setResponseReducer.js +112 -0
  59. package/lib/types.d.ts +2 -4
  60. package/lib/types.d.ts.map +1 -1
  61. package/lib/types.js +1 -1
  62. package/package.json +1 -1
  63. package/src/actionTypes.ts +1 -0
  64. package/src/actions.ts +29 -10
  65. package/src/controller/Controller.ts +25 -8
  66. package/src/controller/createSet.ts +11 -51
  67. package/src/controller/createSetResponse.ts +79 -0
  68. package/src/index.ts +1 -0
  69. package/src/manager/DevtoolsManager.ts +4 -2
  70. package/src/manager/LogoutManager.ts +2 -2
  71. package/src/manager/NetworkManager.ts +6 -6
  72. package/src/manager/__tests__/logoutManager.ts +5 -5
  73. package/src/manager/__tests__/networkManager.ts +6 -6
  74. package/src/manager/__tests__/subscriptionManager.ts +2 -2
  75. package/src/state/__tests__/reducer.ts +64 -25
  76. package/src/state/reducer/createReducer.ts +6 -1
  77. package/src/state/reducer/fetchReducer.ts +2 -2
  78. package/src/state/reducer/setReducer.ts +9 -121
  79. package/src/state/reducer/setResponseReducer.ts +151 -0
  80. package/src/types.ts +6 -5
  81. package/ts3.4/actionTypes.d.ts +1 -0
  82. package/ts3.4/actions.d.ts +23 -11
  83. package/ts3.4/controller/Controller.d.ts +10 -2
  84. package/ts3.4/controller/createSet.d.ts +5 -19
  85. package/ts3.4/controller/createSetResponse.d.ts +24 -0
  86. package/ts3.4/index.d.ts +1 -0
  87. package/ts3.4/manager/NetworkManager.d.ts +2 -2
  88. package/ts3.4/state/reducer/expireReducer.d.ts +1 -1
  89. package/ts3.4/state/reducer/invalidateReducer.d.ts +1 -1
  90. package/ts3.4/state/reducer/setReducer.d.ts +2 -3
  91. package/ts3.4/state/reducer/setResponseReducer.d.ts +4 -0
  92. package/ts3.4/types.d.ts +2 -4
package/README.md CHANGED
@@ -21,7 +21,7 @@ automatic expiry policies, data normalization. Consumes [TypeScript Standard End
21
21
  ### Framework Implementations
22
22
 
23
23
  - [React](https://www.npmjs.com/package/@data-client/react)
24
- - [React-Redux](https://www.npmjs.com/package/@data-client/redux)
24
+ - [React-Redux](https://dataclient.io/docs/guides/redux)
25
25
 
26
26
  ### Sample React Hook suspense implementation
27
27
 
package/dist/index.js CHANGED
@@ -28,6 +28,7 @@ function expireReducer(state, action) {
28
28
 
29
29
  const FETCH_TYPE = 'rdc/fetch';
30
30
  const SET_TYPE = 'rdc/set';
31
+ const SET_RESPONSE_TYPE = 'rdc/setresponse';
31
32
  const OPTIMISTIC_TYPE = 'rdc/optimistic';
32
33
  const RESET_TYPE = 'rdc/reset';
33
34
  const SUBSCRIBE_TYPE = 'rdc/subscribe';
@@ -41,6 +42,7 @@ var actionTypes = /*#__PURE__*/Object.freeze({
41
42
  __proto__: null,
42
43
  FETCH_TYPE: FETCH_TYPE,
43
44
  SET_TYPE: SET_TYPE,
45
+ SET_RESPONSE_TYPE: SET_RESPONSE_TYPE,
44
46
  OPTIMISTIC_TYPE: OPTIMISTIC_TYPE,
45
47
  RESET_TYPE: RESET_TYPE,
46
48
  SUBSCRIBE_TYPE: SUBSCRIBE_TYPE,
@@ -132,9 +134,36 @@ function invalidateReducer(state, action) {
132
134
  };
133
135
  }
134
136
 
137
+ function setReducer(state, action) {
138
+ try {
139
+ const {
140
+ entities,
141
+ indexes,
142
+ entityMeta
143
+ } = normalizr.normalize(action.value, action.schema, action.meta.args, state.entities, state.indexes, state.entityMeta, action.meta);
144
+ return {
145
+ entities,
146
+ indexes,
147
+ endpoints: state.endpoints,
148
+ entityMeta,
149
+ meta: state.meta,
150
+ optimistic: state.optimistic,
151
+ lastReset: state.lastReset
152
+ };
153
+ // reducer must update the state, so in case of processing errors we simply compute the endpoints inline
154
+ } catch (error) {
155
+ // this is not always bubbled up, so let's double sure this doesn't fail silently
156
+ /* istanbul ignore else */
157
+ if (process.env.NODE_ENV !== 'production') {
158
+ console.error(error);
159
+ }
160
+ return state;
161
+ }
162
+ }
163
+
135
164
  class AbortOptimistic extends Error {}
136
165
 
137
- function setReducer(state, action, controller) {
166
+ function setResponseReducer(state, action, controller) {
138
167
  if (action.error) {
139
168
  return reduceError(state, action, action.payload);
140
169
  }
@@ -144,6 +173,7 @@ function setReducer(state, action, controller) {
144
173
  // for true set's payload is contained in action
145
174
  if (action.type === OPTIMISTIC_TYPE) {
146
175
  // this should never happen
176
+ /* istanbul ignore if */
147
177
  if (!action.endpoint.getOptimisticResponse) return state;
148
178
  try {
149
179
  // compute optimistic response based on current state
@@ -262,8 +292,10 @@ function createReducer(controller) {
262
292
  return fetchReducer(state, action);
263
293
  case OPTIMISTIC_TYPE:
264
294
  // eslint-disable-next-line no-fallthrough
295
+ case SET_RESPONSE_TYPE:
296
+ return setResponseReducer(state, action, controller);
265
297
  case SET_TYPE:
266
- return setReducer(state, action, controller);
298
+ return setReducer(state, action);
267
299
  case INVALIDATEALL_TYPE:
268
300
  case INVALIDATE_TYPE:
269
301
  return invalidateReducer(state, action);
@@ -367,7 +399,33 @@ const ensurePojo =
367
399
  typeof FormData !== 'undefined' ? body => body instanceof FormData ? Object.fromEntries(body.entries()) : body : /* istanbul ignore next */body => body;
368
400
  var ensurePojo$1 = ensurePojo;
369
401
 
370
- function createSet(endpoint, {
402
+ function createSet(schema, {
403
+ args,
404
+ fetchedAt,
405
+ value
406
+ }) {
407
+ const expiryLength = 60000;
408
+ /* istanbul ignore next */
409
+ if (process.env.NODE_ENV === 'development' && expiryLength < 0) {
410
+ throw new Error('Negative expiry length are not allowed.');
411
+ }
412
+ const now = Date.now();
413
+ const meta = {
414
+ args: args.map(ensurePojo$1),
415
+ fetchedAt: fetchedAt != null ? fetchedAt : now,
416
+ date: now,
417
+ expiresAt: now + expiryLength
418
+ };
419
+ const action = {
420
+ type: SET_TYPE,
421
+ value,
422
+ schema,
423
+ meta
424
+ };
425
+ return action;
426
+ }
427
+
428
+ function createSetResponse(endpoint, {
371
429
  args,
372
430
  fetchedAt,
373
431
  response,
@@ -388,7 +446,7 @@ function createSet(endpoint, {
388
446
  key: endpoint.key(...args)
389
447
  };
390
448
  const action = {
391
- type: SET_TYPE,
449
+ type: SET_RESPONSE_TYPE,
392
450
  payload: response,
393
451
  endpoint: endpoint,
394
452
  meta
@@ -430,7 +488,7 @@ const unsetDispatch = action => {
430
488
  throw new Error(`Dispatching while constructing your middleware is not allowed. ` + `Other middleware would not be applied to this dispatch.`);
431
489
  };
432
490
  const unsetState = () => {
433
- // This is only the value until it is set by the CacheProvider
491
+ // This is only the value until it is set by the DataProvider
434
492
  /* istanbul ignore next */
435
493
  return initialState;
436
494
  };
@@ -516,24 +574,37 @@ class Controller {
516
574
  */
517
575
  this.resetEntireStore = () => this.dispatch(createReset());
518
576
  /**
519
- * Stores response in cache for given Endpoint and args.
577
+ * Sets value for the Queryable and args.
520
578
  * @see https://dataclient.io/docs/api/Controller#set
521
579
  */
580
+ this.set = (schema, ...rest) => {
581
+ const value = rest[rest.length - 1];
582
+ const action = createSet(schema, {
583
+ args: rest.slice(0, rest.length - 1),
584
+ value
585
+ });
586
+ // TODO: reject with error if this fails in reducer
587
+ return this.dispatch(action);
588
+ };
589
+ /**
590
+ * Sets response for the Endpoint and args.
591
+ * @see https://dataclient.io/docs/api/Controller#setResponse
592
+ */
522
593
  this.setResponse = (endpoint, ...rest) => {
523
594
  const response = rest[rest.length - 1];
524
- const action = createSet(endpoint, {
595
+ const action = createSetResponse(endpoint, {
525
596
  args: rest.slice(0, rest.length - 1),
526
597
  response
527
598
  });
528
599
  return this.dispatch(action);
529
600
  };
530
601
  /**
531
- * Stores the result of Endpoint and args as the error provided.
602
+ * Sets an error response for the Endpoint and args.
532
603
  * @see https://dataclient.io/docs/api/Controller#setError
533
604
  */
534
605
  this.setError = (endpoint, ...rest) => {
535
606
  const response = rest[rest.length - 1];
536
- const action = createSet(endpoint, {
607
+ const action = createSetResponse(endpoint, {
537
608
  args: rest.slice(0, rest.length - 1),
538
609
  response,
539
610
  error: true
@@ -545,7 +616,7 @@ class Controller {
545
616
  * @see https://dataclient.io/docs/api/Controller#resolve
546
617
  */
547
618
  this.resolve = (endpoint, meta) => {
548
- return this.dispatch(createSet(endpoint, meta));
619
+ return this.dispatch(createSetResponse(endpoint, meta));
549
620
  };
550
621
  /**
551
622
  * Marks a new subscription to a given Endpoint.
@@ -785,7 +856,7 @@ class NetworkManager {
785
856
  return next(action);
786
857
  }
787
858
  return Promise.resolve();
788
- case SET_TYPE:
859
+ case SET_RESPONSE_TYPE:
789
860
  // only set after new state is computed
790
861
  return next(action).then(() => {
791
862
  if (action.meta.key in this.fetched) {
@@ -794,7 +865,7 @@ class NetworkManager {
794
865
  const error = (_controller$getState$ = controller.getState().meta[action.meta.key]) == null ? void 0 : _controller$getState$.error;
795
866
  // processing errors result in state meta having error, so we should reject the promise
796
867
  if (error) {
797
- this.handleSet(createSet(action.endpoint, {
868
+ this.handleSet(createSetResponse(action.endpoint, {
798
869
  args: action.meta.args,
799
870
  response: error,
800
871
  fetchedAt: action.meta.fetchedAt,
@@ -1359,8 +1430,10 @@ class DevToolsManager {
1359
1430
  /* istanbul ignore next */
1360
1431
  this.devTools = typeof window !== 'undefined' && window.__REDUX_DEVTOOLS_EXTENSION__ && window.__REDUX_DEVTOOLS_EXTENSION__.connect({
1361
1432
  ...DEFAULT_CONFIG,
1362
- config
1433
+ ...config
1363
1434
  });
1435
+ // we cut it in half so we should double so we don't lose
1436
+ if (config != null && config.maxAge) this.maxBufferLength = config.maxAge * 2;
1364
1437
  if (process.env.NODE_ENV !== 'production' && this.devTools) {
1365
1438
  this.devTools.subscribe(msg => {
1366
1439
  switch (msg.type) {
@@ -1413,7 +1486,7 @@ class DevToolsManager {
1413
1486
  }
1414
1487
  handleAction(action, state) {
1415
1488
  if (this.started) {
1416
- this.devTools.send(action, state, undefined, 'RDC');
1489
+ this.devTools.send(action, state);
1417
1490
  } else {
1418
1491
  // avoid this getting too big in case this is long running
1419
1492
  // we cut in half so we aren't constantly reallocating
@@ -1453,7 +1526,7 @@ class LogoutManager {
1453
1526
  if (shouldLogout) this.shouldLogout = shouldLogout;
1454
1527
  this.middleware = controller => next => async action => {
1455
1528
  await next(action);
1456
- if (action.type === SET_TYPE && action.error && this.shouldLogout(action.payload)) {
1529
+ if (action.type === SET_RESPONSE_TYPE && action.error && this.shouldLogout(action.payload)) {
1457
1530
  this.handleLogout(controller);
1458
1531
  }
1459
1532
  };
@@ -1495,4 +1568,5 @@ exports.applyManager = applyManager;
1495
1568
  exports.createFetch = createFetch;
1496
1569
  exports.createReducer = createReducer;
1497
1570
  exports.createSet = createSet;
1571
+ exports.createSetResponse = createSetResponse;
1498
1572
  exports.initialState = initialState;
@@ -1 +1 @@
1
- !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@data-client/normalizr")):"function"==typeof define&&define.amd?define(["exports","@data-client/normalizr"],t):t(((e="undefined"!=typeof globalThis?globalThis:e||self).RDC=e.RDC||{},e.RDC.Core={}),e.normalizr)}(this,(function(e,t){"use strict";var s="function"==typeof requestIdleCallback?requestIdleCallback:e=>e();const i="rdc/fetch",n="rdc/set",r="rdc/optimistic",a="rdc/reset",o="rdc/subscribe",c="rdc/unsubscribe",l="rdc/invalidate",h="rdc/invalidateall",d="rdc/expireall",u="rdc/gc";var p=Object.freeze({__proto__:null,FETCH_TYPE:i,SET_TYPE:n,OPTIMISTIC_TYPE:r,RESET_TYPE:a,SUBSCRIBE_TYPE:o,UNSUBSCRIBE_TYPE:c,INVALIDATE_TYPE:l,INVALIDATEALL_TYPE:h,EXPIREALL_TYPE:d,GC_TYPE:u});function f(e,t){let s;return t.endpoint.getOptimisticResponse&&t.endpoint.sideEffect?(s=function(e,{args:t,fetchedAt:s}){var i;const n=null!=(i=e.dataExpiryLength)?i:6e4,a=Date.now(),o={args:t,fetchedAt:s,date:a,expiresAt:a+n,key:e.key(...t)};return{type:r,endpoint:e,meta:o}}(t.endpoint,{args:t.meta.args,fetchedAt:t.meta.createdAt}),Object.assign({},e,{optimistic:[...e.optimistic,s]})):e}class m extends Error{}function y(e,t,s){return"AbortError"===s.name?Object.assign({},e,{optimistic:g(e,t)}):Object.assign({},e,{meta:Object.assign({},e.meta,{[t.meta.key]:{date:t.meta.date,error:s,expiresAt:t.meta.expiresAt,errorPolicy:null==t.endpoint.errorPolicy?void 0:t.endpoint.errorPolicy(s)}}),optimistic:g(e,t)})}function g(e,t){return e.optimistic.filter((e=>e.meta.key!==t.meta.key||(e.type===r?e.meta.fetchedAt!==t.meta.fetchedAt:e.meta.date>t.meta.date)))}function v(e){return function(s,o){switch(s||(s=E),o.type){case u:return o.entities.forEach((([e,t])=>{var i,n;null==(i=s.entities[e])||delete i[t],null==(n=s.entityMeta[e])||delete n[t]})),o.endpoints.forEach((e=>{delete s.endpoints[e],delete s.meta[e]})),s;case i:return f(s,o);case r:case n:return function(e,s,i){if(s.error)return y(e,s,s.payload);try{var n;let a;if(s.type===r){if(!s.endpoint.getOptimisticResponse)return e;try{a=s.endpoint.getOptimisticResponse.call(s.endpoint,i.snapshot(e,s.meta.fetchedAt),...s.meta.args)}catch(t){if(t.constructor===m)return e;throw t}}else a=s.payload;const{result:o,entities:c,indexes:l,entityMeta:h}=t.normalize(a,s.endpoint.schema,s.meta.args,e.entities,e.indexes,e.entityMeta,s.meta),d=Object.assign({},e.endpoints,{[s.meta.key]:o});try{if(s.endpoint.update){const e=s.endpoint.update(o,...s.meta.args);Object.keys(e).forEach((t=>{d[t]=e[t](d[t])}))}}catch(e){console.error(`The following error occured during Endpoint.update() for ${s.meta.key}`),console.error(e)}return{entities:c,indexes:l,endpoints:d,entityMeta:h,meta:Object.assign({},e.meta,{[s.meta.key]:{date:s.meta.date,expiresAt:s.meta.expiresAt,prevExpiresAt:null==(n=e.meta[s.meta.key])?void 0:n.expiresAt}}),optimistic:g(e,s),lastReset:e.lastReset}}catch(t){return"object"==typeof t&&(t.message=`Error processing ${s.meta.key}\n\nFull Schema: ${JSON.stringify(s.endpoint.schema,void 0,2)}\n\nError:\n${t.message}`,"payload"in s&&(t.payload=s.payload),t.status=400),y(e,s,t)}}(s,o,e);case h:case l:return function(e,t){const s=Object.assign({},e.endpoints),i=Object.assign({},e.meta),n=e=>{delete s[e];const t=Object.assign({},i[e],{expiresAt:0,invalidated:!0});delete t.error,i[e]=t};return t.type===l?n(t.meta.key):Object.keys(s).forEach((e=>{t.testKey(e)&&n(e)})),Object.assign({},e,{endpoints:s,meta:i})}(s,o);case d:return function(e,t){const s=Object.assign({},e.meta);return Object.keys(s).forEach((e=>{t.testKey(e)&&(s[e]=Object.assign({},s[e],{expiresAt:1}))})),Object.assign({},e,{meta:s})}(s,o);case a:return Object.assign({},E,{lastReset:o.date});default:return s}}}const E={entities:{},indexes:{},endpoints:{},meta:{},entityMeta:{},optimistic:[],lastReset:0};var b=Object.freeze({__proto__:null,MemoCache:t.MemoCache,INVALID:t.INVALID,RIC:s,initialState:E});function L(e,{args:t}){const s=e.key(...t);let n=0,r=0;const a=new Promise(((e,t)=>{[n,r]=[e,t]})),o={args:t,key:s,throttle:!e.sideEffect,resolve:n,reject:r,promise:a,createdAt:Date.now(),nm:!1};return{type:i,payload:()=>e(...t),meta:o,endpoint:e}}var O="undefined"!=typeof FormData?e=>e instanceof FormData?Object.fromEntries(e.entries()):e:e=>e;function I(e,{args:t,fetchedAt:s,response:i,error:r=!1}){var a,o;const c=r?null!=(a=e.errorExpiryLength)?a:1e3:null!=(o=e.dataExpiryLength)?o:6e4,l=Date.now(),h={args:t.map(O),fetchedAt:null!=s?s:l,date:l,expiresAt:l+c,key:e.key(...t)},d={type:n,payload:i,endpoint:e,meta:h};return r&&(d.error=!0),d}function S(e,t){return e.meta[t]}const w=e=>{throw new Error("Dispatching while constructing your middleware is not allowed. Other middleware would not be applied to this dispatch.")},A=()=>E;class x{constructor({dispatch:e=w,getState:s=A,memo:i=new t.MemoCache}={}){this.fetch=(e,...s)=>{const i=L(e,{args:s});return this.dispatch(i),e.schema?i.meta.promise.then((i=>t.denormalize(i,e.schema,{},s))):i.meta.promise},this.fetchIfStale=(e,...s)=>{const{data:i,expiresAt:n,expiryStatus:r}=this.getResponse(e,...s,this.getState());return r!==t.ExpiryStatus.Invalid&&Date.now()<=n?i:this.fetch(e,...s)},this.invalidate=(e,...t)=>null!==t[0]?this.dispatch(function(e,{args:t}){return{type:l,meta:{key:e.key(...t)}}}(e,{args:t})):Promise.resolve(),this.invalidateAll=e=>this.dispatch({type:h,testKey:t=>e.testKey(t)}),this.expireAll=e=>this.dispatch({type:d,testKey:t=>e.testKey(t)}),this.resetEntireStore=()=>this.dispatch({type:a,date:Date.now()}),this.setResponse=(e,...t)=>{const s=t[t.length-1],i=I(e,{args:t.slice(0,t.length-1),response:s});return this.dispatch(i)},this.setError=(e,...t)=>{const s=t[t.length-1],i=I(e,{args:t.slice(0,t.length-1),response:s,error:!0});return this.dispatch(i)},this.resolve=(e,t)=>this.dispatch(I(e,t)),this.subscribe=(e,...t)=>null!==t[0]?this.dispatch(function(e,{args:t}){return{type:o,endpoint:e,meta:{args:t,key:e.key(...t)}}}(e,{args:t})):Promise.resolve(),this.unsubscribe=(e,...t)=>null!==t[0]?this.dispatch(function(e,{args:t}){return{type:c,endpoint:e,meta:{args:t,key:e.key(...t)}}}(e,{args:t})):Promise.resolve(),this.snapshot=(e,t)=>new j(this,e,t),this.dispatch=e,this.getState=s,this.memo=i}getError(e,...t){if(null===t[0])return;const s=t[t.length-1],i=t.slice(0,t.length-1),n=e.key(...i),r=S(s,n);return void 0===s.endpoints[n]||"soft"!==(null==r?void 0:r.errorPolicy)?null==r?void 0:r.error:void 0}getResponse(e,...s){const i=s[s.length-1],n=s.slice(0,s.length-1).map(O),r=1!==n.length||null!==n[0],a=r?e.key(...n):"",o=r?i.endpoints[a]:void 0,c=e.schema,l=S(i,a);let h=null==l?void 0:l.expiresAt;const d=void 0===o&&void 0!==c,u=d?this.memo.buildQueryKey(a,c,n,i.entities,i.indexes):o;if(!r)return{data:u,expiryStatus:t.ExpiryStatus.Valid,expiresAt:1/0};let p=!1;if(d)p=!t.validateQueryKey(u);else if(!c||!k(c))return{data:o,expiryStatus:null!=l&&l.invalidated?t.ExpiryStatus.Invalid:o&&!e.invalidIfStale?t.ExpiryStatus.Valid:t.ExpiryStatus.InvalidIfStale,expiresAt:h||0};const{data:f,paths:m}=this.memo.denormalize(u,c,i.entities,n);return!h&&p&&(h=1),this.getSchemaResponse(f,m,i.entityMeta,h,e.invalidIfStale||p,l)}get(e,...t){const s=t[t.length-1],i=t.slice(0,t.length-1).map(O),n=JSON.stringify(i);return this.memo.query(n,e,i,s.entities,s.indexes)}getSchemaResponse(e,s,i,n,r,a={}){const o="symbol"==typeof e;n||(n=function(e,t){let s=1/0;for(const{pk:n,key:r}of e){var i;const e=null==(i=t[r])||null==(i=i[n])?void 0:i.expiresAt;e<s&&(s=e)}return s}(s,i));return{data:e,expiryStatus:null!=a&&a.invalidated||o&&(null==a||!a.error)?t.ExpiryStatus.Invalid:o||r?t.ExpiryStatus.InvalidIfStale:t.ExpiryStatus.Valid,expiresAt:n}}}function k(e){if(t.isEntity(e))return!0;if(Array.isArray(e))return 0!==e.length&&k(e[0]);if(e&&("object"==typeof e||"function"==typeof e)){const t="schema"in e?e.schema:e;return"function"==typeof t?k(t):Object.values(t).some((e=>k(e)))}return!1}class j{constructor(e,t,s=0){this.state=void 0,this.controller=void 0,this.fetchedAt=void 0,this.abort=j.abort,this.state=t,this.controller=e,this.fetchedAt=s}getResponse(e,...t){return this.controller.getResponse(e,...t,this.state)}getError(e,...t){return this.controller.getError(e,...t,this.state)}get(e,...t){return this.controller.get(e,...t,this.state)}}j.abort=new m;class T extends Error{constructor(){super("Aborted due to RESET"),this.name="ResetError"}}class R{isOnline(){return void 0===navigator.onLine||navigator.onLine}addOnlineListener(e){addEventListener("online",e)}removeOnlineListener(e){removeEventListener("online",e)}addOfflineListener(e){addEventListener("offline",e)}removeOfflineListener(e){removeEventListener("offline",e)}}class _{isOnline(){return!0}addOnlineListener(){}removeOnlineListener(){}addOfflineListener(){}removeOfflineListener(){}}let q;q="undefined"!=typeof navigator&&"function"==typeof addEventListener?R:_;var P=q;let D={};Object.hasOwn=Object.hasOwn||function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},Object.defineProperty(e,"ExpiryStatus",{enumerable:!0,get:function(){return t.ExpiryStatus}}),e.Controller=x,e.DefaultConnectionListener=P,e.DevToolsManager=class{constructor(e,t){this.started=!1,this.actions=[],this.maxBufferLength=100,this.devTools="undefined"!=typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__&&window.__REDUX_DEVTOOLS_EXTENSION__.connect(Object.assign({},D,{config:e})),this.devTools?this.middleware=e=>{this.controller=e;const s=v(e);let i=e.getState();return n=>r=>{const a=n(r);return i=this.started?s(i,r):e.getState(),a.then((()=>{null!=t&&t(r)||this.handleAction(r,i.optimistic.reduce(s,i))})),a}}:this.middleware=()=>e=>t=>e(t)}handleAction(e,t){this.started?this.devTools.send(e,t,void 0,"RDC"):(this.actions.length>this.maxBufferLength&&(this.actions=this.actions.slice(this.maxBufferLength/2)),this.actions.push([e,t]))}init(e){this.devTools&&this.devTools.init(e)}cleanup(){}getMiddleware(){return this.middleware}},e.LogoutManager=class{constructor({handleLogout:e,shouldLogout:t}={}){e&&(this.handleLogout=e),t&&(this.shouldLogout=t),this.middleware=e=>t=>async s=>{await t(s),s.type===n&&s.error&&this.shouldLogout(s.payload)&&this.handleLogout(e)}}cleanup(){}getMiddleware(){return this.middleware}shouldLogout(e){return 401===e.status}handleLogout(e){e.resetEntireStore()}},e.NetworkManager=class{constructor(e=6e4,t=1e3){this.fetched=Object.create(null),this.resolvers={},this.rejectors={},this.fetchedAt={},this.controller=new x,this.dataExpiryLength=e,this.errorExpiryLength=t,this.middleware=e=>(this.controller=e,t=>s=>{switch(s.type){case i:return this.handleFetch(s),void 0!==s.endpoint.getOptimisticResponse&&s.endpoint.sideEffect?t(s):Promise.resolve();case n:return t(s).then((()=>{if(s.meta.key in this.fetched){var t;const i=null==(t=e.getState().meta[s.meta.key])?void 0:t.error;i?this.handleSet(I(s.endpoint,{args:s.meta.args,response:i,fetchedAt:s.meta.fetchedAt,error:!0})):this.handleSet(s)}}));case a:{const e=Object.assign({},this.rejectors);return this.clearAll(),t(s).then((()=>{for(const t in e)e[t](new T)}))}default:return t(s)}})}skipLogging(e){return e.type===i&&e.meta.key in this.fetched}init(){delete this.cleanupDate}cleanup(){this.cleanupDate=Date.now()}allSettled(){const e=Object.values(this.fetched);if(e.length)return Promise.allSettled(e)}clearAll(){for(const e in this.rejectors)this.clear(e)}clear(e){this.fetched[e].catch((()=>{})),delete this.resolvers[e],delete this.rejectors[e],delete this.fetched[e],delete this.fetchedAt[e]}getLastReset(){return this.cleanupDate?this.cleanupDate:this.controller.getState().lastReset}handleFetch(e){const t=e.payload,{key:s,throttle:i,resolve:n,reject:r,createdAt:a}=e.meta,o=()=>{let s=t();return i||(s=(e=>e.then((e=>(n(e),e))).catch((e=>{throw r(e),e})))(s)),s=s.then((t=>{let s=this.getLastReset();return a>=s&&this.controller.resolve(e.endpoint,{args:e.meta.args,response:t,fetchedAt:a}),t})).catch((t=>{const s=this.getLastReset();throw a>=s&&this.controller.resolve(e.endpoint,{args:e.meta.args,response:t,fetchedAt:a,error:!0}),t})),s};return i?this.throttle(s,o,a).then((e=>n(e))).catch((e=>r(e))):o().catch((()=>{}))}handleSet(e){if(e.meta.key in this.fetched){let t;t=e.error?this.rejectors[e.meta.key]:this.resolvers[e.meta.key],t(e.payload),this.clear(e.meta.key)}}getMiddleware(){return this.middleware}throttle(e,t,i){const n=this.getLastReset();return e in this.fetched&&this.fetchedAt[e]>n||(this.fetched[e]=new Promise(((t,s)=>{this.resolvers[e]=t,this.rejectors[e]=s})),this.fetchedAt[e]=i,s((()=>{t().catch((()=>null))}),{timeout:500})),this.fetched[e]}},e.PollingSubscription=class{constructor(e,t,s){if(this.frequencyHistogram=new Map,this.offlineListener=()=>{this.cleanup(),this.connectionListener.addOnlineListener(this.onlineListener)},this.onlineListener=()=>{this.connectionListener.removeOnlineListener(this.onlineListener);const e=Date.now();this.startId=setTimeout((()=>{this.startId&&(delete this.startId,this.update(),this.run())}),Math.max(0,this.lastFetchTime()-e+this.frequency)),this.connectionListener.addOfflineListener(this.offlineListener)},void 0===e.endpoint.pollFrequency)throw new Error("frequency needed for polling subscription");this.endpoint=e.endpoint,this.frequency=e.endpoint.pollFrequency,this.args=e.meta.args,this.key=e.meta.key,this.frequencyHistogram.set(this.frequency,1),this.controller=t,this.connectionListener=s||new P,this.connectionListener.isOnline()?this.onlineListener():this.offlineListener()}add(e){void 0!==e&&(this.frequencyHistogram.has(e)?this.frequencyHistogram.set(e,this.frequencyHistogram.get(e)+1):(this.frequencyHistogram.set(e,1),e<this.frequency&&(this.frequency=e,this.run())))}remove(e){if(void 0===e)return!1;if(this.frequencyHistogram.has(e)&&(this.frequencyHistogram.set(e,this.frequencyHistogram.get(e)-1),this.frequencyHistogram.get(e)<1)){if(this.frequencyHistogram.delete(e),0===this.frequencyHistogram.size)return this.cleanup(),!0;e<=this.frequency&&(this.frequency=Math.min(...this.frequencyHistogram.keys()),this.run())}return!1}cleanup(){this.intervalId&&(clearInterval(this.intervalId),delete this.intervalId),this.lastIntervalId&&(clearInterval(this.lastIntervalId),delete this.lastIntervalId),this.startId&&(clearTimeout(this.startId),delete this.startId),this.connectionListener.removeOnlineListener(this.onlineListener),this.connectionListener.removeOfflineListener(this.offlineListener)}update(){const e=this.endpoint,t=function(...t){return e.call(this,...t)};Object.assign(t,this.endpoint),t.dataExpiryLength=this.frequency/2,t.errorExpiryLength=this.frequency/10,t.errorPolicy=()=>"soft",t.key=()=>this.key,this.controller.fetch(t,...this.args).catch((()=>null))}run(){this.startId||(this.intervalId&&(this.lastIntervalId=this.intervalId),this.intervalId=setInterval((()=>{this.lastIntervalId&&(clearInterval(this.lastIntervalId),delete this.lastIntervalId),this.intervalId&&this.update()}),this.frequency))}lastFetchTime(){var e,t;return null!=(e=null==(t=this.controller.getState().meta[this.key])?void 0:t.date)?e:0}},e.ResetError=T,e.SubscriptionManager=class{constructor(e){this.subscriptions={},this.controller=new x,this.Subscription=e,this.middleware=e=>(this.controller=e,e=>t=>{switch(t.type){case o:try{this.handleSubscribe(t)}catch(e){console.error(e)}return Promise.resolve();case c:return this.handleUnsubscribe(t),Promise.resolve();default:return e(t)}})}cleanup(){for(const e in this.subscriptions)this.subscriptions[e].cleanup()}handleSubscribe(e){const t=e.meta.key;if(t in this.subscriptions){const s=e.endpoint.pollFrequency;this.subscriptions[t].add(s)}else this.subscriptions[t]=new this.Subscription(e,this.controller)}handleUnsubscribe(e){const t=e.meta.key;if(t in this.subscriptions){const s=e.endpoint.pollFrequency;this.subscriptions[t].remove(s)&&delete this.subscriptions[t]}}getMiddleware(){return this.middleware}},e.__INTERNAL__=b,e.actionTypes=p,e.applyManager=function(e,t){return e.map((e=>{const s=e.getMiddleware();return({dispatch:e,getState:i})=>(t.dispatch=e,t.getState=i,s(t))}))},e.createFetch=L,e.createReducer=v,e.createSet=I,e.initialState=E,Object.defineProperty(e,"__esModule",{value:!0})}));
1
+ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@data-client/normalizr")):"function"==typeof define&&define.amd?define(["exports","@data-client/normalizr"],t):t(((e="undefined"!=typeof globalThis?globalThis:e||self).RDC=e.RDC||{},e.RDC.Core={}),e.normalizr)}(this,(function(e,t){"use strict";var s="function"==typeof requestIdleCallback?requestIdleCallback:e=>e();const i="rdc/fetch",n="rdc/set",r="rdc/setresponse",a="rdc/optimistic",o="rdc/reset",c="rdc/subscribe",l="rdc/unsubscribe",h="rdc/invalidate",d="rdc/invalidateall",u="rdc/expireall",p="rdc/gc";var f=Object.freeze({__proto__:null,FETCH_TYPE:i,SET_TYPE:n,SET_RESPONSE_TYPE:r,OPTIMISTIC_TYPE:a,RESET_TYPE:o,SUBSCRIBE_TYPE:c,UNSUBSCRIBE_TYPE:l,INVALIDATE_TYPE:h,INVALIDATEALL_TYPE:d,EXPIREALL_TYPE:u,GC_TYPE:p});function m(e,t){let s;return t.endpoint.getOptimisticResponse&&t.endpoint.sideEffect?(s=function(e,{args:t,fetchedAt:s}){var i;const n=null!=(i=e.dataExpiryLength)?i:6e4,r=Date.now(),o={args:t,fetchedAt:s,date:r,expiresAt:r+n,key:e.key(...t)};return{type:a,endpoint:e,meta:o}}(t.endpoint,{args:t.meta.args,fetchedAt:t.meta.createdAt}),Object.assign({},e,{optimistic:[...e.optimistic,s]})):e}class y extends Error{}function g(e,t,s){return"AbortError"===s.name?Object.assign({},e,{optimistic:v(e,t)}):Object.assign({},e,{meta:Object.assign({},e.meta,{[t.meta.key]:{date:t.meta.date,error:s,expiresAt:t.meta.expiresAt,errorPolicy:null==t.endpoint.errorPolicy?void 0:t.endpoint.errorPolicy(s)}}),optimistic:v(e,t)})}function v(e,t){return e.optimistic.filter((e=>e.meta.key!==t.meta.key||(e.type===a?e.meta.fetchedAt!==t.meta.fetchedAt:e.meta.date>t.meta.date)))}function E(e){return function(s,c){switch(s||(s=b),c.type){case p:return c.entities.forEach((([e,t])=>{var i,n;null==(i=s.entities[e])||delete i[t],null==(n=s.entityMeta[e])||delete n[t]})),c.endpoints.forEach((e=>{delete s.endpoints[e],delete s.meta[e]})),s;case i:return m(s,c);case a:case r:return function(e,s,i){if(s.error)return g(e,s,s.payload);try{var n;let r;if(s.type===a){if(!s.endpoint.getOptimisticResponse)return e;try{r=s.endpoint.getOptimisticResponse.call(s.endpoint,i.snapshot(e,s.meta.fetchedAt),...s.meta.args)}catch(t){if(t.constructor===y)return e;throw t}}else r=s.payload;const{result:o,entities:c,indexes:l,entityMeta:h}=t.normalize(r,s.endpoint.schema,s.meta.args,e.entities,e.indexes,e.entityMeta,s.meta),d=Object.assign({},e.endpoints,{[s.meta.key]:o});try{if(s.endpoint.update){const e=s.endpoint.update(o,...s.meta.args);Object.keys(e).forEach((t=>{d[t]=e[t](d[t])}))}}catch(e){console.error(`The following error occured during Endpoint.update() for ${s.meta.key}`),console.error(e)}return{entities:c,indexes:l,endpoints:d,entityMeta:h,meta:Object.assign({},e.meta,{[s.meta.key]:{date:s.meta.date,expiresAt:s.meta.expiresAt,prevExpiresAt:null==(n=e.meta[s.meta.key])?void 0:n.expiresAt}}),optimistic:v(e,s),lastReset:e.lastReset}}catch(t){return"object"==typeof t&&(t.message=`Error processing ${s.meta.key}\n\nFull Schema: ${JSON.stringify(s.endpoint.schema,void 0,2)}\n\nError:\n${t.message}`,"payload"in s&&(t.payload=s.payload),t.status=400),g(e,s,t)}}(s,c,e);case n:return function(e,s){try{const{entities:i,indexes:n,entityMeta:r}=t.normalize(s.value,s.schema,s.meta.args,e.entities,e.indexes,e.entityMeta,s.meta);return{entities:i,indexes:n,endpoints:e.endpoints,entityMeta:r,meta:e.meta,optimistic:e.optimistic,lastReset:e.lastReset}}catch(t){return e}}(s,c);case d:case h:return function(e,t){const s=Object.assign({},e.endpoints),i=Object.assign({},e.meta),n=e=>{delete s[e];const t=Object.assign({},i[e],{expiresAt:0,invalidated:!0});delete t.error,i[e]=t};return t.type===h?n(t.meta.key):Object.keys(s).forEach((e=>{t.testKey(e)&&n(e)})),Object.assign({},e,{endpoints:s,meta:i})}(s,c);case u:return function(e,t){const s=Object.assign({},e.meta);return Object.keys(s).forEach((e=>{t.testKey(e)&&(s[e]=Object.assign({},s[e],{expiresAt:1}))})),Object.assign({},e,{meta:s})}(s,c);case o:return Object.assign({},b,{lastReset:c.date});default:return s}}}const b={entities:{},indexes:{},endpoints:{},meta:{},entityMeta:{},optimistic:[],lastReset:0};var L=Object.freeze({__proto__:null,MemoCache:t.MemoCache,INVALID:t.INVALID,RIC:s,initialState:b});function S(e,{args:t}){const s=e.key(...t);let n=0,r=0;const a=new Promise(((e,t)=>{[n,r]=[e,t]})),o={args:t,key:s,throttle:!e.sideEffect,resolve:n,reject:r,promise:a,createdAt:Date.now(),nm:!1};return{type:i,payload:()=>e(...t),meta:o,endpoint:e}}var O="undefined"!=typeof FormData?e=>e instanceof FormData?Object.fromEntries(e.entries()):e:e=>e;function I(e,{args:t,fetchedAt:s,value:i}){const r=Date.now(),a={args:t.map(O),fetchedAt:null!=s?s:r,date:r,expiresAt:r+6e4};return{type:n,value:i,schema:e,meta:a}}function x(e,{args:t,fetchedAt:s,response:i,error:n=!1}){var a,o;const c=n?null!=(a=e.errorExpiryLength)?a:1e3:null!=(o=e.dataExpiryLength)?o:6e4,l=Date.now(),h={args:t.map(O),fetchedAt:null!=s?s:l,date:l,expiresAt:l+c,key:e.key(...t)},d={type:r,payload:i,endpoint:e,meta:h};return n&&(d.error=!0),d}function A(e,t){return e.meta[t]}const w=e=>{throw new Error("Dispatching while constructing your middleware is not allowed. Other middleware would not be applied to this dispatch.")},k=()=>b;class j{constructor({dispatch:e=w,getState:s=k,memo:i=new t.MemoCache}={}){this.fetch=(e,...s)=>{const i=S(e,{args:s});return this.dispatch(i),e.schema?i.meta.promise.then((i=>t.denormalize(i,e.schema,{},s))):i.meta.promise},this.fetchIfStale=(e,...s)=>{const{data:i,expiresAt:n,expiryStatus:r}=this.getResponse(e,...s,this.getState());return r!==t.ExpiryStatus.Invalid&&Date.now()<=n?i:this.fetch(e,...s)},this.invalidate=(e,...t)=>null!==t[0]?this.dispatch(function(e,{args:t}){return{type:h,meta:{key:e.key(...t)}}}(e,{args:t})):Promise.resolve(),this.invalidateAll=e=>this.dispatch({type:d,testKey:t=>e.testKey(t)}),this.expireAll=e=>this.dispatch({type:u,testKey:t=>e.testKey(t)}),this.resetEntireStore=()=>this.dispatch({type:o,date:Date.now()}),this.set=(e,...t)=>{const s=t[t.length-1],i=I(e,{args:t.slice(0,t.length-1),value:s});return this.dispatch(i)},this.setResponse=(e,...t)=>{const s=t[t.length-1],i=x(e,{args:t.slice(0,t.length-1),response:s});return this.dispatch(i)},this.setError=(e,...t)=>{const s=t[t.length-1],i=x(e,{args:t.slice(0,t.length-1),response:s,error:!0});return this.dispatch(i)},this.resolve=(e,t)=>this.dispatch(x(e,t)),this.subscribe=(e,...t)=>null!==t[0]?this.dispatch(function(e,{args:t}){return{type:c,endpoint:e,meta:{args:t,key:e.key(...t)}}}(e,{args:t})):Promise.resolve(),this.unsubscribe=(e,...t)=>null!==t[0]?this.dispatch(function(e,{args:t}){return{type:l,endpoint:e,meta:{args:t,key:e.key(...t)}}}(e,{args:t})):Promise.resolve(),this.snapshot=(e,t)=>new T(this,e,t),this.dispatch=e,this.getState=s,this.memo=i}getError(e,...t){if(null===t[0])return;const s=t[t.length-1],i=t.slice(0,t.length-1),n=e.key(...i),r=A(s,n);return void 0===s.endpoints[n]||"soft"!==(null==r?void 0:r.errorPolicy)?null==r?void 0:r.error:void 0}getResponse(e,...s){const i=s[s.length-1],n=s.slice(0,s.length-1).map(O),r=1!==n.length||null!==n[0],a=r?e.key(...n):"",o=r?i.endpoints[a]:void 0,c=e.schema,l=A(i,a);let h=null==l?void 0:l.expiresAt;const d=void 0===o&&void 0!==c,u=d?this.memo.buildQueryKey(a,c,n,i.entities,i.indexes):o;if(!r)return{data:u,expiryStatus:t.ExpiryStatus.Valid,expiresAt:1/0};let p=!1;if(d)p=!t.validateQueryKey(u);else if(!c||!R(c))return{data:o,expiryStatus:null!=l&&l.invalidated?t.ExpiryStatus.Invalid:o&&!e.invalidIfStale?t.ExpiryStatus.Valid:t.ExpiryStatus.InvalidIfStale,expiresAt:h||0};const{data:f,paths:m}=this.memo.denormalize(u,c,i.entities,n);return!h&&p&&(h=1),this.getSchemaResponse(f,m,i.entityMeta,h,e.invalidIfStale||p,l)}get(e,...t){const s=t[t.length-1],i=t.slice(0,t.length-1).map(O),n=JSON.stringify(i);return this.memo.query(n,e,i,s.entities,s.indexes)}getSchemaResponse(e,s,i,n,r,a={}){const o="symbol"==typeof e;n||(n=function(e,t){let s=1/0;for(const{pk:n,key:r}of e){var i;const e=null==(i=t[r])||null==(i=i[n])?void 0:i.expiresAt;e<s&&(s=e)}return s}(s,i));return{data:e,expiryStatus:null!=a&&a.invalidated||o&&(null==a||!a.error)?t.ExpiryStatus.Invalid:o||r?t.ExpiryStatus.InvalidIfStale:t.ExpiryStatus.Valid,expiresAt:n}}}function R(e){if(t.isEntity(e))return!0;if(Array.isArray(e))return 0!==e.length&&R(e[0]);if(e&&("object"==typeof e||"function"==typeof e)){const t="schema"in e?e.schema:e;return"function"==typeof t?R(t):Object.values(t).some((e=>R(e)))}return!1}class T{constructor(e,t,s=0){this.state=void 0,this.controller=void 0,this.fetchedAt=void 0,this.abort=T.abort,this.state=t,this.controller=e,this.fetchedAt=s}getResponse(e,...t){return this.controller.getResponse(e,...t,this.state)}getError(e,...t){return this.controller.getError(e,...t,this.state)}get(e,...t){return this.controller.get(e,...t,this.state)}}T.abort=new y;class _ extends Error{constructor(){super("Aborted due to RESET"),this.name="ResetError"}}class q{isOnline(){return void 0===navigator.onLine||navigator.onLine}addOnlineListener(e){addEventListener("online",e)}removeOnlineListener(e){removeEventListener("online",e)}addOfflineListener(e){addEventListener("offline",e)}removeOfflineListener(e){removeEventListener("offline",e)}}class P{isOnline(){return!0}addOnlineListener(){}removeOnlineListener(){}addOfflineListener(){}removeOfflineListener(){}}let D;D="undefined"!=typeof navigator&&"function"==typeof addEventListener?q:P;var M=D;let C={};Object.hasOwn=Object.hasOwn||function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},Object.defineProperty(e,"ExpiryStatus",{enumerable:!0,get:function(){return t.ExpiryStatus}}),e.Controller=j,e.DefaultConnectionListener=M,e.DevToolsManager=class{constructor(e,t){this.started=!1,this.actions=[],this.maxBufferLength=100,this.devTools="undefined"!=typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__&&window.__REDUX_DEVTOOLS_EXTENSION__.connect(Object.assign({},C,e)),null!=e&&e.maxAge&&(this.maxBufferLength=2*e.maxAge),this.devTools?this.middleware=e=>{this.controller=e;const s=E(e);let i=e.getState();return n=>r=>{const a=n(r);return i=this.started?s(i,r):e.getState(),a.then((()=>{null!=t&&t(r)||this.handleAction(r,i.optimistic.reduce(s,i))})),a}}:this.middleware=()=>e=>t=>e(t)}handleAction(e,t){this.started?this.devTools.send(e,t):(this.actions.length>this.maxBufferLength&&(this.actions=this.actions.slice(this.maxBufferLength/2)),this.actions.push([e,t]))}init(e){this.devTools&&this.devTools.init(e)}cleanup(){}getMiddleware(){return this.middleware}},e.LogoutManager=class{constructor({handleLogout:e,shouldLogout:t}={}){e&&(this.handleLogout=e),t&&(this.shouldLogout=t),this.middleware=e=>t=>async s=>{await t(s),s.type===r&&s.error&&this.shouldLogout(s.payload)&&this.handleLogout(e)}}cleanup(){}getMiddleware(){return this.middleware}shouldLogout(e){return 401===e.status}handleLogout(e){e.resetEntireStore()}},e.NetworkManager=class{constructor(e=6e4,t=1e3){this.fetched=Object.create(null),this.resolvers={},this.rejectors={},this.fetchedAt={},this.controller=new j,this.dataExpiryLength=e,this.errorExpiryLength=t,this.middleware=e=>(this.controller=e,t=>s=>{switch(s.type){case i:return this.handleFetch(s),void 0!==s.endpoint.getOptimisticResponse&&s.endpoint.sideEffect?t(s):Promise.resolve();case r:return t(s).then((()=>{if(s.meta.key in this.fetched){var t;const i=null==(t=e.getState().meta[s.meta.key])?void 0:t.error;i?this.handleSet(x(s.endpoint,{args:s.meta.args,response:i,fetchedAt:s.meta.fetchedAt,error:!0})):this.handleSet(s)}}));case o:{const e=Object.assign({},this.rejectors);return this.clearAll(),t(s).then((()=>{for(const t in e)e[t](new _)}))}default:return t(s)}})}skipLogging(e){return e.type===i&&e.meta.key in this.fetched}init(){delete this.cleanupDate}cleanup(){this.cleanupDate=Date.now()}allSettled(){const e=Object.values(this.fetched);if(e.length)return Promise.allSettled(e)}clearAll(){for(const e in this.rejectors)this.clear(e)}clear(e){this.fetched[e].catch((()=>{})),delete this.resolvers[e],delete this.rejectors[e],delete this.fetched[e],delete this.fetchedAt[e]}getLastReset(){return this.cleanupDate?this.cleanupDate:this.controller.getState().lastReset}handleFetch(e){const t=e.payload,{key:s,throttle:i,resolve:n,reject:r,createdAt:a}=e.meta,o=()=>{let s=t();return i||(s=(e=>e.then((e=>(n(e),e))).catch((e=>{throw r(e),e})))(s)),s=s.then((t=>{let s=this.getLastReset();return a>=s&&this.controller.resolve(e.endpoint,{args:e.meta.args,response:t,fetchedAt:a}),t})).catch((t=>{const s=this.getLastReset();throw a>=s&&this.controller.resolve(e.endpoint,{args:e.meta.args,response:t,fetchedAt:a,error:!0}),t})),s};return i?this.throttle(s,o,a).then((e=>n(e))).catch((e=>r(e))):o().catch((()=>{}))}handleSet(e){if(e.meta.key in this.fetched){let t;t=e.error?this.rejectors[e.meta.key]:this.resolvers[e.meta.key],t(e.payload),this.clear(e.meta.key)}}getMiddleware(){return this.middleware}throttle(e,t,i){const n=this.getLastReset();return e in this.fetched&&this.fetchedAt[e]>n||(this.fetched[e]=new Promise(((t,s)=>{this.resolvers[e]=t,this.rejectors[e]=s})),this.fetchedAt[e]=i,s((()=>{t().catch((()=>null))}),{timeout:500})),this.fetched[e]}},e.PollingSubscription=class{constructor(e,t,s){if(this.frequencyHistogram=new Map,this.offlineListener=()=>{this.cleanup(),this.connectionListener.addOnlineListener(this.onlineListener)},this.onlineListener=()=>{this.connectionListener.removeOnlineListener(this.onlineListener);const e=Date.now();this.startId=setTimeout((()=>{this.startId&&(delete this.startId,this.update(),this.run())}),Math.max(0,this.lastFetchTime()-e+this.frequency)),this.connectionListener.addOfflineListener(this.offlineListener)},void 0===e.endpoint.pollFrequency)throw new Error("frequency needed for polling subscription");this.endpoint=e.endpoint,this.frequency=e.endpoint.pollFrequency,this.args=e.meta.args,this.key=e.meta.key,this.frequencyHistogram.set(this.frequency,1),this.controller=t,this.connectionListener=s||new M,this.connectionListener.isOnline()?this.onlineListener():this.offlineListener()}add(e){void 0!==e&&(this.frequencyHistogram.has(e)?this.frequencyHistogram.set(e,this.frequencyHistogram.get(e)+1):(this.frequencyHistogram.set(e,1),e<this.frequency&&(this.frequency=e,this.run())))}remove(e){if(void 0===e)return!1;if(this.frequencyHistogram.has(e)&&(this.frequencyHistogram.set(e,this.frequencyHistogram.get(e)-1),this.frequencyHistogram.get(e)<1)){if(this.frequencyHistogram.delete(e),0===this.frequencyHistogram.size)return this.cleanup(),!0;e<=this.frequency&&(this.frequency=Math.min(...this.frequencyHistogram.keys()),this.run())}return!1}cleanup(){this.intervalId&&(clearInterval(this.intervalId),delete this.intervalId),this.lastIntervalId&&(clearInterval(this.lastIntervalId),delete this.lastIntervalId),this.startId&&(clearTimeout(this.startId),delete this.startId),this.connectionListener.removeOnlineListener(this.onlineListener),this.connectionListener.removeOfflineListener(this.offlineListener)}update(){const e=this.endpoint,t=function(...t){return e.call(this,...t)};Object.assign(t,this.endpoint),t.dataExpiryLength=this.frequency/2,t.errorExpiryLength=this.frequency/10,t.errorPolicy=()=>"soft",t.key=()=>this.key,this.controller.fetch(t,...this.args).catch((()=>null))}run(){this.startId||(this.intervalId&&(this.lastIntervalId=this.intervalId),this.intervalId=setInterval((()=>{this.lastIntervalId&&(clearInterval(this.lastIntervalId),delete this.lastIntervalId),this.intervalId&&this.update()}),this.frequency))}lastFetchTime(){var e,t;return null!=(e=null==(t=this.controller.getState().meta[this.key])?void 0:t.date)?e:0}},e.ResetError=_,e.SubscriptionManager=class{constructor(e){this.subscriptions={},this.controller=new j,this.Subscription=e,this.middleware=e=>(this.controller=e,e=>t=>{switch(t.type){case c:try{this.handleSubscribe(t)}catch(e){console.error(e)}return Promise.resolve();case l:return this.handleUnsubscribe(t),Promise.resolve();default:return e(t)}})}cleanup(){for(const e in this.subscriptions)this.subscriptions[e].cleanup()}handleSubscribe(e){const t=e.meta.key;if(t in this.subscriptions){const s=e.endpoint.pollFrequency;this.subscriptions[t].add(s)}else this.subscriptions[t]=new this.Subscription(e,this.controller)}handleUnsubscribe(e){const t=e.meta.key;if(t in this.subscriptions){const s=e.endpoint.pollFrequency;this.subscriptions[t].remove(s)&&delete this.subscriptions[t]}}getMiddleware(){return this.middleware}},e.__INTERNAL__=L,e.actionTypes=f,e.applyManager=function(e,t){return e.map((e=>{const s=e.getMiddleware();return({dispatch:e,getState:i})=>(t.dispatch=e,t.getState=i,s(t))}))},e.createFetch=S,e.createReducer=E,e.createSet=I,e.createSetResponse=x,e.initialState=b,Object.defineProperty(e,"__esModule",{value:!0})}));
@@ -1,5 +1,6 @@
1
1
  export const FETCH_TYPE = 'rdc/fetch';
2
2
  export const SET_TYPE = 'rdc/set';
3
+ export const SET_RESPONSE_TYPE = 'rdc/setresponse';
3
4
  export const OPTIMISTIC_TYPE = 'rdc/optimistic';
4
5
  export const RESET_TYPE = 'rdc/reset';
5
6
  export const SUBSCRIBE_TYPE = 'rdc/subscribe';
@@ -8,4 +9,4 @@ export const INVALIDATE_TYPE = 'rdc/invalidate';
8
9
  export const INVALIDATEALL_TYPE = 'rdc/invalidateall';
9
10
  export const EXPIREALL_TYPE = 'rdc/expireall';
10
11
  export const GC_TYPE = 'rdc/gc';
11
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiU0VUX1RZUEUiLCJPUFRJTUlTVElDX1RZUEUiLCJSRVNFVF9UWVBFIiwiU1VCU0NSSUJFX1RZUEUiLCJVTlNVQlNDUklCRV9UWVBFIiwiSU5WQUxJREFURV9UWVBFIiwiSU5WQUxJREFURUFMTF9UWVBFIiwiRVhQSVJFQUxMX1RZUEUiLCJHQ19UWVBFIl0sInNvdXJjZXMiOlsiLi4vc3JjL2FjdGlvblR5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBGRVRDSF9UWVBFID0gJ3JkYy9mZXRjaCcgYXMgY29uc3Q7XG5leHBvcnQgY29uc3QgU0VUX1RZUEUgPSAncmRjL3NldCcgYXMgY29uc3Q7XG5leHBvcnQgY29uc3QgT1BUSU1JU1RJQ19UWVBFID0gJ3JkYy9vcHRpbWlzdGljJyBhcyBjb25zdDtcbmV4cG9ydCBjb25zdCBSRVNFVF9UWVBFID0gJ3JkYy9yZXNldCcgYXMgY29uc3Q7XG5leHBvcnQgY29uc3QgU1VCU0NSSUJFX1RZUEUgPSAncmRjL3N1YnNjcmliZScgYXMgY29uc3Q7XG5leHBvcnQgY29uc3QgVU5TVUJTQ1JJQkVfVFlQRSA9ICdyZGMvdW5zdWJzY3JpYmUnIGFzIGNvbnN0O1xuZXhwb3J0IGNvbnN0IElOVkFMSURBVEVfVFlQRSA9ICdyZGMvaW52YWxpZGF0ZScgYXMgY29uc3Q7XG5leHBvcnQgY29uc3QgSU5WQUxJREFURUFMTF9UWVBFID0gJ3JkYy9pbnZhbGlkYXRlYWxsJyBhcyBjb25zdDtcbmV4cG9ydCBjb25zdCBFWFBJUkVBTExfVFlQRSA9ICdyZGMvZXhwaXJlYWxsJyBhcyBjb25zdDtcbmV4cG9ydCBjb25zdCBHQ19UWVBFID0gJ3JkYy9nYycgYXMgY29uc3Q7XG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sTUFBTUEsVUFBVSxHQUFHLFdBQW9CO0FBQzlDLE9BQU8sTUFBTUMsUUFBUSxHQUFHLFNBQWtCO0FBQzFDLE9BQU8sTUFBTUMsZUFBZSxHQUFHLGdCQUF5QjtBQUN4RCxPQUFPLE1BQU1DLFVBQVUsR0FBRyxXQUFvQjtBQUM5QyxPQUFPLE1BQU1DLGNBQWMsR0FBRyxlQUF3QjtBQUN0RCxPQUFPLE1BQU1DLGdCQUFnQixHQUFHLGlCQUEwQjtBQUMxRCxPQUFPLE1BQU1DLGVBQWUsR0FBRyxnQkFBeUI7QUFDeEQsT0FBTyxNQUFNQyxrQkFBa0IsR0FBRyxtQkFBNEI7QUFDOUQsT0FBTyxNQUFNQyxjQUFjLEdBQUcsZUFBd0I7QUFDdEQsT0FBTyxNQUFNQyxPQUFPLEdBQUcsUUFBaUIiLCJpZ25vcmVMaXN0IjpbXX0=
12
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiU0VUX1RZUEUiLCJTRVRfUkVTUE9OU0VfVFlQRSIsIk9QVElNSVNUSUNfVFlQRSIsIlJFU0VUX1RZUEUiLCJTVUJTQ1JJQkVfVFlQRSIsIlVOU1VCU0NSSUJFX1RZUEUiLCJJTlZBTElEQVRFX1RZUEUiLCJJTlZBTElEQVRFQUxMX1RZUEUiLCJFWFBJUkVBTExfVFlQRSIsIkdDX1RZUEUiXSwic291cmNlcyI6WyIuLi9zcmMvYWN0aW9uVHlwZXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IEZFVENIX1RZUEUgPSAncmRjL2ZldGNoJyBhcyBjb25zdDtcbmV4cG9ydCBjb25zdCBTRVRfVFlQRSA9ICdyZGMvc2V0JyBhcyBjb25zdDtcbmV4cG9ydCBjb25zdCBTRVRfUkVTUE9OU0VfVFlQRSA9ICdyZGMvc2V0cmVzcG9uc2UnIGFzIGNvbnN0O1xuZXhwb3J0IGNvbnN0IE9QVElNSVNUSUNfVFlQRSA9ICdyZGMvb3B0aW1pc3RpYycgYXMgY29uc3Q7XG5leHBvcnQgY29uc3QgUkVTRVRfVFlQRSA9ICdyZGMvcmVzZXQnIGFzIGNvbnN0O1xuZXhwb3J0IGNvbnN0IFNVQlNDUklCRV9UWVBFID0gJ3JkYy9zdWJzY3JpYmUnIGFzIGNvbnN0O1xuZXhwb3J0IGNvbnN0IFVOU1VCU0NSSUJFX1RZUEUgPSAncmRjL3Vuc3Vic2NyaWJlJyBhcyBjb25zdDtcbmV4cG9ydCBjb25zdCBJTlZBTElEQVRFX1RZUEUgPSAncmRjL2ludmFsaWRhdGUnIGFzIGNvbnN0O1xuZXhwb3J0IGNvbnN0IElOVkFMSURBVEVBTExfVFlQRSA9ICdyZGMvaW52YWxpZGF0ZWFsbCcgYXMgY29uc3Q7XG5leHBvcnQgY29uc3QgRVhQSVJFQUxMX1RZUEUgPSAncmRjL2V4cGlyZWFsbCcgYXMgY29uc3Q7XG5leHBvcnQgY29uc3QgR0NfVFlQRSA9ICdyZGMvZ2MnIGFzIGNvbnN0O1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU1BLFVBQVUsR0FBRyxXQUFvQjtBQUM5QyxPQUFPLE1BQU1DLFFBQVEsR0FBRyxTQUFrQjtBQUMxQyxPQUFPLE1BQU1DLGlCQUFpQixHQUFHLGlCQUEwQjtBQUMzRCxPQUFPLE1BQU1DLGVBQWUsR0FBRyxnQkFBeUI7QUFDeEQsT0FBTyxNQUFNQyxVQUFVLEdBQUcsV0FBb0I7QUFDOUMsT0FBTyxNQUFNQyxjQUFjLEdBQUcsZUFBd0I7QUFDdEQsT0FBTyxNQUFNQyxnQkFBZ0IsR0FBRyxpQkFBMEI7QUFDMUQsT0FBTyxNQUFNQyxlQUFlLEdBQUcsZ0JBQXlCO0FBQ3hELE9BQU8sTUFBTUMsa0JBQWtCLEdBQUcsbUJBQTRCO0FBQzlELE9BQU8sTUFBTUMsY0FBYyxHQUFHLGVBQXdCO0FBQ3RELE9BQU8sTUFBTUMsT0FBTyxHQUFHLFFBQWlCIiwiaWdub3JlTGlzdCI6W119
package/legacy/actions.js CHANGED
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2FjdGlvbnMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBFbmRwb2ludEludGVyZmFjZSxcbiAgUmVzb2x2ZVR5cGUsXG4gIFVua25vd25FcnJvcixcbn0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB0eXBlIHtcbiAgU0VUX1RZUEUsXG4gIFJFU0VUX1RZUEUsXG4gIEZFVENIX1RZUEUsXG4gIFNVQlNDUklCRV9UWVBFLFxuICBVTlNVQlNDUklCRV9UWVBFLFxuICBJTlZBTElEQVRFX1RZUEUsXG4gIEdDX1RZUEUsXG4gIE9QVElNSVNUSUNfVFlQRSxcbiAgSU5WQUxJREFURUFMTF9UWVBFLFxuICBFWFBJUkVBTExfVFlQRSxcbn0gZnJvbSAnLi9hY3Rpb25UeXBlcy5qcyc7XG5pbXBvcnQgdHlwZSB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuL2NvbnRyb2xsZXIvdHlwZXMuanMnO1xuXG50eXBlIEVuZHBvaW50QW5kVXBkYXRlPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4gPSBFbmRwb2ludEludGVyZmFjZSAmIHtcbiAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbn07XG50eXBlIEVuZHBvaW50RGVmYXVsdCA9IEVuZHBvaW50SW50ZXJmYWNlICYge1xuICB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEVuZHBvaW50SW50ZXJmYWNlPjtcbn07XG5cbi8qIFNFVCAqL1xuZXhwb3J0IGludGVyZmFjZSBTZXRNZXRhIHtcbiAgYXJnczogcmVhZG9ubHkgYW55W107XG4gIGtleTogc3RyaW5nO1xuICBmZXRjaGVkQXQ6IG51bWJlcjtcbiAgZGF0ZTogbnVtYmVyO1xuICBleHBpcmVzQXQ6IG51bWJlcjtcbn1cbmV4cG9ydCBpbnRlcmZhY2UgU2V0QWN0aW9uU3VjY2VzczxcbiAgRSBleHRlbmRzIEVuZHBvaW50QW5kVXBkYXRlPEU+ID0gRW5kcG9pbnREZWZhdWx0LFxuPiB7XG4gIHR5cGU6IHR5cGVvZiBTRVRfVFlQRTtcbiAgZW5kcG9pbnQ6IEU7XG4gIG1ldGE6IFNldE1ldGE7XG4gIHBheWxvYWQ6IFJlc29sdmVUeXBlPEU+O1xuICBlcnJvcj86IGZhbHNlO1xufVxuZXhwb3J0IGludGVyZmFjZSBTZXRBY3Rpb25FcnJvcjxcbiAgRSBleHRlbmRzIEVuZHBvaW50QW5kVXBkYXRlPEU+ID0gRW5kcG9pbnREZWZhdWx0LFxuPiB7XG4gIHR5cGU6IHR5cGVvZiBTRVRfVFlQRTtcbiAgZW5kcG9pbnQ6IEU7XG4gIG1ldGE6IFNldE1ldGE7XG4gIHBheWxvYWQ6IFVua25vd25FcnJvcjtcbiAgZXJyb3I6IHRydWU7XG59XG5leHBvcnQgdHlwZSBTZXRBY3Rpb248RSBleHRlbmRzIEVuZHBvaW50QW5kVXBkYXRlPEU+ID0gRW5kcG9pbnREZWZhdWx0PiA9XG4gIHwgU2V0QWN0aW9uU3VjY2VzczxFPlxuICB8IFNldEFjdGlvbkVycm9yPEU+O1xuXG4vKiBGRVRDSCAqL1xuZXhwb3J0IGludGVyZmFjZSBGZXRjaE1ldGE8QSBleHRlbmRzIHJlYWRvbmx5IGFueVtdID0gcmVhZG9ubHkgYW55W10+IHtcbiAgYXJnczogQTtcbiAga2V5OiBzdHJpbmc7XG4gIHRocm90dGxlOiBib29sZWFuO1xuICByZXNvbHZlOiAodmFsdWU/OiBhbnkgfCBQcm9taXNlTGlrZTxhbnk+KSA9PiB2b2lkO1xuICByZWplY3Q6IChyZWFzb24/OiBhbnkpID0+IHZvaWQ7XG4gIHByb21pc2U6IFByb21pc2VMaWtlPGFueT47XG4gIGNyZWF0ZWRBdDogbnVtYmVyO1xuICAvLyBpbmRpY2F0ZXMgd2hldGhlciBuZXR3b3JrIG1hbmFnZXIgcHJvY2Vzc2VkIGl0XG4gIG5tPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGZXRjaEFjdGlvbjxFIGV4dGVuZHMgRW5kcG9pbnRBbmRVcGRhdGU8RT4gPSBFbmRwb2ludERlZmF1bHQ+IHtcbiAgdHlwZTogdHlwZW9mIEZFVENIX1RZUEU7XG4gIGVuZHBvaW50OiBFO1xuICBtZXRhOiBGZXRjaE1ldGE8cmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dPjtcbiAgcGF5bG9hZDogKCkgPT4gUmV0dXJuVHlwZTxFPjtcbn1cblxuLyogT1BUSU1JU1RJQyAqL1xuZXhwb3J0IGludGVyZmFjZSBPcHRpbWlzdGljQWN0aW9uPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRBbmRVcGRhdGU8RT4gPSBFbmRwb2ludERlZmF1bHQsXG4+IHtcbiAgdHlwZTogdHlwZW9mIE9QVElNSVNUSUNfVFlQRTtcbiAgZW5kcG9pbnQ6IEU7XG4gIG1ldGE6IFNldE1ldGE7XG4gIGVycm9yPzogZmFsc2U7XG59XG5cbi8qIFNVQlNDUklCRSAqL1xuZXhwb3J0IGludGVyZmFjZSBTdWJzY3JpYmVBY3Rpb248XG4gIEUgZXh0ZW5kcyBFbmRwb2ludEFuZFVwZGF0ZTxFPiA9IEVuZHBvaW50RGVmYXVsdCxcbj4ge1xuICB0eXBlOiB0eXBlb2YgU1VCU0NSSUJFX1RZUEU7XG4gIGVuZHBvaW50OiBFO1xuICBtZXRhOiB7XG4gICAgYXJnczogcmVhZG9ubHkgYW55W107XG4gICAga2V5OiBzdHJpbmc7XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVW5zdWJzY3JpYmVBY3Rpb248XG4gIEUgZXh0ZW5kcyBFbmRwb2ludEFuZFVwZGF0ZTxFPiA9IEVuZHBvaW50RGVmYXVsdCxcbj4ge1xuICB0eXBlOiB0eXBlb2YgVU5TVUJTQ1JJQkVfVFlQRTtcbiAgZW5kcG9pbnQ6IEU7XG4gIG1ldGE6IHtcbiAgICBhcmdzOiByZWFkb25seSBhbnlbXTtcbiAgICBrZXk6IHN0cmluZztcbiAgfTtcbn1cblxuLyogRVhQSVJZICovXG5leHBvcnQgaW50ZXJmYWNlIEV4cGlyZUFsbEFjdGlvbiB7XG4gIHR5cGU6IHR5cGVvZiBFWFBJUkVBTExfVFlQRTtcbiAgdGVzdEtleTogKGtleTogc3RyaW5nKSA9PiBib29sZWFuO1xufVxuXG4vKiBJTlZBTElEQVRFICovXG5leHBvcnQgaW50ZXJmYWNlIEludmFsaWRhdGVBbGxBY3Rpb24ge1xuICB0eXBlOiB0eXBlb2YgSU5WQUxJREFURUFMTF9UWVBFO1xuICB0ZXN0S2V5OiAoa2V5OiBzdHJpbmcpID0+IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW52YWxpZGF0ZUFjdGlvbiB7XG4gIHR5cGU6IHR5cGVvZiBJTlZBTElEQVRFX1RZUEU7XG4gIG1ldGE6IHtcbiAgICBrZXk6IHN0cmluZztcbiAgfTtcbn1cblxuLyogUkVTRVQgKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVzZXRBY3Rpb24ge1xuICB0eXBlOiB0eXBlb2YgUkVTRVRfVFlQRTtcbiAgZGF0ZTogbnVtYmVyO1xufVxuXG4vKiBHQyAqL1xuZXhwb3J0IGludGVyZmFjZSBHQ0FjdGlvbiB7XG4gIHR5cGU6IHR5cGVvZiBHQ19UWVBFO1xuICBlbnRpdGllczogW3N0cmluZywgc3RyaW5nXVtdO1xuICBlbmRwb2ludHM6IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgdHlwZSBBY3Rpb25UeXBlcyA9XG4gIHwgRmV0Y2hBY3Rpb25cbiAgfCBPcHRpbWlzdGljQWN0aW9uXG4gIHwgU2V0QWN0aW9uXG4gIHwgU3Vic2NyaWJlQWN0aW9uXG4gIHwgVW5zdWJzY3JpYmVBY3Rpb25cbiAgfCBJbnZhbGlkYXRlQWN0aW9uXG4gIHwgSW52YWxpZGF0ZUFsbEFjdGlvblxuICB8IEV4cGlyZUFsbEFjdGlvblxuICB8IFJlc2V0QWN0aW9uXG4gIHwgR0NBY3Rpb247XG4iXSwibWFwcGluZ3MiOiIiLCJpZ25vcmVMaXN0IjpbXX0=
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2FjdGlvbnMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBEZW5vcm1hbGl6ZSxcbiAgRW5kcG9pbnRJbnRlcmZhY2UsXG4gIFF1ZXJ5YWJsZSxcbiAgUmVzb2x2ZVR5cGUsXG4gIFVua25vd25FcnJvcixcbn0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB0eXBlIHtcbiAgU0VUX1RZUEUsXG4gIFJFU0VUX1RZUEUsXG4gIEZFVENIX1RZUEUsXG4gIFNVQlNDUklCRV9UWVBFLFxuICBVTlNVQlNDUklCRV9UWVBFLFxuICBJTlZBTElEQVRFX1RZUEUsXG4gIEdDX1RZUEUsXG4gIE9QVElNSVNUSUNfVFlQRSxcbiAgSU5WQUxJREFURUFMTF9UWVBFLFxuICBFWFBJUkVBTExfVFlQRSxcbiAgU0VUX1JFU1BPTlNFX1RZUEUsXG59IGZyb20gJy4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi9jb250cm9sbGVyL3R5cGVzLmpzJztcblxudHlwZSBFbmRwb2ludEFuZFVwZGF0ZTxFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2U+ID0gRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG59O1xudHlwZSBFbmRwb2ludERlZmF1bHQgPSBFbmRwb2ludEludGVyZmFjZSAmIHtcbiAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFbmRwb2ludEludGVyZmFjZT47XG59O1xuXG4vKiBTRVQgKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2V0TWV0YSB7XG4gIGFyZ3M6IHJlYWRvbmx5IGFueVtdO1xuICBmZXRjaGVkQXQ6IG51bWJlcjtcbiAgZGF0ZTogbnVtYmVyO1xuICBleHBpcmVzQXQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTZXRBY3Rpb248UyBleHRlbmRzIFF1ZXJ5YWJsZSA9IGFueT4ge1xuICB0eXBlOiB0eXBlb2YgU0VUX1RZUEU7XG4gIHNjaGVtYTogUztcbiAgbWV0YTogU2V0TWV0YTtcbiAgdmFsdWU6IERlbm9ybWFsaXplPFM+O1xufVxuXG4vKiBzZXRSZXNwb25zZSAqL1xuZXhwb3J0IGludGVyZmFjZSBTZXRSZXNwb25zZU1ldGEge1xuICBhcmdzOiByZWFkb25seSBhbnlbXTtcbiAga2V5OiBzdHJpbmc7XG4gIGZldGNoZWRBdDogbnVtYmVyO1xuICBkYXRlOiBudW1iZXI7XG4gIGV4cGlyZXNBdDogbnVtYmVyO1xufVxuZXhwb3J0IGludGVyZmFjZSBTZXRSZXNwb25zZUFjdGlvblN1Y2Nlc3M8XG4gIEUgZXh0ZW5kcyBFbmRwb2ludEFuZFVwZGF0ZTxFPiA9IEVuZHBvaW50RGVmYXVsdCxcbj4ge1xuICB0eXBlOiB0eXBlb2YgU0VUX1JFU1BPTlNFX1RZUEU7XG4gIGVuZHBvaW50OiBFO1xuICBtZXRhOiBTZXRSZXNwb25zZU1ldGE7XG4gIHBheWxvYWQ6IFJlc29sdmVUeXBlPEU+O1xuICBlcnJvcj86IGZhbHNlO1xufVxuZXhwb3J0IGludGVyZmFjZSBTZXRSZXNwb25zZUFjdGlvbkVycm9yPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRBbmRVcGRhdGU8RT4gPSBFbmRwb2ludERlZmF1bHQsXG4+IHtcbiAgdHlwZTogdHlwZW9mIFNFVF9SRVNQT05TRV9UWVBFO1xuICBlbmRwb2ludDogRTtcbiAgbWV0YTogU2V0UmVzcG9uc2VNZXRhO1xuICBwYXlsb2FkOiBVbmtub3duRXJyb3I7XG4gIGVycm9yOiB0cnVlO1xufVxuZXhwb3J0IHR5cGUgU2V0UmVzcG9uc2VBY3Rpb248XG4gIEUgZXh0ZW5kcyBFbmRwb2ludEFuZFVwZGF0ZTxFPiA9IEVuZHBvaW50RGVmYXVsdCxcbj4gPSBTZXRSZXNwb25zZUFjdGlvblN1Y2Nlc3M8RT4gfCBTZXRSZXNwb25zZUFjdGlvbkVycm9yPEU+O1xuXG4vKiBGRVRDSCAqL1xuZXhwb3J0IGludGVyZmFjZSBGZXRjaE1ldGE8QSBleHRlbmRzIHJlYWRvbmx5IGFueVtdID0gcmVhZG9ubHkgYW55W10+IHtcbiAgYXJnczogQTtcbiAga2V5OiBzdHJpbmc7XG4gIHRocm90dGxlOiBib29sZWFuO1xuICByZXNvbHZlOiAodmFsdWU/OiBhbnkgfCBQcm9taXNlTGlrZTxhbnk+KSA9PiB2b2lkO1xuICByZWplY3Q6IChyZWFzb24/OiBhbnkpID0+IHZvaWQ7XG4gIHByb21pc2U6IFByb21pc2VMaWtlPGFueT47XG4gIGNyZWF0ZWRBdDogbnVtYmVyO1xuICAvLyBpbmRpY2F0ZXMgd2hldGhlciBuZXR3b3JrIG1hbmFnZXIgcHJvY2Vzc2VkIGl0XG4gIG5tPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGZXRjaEFjdGlvbjxFIGV4dGVuZHMgRW5kcG9pbnRBbmRVcGRhdGU8RT4gPSBFbmRwb2ludERlZmF1bHQ+IHtcbiAgdHlwZTogdHlwZW9mIEZFVENIX1RZUEU7XG4gIGVuZHBvaW50OiBFO1xuICBtZXRhOiBGZXRjaE1ldGE8cmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dPjtcbiAgcGF5bG9hZDogKCkgPT4gUmV0dXJuVHlwZTxFPjtcbn1cblxuLyogT1BUSU1JU1RJQyAqL1xuZXhwb3J0IGludGVyZmFjZSBPcHRpbWlzdGljQWN0aW9uPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRBbmRVcGRhdGU8RT4gPSBFbmRwb2ludERlZmF1bHQsXG4+IHtcbiAgdHlwZTogdHlwZW9mIE9QVElNSVNUSUNfVFlQRTtcbiAgZW5kcG9pbnQ6IEU7XG4gIG1ldGE6IFNldFJlc3BvbnNlTWV0YTtcbiAgZXJyb3I/OiBmYWxzZTtcbn1cblxuLyogU1VCU0NSSUJFICovXG5leHBvcnQgaW50ZXJmYWNlIFN1YnNjcmliZUFjdGlvbjxcbiAgRSBleHRlbmRzIEVuZHBvaW50QW5kVXBkYXRlPEU+ID0gRW5kcG9pbnREZWZhdWx0LFxuPiB7XG4gIHR5cGU6IHR5cGVvZiBTVUJTQ1JJQkVfVFlQRTtcbiAgZW5kcG9pbnQ6IEU7XG4gIG1ldGE6IHtcbiAgICBhcmdzOiByZWFkb25seSBhbnlbXTtcbiAgICBrZXk6IHN0cmluZztcbiAgfTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVbnN1YnNjcmliZUFjdGlvbjxcbiAgRSBleHRlbmRzIEVuZHBvaW50QW5kVXBkYXRlPEU+ID0gRW5kcG9pbnREZWZhdWx0LFxuPiB7XG4gIHR5cGU6IHR5cGVvZiBVTlNVQlNDUklCRV9UWVBFO1xuICBlbmRwb2ludDogRTtcbiAgbWV0YToge1xuICAgIGFyZ3M6IHJlYWRvbmx5IGFueVtdO1xuICAgIGtleTogc3RyaW5nO1xuICB9O1xufVxuXG4vKiBFWFBJUlkgKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXhwaXJlQWxsQWN0aW9uIHtcbiAgdHlwZTogdHlwZW9mIEVYUElSRUFMTF9UWVBFO1xuICB0ZXN0S2V5OiAoa2V5OiBzdHJpbmcpID0+IGJvb2xlYW47XG59XG5cbi8qIElOVkFMSURBVEUgKi9cbmV4cG9ydCBpbnRlcmZhY2UgSW52YWxpZGF0ZUFsbEFjdGlvbiB7XG4gIHR5cGU6IHR5cGVvZiBJTlZBTElEQVRFQUxMX1RZUEU7XG4gIHRlc3RLZXk6IChrZXk6IHN0cmluZykgPT4gYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJbnZhbGlkYXRlQWN0aW9uIHtcbiAgdHlwZTogdHlwZW9mIElOVkFMSURBVEVfVFlQRTtcbiAgbWV0YToge1xuICAgIGtleTogc3RyaW5nO1xuICB9O1xufVxuXG4vKiBSRVNFVCAqL1xuZXhwb3J0IGludGVyZmFjZSBSZXNldEFjdGlvbiB7XG4gIHR5cGU6IHR5cGVvZiBSRVNFVF9UWVBFO1xuICBkYXRlOiBudW1iZXI7XG59XG5cbi8qIEdDICovXG5leHBvcnQgaW50ZXJmYWNlIEdDQWN0aW9uIHtcbiAgdHlwZTogdHlwZW9mIEdDX1RZUEU7XG4gIGVudGl0aWVzOiBbc3RyaW5nLCBzdHJpbmddW107XG4gIGVuZHBvaW50czogc3RyaW5nW107XG59XG5cbmV4cG9ydCB0eXBlIEFjdGlvblR5cGVzID1cbiAgfCBGZXRjaEFjdGlvblxuICB8IE9wdGltaXN0aWNBY3Rpb25cbiAgfCBTZXRBY3Rpb25cbiAgfCBTZXRSZXNwb25zZUFjdGlvblxuICB8IFN1YnNjcmliZUFjdGlvblxuICB8IFVuc3Vic2NyaWJlQWN0aW9uXG4gIHwgSW52YWxpZGF0ZUFjdGlvblxuICB8IEludmFsaWRhdGVBbGxBY3Rpb25cbiAgfCBFeHBpcmVBbGxBY3Rpb25cbiAgfCBSZXNldEFjdGlvblxuICB8IEdDQWN0aW9uO1xuIl0sIm1hcHBpbmdzIjoiIiwiaWdub3JlTGlzdCI6W119
@@ -6,6 +6,7 @@ import createInvalidate from './createInvalidate.js';
6
6
  import createInvalidateAll from './createInvalidateAll.js';
7
7
  import createReset from './createReset.js';
8
8
  import createSet from './createSet.js';
9
+ import createSetResponse from './createSetResponse.js';
9
10
  import { createUnsubscription, createSubscription } from './createSubscription.js';
10
11
  import ensurePojo from './ensurePojo.js';
11
12
  import { initialState } from '../state/reducer/createReducer.js';
@@ -14,7 +15,7 @@ const unsetDispatch = action => {
14
15
  throw new Error(`Dispatching while constructing your middleware is not allowed. ` + `Other middleware would not be applied to this dispatch.`);
15
16
  };
16
17
  const unsetState = () => {
17
- // This is only the value until it is set by the CacheProvider
18
+ // This is only the value until it is set by the DataProvider
18
19
  /* istanbul ignore next */
19
20
  return initialState;
20
21
  };
@@ -100,24 +101,37 @@ export default class Controller {
100
101
  */
101
102
  this.resetEntireStore = () => this.dispatch(createReset());
102
103
  /**
103
- * Stores response in cache for given Endpoint and args.
104
+ * Sets value for the Queryable and args.
104
105
  * @see https://dataclient.io/docs/api/Controller#set
105
106
  */
107
+ this.set = (schema, ...rest) => {
108
+ const value = rest[rest.length - 1];
109
+ const action = createSet(schema, {
110
+ args: rest.slice(0, rest.length - 1),
111
+ value
112
+ });
113
+ // TODO: reject with error if this fails in reducer
114
+ return this.dispatch(action);
115
+ };
116
+ /**
117
+ * Sets response for the Endpoint and args.
118
+ * @see https://dataclient.io/docs/api/Controller#setResponse
119
+ */
106
120
  this.setResponse = (endpoint, ...rest) => {
107
121
  const response = rest[rest.length - 1];
108
- const action = createSet(endpoint, {
122
+ const action = createSetResponse(endpoint, {
109
123
  args: rest.slice(0, rest.length - 1),
110
124
  response
111
125
  });
112
126
  return this.dispatch(action);
113
127
  };
114
128
  /**
115
- * Stores the result of Endpoint and args as the error provided.
129
+ * Sets an error response for the Endpoint and args.
116
130
  * @see https://dataclient.io/docs/api/Controller#setError
117
131
  */
118
132
  this.setError = (endpoint, ...rest) => {
119
133
  const response = rest[rest.length - 1];
120
- const action = createSet(endpoint, {
134
+ const action = createSetResponse(endpoint, {
121
135
  args: rest.slice(0, rest.length - 1),
122
136
  response,
123
137
  error: true
@@ -129,7 +143,7 @@ export default class Controller {
129
143
  * @see https://dataclient.io/docs/api/Controller#resolve
130
144
  */
131
145
  this.resolve = (endpoint, meta) => {
132
- return this.dispatch(createSet(endpoint, meta));
146
+ return this.dispatch(createSetResponse(endpoint, meta));
133
147
  };
134
148
  /**
135
149
  * Marks a new subscription to a given Endpoint.
@@ -330,4 +344,4 @@ class Snapshot {
330
344
  }
331
345
  }
332
346
  Snapshot.abort = new AbortOptimistic();
333
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ExpiryStatus","MemoCache","isEntity","denormalize","validateQueryKey","AbortOptimistic","createExpireAll","createFetch","createInvalidate","createInvalidateAll","createReset","createSet","createUnsubscription","createSubscription","ensurePojo","initialState","selectMeta","unsetDispatch","action","Error","unsetState","Controller","constructor","dispatch","getState","memo","fetch","endpoint","args","schema","meta","promise","then","input","fetchIfStale","data","expiresAt","expiryStatus","getResponse","Invalid","Date","now","invalidate","Promise","resolve","invalidateAll","options","key","testKey","expireAll","resetEntireStore","setResponse","rest","response","length","slice","setError","error","subscribe","unsubscribe","snapshot","state","fetchedAt","Snapshot","getError","endpoints","undefined","errorPolicy","map","isActive","cacheEndpoints","shouldQuery","buildQueryKey","entities","indexes","Valid","Infinity","isInvalid","schemaHasEntity","invalidated","invalidIfStale","InvalidIfStale","paths","getSchemaResponse","entityMeta","get","JSON","stringify","query","invalidDenormalize","entityExpiresAt","pk","_entityMeta$key","entityExpiry","Array","isArray","nestedSchema","Object","values","some","x","controller","abort"],"sources":["../../src/controller/Controller.ts"],"sourcesContent":["import type {\n  ErrorTypes,\n  SnapshotInterface,\n  Schema,\n  Denormalize,\n  Queryable,\n  SchemaArgs,\n  NI,\n} from '@data-client/normalizr';\nimport {\n  ExpiryStatus,\n  EndpointInterface,\n  FetchFunction,\n  ResolveType,\n  DenormalizeNullable,\n  EntityPath,\n  MemoCache,\n  isEntity,\n  denormalize,\n  validateQueryKey,\n} from '@data-client/normalizr';\n\nimport AbortOptimistic from './AbortOptimistic.js';\nimport createExpireAll from './createExpireAll.js';\nimport createFetch from './createFetch.js';\nimport createInvalidate from './createInvalidate.js';\nimport createInvalidateAll from './createInvalidateAll.js';\nimport createReset from './createReset.js';\nimport createSet from './createSet.js';\nimport {\n  createUnsubscription,\n  createSubscription,\n} from './createSubscription.js';\nimport ensurePojo from './ensurePojo.js';\nimport type { EndpointUpdateFunction } from './types.js';\nimport { initialState } from '../state/reducer/createReducer.js';\nimport selectMeta from '../state/selectMeta.js';\nimport type { ActionTypes, State } from '../types.js';\n\nexport type GenericDispatch = (value: any) => Promise<void>;\nexport type DataClientDispatch = (value: ActionTypes) => Promise<void>;\n\ninterface ConstructorProps<D extends GenericDispatch = DataClientDispatch> {\n  dispatch?: D;\n  getState?: () => State<unknown>;\n  memo?: Pick<MemoCache, 'denormalize' | 'query' | 'buildQueryKey'>;\n}\n\nconst unsetDispatch = (action: unknown): Promise<void> => {\n  throw new Error(\n    `Dispatching while constructing your middleware is not allowed. ` +\n      `Other middleware would not be applied to this dispatch.`,\n  );\n};\nconst unsetState = (): State<unknown> => {\n  // This is only the value until it is set by the CacheProvider\n  /* istanbul ignore next */\n  return initialState;\n};\n\n/**\n * Imperative control of Reactive Data Client store\n * @see https://dataclient.io/docs/api/Controller\n */\nexport default class Controller<\n  D extends GenericDispatch = DataClientDispatch,\n> {\n  /**\n   * Dispatches an action to Reactive Data Client reducer.\n   *\n   * @see https://dataclient.io/docs/api/Controller#dispatch\n   */\n  declare readonly dispatch: D;\n  /**\n   * Gets the latest state snapshot that is fully committed.\n   *\n   * This can be useful for imperative use-cases like event handlers.\n   * This should *not* be used to render; instead useSuspense() or useCache()\n   * @see https://dataclient.io/docs/api/Controller#getState\n   */\n  declare readonly getState: () => State<unknown>;\n  /**\n   * Singleton to maintain referential equality between calls\n   */\n  declare readonly memo: Pick<\n    MemoCache,\n    'denormalize' | 'query' | 'buildQueryKey'\n  >;\n\n  constructor({\n    dispatch = unsetDispatch as any,\n    getState = unsetState,\n    memo = new MemoCache(),\n  }: ConstructorProps<D> = {}) {\n    this.dispatch = dispatch;\n    this.getState = getState;\n    this.memo = memo;\n  }\n\n  /*************** Action Dispatchers ***************/\n\n  /**\n   * Fetches the endpoint with given args, updating the Reactive Data Client cache with the response or error upon completion.\n   * @see https://dataclient.io/docs/api/Controller#fetch\n   */\n  fetch = <\n    E extends EndpointInterface & { update?: EndpointUpdateFunction<E> },\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>]\n  ): E['schema'] extends undefined | null ? ReturnType<E>\n  : Promise<Denormalize<E['schema']>> => {\n    const action = createFetch(endpoint, {\n      args,\n    });\n    this.dispatch(action);\n\n    if (endpoint.schema) {\n      return action.meta.promise.then(input =>\n        denormalize(input, endpoint.schema, {}, args),\n      ) as any;\n    }\n    return action.meta.promise as any;\n  };\n\n  /**\n   * Fetches only if endpoint is considered 'stale'; otherwise returns undefined\n   * @see https://dataclient.io/docs/api/Controller#fetchIfStale\n   */\n  fetchIfStale = <\n    E extends EndpointInterface & { update?: EndpointUpdateFunction<E> },\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>]\n  ): E['schema'] extends undefined | null ? ReturnType<E> | ResolveType<E>\n  : Promise<Denormalize<E['schema']>> | Denormalize<E['schema']> => {\n    const { data, expiresAt, expiryStatus } = this.getResponse(\n      endpoint,\n      ...args,\n      this.getState(),\n    );\n    if (expiryStatus !== ExpiryStatus.Invalid && Date.now() <= expiresAt)\n      return data as any;\n    return this.fetch(endpoint, ...args);\n  };\n\n  /**\n   * Forces refetching and suspense on useSuspense with the same Endpoint and parameters.\n   * @see https://dataclient.io/docs/api/Controller#invalidate\n   */\n  invalidate = <E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null ?\n      this.dispatch(\n        createInvalidate(endpoint, {\n          args: args as Parameters<E>,\n        }),\n      )\n    : Promise.resolve();\n\n  /**\n   * Forces refetching and suspense on useSuspense on all matching endpoint result keys.\n   * @see https://dataclient.io/docs/api/Controller#invalidateAll\n   * @returns Promise that resolves when invalidation is commited.\n   */\n  invalidateAll = (options: { testKey: (key: string) => boolean }) =>\n    this.dispatch(createInvalidateAll((key: string) => options.testKey(key)));\n\n  /**\n   * Sets all matching endpoint result keys to be STALE.\n   * @see https://dataclient.io/docs/api/Controller#expireAll\n   * @returns Promise that resolves when expiry is commited. *NOT* fetch promise\n   */\n  expireAll = (options: { testKey: (key: string) => boolean }) =>\n    this.dispatch(createExpireAll((key: string) => options.testKey(key)));\n\n  /**\n   * Resets the entire Reactive Data Client cache. All inflight requests will not resolve.\n   * @see https://dataclient.io/docs/api/Controller#resetEntireStore\n   */\n  resetEntireStore = (): Promise<void> => this.dispatch(createReset());\n\n  /**\n   * Stores response in cache for given Endpoint and args.\n   * @see https://dataclient.io/docs/api/Controller#set\n   */\n  setResponse = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, any]\n  ): Promise<void> => {\n    const response: ResolveType<E> = rest[rest.length - 1];\n    const action = createSet(endpoint, {\n      args: rest.slice(0, rest.length - 1) as Parameters<E>,\n      response,\n    });\n    return this.dispatch(action);\n  };\n\n  /**\n   * Stores the result of Endpoint and args as the error provided.\n   * @see https://dataclient.io/docs/api/Controller#setError\n   */\n  setError = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, Error]\n  ): Promise<void> => {\n    const response: Error = rest[rest.length - 1];\n    const action = createSet(endpoint, {\n      args: rest.slice(0, rest.length - 1) as Parameters<E>,\n      response,\n      error: true,\n    });\n    return this.dispatch(action);\n  };\n\n  /**\n   * Resolves an inflight fetch. `fetchedAt` should `fetch`'s `createdAt`\n   * @see https://dataclient.io/docs/api/Controller#resolve\n   */\n  resolve = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    meta:\n      | {\n          args: readonly [...Parameters<E>];\n          response: Error;\n          fetchedAt: number;\n          error: true;\n        }\n      | {\n          args: readonly [...Parameters<E>];\n          response: any;\n          fetchedAt: number;\n          error?: false | undefined;\n        },\n  ): Promise<void> => {\n    return this.dispatch(createSet(endpoint, meta as any));\n  };\n\n  /**\n   * Marks a new subscription to a given Endpoint.\n   * @see https://dataclient.io/docs/api/Controller#subscribe\n   */\n  subscribe = <\n    E extends EndpointInterface<\n      FetchFunction,\n      Schema | undefined,\n      undefined | false\n    >,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null ?\n      this.dispatch(\n        createSubscription(endpoint, {\n          args: args as Parameters<E>,\n        }),\n      )\n    : Promise.resolve();\n\n  /**\n   * Marks completion of subscription to a given Endpoint.\n   * @see https://dataclient.io/docs/api/Controller#unsubscribe\n   */\n  unsubscribe = <\n    E extends EndpointInterface<\n      FetchFunction,\n      Schema | undefined,\n      undefined | false\n    >,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null ?\n      this.dispatch(\n        createUnsubscription(endpoint, {\n          args: args as Parameters<E>,\n        }),\n      )\n    : Promise.resolve();\n\n  /*************** More ***************/\n\n  /* TODO:\n  abort = <E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>]\n  ): Promise<void>\n  */\n\n  /**\n   * Gets a snapshot (https://dataclient.io/docs/api/Snapshot)\n   * @see https://dataclient.io/docs/api/Controller#snapshot\n   */\n  snapshot = (state: State<unknown>, fetchedAt?: number): SnapshotInterface => {\n    return new Snapshot(this, state, fetchedAt);\n  };\n\n  /**\n   * Gets the error, if any, for a given endpoint. Returns undefined for no errors.\n   * @see https://dataclient.io/docs/api/Controller#getError\n   */\n  getError<E extends EndpointInterface>(\n    endpoint: E,\n    ...rest:\n      | readonly [null, State<unknown>]\n      | readonly [...Parameters<E>, State<unknown>]\n  ): ErrorTypes | undefined;\n\n  getError<E extends Pick<EndpointInterface, 'key'>>(\n    endpoint: E,\n    ...rest:\n      | readonly [null, State<unknown>]\n      | readonly [...Parameters<E['key']>, State<unknown>]\n  ): ErrorTypes | undefined;\n\n  getError(\n    endpoint: EndpointInterface,\n    ...rest: readonly [...unknown[], State<unknown>]\n  ): ErrorTypes | undefined {\n    if (rest[0] === null) return;\n    const state = rest[rest.length - 1] as State<unknown>;\n    // this is typescript generics breaking\n    const args: any = rest.slice(0, rest.length - 1);\n    const key = endpoint.key(...args);\n\n    const meta = selectMeta(state, key);\n    const error = state.endpoints[key];\n\n    if (error !== undefined && meta?.errorPolicy === 'soft') return;\n\n    return meta?.error as any;\n  }\n\n  /**\n   * Gets the (globally referentially stable) response for a given endpoint/args pair from state given.\n   * @see https://dataclient.io/docs/api/Controller#getResponse\n   */\n  getResponse<E extends EndpointInterface>(\n    endpoint: E,\n    ...rest:\n      | readonly [null, State<unknown>]\n      | readonly [...Parameters<E>, State<unknown>]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  };\n\n  getResponse<\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n  >(\n    endpoint: E,\n    ...rest: readonly [\n      ...(readonly [...Parameters<E['key']>] | readonly [null]),\n      State<unknown>,\n    ]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  };\n\n  getResponse(\n    endpoint: EndpointInterface,\n    ...rest: readonly [...unknown[], State<unknown>]\n  ): {\n    data: unknown;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } {\n    const state = rest[rest.length - 1] as State<unknown>;\n    // this is typescript generics breaking\n    const args: any = rest\n      .slice(0, rest.length - 1)\n      // handle FormData\n      .map(ensurePojo);\n    const isActive = args.length !== 1 || args[0] !== null;\n    const key = isActive ? endpoint.key(...args) : '';\n    const cacheEndpoints = isActive ? state.endpoints[key] : undefined;\n    const schema = endpoint.schema;\n    const meta = selectMeta(state, key);\n    let expiresAt = meta?.expiresAt;\n    // if we have no endpoint entry, and our endpoint has a schema - try querying the store\n    const shouldQuery = cacheEndpoints === undefined && schema !== undefined;\n\n    const input =\n      shouldQuery ?\n        // nothing in endpoints cache, so try querying if we have a schema to do so\n        this.memo.buildQueryKey(\n          key,\n          schema,\n          args,\n          state.entities as any,\n          state.indexes,\n        )\n      : cacheEndpoints;\n\n    if (!isActive) {\n      // when not active simply return the query input without denormalizing\n      return {\n        data: input as any,\n        expiryStatus: ExpiryStatus.Valid,\n        expiresAt: Infinity,\n      };\n    }\n\n    let isInvalid = false;\n    if (shouldQuery) {\n      isInvalid = !validateQueryKey(input);\n    } else if (!schema || !schemaHasEntity(schema)) {\n      return {\n        data: cacheEndpoints,\n        expiryStatus:\n          meta?.invalidated ? ExpiryStatus.Invalid\n          : cacheEndpoints && !endpoint.invalidIfStale ? ExpiryStatus.Valid\n          : ExpiryStatus.InvalidIfStale,\n        expiresAt: expiresAt || 0,\n      };\n    }\n\n    // second argument is false if any entities are missing\n    // eslint-disable-next-line prefer-const\n    const { data, paths } = this.memo.denormalize(\n      input,\n      schema,\n      state.entities,\n      args,\n    ) as { data: any; paths: EntityPath[] };\n\n    // note: isInvalid can only be true if shouldQuery is true\n    if (!expiresAt && isInvalid) expiresAt = 1;\n\n    return this.getSchemaResponse(\n      data,\n      paths,\n      state.entityMeta,\n      expiresAt,\n      endpoint.invalidIfStale || isInvalid,\n      meta,\n    );\n  }\n\n  /**\n   * Queries the store for a Querable schema\n   * @see https://dataclient.io/docs/api/Controller#get\n   */\n  get<S extends Queryable>(\n    schema: S,\n    ...rest: readonly [\n      ...SchemaArgs<S>,\n      Pick<State<unknown>, 'entities' | 'entityMeta'>,\n    ]\n  ): DenormalizeNullable<S> | undefined {\n    const state = rest[rest.length - 1] as State<any>;\n    // this is typescript generics breaking\n    const args: any = rest\n      .slice(0, rest.length - 1)\n      .map(ensurePojo) as SchemaArgs<S>;\n\n    // NOTE: different orders can result in cache busting here; but since it's just a perf penalty we will allow for now\n    const key = JSON.stringify(args);\n\n    return this.memo.query(\n      key,\n      schema,\n      args,\n      state.entities as any,\n      state.indexes,\n    );\n  }\n\n  private getSchemaResponse<T>(\n    data: T,\n    paths: EntityPath[],\n    entityMeta: State<unknown>['entityMeta'],\n    expiresAt: number,\n    invalidIfStale: boolean,\n    meta: { error?: unknown; invalidated?: unknown } = {},\n  ): {\n    data: T;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } {\n    const invalidDenormalize = typeof data === 'symbol';\n\n    // fallback to entity expiry time\n    if (!expiresAt) {\n      expiresAt = entityExpiresAt(paths, entityMeta);\n    }\n\n    // https://dataclient.io/docs/concepts/expiry-policy#expiry-status\n    // we don't track the difference between stale or fresh because that is tied to triggering\n    // conditions\n    const expiryStatus =\n      meta?.invalidated || (invalidDenormalize && !meta?.error) ?\n        ExpiryStatus.Invalid\n      : invalidDenormalize || invalidIfStale ? ExpiryStatus.InvalidIfStale\n      : ExpiryStatus.Valid;\n\n    return { data, expiryStatus, expiresAt };\n  }\n}\n\n// benchmark: https://www.measurethat.net/Benchmarks/Show/24691/0/min-reducer-vs-imperative-with-paths\n// earliest expiry dictates age\nfunction entityExpiresAt(\n  paths: EntityPath[],\n  entityMeta: {\n    readonly [entityKey: string]: {\n      readonly [pk: string]: {\n        readonly date: number;\n        readonly expiresAt: number;\n        readonly fetchedAt: number; // This is only the value until it is set by the CacheProvider\n      };\n    };\n  },\n) {\n  let expiresAt = Infinity;\n  for (const { pk, key } of paths) {\n    const entityExpiry = entityMeta[key]?.[pk]?.expiresAt;\n    // expiresAt will always resolve to false with any comparison\n    if (entityExpiry < expiresAt) expiresAt = entityExpiry;\n  }\n  return expiresAt;\n}\n\n/** Determine whether the schema has any entities.\n *\n * Without entities, denormalization is not needed, and results should not be queried.\n */\nfunction schemaHasEntity(schema: Schema): boolean {\n  if (isEntity(schema)) return true;\n  if (Array.isArray(schema))\n    return schema.length !== 0 && schemaHasEntity(schema[0]);\n  if (schema && (typeof schema === 'object' || typeof schema === 'function')) {\n    const nestedSchema =\n      'schema' in schema ? (schema.schema as Record<string, Schema>) : schema;\n    if (typeof nestedSchema === 'function') {\n      return schemaHasEntity(nestedSchema);\n    }\n    return Object.values(nestedSchema).some(x => schemaHasEntity(x));\n  }\n  return false;\n}\n\nexport type { ErrorTypes };\n\nclass Snapshot<T = unknown> implements SnapshotInterface {\n  static readonly abort = new AbortOptimistic();\n\n  private state: State<T>;\n  private controller: Controller;\n  readonly fetchedAt: number;\n  readonly abort = Snapshot.abort;\n\n  constructor(controller: Controller, state: State<T>, fetchedAt = 0) {\n    this.state = state;\n    this.controller = controller;\n    this.fetchedAt = fetchedAt;\n  }\n\n  /*************** Data Access ***************/\n  /** @see https://dataclient.io/docs/api/Snapshot#getResponse */\n  getResponse<E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [null]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  };\n\n  getResponse<E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  };\n\n  getResponse<\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E['key']>] | readonly [null]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  };\n\n  getResponse<\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E['key']>] | readonly [null]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } {\n    return this.controller.getResponse(endpoint, ...args, this.state);\n  }\n\n  /** @see https://dataclient.io/docs/api/Snapshot#getError */\n  getError<E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): ErrorTypes | undefined;\n\n  getError<E extends Pick<EndpointInterface, 'key'>>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E['key']>] | readonly [null]\n  ): ErrorTypes | undefined;\n\n  getError<E extends Pick<EndpointInterface, 'key'>>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E['key']>] | readonly [null]\n  ): ErrorTypes | undefined {\n    return this.controller.getError(endpoint, ...args, this.state);\n  }\n\n  /**\n   * Retrieved memoized value for any Querable schema\n   * @see https://dataclient.io/docs/api/Snapshot#get\n   */\n  get<S extends Queryable>(\n    schema: S,\n    ...args: SchemaArgs<S>\n  ): DenormalizeNullable<S> | undefined {\n    return this.controller.get(schema, ...args, this.state);\n  }\n}\n"],"mappings":"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","ignoreList":[]}
347
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ExpiryStatus","MemoCache","isEntity","denormalize","validateQueryKey","AbortOptimistic","createExpireAll","createFetch","createInvalidate","createInvalidateAll","createReset","createSet","createSetResponse","createUnsubscription","createSubscription","ensurePojo","initialState","selectMeta","unsetDispatch","action","Error","unsetState","Controller","constructor","dispatch","getState","memo","fetch","endpoint","args","schema","meta","promise","then","input","fetchIfStale","data","expiresAt","expiryStatus","getResponse","Invalid","Date","now","invalidate","Promise","resolve","invalidateAll","options","key","testKey","expireAll","resetEntireStore","set","rest","value","length","slice","setResponse","response","setError","error","subscribe","unsubscribe","snapshot","state","fetchedAt","Snapshot","getError","endpoints","undefined","errorPolicy","map","isActive","cacheEndpoints","shouldQuery","buildQueryKey","entities","indexes","Valid","Infinity","isInvalid","schemaHasEntity","invalidated","invalidIfStale","InvalidIfStale","paths","getSchemaResponse","entityMeta","get","JSON","stringify","query","invalidDenormalize","entityExpiresAt","pk","_entityMeta$key","entityExpiry","Array","isArray","nestedSchema","Object","values","some","x","controller","abort"],"sources":["../../src/controller/Controller.ts"],"sourcesContent":["import type {\n  ErrorTypes,\n  SnapshotInterface,\n  Schema,\n  Denormalize,\n  Queryable,\n  SchemaArgs,\n} from '@data-client/normalizr';\nimport {\n  ExpiryStatus,\n  EndpointInterface,\n  FetchFunction,\n  ResolveType,\n  DenormalizeNullable,\n  EntityPath,\n  MemoCache,\n  isEntity,\n  denormalize,\n  validateQueryKey,\n} from '@data-client/normalizr';\n\nimport AbortOptimistic from './AbortOptimistic.js';\nimport createExpireAll from './createExpireAll.js';\nimport createFetch from './createFetch.js';\nimport createInvalidate from './createInvalidate.js';\nimport createInvalidateAll from './createInvalidateAll.js';\nimport createReset from './createReset.js';\nimport createSet from './createSet.js';\nimport createSetResponse from './createSetResponse.js';\nimport {\n  createUnsubscription,\n  createSubscription,\n} from './createSubscription.js';\nimport ensurePojo from './ensurePojo.js';\nimport type { EndpointUpdateFunction } from './types.js';\nimport { initialState } from '../state/reducer/createReducer.js';\nimport selectMeta from '../state/selectMeta.js';\nimport type { ActionTypes, State } from '../types.js';\n\nexport type GenericDispatch = (value: any) => Promise<void>;\nexport type DataClientDispatch = (value: ActionTypes) => Promise<void>;\n\ninterface ConstructorProps<D extends GenericDispatch = DataClientDispatch> {\n  dispatch?: D;\n  getState?: () => State<unknown>;\n  memo?: Pick<MemoCache, 'denormalize' | 'query' | 'buildQueryKey'>;\n}\n\nconst unsetDispatch = (action: unknown): Promise<void> => {\n  throw new Error(\n    `Dispatching while constructing your middleware is not allowed. ` +\n      `Other middleware would not be applied to this dispatch.`,\n  );\n};\nconst unsetState = (): State<unknown> => {\n  // This is only the value until it is set by the DataProvider\n  /* istanbul ignore next */\n  return initialState;\n};\n\n/**\n * Imperative control of Reactive Data Client store\n * @see https://dataclient.io/docs/api/Controller\n */\nexport default class Controller<\n  D extends GenericDispatch = DataClientDispatch,\n> {\n  /**\n   * Dispatches an action to Reactive Data Client reducer.\n   *\n   * @see https://dataclient.io/docs/api/Controller#dispatch\n   */\n  declare readonly dispatch: D;\n  /**\n   * Gets the latest state snapshot that is fully committed.\n   *\n   * This can be useful for imperative use-cases like event handlers.\n   * This should *not* be used to render; instead useSuspense() or useCache()\n   * @see https://dataclient.io/docs/api/Controller#getState\n   */\n  declare readonly getState: () => State<unknown>;\n  /**\n   * Singleton to maintain referential equality between calls\n   */\n  declare readonly memo: Pick<\n    MemoCache,\n    'denormalize' | 'query' | 'buildQueryKey'\n  >;\n\n  constructor({\n    dispatch = unsetDispatch as any,\n    getState = unsetState,\n    memo = new MemoCache(),\n  }: ConstructorProps<D> = {}) {\n    this.dispatch = dispatch;\n    this.getState = getState;\n    this.memo = memo;\n  }\n\n  /*************** Action Dispatchers ***************/\n\n  /**\n   * Fetches the endpoint with given args, updating the Reactive Data Client cache with the response or error upon completion.\n   * @see https://dataclient.io/docs/api/Controller#fetch\n   */\n  fetch = <\n    E extends EndpointInterface & { update?: EndpointUpdateFunction<E> },\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>]\n  ): E['schema'] extends undefined | null ? ReturnType<E>\n  : Promise<Denormalize<E['schema']>> => {\n    const action = createFetch(endpoint, {\n      args,\n    });\n    this.dispatch(action);\n\n    if (endpoint.schema) {\n      return action.meta.promise.then(input =>\n        denormalize(input, endpoint.schema, {}, args),\n      ) as any;\n    }\n    return action.meta.promise as any;\n  };\n\n  /**\n   * Fetches only if endpoint is considered 'stale'; otherwise returns undefined\n   * @see https://dataclient.io/docs/api/Controller#fetchIfStale\n   */\n  fetchIfStale = <\n    E extends EndpointInterface & { update?: EndpointUpdateFunction<E> },\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>]\n  ): E['schema'] extends undefined | null ? ReturnType<E> | ResolveType<E>\n  : Promise<Denormalize<E['schema']>> | Denormalize<E['schema']> => {\n    const { data, expiresAt, expiryStatus } = this.getResponse(\n      endpoint,\n      ...args,\n      this.getState(),\n    );\n    if (expiryStatus !== ExpiryStatus.Invalid && Date.now() <= expiresAt)\n      return data as any;\n    return this.fetch(endpoint, ...args);\n  };\n\n  /**\n   * Forces refetching and suspense on useSuspense with the same Endpoint and parameters.\n   * @see https://dataclient.io/docs/api/Controller#invalidate\n   */\n  invalidate = <E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null ?\n      this.dispatch(\n        createInvalidate(endpoint, {\n          args: args as Parameters<E>,\n        }),\n      )\n    : Promise.resolve();\n\n  /**\n   * Forces refetching and suspense on useSuspense on all matching endpoint result keys.\n   * @see https://dataclient.io/docs/api/Controller#invalidateAll\n   * @returns Promise that resolves when invalidation is commited.\n   */\n  invalidateAll = (options: { testKey: (key: string) => boolean }) =>\n    this.dispatch(createInvalidateAll((key: string) => options.testKey(key)));\n\n  /**\n   * Sets all matching endpoint result keys to be STALE.\n   * @see https://dataclient.io/docs/api/Controller#expireAll\n   * @returns Promise that resolves when expiry is commited. *NOT* fetch promise\n   */\n  expireAll = (options: { testKey: (key: string) => boolean }) =>\n    this.dispatch(createExpireAll((key: string) => options.testKey(key)));\n\n  /**\n   * Resets the entire Reactive Data Client cache. All inflight requests will not resolve.\n   * @see https://dataclient.io/docs/api/Controller#resetEntireStore\n   */\n  resetEntireStore = (): Promise<void> => this.dispatch(createReset());\n\n  /**\n   * Sets value for the Queryable and args.\n   * @see https://dataclient.io/docs/api/Controller#set\n   */\n  set = <S extends Queryable>(\n    schema: S,\n    ...rest: readonly [...SchemaArgs<S>, any]\n  ): Promise<void> => {\n    const value: Denormalize<S> = rest[rest.length - 1];\n    const action = createSet(schema, {\n      args: rest.slice(0, rest.length - 1) as SchemaArgs<S>,\n      value,\n    });\n    // TODO: reject with error if this fails in reducer\n    return this.dispatch(action);\n  };\n\n  /**\n   * Sets response for the Endpoint and args.\n   * @see https://dataclient.io/docs/api/Controller#setResponse\n   */\n  setResponse = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, any]\n  ): Promise<void> => {\n    const response: ResolveType<E> = rest[rest.length - 1];\n    const action = createSetResponse(endpoint, {\n      args: rest.slice(0, rest.length - 1) as Parameters<E>,\n      response,\n    });\n    return this.dispatch(action);\n  };\n\n  /**\n   * Sets an error response for the Endpoint and args.\n   * @see https://dataclient.io/docs/api/Controller#setError\n   */\n  setError = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, Error]\n  ): Promise<void> => {\n    const response: Error = rest[rest.length - 1];\n    const action = createSetResponse(endpoint, {\n      args: rest.slice(0, rest.length - 1) as Parameters<E>,\n      response,\n      error: true,\n    });\n    return this.dispatch(action);\n  };\n\n  /**\n   * Resolves an inflight fetch. `fetchedAt` should `fetch`'s `createdAt`\n   * @see https://dataclient.io/docs/api/Controller#resolve\n   */\n  resolve = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    meta:\n      | {\n          args: readonly [...Parameters<E>];\n          response: Error;\n          fetchedAt: number;\n          error: true;\n        }\n      | {\n          args: readonly [...Parameters<E>];\n          response: any;\n          fetchedAt: number;\n          error?: false | undefined;\n        },\n  ): Promise<void> => {\n    return this.dispatch(createSetResponse(endpoint, meta as any));\n  };\n\n  /**\n   * Marks a new subscription to a given Endpoint.\n   * @see https://dataclient.io/docs/api/Controller#subscribe\n   */\n  subscribe = <\n    E extends EndpointInterface<\n      FetchFunction,\n      Schema | undefined,\n      undefined | false\n    >,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null ?\n      this.dispatch(\n        createSubscription(endpoint, {\n          args: args as Parameters<E>,\n        }),\n      )\n    : Promise.resolve();\n\n  /**\n   * Marks completion of subscription to a given Endpoint.\n   * @see https://dataclient.io/docs/api/Controller#unsubscribe\n   */\n  unsubscribe = <\n    E extends EndpointInterface<\n      FetchFunction,\n      Schema | undefined,\n      undefined | false\n    >,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null ?\n      this.dispatch(\n        createUnsubscription(endpoint, {\n          args: args as Parameters<E>,\n        }),\n      )\n    : Promise.resolve();\n\n  /*************** More ***************/\n\n  /* TODO:\n  abort = <E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>]\n  ): Promise<void>\n  */\n\n  /**\n   * Gets a snapshot (https://dataclient.io/docs/api/Snapshot)\n   * @see https://dataclient.io/docs/api/Controller#snapshot\n   */\n  snapshot = (state: State<unknown>, fetchedAt?: number): SnapshotInterface => {\n    return new Snapshot(this, state, fetchedAt);\n  };\n\n  /**\n   * Gets the error, if any, for a given endpoint. Returns undefined for no errors.\n   * @see https://dataclient.io/docs/api/Controller#getError\n   */\n  getError<E extends EndpointInterface>(\n    endpoint: E,\n    ...rest:\n      | readonly [null, State<unknown>]\n      | readonly [...Parameters<E>, State<unknown>]\n  ): ErrorTypes | undefined;\n\n  getError<E extends Pick<EndpointInterface, 'key'>>(\n    endpoint: E,\n    ...rest:\n      | readonly [null, State<unknown>]\n      | readonly [...Parameters<E['key']>, State<unknown>]\n  ): ErrorTypes | undefined;\n\n  getError(\n    endpoint: EndpointInterface,\n    ...rest: readonly [...unknown[], State<unknown>]\n  ): ErrorTypes | undefined {\n    if (rest[0] === null) return;\n    const state = rest[rest.length - 1] as State<unknown>;\n    // this is typescript generics breaking\n    const args: any = rest.slice(0, rest.length - 1);\n    const key = endpoint.key(...args);\n\n    const meta = selectMeta(state, key);\n    const error = state.endpoints[key];\n\n    if (error !== undefined && meta?.errorPolicy === 'soft') return;\n\n    return meta?.error as any;\n  }\n\n  /**\n   * Gets the (globally referentially stable) response for a given endpoint/args pair from state given.\n   * @see https://dataclient.io/docs/api/Controller#getResponse\n   */\n  getResponse<E extends EndpointInterface>(\n    endpoint: E,\n    ...rest:\n      | readonly [null, State<unknown>]\n      | readonly [...Parameters<E>, State<unknown>]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  };\n\n  getResponse<\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n  >(\n    endpoint: E,\n    ...rest: readonly [\n      ...(readonly [...Parameters<E['key']>] | readonly [null]),\n      State<unknown>,\n    ]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  };\n\n  getResponse(\n    endpoint: EndpointInterface,\n    ...rest: readonly [...unknown[], State<unknown>]\n  ): {\n    data: unknown;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } {\n    const state = rest[rest.length - 1] as State<unknown>;\n    // this is typescript generics breaking\n    const args: any = rest\n      .slice(0, rest.length - 1)\n      // handle FormData\n      .map(ensurePojo);\n    const isActive = args.length !== 1 || args[0] !== null;\n    const key = isActive ? endpoint.key(...args) : '';\n    const cacheEndpoints = isActive ? state.endpoints[key] : undefined;\n    const schema = endpoint.schema;\n    const meta = selectMeta(state, key);\n    let expiresAt = meta?.expiresAt;\n    // if we have no endpoint entry, and our endpoint has a schema - try querying the store\n    const shouldQuery = cacheEndpoints === undefined && schema !== undefined;\n\n    const input =\n      shouldQuery ?\n        // nothing in endpoints cache, so try querying if we have a schema to do so\n        this.memo.buildQueryKey(\n          key,\n          schema,\n          args,\n          state.entities as any,\n          state.indexes,\n        )\n      : cacheEndpoints;\n\n    if (!isActive) {\n      // when not active simply return the query input without denormalizing\n      return {\n        data: input as any,\n        expiryStatus: ExpiryStatus.Valid,\n        expiresAt: Infinity,\n      };\n    }\n\n    let isInvalid = false;\n    if (shouldQuery) {\n      isInvalid = !validateQueryKey(input);\n    } else if (!schema || !schemaHasEntity(schema)) {\n      return {\n        data: cacheEndpoints,\n        expiryStatus:\n          meta?.invalidated ? ExpiryStatus.Invalid\n          : cacheEndpoints && !endpoint.invalidIfStale ? ExpiryStatus.Valid\n          : ExpiryStatus.InvalidIfStale,\n        expiresAt: expiresAt || 0,\n      };\n    }\n\n    // second argument is false if any entities are missing\n    // eslint-disable-next-line prefer-const\n    const { data, paths } = this.memo.denormalize(\n      input,\n      schema,\n      state.entities,\n      args,\n    ) as { data: any; paths: EntityPath[] };\n\n    // note: isInvalid can only be true if shouldQuery is true\n    if (!expiresAt && isInvalid) expiresAt = 1;\n\n    return this.getSchemaResponse(\n      data,\n      paths,\n      state.entityMeta,\n      expiresAt,\n      endpoint.invalidIfStale || isInvalid,\n      meta,\n    );\n  }\n\n  /**\n   * Queries the store for a Querable schema\n   * @see https://dataclient.io/docs/api/Controller#get\n   */\n  get<S extends Queryable>(\n    schema: S,\n    ...rest: readonly [\n      ...SchemaArgs<S>,\n      Pick<State<unknown>, 'entities' | 'entityMeta'>,\n    ]\n  ): DenormalizeNullable<S> | undefined {\n    const state = rest[rest.length - 1] as State<any>;\n    // this is typescript generics breaking\n    const args: any = rest\n      .slice(0, rest.length - 1)\n      .map(ensurePojo) as SchemaArgs<S>;\n\n    // NOTE: different orders can result in cache busting here; but since it's just a perf penalty we will allow for now\n    const key = JSON.stringify(args);\n\n    return this.memo.query(\n      key,\n      schema,\n      args,\n      state.entities as any,\n      state.indexes,\n    );\n  }\n\n  private getSchemaResponse<T>(\n    data: T,\n    paths: EntityPath[],\n    entityMeta: State<unknown>['entityMeta'],\n    expiresAt: number,\n    invalidIfStale: boolean,\n    meta: { error?: unknown; invalidated?: unknown } = {},\n  ): {\n    data: T;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } {\n    const invalidDenormalize = typeof data === 'symbol';\n\n    // fallback to entity expiry time\n    if (!expiresAt) {\n      expiresAt = entityExpiresAt(paths, entityMeta);\n    }\n\n    // https://dataclient.io/docs/concepts/expiry-policy#expiry-status\n    // we don't track the difference between stale or fresh because that is tied to triggering\n    // conditions\n    const expiryStatus =\n      meta?.invalidated || (invalidDenormalize && !meta?.error) ?\n        ExpiryStatus.Invalid\n      : invalidDenormalize || invalidIfStale ? ExpiryStatus.InvalidIfStale\n      : ExpiryStatus.Valid;\n\n    return { data, expiryStatus, expiresAt };\n  }\n}\n\n// benchmark: https://www.measurethat.net/Benchmarks/Show/24691/0/min-reducer-vs-imperative-with-paths\n// earliest expiry dictates age\nfunction entityExpiresAt(\n  paths: EntityPath[],\n  entityMeta: {\n    readonly [entityKey: string]: {\n      readonly [pk: string]: {\n        readonly date: number;\n        readonly expiresAt: number;\n        readonly fetchedAt: number; // This is only the value until it is set by the DataProvider\n      };\n    };\n  },\n) {\n  let expiresAt = Infinity;\n  for (const { pk, key } of paths) {\n    const entityExpiry = entityMeta[key]?.[pk]?.expiresAt;\n    // expiresAt will always resolve to false with any comparison\n    if (entityExpiry < expiresAt) expiresAt = entityExpiry;\n  }\n  return expiresAt;\n}\n\n/** Determine whether the schema has any entities.\n *\n * Without entities, denormalization is not needed, and results should not be queried.\n */\nfunction schemaHasEntity(schema: Schema): boolean {\n  if (isEntity(schema)) return true;\n  if (Array.isArray(schema))\n    return schema.length !== 0 && schemaHasEntity(schema[0]);\n  if (schema && (typeof schema === 'object' || typeof schema === 'function')) {\n    const nestedSchema =\n      'schema' in schema ? (schema.schema as Record<string, Schema>) : schema;\n    if (typeof nestedSchema === 'function') {\n      return schemaHasEntity(nestedSchema);\n    }\n    return Object.values(nestedSchema).some(x => schemaHasEntity(x));\n  }\n  return false;\n}\n\nexport type { ErrorTypes };\n\nclass Snapshot<T = unknown> implements SnapshotInterface {\n  static readonly abort = new AbortOptimistic();\n\n  private state: State<T>;\n  private controller: Controller;\n  readonly fetchedAt: number;\n  readonly abort = Snapshot.abort;\n\n  constructor(controller: Controller, state: State<T>, fetchedAt = 0) {\n    this.state = state;\n    this.controller = controller;\n    this.fetchedAt = fetchedAt;\n  }\n\n  /*************** Data Access ***************/\n  /** @see https://dataclient.io/docs/api/Snapshot#getResponse */\n  getResponse<E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [null]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  };\n\n  getResponse<E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  };\n\n  getResponse<\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E['key']>] | readonly [null]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  };\n\n  getResponse<\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E['key']>] | readonly [null]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } {\n    return this.controller.getResponse(endpoint, ...args, this.state);\n  }\n\n  /** @see https://dataclient.io/docs/api/Snapshot#getError */\n  getError<E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): ErrorTypes | undefined;\n\n  getError<E extends Pick<EndpointInterface, 'key'>>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E['key']>] | readonly [null]\n  ): ErrorTypes | undefined;\n\n  getError<E extends Pick<EndpointInterface, 'key'>>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E['key']>] | readonly [null]\n  ): ErrorTypes | undefined {\n    return this.controller.getError(endpoint, ...args, this.state);\n  }\n\n  /**\n   * Retrieved memoized value for any Querable schema\n   * @see https://dataclient.io/docs/api/Snapshot#get\n   */\n  get<S extends Queryable>(\n    schema: S,\n    ...args: SchemaArgs<S>\n  ): DenormalizeNullable<S> | undefined {\n    return this.controller.get(schema, ...args, this.state);\n  }\n}\n"],"mappings":"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","ignoreList":[]}