@data-client/core 0.14.4 → 0.14.6

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 (56) hide show
  1. package/dist/index.js +64 -95
  2. package/dist/index.umd.min.js +1 -1
  3. package/legacy/index.js +1 -1
  4. package/legacy/manager/DevtoolsManager.js +50 -52
  5. package/legacy/manager/LogoutManager.js +3 -8
  6. package/legacy/manager/NetworkManager.js +9 -21
  7. package/legacy/manager/SubscriptionManager.js +2 -15
  8. package/legacy/manager/applyManager.js +5 -3
  9. package/legacy/middlewareTypes.js +1 -1
  10. package/legacy/types.js +13 -1
  11. package/lib/index.d.ts +1 -1
  12. package/lib/index.d.ts.map +1 -1
  13. package/lib/index.js +1 -1
  14. package/lib/manager/DevtoolsManager.d.ts +4 -7
  15. package/lib/manager/DevtoolsManager.d.ts.map +1 -1
  16. package/lib/manager/DevtoolsManager.js +50 -52
  17. package/lib/manager/LogoutManager.d.ts +5 -8
  18. package/lib/manager/LogoutManager.d.ts.map +1 -1
  19. package/lib/manager/LogoutManager.js +3 -8
  20. package/lib/manager/NetworkManager.d.ts +3 -11
  21. package/lib/manager/NetworkManager.d.ts.map +1 -1
  22. package/lib/manager/NetworkManager.js +9 -21
  23. package/lib/manager/SubscriptionManager.d.ts +1 -10
  24. package/lib/manager/SubscriptionManager.d.ts.map +1 -1
  25. package/lib/manager/SubscriptionManager.js +2 -15
  26. package/lib/manager/applyManager.d.ts +8 -5
  27. package/lib/manager/applyManager.d.ts.map +1 -1
  28. package/lib/manager/applyManager.js +5 -3
  29. package/lib/middlewareTypes.d.ts +6 -10
  30. package/lib/middlewareTypes.d.ts.map +1 -1
  31. package/lib/middlewareTypes.js +1 -1
  32. package/lib/types.d.ts +16 -1
  33. package/lib/types.d.ts.map +1 -1
  34. package/lib/types.js +13 -1
  35. package/package.json +2 -2
  36. package/src/index.ts +1 -0
  37. package/src/manager/DevtoolsManager.ts +37 -40
  38. package/src/manager/LogoutManager.ts +15 -27
  39. package/src/manager/NetworkManager.ts +57 -70
  40. package/src/manager/SubscriptionManager.ts +18 -32
  41. package/src/manager/__tests__/applyManager.ts +61 -1
  42. package/src/manager/__tests__/logoutManager.ts +8 -10
  43. package/src/manager/__tests__/manager.ts +2 -3
  44. package/src/manager/__tests__/networkManager.ts +15 -18
  45. package/src/manager/__tests__/subscriptionManager.ts +14 -16
  46. package/src/manager/applyManager.ts +20 -8
  47. package/src/middlewareTypes.ts +7 -17
  48. package/src/types.ts +16 -1
  49. package/ts3.4/index.d.ts +1 -1
  50. package/ts3.4/manager/DevtoolsManager.d.ts +3 -6
  51. package/ts3.4/manager/LogoutManager.d.ts +4 -7
  52. package/ts3.4/manager/NetworkManager.d.ts +3 -11
  53. package/ts3.4/manager/SubscriptionManager.d.ts +1 -10
  54. package/ts3.4/manager/applyManager.d.ts +8 -5
  55. package/ts3.4/middlewareTypes.d.ts +5 -9
  56. package/ts3.4/types.d.ts +16 -1
package/dist/index.js CHANGED
@@ -818,8 +818,6 @@ class NetworkManager {
818
818
  this.rejectors = {};
819
819
  this.fetchedAt = {};
820
820
  this.controller = new Controller();
821
- this.dataExpiryLength = dataExpiryLength;
822
- this.errorExpiryLength = errorExpiryLength;
823
821
  this.middleware = controller => {
824
822
  this.controller = controller;
825
823
  return next => action => {
@@ -872,14 +870,9 @@ class NetworkManager {
872
870
  }
873
871
  };
874
872
  };
873
+ this.dataExpiryLength = dataExpiryLength;
874
+ this.errorExpiryLength = errorExpiryLength;
875
875
  }
876
-
877
- /** Used by DevtoolsManager to determine whether to log an action */
878
- skipLogging(action) {
879
- /* istanbul ignore next */
880
- return action.type === FETCH_TYPE && action.key in this.fetched;
881
- }
882
-
883
876
  /** On mount */
884
877
  init() {
885
878
  delete this.cleanupDate;
@@ -891,6 +884,12 @@ class NetworkManager {
891
884
  // this must be reversible (done in init) so useEffect() remains symmetric
892
885
  this.cleanupDate = Date.now();
893
886
  }
887
+
888
+ /** Used by DevtoolsManager to determine whether to log an action */
889
+ skipLogging(action) {
890
+ /* istanbul ignore next */
891
+ return action.type === FETCH_TYPE && action.key in this.fetched;
892
+ }
894
893
  allSettled() {
895
894
  const fetches = Object.values(this.fetched);
896
895
  if (fetches.length) return Promise.allSettled(fetches);
@@ -1005,17 +1004,6 @@ class NetworkManager {
1005
1004
  }
1006
1005
  }
1007
1006
 
1008
- /** Attaches NetworkManager to store
1009
- *
1010
- * Intercepts 'rdc/fetch' actions to start requests.
1011
- *
1012
- * Resolve/rejects a request when matching 'rdc/set' event
1013
- * is seen.
1014
- */
1015
- getMiddleware() {
1016
- return this.middleware;
1017
- }
1018
-
1019
1007
  /** Ensures only one request for a given key is in flight at any time
1020
1008
  *
1021
1009
  * Uses key to either retrieve in-flight promise, or if not
@@ -1065,7 +1053,7 @@ function applyManager(managers, controller) {
1065
1053
  console.warn('See https://dataclient.io/docs/guides/redux for hooking up redux');
1066
1054
  }
1067
1055
  return managers.map((manager, i) => {
1068
- const middleware = manager.getMiddleware();
1056
+ if (!manager.middleware) manager.middleware = manager.getMiddleware == null ? void 0 : manager.getMiddleware();
1069
1057
  return ({
1070
1058
  dispatch,
1071
1059
  getState
@@ -1075,13 +1063,15 @@ function applyManager(managers, controller) {
1075
1063
  controller.getState = getState;
1076
1064
  }
1077
1065
  // controller is a superset of the middleware API
1078
- return middleware(controller);
1066
+ return manager.middleware(controller);
1079
1067
  };
1080
1068
  });
1081
1069
  }
1082
1070
 
1083
1071
  /* These should be compatible with redux */
1084
1072
 
1073
+ /* The next are types from React; but we don't want dependencies on it */
1074
+
1085
1075
  class BrowserConnectionListener {
1086
1076
  isOnline() {
1087
1077
  if (navigator.onLine !== undefined) {
@@ -1286,7 +1276,6 @@ class SubscriptionManager {
1286
1276
  constructor(Subscription) {
1287
1277
  this.subscriptions = {};
1288
1278
  this.controller = new Controller();
1289
- this.Subscription = Subscription;
1290
1279
  this.middleware = controller => {
1291
1280
  this.controller = controller;
1292
1281
  return next => action => {
@@ -1306,8 +1295,8 @@ class SubscriptionManager {
1306
1295
  }
1307
1296
  };
1308
1297
  };
1298
+ this.Subscription = Subscription;
1309
1299
  }
1310
-
1311
1300
  /** Ensures all subscriptions are cleaned up. */
1312
1301
  cleanup() {
1313
1302
  for (const key in this.subscriptions) {
@@ -1345,21 +1334,9 @@ class SubscriptionManager {
1345
1334
  console.error(`Mismatched unsubscribe: ${key} is not subscribed`);
1346
1335
  }
1347
1336
  }
1348
-
1349
- /** Attaches Manager to store
1350
- *
1351
- * Intercepts 'rdc/subscribe'/'rest-hordc/ribe' to register resources that
1352
- * need to be kept up to date.
1353
- *
1354
- * Will possibly dispatch 'rdc/fetch' or 'rest-hordc/' to keep resources fresh
1355
- *
1356
- */
1357
- getMiddleware() {
1358
- return this.middleware;
1359
- }
1360
1337
  }
1361
1338
 
1362
- /* eslint-disable no-inner-declarations */
1339
+ var _DevToolsManager;
1363
1340
  let DEFAULT_CONFIG = {};
1364
1341
  if (process.env.NODE_ENV !== 'production') {
1365
1342
  var _globalThis$document;
@@ -1444,7 +1421,24 @@ class DevToolsManager {
1444
1421
  });
1445
1422
  // we cut it in half so we should double so we don't lose
1446
1423
  if (config != null && config.maxAge) this.maxBufferLength = config.maxAge * 2;
1424
+ if (skipLogging) this.skipLogging = skipLogging;
1425
+ }
1426
+ handleAction(action, state) {
1427
+ if (this.started) {
1428
+ this.devTools.send(action, state);
1429
+ } else {
1430
+ // avoid this getting too big in case this is long running
1431
+ // we cut in half so we aren't constantly reallocating
1432
+ if (this.actions.length > this.maxBufferLength) this.actions = this.actions.slice(this.maxBufferLength / 2);
1433
+ // queue actions
1434
+ this.actions.push([action, state]);
1435
+ }
1436
+ }
1437
+
1438
+ /** Called when initial state is ready */
1439
+ init(state) {
1447
1440
  if (process.env.NODE_ENV !== 'production' && this.devTools) {
1441
+ this.devTools.init(state);
1448
1442
  this.devTools.subscribe(msg => {
1449
1443
  switch (msg.type) {
1450
1444
  case 'START':
@@ -1467,62 +1461,42 @@ class DevToolsManager {
1467
1461
  }
1468
1462
  });
1469
1463
  }
1470
-
1471
- /* istanbul ignore if */
1472
- /* istanbul ignore next */
1473
- if (this.devTools) {
1474
- this.middleware = controller => {
1475
- this.controller = controller;
1476
- const reducer = createReducer(controller);
1477
- let state = controller.getState();
1478
- return next => action => {
1479
- const shouldSkip = skipLogging == null ? void 0 : skipLogging(action);
1480
- const ret = next(action);
1481
- if (this.started) {
1482
- // we track state changes here since getState() will only update after a batch commit
1483
- state = reducer(state, action);
1484
- } else {
1485
- state = controller.getState();
1486
- }
1487
- ret.then(() => {
1488
- if (shouldSkip) return;
1489
- this.handleAction(action, state.optimistic.reduce(reducer, state));
1490
- });
1491
- return ret;
1492
- };
1493
- };
1494
- } else {
1495
- this.middleware = () => next => action => next(action);
1496
- }
1497
- }
1498
- handleAction(action, state) {
1499
- if (this.started) {
1500
- this.devTools.send(action, state);
1501
- } else {
1502
- // avoid this getting too big in case this is long running
1503
- // we cut in half so we aren't constantly reallocating
1504
- if (this.actions.length > this.maxBufferLength) this.actions = this.actions.slice(this.maxBufferLength / 2);
1505
- // queue actions
1506
- this.actions.push([action, state]);
1507
- }
1508
- }
1509
-
1510
- /** Called when initial state is ready */
1511
- init(state) {
1512
- /* istanbul ignore if */
1513
- if (this.devTools) this.devTools.init(state);
1514
1464
  }
1515
1465
 
1516
1466
  /** Ensures all subscriptions are cleaned up. */
1517
1467
  cleanup() {}
1518
-
1519
- /** Attaches Manager to store
1520
- *
1521
- */
1522
- getMiddleware() {
1523
- return this.middleware;
1524
- }
1525
1468
  }
1469
+ _DevToolsManager = DevToolsManager;
1470
+ (() => {
1471
+ /* istanbul ignore if */
1472
+ /* istanbul ignore next */
1473
+ if (process.env.NODE_ENV !== 'production') {
1474
+ _DevToolsManager.prototype.middleware = function (controller) {
1475
+ if (!this.devTools) return next => action => next(action);
1476
+ this.controller = controller;
1477
+ const reducer = createReducer(controller);
1478
+ let state = controller.getState();
1479
+ return next => action => {
1480
+ var _this$skipLogging;
1481
+ const shouldSkip = (_this$skipLogging = this.skipLogging) == null ? void 0 : _this$skipLogging.call(this, action);
1482
+ const ret = next(action);
1483
+ if (this.started) {
1484
+ // we track state changes here since getState() will only update after a batch commit
1485
+ state = reducer(state, action);
1486
+ } else {
1487
+ state = controller.getState();
1488
+ }
1489
+ ret.then(() => {
1490
+ if (shouldSkip) return;
1491
+ this.handleAction(action, state.optimistic.reduce(reducer, state));
1492
+ });
1493
+ return ret;
1494
+ };
1495
+ };
1496
+ } else {
1497
+ _DevToolsManager.prototype.middleware = () => next => action => next(action);
1498
+ }
1499
+ })();
1526
1500
 
1527
1501
  /** Handling network unauthorized indicators like HTTP 401
1528
1502
  *
@@ -1533,19 +1507,16 @@ class LogoutManager {
1533
1507
  handleLogout,
1534
1508
  shouldLogout
1535
1509
  } = {}) {
1536
- if (handleLogout) this.handleLogout = handleLogout;
1537
- if (shouldLogout) this.shouldLogout = shouldLogout;
1538
1510
  this.middleware = controller => next => async action => {
1539
1511
  await next(action);
1540
1512
  if (action.type === SET_RESPONSE_TYPE && action.error && this.shouldLogout(action.response)) {
1541
1513
  this.handleLogout(controller);
1542
1514
  }
1543
1515
  };
1516
+ if (handleLogout) this.handleLogout = handleLogout;
1517
+ if (shouldLogout) this.shouldLogout = shouldLogout;
1544
1518
  }
1545
1519
  cleanup() {}
1546
- getMiddleware() {
1547
- return this.middleware;
1548
- }
1549
1520
  shouldLogout(error) {
1550
1521
  // 401 indicates reauthorization is needed
1551
1522
  return error.status === 401;
@@ -1555,8 +1526,6 @@ class LogoutManager {
1555
1526
  }
1556
1527
  }
1557
1528
 
1558
- // this further restricts the types to be future compatible
1559
-
1560
1529
  Object.hasOwn = Object.hasOwn || /* istanbul ignore next */function hasOwn(it, key) {
1561
1530
  return Object.prototype.hasOwnProperty.call(it, key);
1562
1531
  };
@@ -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";function s(e,t){const s=Date.now();return{fetchedAt:null!=t?t:s,date:s,expiresAt:s+e}}const i="rdc/fetch",n="rdc/set",r="rdc/setresponse",o="rdc/optimistic",a="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:o,RESET_TYPE:a,SUBSCRIBE_TYPE:c,UNSUBSCRIBE_TYPE:l,INVALIDATE_TYPE:h,INVALIDATEALL_TYPE:d,EXPIREALL_TYPE:u,GC_TYPE:p});function g(e,t,i){var n;return{type:o,key:e.key(...t),args:t,endpoint:e,meta:s(null!=(n=e.dataExpiryLength)?n:6e4,i)}}class y extends Error{}function m(e,t,s){return"AbortError"===s.name?Object.assign({},e,{optimistic:v(e,t)}):Object.assign({},e,{meta:Object.assign({},e.meta,{[t.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.key!==t.key||(e.type===o?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 function(e,t){if(t.endpoint.getOptimisticResponse&&t.endpoint.sideEffect){const s=g(t.endpoint,t.args,t.meta.fetchedAt);return Object.assign({},e,{optimistic:[...e.optimistic,s]})}return e}(s,c);case o:case r:return function(e,s,i){if(s.error)return m(e,s,s.response);try{var n;let r;if(s.type===o){if(!s.endpoint.getOptimisticResponse)return e;try{r=s.endpoint.getOptimisticResponse.call(s.endpoint,i.snapshot(e,s.meta.fetchedAt),...s.args)}catch(t){if(t.constructor===y)return e;throw t}}else r=s.response;const{result:a,entities:c,indexes:l,entityMeta:h}=t.normalize(s.endpoint.schema,r,s.args,e,s.meta),d=Object.assign({},e.endpoints,{[s.key]:a});try{if(s.endpoint.update){const e=s.endpoint.update(a,...s.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.key}`),console.error(e)}return{entities:c,endpoints:d,indexes:l,meta:Object.assign({},e.meta,{[s.key]:{date:s.meta.date,expiresAt:s.meta.expiresAt,prevExpiresAt:null==(n=e.meta[s.key])?void 0:n.expiresAt}}),entityMeta:h,optimistic:v(e,s),lastReset:e.lastReset}}catch(t){return"object"==typeof t&&(t.message=`Error processing ${s.key}\n\nFull Schema: ${JSON.stringify(s.endpoint.schema,void 0,2)}\n\nError:\n${t.message}`,"response"in s&&(t.response=s.response),t.status=400),m(e,s,t)}}(s,c,e);case n:return function(e,s,i){let n;if("function"==typeof s.value){const t=i.get(s.schema,...s.args,e);if(void 0===t)return e;n=s.value(t)}else n=s.value;try{const{entities:i,indexes:r,entityMeta:o}=t.normalize(s.schema,n,s.args,e,s.meta);return{entities:i,endpoints:e.endpoints,indexes:r,meta:e.meta,entityMeta:o,optimistic:e.optimistic,lastReset:e.lastReset}}catch(t){return e}}(s,c,e);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.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 a:return Object.assign({},b,{lastReset:c.date});default:return s}}}const b={entities:{},endpoints:{},indexes:{},meta:{},entityMeta:{},optimistic:[],lastReset:0};var L=Object.freeze({__proto__:null,MemoCache:t.MemoCache,INVALID:t.INVALID,initialState:b});function O(e,{args:t}){return{type:c,endpoint:e,args:t,key:e.key(...t)}}function S(e,{args:t}){return{type:l,key:e.key(...t),args:t,endpoint:e}}var I="undefined"!=typeof FormData?e=>e instanceof FormData?Object.fromEntries(e.entries()):e:e=>e;function x(e,{args:t,fetchedAt:i,response:n,error:o=!1}){var a,c;const l=o?null!=(a=e.errorExpiryLength)?a:1e3:null!=(c=e.dataExpiryLength)?c:6e4;return{type:r,key:e.key(...t),response:n,args:t.map(I),endpoint:e,meta:s(l,i),error:o}}function w(e,{args:t,fetchedAt:i,value:r}){return{type:n,value:r,args:t.map(I),schema:e,meta:s(6e4,i)}}function A(){return{type:a,date:Date.now()}}function k(e){return{type:d,testKey:e}}function j(e,{args:t}){return{type:h,key:e.key(...t)}}function _(e,{args:t}){let s=0,n=0;const r=new Promise(((e,t)=>{[s,n]=[e,t]})),o={fetchedAt:Date.now(),resolve:s,reject:n,promise:r};return{type:i,key:e.key(...t),args:t,endpoint:e,meta:o}}function R(e){return{type:u,testKey:e}}var T=Object.freeze({__proto__:null,createSubscription:O,createUnsubscription:S,createSetResponse:x,createSet:w,createReset:A,createOptimistic:g,createMeta:s,createInvalidateAll:k,createInvalidate:j,createFetch:_,createExpireAll:R});function P(e,t){return e.meta[t]}const q=e=>{throw new Error("Dispatching while constructing your middleware is not allowed. Other middleware would not be applied to this dispatch.")},D=()=>b;class M{constructor({dispatch:e=q,getState:s=D,memo:i=new t.MemoCache}={}){this.fetch=(e,...s)=>{const i=_(e,{args:s});return this.dispatch(i),e.schema?i.meta.promise.then((i=>t.denormalize(e.schema,i,{},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(j(e,{args:t})):Promise.resolve(),this.invalidateAll=e=>this.dispatch(k((t=>e.testKey(t)))),this.expireAll=e=>this.dispatch(R((t=>e.testKey(t)))),this.resetEntireStore=()=>this.dispatch(A()),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(O(e,{args:t})):Promise.resolve(),this.unsubscribe=(e,...t)=>null!==t[0]?this.dispatch(S(e,{args:t})):Promise.resolve(),this.snapshot=(e,t)=>new H(this,e,t),this.dispatch=e,this.getState=s,this.memo=i}set(e,...t){const s=t[t.length-1],i=w(e,{args:t.slice(0,t.length-1),value:s});return this.dispatch(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=P(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(I),r=1!==n.length||null!==n[0],o=r?e.key(...n):"",a=r?i.endpoints[o]:void 0,c=e.schema,l=P(i,o);let h=null==l?void 0:l.expiresAt;const d=void 0===a&&void 0!==c,u=d?this.memo.buildQueryKey(c,n,i.entities,i.indexes,o):a;if(!r)return{data:u,expiryStatus:t.ExpiryStatus.Valid,expiresAt:1/0};let p=!1;if(d)p=!t.validateQueryKey(u);else if(!c||!C(c))return{data:a,expiryStatus:null!=l&&l.invalidated?t.ExpiryStatus.Invalid:a&&!e.invalidIfStale?t.ExpiryStatus.Valid:t.ExpiryStatus.InvalidIfStale,expiresAt:h||0};const{data:f,paths:g}=this.memo.denormalize(c,u,i.entities,n);return!h&&p&&(h=1),this.getSchemaResponse(f,g,i.entityMeta,h,e.invalidIfStale||p,l)}get(e,...t){const s=t[t.length-1],i=t.slice(0,t.length-1).map(I);return this.memo.query(e,i,s.entities,s.indexes)}getSchemaResponse(e,s,i,n,r,o={}){const a="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!=o&&o.invalidated||a&&(null==o||!o.error)?t.ExpiryStatus.Invalid:a||r?t.ExpiryStatus.InvalidIfStale:t.ExpiryStatus.Valid,expiresAt:n}}}function C(e){if(t.isEntity(e))return!0;if(Array.isArray(e))return 0!==e.length&&C(e[0]);if(e&&("object"==typeof e||"function"==typeof e)){const t="schema"in e?e.schema:e;return"function"==typeof t?C(t):Object.values(t).some((e=>C(e)))}return!1}class H{constructor(e,t,s=0){this.state=void 0,this.controller=void 0,this.fetchedAt=void 0,this.abort=H.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)}}H.abort=new y;class N extends Error{constructor(){super("Aborted due to RESET"),this.name="ResetError"}}class F{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 z{isOnline(){return!0}addOnlineListener(){}removeOnlineListener(){}addOfflineListener(){}removeOfflineListener(){}}let Y;Y="undefined"!=typeof navigator&&"function"==typeof addEventListener?F:z;var V=Y;let B={};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=M,e.DefaultConnectionListener=V,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({},B,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 o=null==t?void 0:t(r),a=n(r);return i=this.started?s(i,r):e.getState(),a.then((()=>{o||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.response)&&this.handleLogout(e)}}cleanup(){}getMiddleware(){return this.middleware}shouldLogout(e){return 401===e.status}handleLogout(e){e.resetEntireStore()}},e.NetworkManager=class{constructor({dataExpiryLength:e=6e4,errorExpiryLength:t=1e3}={}){this.fetched=Object.create(null),this.resolvers={},this.rejectors={},this.fetchedAt={},this.controller=new M,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.key in this.fetched){var t;const i=null==(t=e.getState().meta[s.key])?void 0:t.error;i?this.handleSet(x(s.endpoint,{args:s.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 N)}))}default:return t(s)}})}skipLogging(e){return e.type===i&&e.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{resolve:t,reject:s,fetchedAt:i}=e.meta,n=!e.endpoint.sideEffect,r=()=>{let r=e.endpoint(...e.args);return n||(r=(e=>e.then((e=>(t(e),e))).catch((e=>{throw s(e),e})))(r)),r=r.then((t=>{let s=this.getLastReset();return i>=s&&this.controller.resolve(e.endpoint,{args:e.args,response:t,fetchedAt:i}),t})).catch((t=>{const s=this.getLastReset();throw i>=s&&this.controller.resolve(e.endpoint,{args:e.args,response:t,fetchedAt:i,error:!0}),t})),r};return n?this.throttle(e.key,r,i).then((e=>t(e))).catch((e=>s(e))):r().catch((()=>{}))}handleSet(e){if(e.key in this.fetched){let t;t=e.error?this.rejectors[e.key]:this.resolvers[e.key],t(e.response),this.clear(e.key)}}getMiddleware(){return this.middleware}throttle(e,t,s){const i=this.getLastReset();return e in this.fetched&&this.fetchedAt[e]>i||(this.fetched[e]=new Promise(((t,s)=>{this.resolvers[e]=t,this.rejectors[e]=s})),this.fetchedAt[e]=s,this.idleCallback((()=>{t().catch((()=>null))}),{timeout:500})),this.fetched[e]}idleCallback(e,t){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.args,this.key=e.key,this.frequencyHistogram.set(this.frequency,1),this.controller=t,this.connectionListener=s||new V,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=N,e.SubscriptionManager=class{constructor(e){this.subscriptions={},this.controller=new M,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.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.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.actions=T,e.applyManager=function(e,t){return e.map(((e,s)=>{const i=e.getMiddleware();return({dispatch:e,getState:n})=>(0===s&&(t.dispatch=e,t.getState=n),i(t))}))},e.createReducer=E,e.initialState=b,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";function s(e,t){const s=Date.now();return{fetchedAt:null!=t?t:s,date:s,expiresAt:s+e}}const i="rdc/fetch",n="rdc/set",r="rdc/setresponse",o="rdc/optimistic",a="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:o,RESET_TYPE:a,SUBSCRIBE_TYPE:c,UNSUBSCRIBE_TYPE:l,INVALIDATE_TYPE:h,INVALIDATEALL_TYPE:d,EXPIREALL_TYPE:u,GC_TYPE:p});function y(e,t,i){var n;return{type:o,key:e.key(...t),args:t,endpoint:e,meta:s(null!=(n=e.dataExpiryLength)?n:6e4,i)}}class g extends Error{}function m(e,t,s){return"AbortError"===s.name?Object.assign({},e,{optimistic:v(e,t)}):Object.assign({},e,{meta:Object.assign({},e.meta,{[t.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.key!==t.key||(e.type===o?e.meta.fetchedAt!==t.meta.fetchedAt:e.meta.date>t.meta.date)))}const E={entities:{},endpoints:{},indexes:{},meta:{},entityMeta:{},optimistic:[],lastReset:0};var b=Object.freeze({__proto__:null,MemoCache:t.MemoCache,INVALID:t.INVALID,initialState:E});function L(e,{args:t}){return{type:c,endpoint:e,args:t,key:e.key(...t)}}function O(e,{args:t}){return{type:l,key:e.key(...t),args:t,endpoint:e}}var S="undefined"!=typeof FormData?e=>e instanceof FormData?Object.fromEntries(e.entries()):e:e=>e;function I(e,{args:t,fetchedAt:i,response:n,error:o=!1}){var a,c;const l=o?null!=(a=e.errorExpiryLength)?a:1e3:null!=(c=e.dataExpiryLength)?c:6e4;return{type:r,key:e.key(...t),response:n,args:t.map(S),endpoint:e,meta:s(l,i),error:o}}function x(e,{args:t,fetchedAt:i,value:r}){return{type:n,value:r,args:t.map(S),schema:e,meta:s(6e4,i)}}function A(){return{type:a,date:Date.now()}}function w(e){return{type:d,testKey:e}}function k(e,{args:t}){return{type:h,key:e.key(...t)}}function j(e,{args:t}){let s=0,n=0;const r=new Promise(((e,t)=>{[s,n]=[e,t]})),o={fetchedAt:Date.now(),resolve:s,reject:n,promise:r};return{type:i,key:e.key(...t),args:t,endpoint:e,meta:o}}function _(e){return{type:u,testKey:e}}var R=Object.freeze({__proto__:null,createSubscription:L,createUnsubscription:O,createSetResponse:I,createSet:x,createReset:A,createOptimistic:y,createMeta:s,createInvalidateAll:w,createInvalidate:k,createFetch:j,createExpireAll:_});function T(e,t){return e.meta[t]}const P=e=>{throw new Error("Dispatching while constructing your middleware is not allowed. Other middleware would not be applied to this dispatch.")},q=()=>E;class D{constructor({dispatch:e=P,getState:s=q,memo:i=new t.MemoCache}={}){this.fetch=(e,...s)=>{const i=j(e,{args:s});return this.dispatch(i),e.schema?i.meta.promise.then((i=>t.denormalize(e.schema,i,{},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(k(e,{args:t})):Promise.resolve(),this.invalidateAll=e=>this.dispatch(w((t=>e.testKey(t)))),this.expireAll=e=>this.dispatch(_((t=>e.testKey(t)))),this.resetEntireStore=()=>this.dispatch(A()),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(L(e,{args:t})):Promise.resolve(),this.unsubscribe=(e,...t)=>null!==t[0]?this.dispatch(O(e,{args:t})):Promise.resolve(),this.snapshot=(e,t)=>new C(this,e,t),this.dispatch=e,this.getState=s,this.memo=i}set(e,...t){const s=t[t.length-1],i=x(e,{args:t.slice(0,t.length-1),value:s});return this.dispatch(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=T(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(S),r=1!==n.length||null!==n[0],o=r?e.key(...n):"",a=r?i.endpoints[o]:void 0,c=e.schema,l=T(i,o);let h=null==l?void 0:l.expiresAt;const d=void 0===a&&void 0!==c,u=d?this.memo.buildQueryKey(c,n,i.entities,i.indexes,o):a;if(!r)return{data:u,expiryStatus:t.ExpiryStatus.Valid,expiresAt:1/0};let p=!1;if(d)p=!t.validateQueryKey(u);else if(!c||!M(c))return{data:a,expiryStatus:null!=l&&l.invalidated?t.ExpiryStatus.Invalid:a&&!e.invalidIfStale?t.ExpiryStatus.Valid:t.ExpiryStatus.InvalidIfStale,expiresAt:h||0};const{data:f,paths:y}=this.memo.denormalize(c,u,i.entities,n);return!h&&p&&(h=1),this.getSchemaResponse(f,y,i.entityMeta,h,e.invalidIfStale||p,l)}get(e,...t){const s=t[t.length-1],i=t.slice(0,t.length-1).map(S);return this.memo.query(e,i,s.entities,s.indexes)}getSchemaResponse(e,s,i,n,r,o={}){const a="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!=o&&o.invalidated||a&&(null==o||!o.error)?t.ExpiryStatus.Invalid:a||r?t.ExpiryStatus.InvalidIfStale:t.ExpiryStatus.Valid,expiresAt:n}}}function M(e){if(t.isEntity(e))return!0;if(Array.isArray(e))return 0!==e.length&&M(e[0]);if(e&&("object"==typeof e||"function"==typeof e)){const t="schema"in e?e.schema:e;return"function"==typeof t?M(t):Object.values(t).some((e=>M(e)))}return!1}class C{constructor(e,t,s=0){this.state=void 0,this.controller=void 0,this.fetchedAt=void 0,this.abort=C.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)}}C.abort=new g;class H extends Error{constructor(){super("Aborted due to RESET"),this.name="ResetError"}}class N{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 F{isOnline(){return!0}addOnlineListener(){}removeOnlineListener(){}addOfflineListener(){}removeOfflineListener(){}}let z;z="undefined"!=typeof navigator&&"function"==typeof addEventListener?N:F;var Y=z;let V={};class B{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({},V,e)),null!=e&&e.maxAge&&(this.maxBufferLength=2*e.maxAge),t&&(this.skipLogging=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){}cleanup(){}}B.prototype.middleware=()=>e=>t=>e(t);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=D,e.DefaultConnectionListener=Y,e.DevToolsManager=B,e.LogoutManager=class{constructor({handleLogout:e,shouldLogout:t}={}){this.middleware=e=>t=>async s=>{await t(s),s.type===r&&s.error&&this.shouldLogout(s.response)&&this.handleLogout(e)},e&&(this.handleLogout=e),t&&(this.shouldLogout=t)}cleanup(){}shouldLogout(e){return 401===e.status}handleLogout(e){e.resetEntireStore()}},e.NetworkManager=class{constructor({dataExpiryLength:e=6e4,errorExpiryLength:t=1e3}={}){this.fetched=Object.create(null),this.resolvers={},this.rejectors={},this.fetchedAt={},this.controller=new D,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.key in this.fetched){var t;const i=null==(t=e.getState().meta[s.key])?void 0:t.error;i?this.handleSet(I(s.endpoint,{args:s.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 H)}))}default:return t(s)}}),this.dataExpiryLength=e,this.errorExpiryLength=t}init(){delete this.cleanupDate}cleanup(){this.cleanupDate=Date.now()}skipLogging(e){return e.type===i&&e.key in this.fetched}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{resolve:t,reject:s,fetchedAt:i}=e.meta,n=!e.endpoint.sideEffect,r=()=>{let r=e.endpoint(...e.args);return n||(r=(e=>e.then((e=>(t(e),e))).catch((e=>{throw s(e),e})))(r)),r=r.then((t=>{let s=this.getLastReset();return i>=s&&this.controller.resolve(e.endpoint,{args:e.args,response:t,fetchedAt:i}),t})).catch((t=>{const s=this.getLastReset();throw i>=s&&this.controller.resolve(e.endpoint,{args:e.args,response:t,fetchedAt:i,error:!0}),t})),r};return n?this.throttle(e.key,r,i).then((e=>t(e))).catch((e=>s(e))):r().catch((()=>{}))}handleSet(e){if(e.key in this.fetched){let t;t=e.error?this.rejectors[e.key]:this.resolvers[e.key],t(e.response),this.clear(e.key)}}throttle(e,t,s){const i=this.getLastReset();return e in this.fetched&&this.fetchedAt[e]>i||(this.fetched[e]=new Promise(((t,s)=>{this.resolvers[e]=t,this.rejectors[e]=s})),this.fetchedAt[e]=s,this.idleCallback((()=>{t().catch((()=>null))}),{timeout:500})),this.fetched[e]}idleCallback(e,t){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.args,this.key=e.key,this.frequencyHistogram.set(this.frequency,1),this.controller=t,this.connectionListener=s||new Y,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=H,e.SubscriptionManager=class{constructor(e){this.subscriptions={},this.controller=new D,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)}}),this.Subscription=e}cleanup(){for(const e in this.subscriptions)this.subscriptions[e].cleanup()}handleSubscribe(e){const t=e.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.key;if(t in this.subscriptions){const s=e.endpoint.pollFrequency;this.subscriptions[t].remove(s)&&delete this.subscriptions[t]}}},e.__INTERNAL__=b,e.actionTypes=f,e.actions=R,e.applyManager=function(e,t){return e.map(((e,s)=>(e.middleware||(e.middleware=null==e.getMiddleware?void 0:e.getMiddleware()),({dispatch:i,getState:n})=>(0===s&&(t.dispatch=i,t.getState=n),e.middleware(t)))))},e.createReducer=function(e){return function(s,c){switch(s||(s=E),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 function(e,t){if(t.endpoint.getOptimisticResponse&&t.endpoint.sideEffect){const s=y(t.endpoint,t.args,t.meta.fetchedAt);return Object.assign({},e,{optimistic:[...e.optimistic,s]})}return e}(s,c);case o:case r:return function(e,s,i){if(s.error)return m(e,s,s.response);try{var n;let r;if(s.type===o){if(!s.endpoint.getOptimisticResponse)return e;try{r=s.endpoint.getOptimisticResponse.call(s.endpoint,i.snapshot(e,s.meta.fetchedAt),...s.args)}catch(t){if(t.constructor===g)return e;throw t}}else r=s.response;const{result:a,entities:c,indexes:l,entityMeta:h}=t.normalize(s.endpoint.schema,r,s.args,e,s.meta),d=Object.assign({},e.endpoints,{[s.key]:a});try{if(s.endpoint.update){const e=s.endpoint.update(a,...s.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.key}`),console.error(e)}return{entities:c,endpoints:d,indexes:l,meta:Object.assign({},e.meta,{[s.key]:{date:s.meta.date,expiresAt:s.meta.expiresAt,prevExpiresAt:null==(n=e.meta[s.key])?void 0:n.expiresAt}}),entityMeta:h,optimistic:v(e,s),lastReset:e.lastReset}}catch(t){return"object"==typeof t&&(t.message=`Error processing ${s.key}\n\nFull Schema: ${JSON.stringify(s.endpoint.schema,void 0,2)}\n\nError:\n${t.message}`,"response"in s&&(t.response=s.response),t.status=400),m(e,s,t)}}(s,c,e);case n:return function(e,s,i){let n;if("function"==typeof s.value){const t=i.get(s.schema,...s.args,e);if(void 0===t)return e;n=s.value(t)}else n=s.value;try{const{entities:i,indexes:r,entityMeta:o}=t.normalize(s.schema,n,s.args,e,s.meta);return{entities:i,endpoints:e.endpoints,indexes:r,meta:e.meta,entityMeta:o,optimistic:e.optimistic,lastReset:e.lastReset}}catch(t){return e}}(s,c,e);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.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 a:return Object.assign({},E,{lastReset:c.date});default:return s}}},e.initialState=E,Object.defineProperty(e,"__esModule",{value:!0})}));
package/legacy/index.js CHANGED
@@ -16,4 +16,4 @@ export { _actionTypes as actionTypes };
16
16
  /* istanbul ignore next */
17
17
  export * from './types.js';
18
18
  export * from './manager/index.js';
19
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPYmplY3QiLCJoYXNPd24iLCJpdCIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIl9JTlRFUk5BTF9fIiwiX19JTlRFUk5BTF9fIiwiRXhwaXJ5U3RhdHVzIiwiZGVmYXVsdCIsIk5ldHdvcmtNYW5hZ2VyIiwiUmVzZXRFcnJvciIsImNyZWF0ZVJlZHVjZXIiLCJpbml0aWFsU3RhdGUiLCJhcHBseU1hbmFnZXIiLCJDb250cm9sbGVyIiwiX2FjdGlvbnMiLCJhY3Rpb25zIiwiX2FjdGlvblR5cGVzIiwiYWN0aW9uVHlwZXMiXSwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0Lmhhc093biA9XG4gIE9iamVjdC5oYXNPd24gfHxcbiAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi8gZnVuY3Rpb24gaGFzT3duKGl0LCBrZXkpIHtcbiAgICByZXR1cm4gT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKGl0LCBrZXkpO1xuICB9O1xuXG5leHBvcnQgKiBhcyBfX0lOVEVSTkFMX18gZnJvbSAnLi9pbnRlcm5hbC5qcyc7XG5leHBvcnQgdHlwZSB7XG4gIE5ldHdvcmtFcnJvcixcbiAgVW5rbm93bkVycm9yLFxuICBFcnJvclR5cGVzLFxuICBTY2hlbWEsXG4gIEVuZHBvaW50SW50ZXJmYWNlLFxuICBFbnRpdHlJbnRlcmZhY2UsXG4gIFJlc29sdmVUeXBlLFxuICBEZW5vcm1hbGl6ZU51bGxhYmxlLFxuICBEZW5vcm1hbGl6ZSxcbiAgTm9ybWFsaXplLFxuICBOb3JtYWxpemVOdWxsYWJsZSxcbiAgRmV0Y2hGdW5jdGlvbixcbiAgRW5kcG9pbnRFeHRyYU9wdGlvbnMsXG4gIFF1ZXJ5YWJsZSxcbiAgU2NoZW1hQXJncyxcbiAgTkksXG59IGZyb20gJ0BkYXRhLWNsaWVudC9ub3JtYWxpenInO1xuZXhwb3J0IHsgRXhwaXJ5U3RhdHVzIH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5leHBvcnQge1xuICBkZWZhdWx0IGFzIE5ldHdvcmtNYW5hZ2VyLFxuICBSZXNldEVycm9yLFxufSBmcm9tICcuL21hbmFnZXIvTmV0d29ya01hbmFnZXIuanMnO1xuZXhwb3J0IHtcbiAgZGVmYXVsdCBhcyBjcmVhdGVSZWR1Y2VyLFxuICBpbml0aWFsU3RhdGUsXG59IGZyb20gJy4vc3RhdGUvcmVkdWNlci9jcmVhdGVSZWR1Y2VyLmpzJztcbmV4cG9ydCB7IGRlZmF1bHQgYXMgYXBwbHlNYW5hZ2VyIH0gZnJvbSAnLi9tYW5hZ2VyL2FwcGx5TWFuYWdlci5qcyc7XG5cbmV4cG9ydCB7IGRlZmF1bHQgYXMgQ29udHJvbGxlciB9IGZyb20gJy4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmV4cG9ydCB0eXBlIHtcbiAgRGF0YUNsaWVudERpc3BhdGNoLFxuICBHZW5lcmljRGlzcGF0Y2gsXG59IGZyb20gJy4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmV4cG9ydCAqIGFzIGFjdGlvbnMgZnJvbSAnLi9jb250cm9sbGVyL2FjdGlvbnMvaW5kZXguanMnO1xuXG5leHBvcnQgKiBmcm9tICcuL2NvbnRyb2xsZXIvdHlwZXMuanMnO1xuZXhwb3J0ICogYXMgYWN0aW9uVHlwZXMgZnJvbSAnLi9hY3Rpb25UeXBlcy5qcyc7XG4vKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL21hbmFnZXIvaW5kZXguanMnO1xuIl0sIm1hcHBpbmdzIjoiQUFBQUEsTUFBTSxDQUFDQyxNQUFNLEdBQ1hELE1BQU0sQ0FBQ0MsTUFBTSxJQUNiLDBCQUEyQixTQUFTQSxNQUFNQSxDQUFDQyxFQUFFLEVBQUVDLEdBQUcsRUFBRTtFQUNsRCxPQUFPSCxNQUFNLENBQUNJLFNBQVMsQ0FBQ0MsY0FBYyxDQUFDQyxJQUFJLENBQUNKLEVBQUUsRUFBRUMsR0FBRyxDQUFDO0FBQ3RELENBQUM7QUFBQyxZQUFBSSxXQUFBLE1BRTBCLGVBQWU7QUFBQSxTQUFBQSxXQUFBLElBQWpDQyxZQUFZO0FBbUJ4QixTQUFTQyxZQUFZLFFBQVEsd0JBQXdCO0FBQ3JELFNBQ0VDLE9BQU8sSUFBSUMsY0FBYyxFQUN6QkMsVUFBVSxRQUNMLDZCQUE2QjtBQUNwQyxTQUNFRixPQUFPLElBQUlHLGFBQWEsRUFDeEJDLFlBQVksUUFDUCxrQ0FBa0M7QUFDekMsU0FBU0osT0FBTyxJQUFJSyxZQUFZLFFBQVEsMkJBQTJCO0FBRW5FLFNBQVNMLE9BQU8sSUFBSU0sVUFBVSxRQUFRLDRCQUE0QjtBQUFDLFlBQUFDLFFBQUEsTUFLMUMsK0JBQStCO0FBQUEsU0FBQUEsUUFBQSxJQUE1Q0MsT0FBTztBQUVuQixjQUFjLHVCQUF1QjtBQUFDLFlBQUFDLFlBQUEsTUFDVCxrQkFBa0I7QUFBQSxTQUFBQSxZQUFBLElBQW5DQyxXQUFXO0FBQ3ZCO0FBQ0EsY0FBYyxZQUFZO0FBQzFCLGNBQWMsb0JBQW9CIiwiaWdub3JlTGlzdCI6W119
19
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPYmplY3QiLCJoYXNPd24iLCJpdCIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIl9JTlRFUk5BTF9fIiwiX19JTlRFUk5BTF9fIiwiRXhwaXJ5U3RhdHVzIiwiZGVmYXVsdCIsIk5ldHdvcmtNYW5hZ2VyIiwiUmVzZXRFcnJvciIsImNyZWF0ZVJlZHVjZXIiLCJpbml0aWFsU3RhdGUiLCJhcHBseU1hbmFnZXIiLCJDb250cm9sbGVyIiwiX2FjdGlvbnMiLCJhY3Rpb25zIiwiX2FjdGlvblR5cGVzIiwiYWN0aW9uVHlwZXMiXSwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0Lmhhc093biA9XG4gIE9iamVjdC5oYXNPd24gfHxcbiAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi8gZnVuY3Rpb24gaGFzT3duKGl0LCBrZXkpIHtcbiAgICByZXR1cm4gT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKGl0LCBrZXkpO1xuICB9O1xuXG5leHBvcnQgKiBhcyBfX0lOVEVSTkFMX18gZnJvbSAnLi9pbnRlcm5hbC5qcyc7XG5leHBvcnQgdHlwZSB7XG4gIE5ldHdvcmtFcnJvcixcbiAgVW5rbm93bkVycm9yLFxuICBFcnJvclR5cGVzLFxuICBTY2hlbWEsXG4gIEVuZHBvaW50SW50ZXJmYWNlLFxuICBFbnRpdHlJbnRlcmZhY2UsXG4gIFNjaGVtYUNsYXNzLFxuICBSZXNvbHZlVHlwZSxcbiAgRGVub3JtYWxpemVOdWxsYWJsZSxcbiAgRGVub3JtYWxpemUsXG4gIE5vcm1hbGl6ZSxcbiAgTm9ybWFsaXplTnVsbGFibGUsXG4gIEZldGNoRnVuY3Rpb24sXG4gIEVuZHBvaW50RXh0cmFPcHRpb25zLFxuICBRdWVyeWFibGUsXG4gIFNjaGVtYUFyZ3MsXG4gIE5JLFxufSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcbmV4cG9ydCB7IEV4cGlyeVN0YXR1cyB9IGZyb20gJ0BkYXRhLWNsaWVudC9ub3JtYWxpenInO1xuZXhwb3J0IHtcbiAgZGVmYXVsdCBhcyBOZXR3b3JrTWFuYWdlcixcbiAgUmVzZXRFcnJvcixcbn0gZnJvbSAnLi9tYW5hZ2VyL05ldHdvcmtNYW5hZ2VyLmpzJztcbmV4cG9ydCB7XG4gIGRlZmF1bHQgYXMgY3JlYXRlUmVkdWNlcixcbiAgaW5pdGlhbFN0YXRlLFxufSBmcm9tICcuL3N0YXRlL3JlZHVjZXIvY3JlYXRlUmVkdWNlci5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIGFwcGx5TWFuYWdlciB9IGZyb20gJy4vbWFuYWdlci9hcHBseU1hbmFnZXIuanMnO1xuXG5leHBvcnQgeyBkZWZhdWx0IGFzIENvbnRyb2xsZXIgfSBmcm9tICcuL2NvbnRyb2xsZXIvQ29udHJvbGxlci5qcyc7XG5leHBvcnQgdHlwZSB7XG4gIERhdGFDbGllbnREaXNwYXRjaCxcbiAgR2VuZXJpY0Rpc3BhdGNoLFxufSBmcm9tICcuL2NvbnRyb2xsZXIvQ29udHJvbGxlci5qcyc7XG5leHBvcnQgKiBhcyBhY3Rpb25zIGZyb20gJy4vY29udHJvbGxlci9hY3Rpb25zL2luZGV4LmpzJztcblxuZXhwb3J0ICogZnJvbSAnLi9jb250cm9sbGVyL3R5cGVzLmpzJztcbmV4cG9ydCAqIGFzIGFjdGlvblR5cGVzIGZyb20gJy4vYWN0aW9uVHlwZXMuanMnO1xuLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9tYW5hZ2VyL2luZGV4LmpzJztcbiJdLCJtYXBwaW5ncyI6IkFBQUFBLE1BQU0sQ0FBQ0MsTUFBTSxHQUNYRCxNQUFNLENBQUNDLE1BQU0sSUFDYiwwQkFBMkIsU0FBU0EsTUFBTUEsQ0FBQ0MsRUFBRSxFQUFFQyxHQUFHLEVBQUU7RUFDbEQsT0FBT0gsTUFBTSxDQUFDSSxTQUFTLENBQUNDLGNBQWMsQ0FBQ0MsSUFBSSxDQUFDSixFQUFFLEVBQUVDLEdBQUcsQ0FBQztBQUN0RCxDQUFDO0FBQUMsWUFBQUksV0FBQSxNQUUwQixlQUFlO0FBQUEsU0FBQUEsV0FBQSxJQUFqQ0MsWUFBWTtBQW9CeEIsU0FBU0MsWUFBWSxRQUFRLHdCQUF3QjtBQUNyRCxTQUNFQyxPQUFPLElBQUlDLGNBQWMsRUFDekJDLFVBQVUsUUFDTCw2QkFBNkI7QUFDcEMsU0FDRUYsT0FBTyxJQUFJRyxhQUFhLEVBQ3hCQyxZQUFZLFFBQ1Asa0NBQWtDO0FBQ3pDLFNBQVNKLE9BQU8sSUFBSUssWUFBWSxRQUFRLDJCQUEyQjtBQUVuRSxTQUFTTCxPQUFPLElBQUlNLFVBQVUsUUFBUSw0QkFBNEI7QUFBQyxZQUFBQyxRQUFBLE1BSzFDLCtCQUErQjtBQUFBLFNBQUFBLFFBQUEsSUFBNUNDLE9BQU87QUFFbkIsY0FBYyx1QkFBdUI7QUFBQyxZQUFBQyxZQUFBLE1BQ1Qsa0JBQWtCO0FBQUEsU0FBQUEsWUFBQSxJQUFuQ0MsV0FBVztBQUN2QjtBQUNBLGNBQWMsWUFBWTtBQUMxQixjQUFjLG9CQUFvQiIsImlnbm9yZUxpc3QiOltdfQ==
@@ -1,3 +1,4 @@
1
+ var _DevToolsManager;
1
2
  /* eslint-disable no-inner-declarations */
2
3
 
3
4
  import createReducer from '../state/reducer/createReducer.js';
@@ -81,7 +82,24 @@ export default class DevToolsManager {
81
82
  this.devTools = typeof window !== 'undefined' && window.__REDUX_DEVTOOLS_EXTENSION__ && window.__REDUX_DEVTOOLS_EXTENSION__.connect(Object.assign({}, DEFAULT_CONFIG, config));
82
83
  // we cut it in half so we should double so we don't lose
83
84
  if (config != null && config.maxAge) this.maxBufferLength = config.maxAge * 2;
85
+ if (skipLogging) this.skipLogging = skipLogging;
86
+ }
87
+ handleAction(action, state) {
88
+ if (this.started) {
89
+ this.devTools.send(action, state);
90
+ } else {
91
+ // avoid this getting too big in case this is long running
92
+ // we cut in half so we aren't constantly reallocating
93
+ if (this.actions.length > this.maxBufferLength) this.actions = this.actions.slice(this.maxBufferLength / 2);
94
+ // queue actions
95
+ this.actions.push([action, state]);
96
+ }
97
+ }
98
+
99
+ /** Called when initial state is ready */
100
+ init(state) {
84
101
  if (process.env.NODE_ENV !== 'production' && this.devTools) {
102
+ this.devTools.init(state);
85
103
  this.devTools.subscribe(msg => {
86
104
  switch (msg.type) {
87
105
  case 'START':
@@ -104,60 +122,40 @@ export default class DevToolsManager {
104
122
  }
105
123
  });
106
124
  }
107
-
108
- /* istanbul ignore if */
109
- /* istanbul ignore next */
110
- if (this.devTools) {
111
- this.middleware = controller => {
112
- this.controller = controller;
113
- const reducer = createReducer(controller);
114
- let state = controller.getState();
115
- return next => action => {
116
- const shouldSkip = skipLogging == null ? void 0 : skipLogging(action);
117
- const ret = next(action);
118
- if (this.started) {
119
- // we track state changes here since getState() will only update after a batch commit
120
- state = reducer(state, action);
121
- } else {
122
- state = controller.getState();
123
- }
124
- ret.then(() => {
125
- if (shouldSkip) return;
126
- this.handleAction(action, state.optimistic.reduce(reducer, state));
127
- });
128
- return ret;
129
- };
130
- };
131
- } else {
132
- this.middleware = () => next => action => next(action);
133
- }
134
- }
135
- handleAction(action, state) {
136
- if (this.started) {
137
- this.devTools.send(action, state);
138
- } else {
139
- // avoid this getting too big in case this is long running
140
- // we cut in half so we aren't constantly reallocating
141
- if (this.actions.length > this.maxBufferLength) this.actions = this.actions.slice(this.maxBufferLength / 2);
142
- // queue actions
143
- this.actions.push([action, state]);
144
- }
145
- }
146
-
147
- /** Called when initial state is ready */
148
- init(state) {
149
- /* istanbul ignore if */
150
- if (this.devTools) this.devTools.init(state);
151
125
  }
152
126
 
153
127
  /** Ensures all subscriptions are cleaned up. */
154
128
  cleanup() {}
155
-
156
- /** Attaches Manager to store
157
- *
158
- */
159
- getMiddleware() {
160
- return this.middleware;
161
- }
162
129
  }
163
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["createReducer","DEFAULT_CONFIG","process","env","NODE_ENV","_globalThis$document","extraEndpointKeys","serializeEndpoint","endpoint","_toJSON","_endpoint$schema","serial","name","schema","toJSON","sideEffect","forEach","key","HASINTL","Intl","globalThis","document","title","autoPause","features","pause","lock","persist","export","import","jump","skip","reorder","dispatch","test","actionSanitizer","action","Object","assign","serialize","options","undefined","replacer","value","isFinite","endsWith","DateTimeFormat","hour","minute","second","fractionalSecondDigits","format","DevToolsManager","constructor","config","skipLogging","started","actions","maxBufferLength","devTools","window","__REDUX_DEVTOOLS_EXTENSION__","connect","maxAge","subscribe","msg","type","length","state","handleAction","payload","controller","resetEntireStore","middleware","reducer","getState","next","shouldSkip","ret","then","optimistic","reduce","send","slice","push","init","cleanup","getMiddleware"],"sources":["../../src/manager/DevtoolsManager.ts"],"sourcesContent":["/* eslint-disable no-inner-declarations */\nimport type { DevToolsConfig } from './devtoolsTypes.js';\nimport type { Middleware } from './LogoutManager.js';\nimport { Controller, EndpointInterface } from '../index.js';\nimport createReducer from '../state/reducer/createReducer.js';\nimport type { Manager, State, ActionTypes } from '../types.js';\n\nexport type { DevToolsConfig };\n\nlet DEFAULT_CONFIG = {};\n\nif (process.env.NODE_ENV !== 'production') {\n  const extraEndpointKeys = [\n    'dataExpiryLength',\n    'errorExpiryLength',\n    'errorPolicy',\n    'invalidIfStale',\n    'pollFrequency',\n    'getOptimisticResponse',\n    'update',\n  ];\n\n  function serializeEndpoint(endpoint: EndpointInterface) {\n    const serial: any = {\n      name: endpoint.name,\n      schema: (endpoint.schema as any)?.toJSON?.() ?? endpoint.schema,\n      sideEffect: endpoint.sideEffect,\n    };\n    extraEndpointKeys.forEach(key => {\n      if (key in endpoint)\n        serial[key] = endpoint[key as keyof EndpointInterface];\n    });\n    return serial;\n  }\n\n  const HASINTL = typeof Intl !== 'undefined';\n  DEFAULT_CONFIG = {\n    name: `Data Client: ${globalThis.document?.title}`,\n    autoPause: true,\n    features: {\n      pause: true, // start/pause recording of dispatched actions\n      lock: true, // lock/unlock dispatching actions and side effects\n      persist: false, // persist states on page reloading\n      export: true, // export history of actions in a file\n      import: 'custom', // import history of actions from a file\n      jump: true, // jump back and forth (time travelling)\n      skip: true, // skip (cancel) actions\n      reorder: true, // drag and drop actions in the history list\n      dispatch: false, // dispatch custom actions or action creators\n      test: false, // generate tests for the selected actions\n    },\n    actionSanitizer: (action: ActionTypes) => {\n      if (!('endpoint' in action)) return action;\n      return {\n        ...action,\n        endpoint: serializeEndpoint(action.endpoint),\n      };\n    },\n    serialize: {\n      options: undefined,\n      /* istanbul ignore next */\n      replacer:\n        HASINTL ?\n          (key: string | number | symbol, value: unknown) => {\n            if (\n              typeof value === 'number' &&\n              typeof key === 'string' &&\n              isFinite(value) &&\n              (key === 'date' || key.endsWith('At'))\n            ) {\n              return Intl.DateTimeFormat('en-US', {\n                hour: 'numeric',\n                minute: 'numeric',\n                second: 'numeric',\n                fractionalSecondDigits: 3,\n              }).format(value);\n            }\n            return value;\n          }\n        : undefined,\n    },\n  };\n}\n\n/** Integrates with https://github.com/reduxjs/redux-devtools\n *\n * Options: https://github.com/reduxjs/redux-devtools/blob/main/extension/docs/API/Arguments.md\n *\n * @see https://dataclient.io/docs/api/DevToolsManager\n */\nexport default class DevToolsManager implements Manager {\n  protected declare middleware: Middleware;\n  protected declare devTools: undefined | any;\n  protected started = false;\n  protected actions: [ActionTypes, State<unknown>][] = [];\n  protected declare controller: Controller;\n  maxBufferLength = 100;\n\n  constructor(\n    config?: DevToolsConfig,\n    skipLogging?: (action: ActionTypes) => boolean,\n  ) {\n    /* istanbul ignore next */\n    this.devTools =\n      typeof window !== 'undefined' &&\n      (window as any).__REDUX_DEVTOOLS_EXTENSION__ &&\n      (window as any).__REDUX_DEVTOOLS_EXTENSION__.connect({\n        ...DEFAULT_CONFIG,\n        ...config,\n      });\n    // we cut it in half so we should double so we don't lose\n    if (config?.maxAge) this.maxBufferLength = config.maxAge * 2;\n    if (process.env.NODE_ENV !== 'production' && this.devTools) {\n      this.devTools.subscribe((msg: any) => {\n        switch (msg.type) {\n          case 'START':\n            this.started = true;\n\n            if (this.actions.length) {\n              this.actions.forEach(([action, state]) => {\n                this.handleAction(action, state);\n              });\n              this.actions = [];\n            }\n            break;\n          case 'STOP':\n            this.started = false;\n            break;\n          case 'DISPATCH':\n            if (msg.payload.type === 'RESET') {\n              this.controller.resetEntireStore();\n            }\n            break;\n        }\n      });\n    }\n\n    /* istanbul ignore if */\n    /* istanbul ignore next */\n    if (this.devTools) {\n      this.middleware = controller => {\n        this.controller = controller;\n        const reducer = createReducer(controller as any);\n        let state = controller.getState();\n        return next => action => {\n          const shouldSkip = skipLogging?.(action);\n          const ret = next(action);\n          if (this.started) {\n            // we track state changes here since getState() will only update after a batch commit\n            state = reducer(state, action);\n          } else {\n            state = controller.getState();\n          }\n          ret.then(() => {\n            if (shouldSkip) return;\n            this.handleAction(action, state.optimistic.reduce(reducer, state));\n          });\n          return ret;\n        };\n      };\n    } else {\n      this.middleware = () => next => action => next(action);\n    }\n  }\n\n  handleAction(action: any, state: any) {\n    if (this.started) {\n      this.devTools.send(action, state);\n    } else {\n      // avoid this getting too big in case this is long running\n      // we cut in half so we aren't constantly reallocating\n      if (this.actions.length > this.maxBufferLength)\n        this.actions = this.actions.slice(this.maxBufferLength / 2);\n      // queue actions\n      this.actions.push([action, state]);\n    }\n  }\n\n  /** Called when initial state is ready */\n  init(state: State<any>) {\n    /* istanbul ignore if */\n    if (this.devTools) this.devTools.init(state);\n  }\n\n  /** Ensures all subscriptions are cleaned up. */\n  cleanup() {}\n\n  /** Attaches Manager to store\n   *\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n}\n"],"mappings":"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","ignoreList":[]}
130
+ _DevToolsManager = DevToolsManager;
131
+ (() => {
132
+ /* istanbul ignore if */
133
+ /* istanbul ignore next */
134
+ if (process.env.NODE_ENV !== 'production') {
135
+ _DevToolsManager.prototype.middleware = function (controller) {
136
+ if (!this.devTools) return next => action => next(action);
137
+ this.controller = controller;
138
+ const reducer = createReducer(controller);
139
+ let state = controller.getState();
140
+ return next => action => {
141
+ var _this$skipLogging;
142
+ const shouldSkip = (_this$skipLogging = this.skipLogging) == null ? void 0 : _this$skipLogging.call(this, action);
143
+ const ret = next(action);
144
+ if (this.started) {
145
+ // we track state changes here since getState() will only update after a batch commit
146
+ state = reducer(state, action);
147
+ } else {
148
+ state = controller.getState();
149
+ }
150
+ ret.then(() => {
151
+ if (shouldSkip) return;
152
+ this.handleAction(action, state.optimistic.reduce(reducer, state));
153
+ });
154
+ return ret;
155
+ };
156
+ };
157
+ } else {
158
+ _DevToolsManager.prototype.middleware = () => next => action => next(action);
159
+ }
160
+ })();
161
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["createReducer","DEFAULT_CONFIG","process","env","NODE_ENV","_globalThis$document","extraEndpointKeys","serializeEndpoint","endpoint","_toJSON","_endpoint$schema","serial","name","schema","toJSON","sideEffect","forEach","key","HASINTL","Intl","globalThis","document","title","autoPause","features","pause","lock","persist","export","import","jump","skip","reorder","dispatch","test","actionSanitizer","action","Object","assign","serialize","options","undefined","replacer","value","isFinite","endsWith","DateTimeFormat","hour","minute","second","fractionalSecondDigits","format","DevToolsManager","constructor","config","skipLogging","started","actions","maxBufferLength","devTools","window","__REDUX_DEVTOOLS_EXTENSION__","connect","maxAge","handleAction","state","send","length","slice","push","init","subscribe","msg","type","payload","controller","resetEntireStore","cleanup","_DevToolsManager","prototype","middleware","next","reducer","getState","_this$skipLogging","shouldSkip","call","ret","then","optimistic","reduce"],"sources":["../../src/manager/DevtoolsManager.ts"],"sourcesContent":["/* eslint-disable no-inner-declarations */\nimport type { DevToolsConfig } from './devtoolsTypes.js';\nimport type { Controller, EndpointInterface } from '../index.js';\nimport type { Middleware } from '../middlewareTypes.js';\nimport createReducer from '../state/reducer/createReducer.js';\nimport type { Manager, State, ActionTypes } from '../types.js';\n\nexport type { DevToolsConfig };\n\nlet DEFAULT_CONFIG = {};\n\nif (process.env.NODE_ENV !== 'production') {\n  const extraEndpointKeys = [\n    'dataExpiryLength',\n    'errorExpiryLength',\n    'errorPolicy',\n    'invalidIfStale',\n    'pollFrequency',\n    'getOptimisticResponse',\n    'update',\n  ];\n\n  function serializeEndpoint(endpoint: EndpointInterface) {\n    const serial: any = {\n      name: endpoint.name,\n      schema: (endpoint.schema as any)?.toJSON?.() ?? endpoint.schema,\n      sideEffect: endpoint.sideEffect,\n    };\n    extraEndpointKeys.forEach(key => {\n      if (key in endpoint)\n        serial[key] = endpoint[key as keyof EndpointInterface];\n    });\n    return serial;\n  }\n\n  const HASINTL = typeof Intl !== 'undefined';\n  DEFAULT_CONFIG = {\n    name: `Data Client: ${globalThis.document?.title}`,\n    autoPause: true,\n    features: {\n      pause: true, // start/pause recording of dispatched actions\n      lock: true, // lock/unlock dispatching actions and side effects\n      persist: false, // persist states on page reloading\n      export: true, // export history of actions in a file\n      import: 'custom', // import history of actions from a file\n      jump: true, // jump back and forth (time travelling)\n      skip: true, // skip (cancel) actions\n      reorder: true, // drag and drop actions in the history list\n      dispatch: false, // dispatch custom actions or action creators\n      test: false, // generate tests for the selected actions\n    },\n    actionSanitizer: (action: ActionTypes) => {\n      if (!('endpoint' in action)) return action;\n      return {\n        ...action,\n        endpoint: serializeEndpoint(action.endpoint),\n      };\n    },\n    serialize: {\n      options: undefined,\n      /* istanbul ignore next */\n      replacer:\n        HASINTL ?\n          (key: string | number | symbol, value: unknown) => {\n            if (\n              typeof value === 'number' &&\n              typeof key === 'string' &&\n              isFinite(value) &&\n              (key === 'date' || key.endsWith('At'))\n            ) {\n              return Intl.DateTimeFormat('en-US', {\n                hour: 'numeric',\n                minute: 'numeric',\n                second: 'numeric',\n                fractionalSecondDigits: 3,\n              }).format(value);\n            }\n            return value;\n          }\n        : undefined,\n    },\n  };\n}\n\n/** Integrates with https://github.com/reduxjs/redux-devtools\n *\n * Options: https://github.com/reduxjs/redux-devtools/blob/main/extension/docs/API/Arguments.md\n *\n * @see https://dataclient.io/docs/api/DevToolsManager\n */\nexport default class DevToolsManager implements Manager {\n  declare middleware: Middleware;\n  protected declare devTools: undefined | any;\n  protected started = false;\n  protected actions: [ActionTypes, State<unknown>][] = [];\n  protected declare controller: Controller;\n  declare skipLogging?: (action: ActionTypes) => boolean;\n  maxBufferLength = 100;\n\n  constructor(\n    config?: DevToolsConfig,\n    skipLogging?: (action: ActionTypes) => boolean,\n  ) {\n    /* istanbul ignore next */\n    this.devTools =\n      typeof window !== 'undefined' &&\n      (window as any).__REDUX_DEVTOOLS_EXTENSION__ &&\n      (window as any).__REDUX_DEVTOOLS_EXTENSION__.connect({\n        ...DEFAULT_CONFIG,\n        ...config,\n      });\n    // we cut it in half so we should double so we don't lose\n    if (config?.maxAge) this.maxBufferLength = config.maxAge * 2;\n    if (skipLogging) this.skipLogging = skipLogging;\n  }\n\n  static {\n    /* istanbul ignore if */\n    /* istanbul ignore next */\n    if (process.env.NODE_ENV !== 'production') {\n      this.prototype.middleware = function (controller) {\n        if (!this.devTools) return next => action => next(action);\n        this.controller = controller;\n        const reducer = createReducer(controller as any);\n        let state = controller.getState();\n        return next => action => {\n          const shouldSkip = this.skipLogging?.(action);\n          const ret = next(action);\n          if (this.started) {\n            // we track state changes here since getState() will only update after a batch commit\n            state = reducer(state, action);\n          } else {\n            state = controller.getState();\n          }\n          ret.then(() => {\n            if (shouldSkip) return;\n            this.handleAction(action, state.optimistic.reduce(reducer, state));\n          });\n          return ret;\n        };\n      };\n    } else {\n      this.prototype.middleware = () => next => action => next(action);\n    }\n  }\n\n  handleAction(action: any, state: any) {\n    if (this.started) {\n      this.devTools.send(action, state);\n    } else {\n      // avoid this getting too big in case this is long running\n      // we cut in half so we aren't constantly reallocating\n      if (this.actions.length > this.maxBufferLength)\n        this.actions = this.actions.slice(this.maxBufferLength / 2);\n      // queue actions\n      this.actions.push([action, state]);\n    }\n  }\n\n  /** Called when initial state is ready */\n  init(state: State<any>) {\n    if (process.env.NODE_ENV !== 'production' && this.devTools) {\n      this.devTools.init(state);\n      this.devTools.subscribe((msg: any) => {\n        switch (msg.type) {\n          case 'START':\n            this.started = true;\n\n            if (this.actions.length) {\n              this.actions.forEach(([action, state]) => {\n                this.handleAction(action, state);\n              });\n              this.actions = [];\n            }\n            break;\n          case 'STOP':\n            this.started = false;\n            break;\n          case 'DISPATCH':\n            if (msg.payload.type === 'RESET') {\n              this.controller.resetEntireStore();\n            }\n            break;\n        }\n      });\n    }\n  }\n\n  /** Ensures all subscriptions are cleaned up. */\n  cleanup() {}\n}\n"],"mappings":"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","ignoreList":[]}
@@ -8,19 +8,16 @@ export default class LogoutManager {
8
8
  handleLogout,
9
9
  shouldLogout
10
10
  } = {}) {
11
- if (handleLogout) this.handleLogout = handleLogout;
12
- if (shouldLogout) this.shouldLogout = shouldLogout;
13
11
  this.middleware = controller => next => async action => {
14
12
  await next(action);
15
13
  if (action.type === SET_RESPONSE_TYPE && action.error && this.shouldLogout(action.response)) {
16
14
  this.handleLogout(controller);
17
15
  }
18
16
  };
17
+ if (handleLogout) this.handleLogout = handleLogout;
18
+ if (shouldLogout) this.shouldLogout = shouldLogout;
19
19
  }
20
20
  cleanup() {}
21
- getMiddleware() {
22
- return this.middleware;
23
- }
24
21
  shouldLogout(error) {
25
22
  // 401 indicates reauthorization is needed
26
23
  return error.status === 401;
@@ -29,6 +26,4 @@ export default class LogoutManager {
29
26
  controller.resetEntireStore();
30
27
  }
31
28
  }
32
-
33
- // this further restricts the types to be future compatible
34
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTRVRfUkVTUE9OU0VfVFlQRSIsIkxvZ291dE1hbmFnZXIiLCJjb25zdHJ1Y3RvciIsImhhbmRsZUxvZ291dCIsInNob3VsZExvZ291dCIsIm1pZGRsZXdhcmUiLCJjb250cm9sbGVyIiwibmV4dCIsImFjdGlvbiIsInR5cGUiLCJlcnJvciIsInJlc3BvbnNlIiwiY2xlYW51cCIsImdldE1pZGRsZXdhcmUiLCJzdGF0dXMiLCJyZXNldEVudGlyZVN0b3JlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL21hbmFnZXIvTG9nb3V0TWFuYWdlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTRVRfUkVTUE9OU0VfVFlQRSB9IGZyb20gJy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCBDb250cm9sbGVyIGZyb20gJy4uL2NvbnRyb2xsZXIvQ29udHJvbGxlci5qcyc7XG5pbXBvcnQgeyBVbmtub3duRXJyb3IgfSBmcm9tICcuLi9pbmRleC5qcyc7XG5pbXBvcnQgeyBBY3Rpb25UeXBlcywgTWFuYWdlciB9IGZyb20gJy4uL3R5cGVzLmpzJztcblxuLyoqIEhhbmRsaW5nIG5ldHdvcmsgdW5hdXRob3JpemVkIGluZGljYXRvcnMgbGlrZSBIVFRQIDQwMVxuICpcbiAqIEBzZWUgaHR0cHM6Ly9kYXRhY2xpZW50LmlvL2RvY3MvYXBpL0xvZ291dE1hbmFnZXJcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTG9nb3V0TWFuYWdlciBpbXBsZW1lbnRzIE1hbmFnZXIge1xuICBwcm90ZWN0ZWQgZGVjbGFyZSBtaWRkbGV3YXJlOiBNaWRkbGV3YXJlO1xuXG4gIGNvbnN0cnVjdG9yKHsgaGFuZGxlTG9nb3V0LCBzaG91bGRMb2dvdXQgfTogUHJvcHMgPSB7fSkge1xuICAgIGlmIChoYW5kbGVMb2dvdXQpIHRoaXMuaGFuZGxlTG9nb3V0ID0gaGFuZGxlTG9nb3V0O1xuICAgIGlmIChzaG91bGRMb2dvdXQpIHRoaXMuc2hvdWxkTG9nb3V0ID0gc2hvdWxkTG9nb3V0O1xuICAgIHRoaXMubWlkZGxld2FyZSA9IGNvbnRyb2xsZXIgPT4gbmV4dCA9PiBhc3luYyBhY3Rpb24gPT4ge1xuICAgICAgYXdhaXQgbmV4dChhY3Rpb24pO1xuICAgICAgaWYgKFxuICAgICAgICBhY3Rpb24udHlwZSA9PT0gU0VUX1JFU1BPTlNFX1RZUEUgJiZcbiAgICAgICAgYWN0aW9uLmVycm9yICYmXG4gICAgICAgIHRoaXMuc2hvdWxkTG9nb3V0KGFjdGlvbi5yZXNwb25zZSlcbiAgICAgICkge1xuICAgICAgICB0aGlzLmhhbmRsZUxvZ291dChjb250cm9sbGVyKTtcbiAgICAgIH1cbiAgICB9O1xuICB9XG5cbiAgY2xlYW51cCgpIHt9XG5cbiAgZ2V0TWlkZGxld2FyZSgpIHtcbiAgICByZXR1cm4gdGhpcy5taWRkbGV3YXJlO1xuICB9XG5cbiAgcHJvdGVjdGVkIHNob3VsZExvZ291dChlcnJvcjogVW5rbm93bkVycm9yKSB7XG4gICAgLy8gNDAxIGluZGljYXRlcyByZWF1dGhvcml6YXRpb24gaXMgbmVlZGVkXG4gICAgcmV0dXJuIGVycm9yLnN0YXR1cyA9PT0gNDAxO1xuICB9XG5cbiAgaGFuZGxlTG9nb3V0KGNvbnRyb2xsZXI6IENvbnRyb2xsZXI8RGlzcGF0Y2g+KSB7XG4gICAgY29udHJvbGxlci5yZXNldEVudGlyZVN0b3JlKCk7XG4gIH1cbn1cblxudHlwZSBEaXNwYXRjaCA9ICh2YWx1ZTogQWN0aW9uVHlwZXMpID0+IFByb21pc2U8dm9pZD47XG5cbi8vIHRoaXMgZnVydGhlciByZXN0cmljdHMgdGhlIHR5cGVzIHRvIGJlIGZ1dHVyZSBjb21wYXRpYmxlXG5leHBvcnQgdHlwZSBNaWRkbGV3YXJlID0gPEMgZXh0ZW5kcyBDb250cm9sbGVyPERpc3BhdGNoPj4oXG4gIGNvbnRyb2xsZXI6IEMsXG4pID0+IChuZXh0OiBDWydkaXNwYXRjaCddKSA9PiBDWydkaXNwYXRjaCddO1xuXG50eXBlIEhhbmRsZUxvZ291dCA9IChjb250cm9sbGVyOiBDb250cm9sbGVyPERpc3BhdGNoPikgPT4gdm9pZDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgaGFuZGxlTG9nb3V0PzogSGFuZGxlTG9nb3V0O1xuICBzaG91bGRMb2dvdXQ/OiAoZXJyb3I6IFVua25vd25FcnJvcikgPT4gYm9vbGVhbjtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsaUJBQWlCLFFBQVEsbUJBQW1CO0FBS3JEO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxNQUFNQyxhQUFhLENBQW9CO0VBR3BEQyxXQUFXQSxDQUFDO0lBQUVDLFlBQVk7SUFBRUM7RUFBb0IsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFO0lBQ3RELElBQUlELFlBQVksRUFBRSxJQUFJLENBQUNBLFlBQVksR0FBR0EsWUFBWTtJQUNsRCxJQUFJQyxZQUFZLEVBQUUsSUFBSSxDQUFDQSxZQUFZLEdBQUdBLFlBQVk7SUFDbEQsSUFBSSxDQUFDQyxVQUFVLEdBQUdDLFVBQVUsSUFBSUMsSUFBSSxJQUFJLE1BQU1DLE1BQU0sSUFBSTtNQUN0RCxNQUFNRCxJQUFJLENBQUNDLE1BQU0sQ0FBQztNQUNsQixJQUNFQSxNQUFNLENBQUNDLElBQUksS0FBS1QsaUJBQWlCLElBQ2pDUSxNQUFNLENBQUNFLEtBQUssSUFDWixJQUFJLENBQUNOLFlBQVksQ0FBQ0ksTUFBTSxDQUFDRyxRQUFRLENBQUMsRUFDbEM7UUFDQSxJQUFJLENBQUNSLFlBQVksQ0FBQ0csVUFBVSxDQUFDO01BQy9CO0lBQ0YsQ0FBQztFQUNIO0VBRUFNLE9BQU9BLENBQUEsRUFBRyxDQUFDO0VBRVhDLGFBQWFBLENBQUEsRUFBRztJQUNkLE9BQU8sSUFBSSxDQUFDUixVQUFVO0VBQ3hCO0VBRVVELFlBQVlBLENBQUNNLEtBQW1CLEVBQUU7SUFDMUM7SUFDQSxPQUFPQSxLQUFLLENBQUNJLE1BQU0sS0FBSyxHQUFHO0VBQzdCO0VBRUFYLFlBQVlBLENBQUNHLFVBQWdDLEVBQUU7SUFDN0NBLFVBQVUsQ0FBQ1MsZ0JBQWdCLENBQUMsQ0FBQztFQUMvQjtBQUNGOztBQUlBIiwiaWdub3JlTGlzdCI6W119
29
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTRVRfUkVTUE9OU0VfVFlQRSIsIkxvZ291dE1hbmFnZXIiLCJjb25zdHJ1Y3RvciIsImhhbmRsZUxvZ291dCIsInNob3VsZExvZ291dCIsIm1pZGRsZXdhcmUiLCJjb250cm9sbGVyIiwibmV4dCIsImFjdGlvbiIsInR5cGUiLCJlcnJvciIsInJlc3BvbnNlIiwiY2xlYW51cCIsInN0YXR1cyIsInJlc2V0RW50aXJlU3RvcmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9Mb2dvdXRNYW5hZ2VyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNFVF9SRVNQT05TRV9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgQ29udHJvbGxlciBmcm9tICcuLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHsgVW5rbm93bkVycm9yIH0gZnJvbSAnLi4vaW5kZXguanMnO1xuaW1wb3J0IHR5cGUgeyBNYW5hZ2VyLCBNaWRkbGV3YXJlIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG4vKiogSGFuZGxpbmcgbmV0d29yayB1bmF1dGhvcml6ZWQgaW5kaWNhdG9ycyBsaWtlIEhUVFAgNDAxXG4gKlxuICogQHNlZSBodHRwczovL2RhdGFjbGllbnQuaW8vZG9jcy9hcGkvTG9nb3V0TWFuYWdlclxuICovXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBMb2dvdXRNYW5hZ2VyIGltcGxlbWVudHMgTWFuYWdlciB7XG4gIGNvbnN0cnVjdG9yKHsgaGFuZGxlTG9nb3V0LCBzaG91bGRMb2dvdXQgfTogUHJvcHMgPSB7fSkge1xuICAgIGlmIChoYW5kbGVMb2dvdXQpIHRoaXMuaGFuZGxlTG9nb3V0ID0gaGFuZGxlTG9nb3V0O1xuICAgIGlmIChzaG91bGRMb2dvdXQpIHRoaXMuc2hvdWxkTG9nb3V0ID0gc2hvdWxkTG9nb3V0O1xuICB9XG5cbiAgbWlkZGxld2FyZTogTWlkZGxld2FyZSA9IGNvbnRyb2xsZXIgPT4gbmV4dCA9PiBhc3luYyBhY3Rpb24gPT4ge1xuICAgIGF3YWl0IG5leHQoYWN0aW9uKTtcbiAgICBpZiAoXG4gICAgICBhY3Rpb24udHlwZSA9PT0gU0VUX1JFU1BPTlNFX1RZUEUgJiZcbiAgICAgIGFjdGlvbi5lcnJvciAmJlxuICAgICAgdGhpcy5zaG91bGRMb2dvdXQoYWN0aW9uLnJlc3BvbnNlKVxuICAgICkge1xuICAgICAgdGhpcy5oYW5kbGVMb2dvdXQoY29udHJvbGxlcik7XG4gICAgfVxuICB9O1xuXG4gIGNsZWFudXAoKSB7fVxuXG4gIHByb3RlY3RlZCBzaG91bGRMb2dvdXQoZXJyb3I6IFVua25vd25FcnJvcikge1xuICAgIC8vIDQwMSBpbmRpY2F0ZXMgcmVhdXRob3JpemF0aW9uIGlzIG5lZWRlZFxuICAgIHJldHVybiBlcnJvci5zdGF0dXMgPT09IDQwMTtcbiAgfVxuXG4gIGhhbmRsZUxvZ291dChjb250cm9sbGVyOiBDb250cm9sbGVyKSB7XG4gICAgY29udHJvbGxlci5yZXNldEVudGlyZVN0b3JlKCk7XG4gIH1cbn1cblxudHlwZSBIYW5kbGVMb2dvdXQgPSAoY29udHJvbGxlcjogQ29udHJvbGxlcikgPT4gdm9pZDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgaGFuZGxlTG9nb3V0PzogSGFuZGxlTG9nb3V0O1xuICBzaG91bGRMb2dvdXQ/OiAoZXJyb3I6IFVua25vd25FcnJvcikgPT4gYm9vbGVhbjtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsaUJBQWlCLFFBQVEsbUJBQW1CO0FBS3JEO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxNQUFNQyxhQUFhLENBQW9CO0VBQ3BEQyxXQUFXQSxDQUFDO0lBQUVDLFlBQVk7SUFBRUM7RUFBb0IsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFO0lBQUEsS0FLeERDLFVBQVUsR0FBZUMsVUFBVSxJQUFJQyxJQUFJLElBQUksTUFBTUMsTUFBTSxJQUFJO01BQzdELE1BQU1ELElBQUksQ0FBQ0MsTUFBTSxDQUFDO01BQ2xCLElBQ0VBLE1BQU0sQ0FBQ0MsSUFBSSxLQUFLVCxpQkFBaUIsSUFDakNRLE1BQU0sQ0FBQ0UsS0FBSyxJQUNaLElBQUksQ0FBQ04sWUFBWSxDQUFDSSxNQUFNLENBQUNHLFFBQVEsQ0FBQyxFQUNsQztRQUNBLElBQUksQ0FBQ1IsWUFBWSxDQUFDRyxVQUFVLENBQUM7TUFDL0I7SUFDRixDQUFDO0lBYkMsSUFBSUgsWUFBWSxFQUFFLElBQUksQ0FBQ0EsWUFBWSxHQUFHQSxZQUFZO0lBQ2xELElBQUlDLFlBQVksRUFBRSxJQUFJLENBQUNBLFlBQVksR0FBR0EsWUFBWTtFQUNwRDtFQWFBUSxPQUFPQSxDQUFBLEVBQUcsQ0FBQztFQUVEUixZQUFZQSxDQUFDTSxLQUFtQixFQUFFO0lBQzFDO0lBQ0EsT0FBT0EsS0FBSyxDQUFDRyxNQUFNLEtBQUssR0FBRztFQUM3QjtFQUVBVixZQUFZQSxDQUFDRyxVQUFzQixFQUFFO0lBQ25DQSxVQUFVLENBQUNRLGdCQUFnQixDQUFDLENBQUM7RUFDL0I7QUFDRiIsImlnbm9yZUxpc3QiOltdfQ==