@data-client/core 0.14.16 → 0.14.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -349,9 +349,9 @@ function createSubscription(endpoint, {
349
349
  }) {
350
350
  return {
351
351
  type: SUBSCRIBE,
352
- endpoint,
352
+ key: endpoint.key(...args),
353
353
  args,
354
- key: endpoint.key(...args)
354
+ endpoint
355
355
  };
356
356
  }
357
357
  function createUnsubscription(endpoint, {
@@ -707,7 +707,7 @@ class Controller {
707
707
  }
708
708
 
709
709
  // second argument is false if any entities are missing
710
- // eslint-disable-next-line prefer-const
710
+
711
711
  const {
712
712
  data,
713
713
  paths
@@ -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",f=i,y=n,g=r,m=o,v=a,E=c,L=l,b=h,S=d,I=u,O=p;var A=Object.freeze({__proto__:null,FETCH:i,SET:n,SET_RESPONSE:r,OPTIMISTIC:o,RESET:a,SUBSCRIBE:c,UNSUBSCRIBE:l,INVALIDATE:h,INVALIDATEALL:d,EXPIREALL:u,GC:p,FETCH_TYPE:f,SET_TYPE:y,SET_RESPONSE_TYPE:g,OPTIMISTIC_TYPE:m,RESET_TYPE:v,SUBSCRIBE_TYPE:E,UNSUBSCRIBE_TYPE:L,INVALIDATE_TYPE:b,INVALIDATEALL_TYPE:S,EXPIREALL_TYPE:I,GC_TYPE:O});function x(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 w extends Error{}function k(e,t,s){return"AbortError"===s.name?Object.assign({},e,{optimistic:R(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:R(e,t)})}function R(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 T={entities:{},endpoints:{},indexes:{},meta:{},entityMeta:{},optimistic:[],lastReset:0};var j=Object.freeze({__proto__:null,MemoCache:t.MemoCache,INVALID:t.INVALID,initialState:T});function _(e,{args:t}){return{type:c,endpoint:e,args:t,key:e.key(...t)}}function P(e,{args:t}){return{type:l,key:e.key(...t),args:t,endpoint:e}}var q="undefined"!=typeof FormData?e=>e instanceof FormData?Object.fromEntries(e.entries()):e:e=>e;function D(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(q),endpoint:e,meta:s(l,i),error:o}}function M(e,{args:t,fetchedAt:i,value:r}){return{type:n,value:r,args:t.map(q),schema:e,meta:s(6e4,i)}}function C(){return{type:a,date:Date.now()}}function N(e){return{type:d,testKey:e}}function H(e,{args:t}){return{type:h,key:e.key(...t)}}function F(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 B(e){return{type:u,testKey:e}}var z=Object.freeze({__proto__:null,createSubscription:_,createUnsubscription:P,createSetResponse:D,createSet:M,createReset:C,createOptimistic:x,createMeta:s,createInvalidateAll:N,createInvalidate:H,createFetch:F,createExpireAll:B});function U(e,t){return e.meta[t]}const V=e=>{throw new Error("Dispatching while constructing your middleware is not allowed. Other middleware would not be applied to this dispatch.")},Y=()=>T;class K{constructor({dispatch:e=V,getState:s=Y,memo:i=new t.MemoCache}={}){this.fetch=(e,...s)=>{const i=F(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(H(e,{args:t})):Promise.resolve(),this.invalidateAll=e=>this.dispatch(N((t=>e.testKey(t)))),this.expireAll=e=>this.dispatch(B((t=>e.testKey(t)))),this.resetEntireStore=()=>this.dispatch(C()),this.setResponse=(e,...t)=>{const s=t[t.length-1],i=D(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=D(e,{args:t.slice(0,t.length-1),response:s,error:!0});return this.dispatch(i)},this.resolve=(e,t)=>this.dispatch(D(e,t)),this.subscribe=(e,...t)=>null!==t[0]?this.dispatch(_(e,{args:t})):Promise.resolve(),this.unsubscribe=(e,...t)=>null!==t[0]?this.dispatch(P(e,{args:t})):Promise.resolve(),this.snapshot=(e,t)=>new $(this,e,t),this.dispatch=e,this.getState=s,this.memo=i}set(e,...t){const s=t[t.length-1],i=M(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=U(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(q),r=1!==n.length||null!==n[0],o=r?e.key(...n):"",a=r?i.endpoints[o]:void 0,c=e.schema,l=U(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||!X(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(q);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 X(e){if(t.isEntity(e))return!0;if(Array.isArray(e))return 0!==e.length&&X(e[0]);if(e&&("object"==typeof e||"function"==typeof e)){const t="schema"in e?e.schema:e;return"function"==typeof t?X(t):Object.values(t).some((e=>X(e)))}return!1}class ${constructor(e,t,s=0){this.state=void 0,this.controller=void 0,this.fetchedAt=void 0,this.abort=$.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)}}$.abort=new w;class G 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 J{isOnline(){return!0}addOnlineListener(){}removeOnlineListener(){}addOfflineListener(){}removeOfflineListener(){}}let W;W="undefined"!=typeof navigator&&"function"==typeof addEventListener?Q:J;var Z=W;let ee={};class te{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({},ee,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(){}}te.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=K,e.DefaultConnectionListener=Z,e.DevToolsManager=te,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 K,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(D(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 G)}))}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 Z,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=G,e.SubscriptionManager=class{constructor(e){this.subscriptions={},this.controller=new K,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__=j,e.actionTypes=A,e.actions=z,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=T),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=x(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 k(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===w)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:R(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),k(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({},T,{lastReset:c.date});default:return s}}},e.initialState=T,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",f=i,y=n,g=r,m=o,v=a,E=c,L=l,b=h,S=d,I=u,O=p;var A=Object.freeze({__proto__:null,FETCH:i,SET:n,SET_RESPONSE:r,OPTIMISTIC:o,RESET:a,SUBSCRIBE:c,UNSUBSCRIBE:l,INVALIDATE:h,INVALIDATEALL:d,EXPIREALL:u,GC:p,FETCH_TYPE:f,SET_TYPE:y,SET_RESPONSE_TYPE:g,OPTIMISTIC_TYPE:m,RESET_TYPE:v,SUBSCRIBE_TYPE:E,UNSUBSCRIBE_TYPE:L,INVALIDATE_TYPE:b,INVALIDATEALL_TYPE:S,EXPIREALL_TYPE:I,GC_TYPE:O});function x(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 w extends Error{}function k(e,t,s){return"AbortError"===s.name?Object.assign({},e,{optimistic:R(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:R(e,t)})}function R(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 T={entities:{},endpoints:{},indexes:{},meta:{},entityMeta:{},optimistic:[],lastReset:0};var j=Object.freeze({__proto__:null,MemoCache:t.MemoCache,INVALID:t.INVALID,initialState:T});function _(e,{args:t}){return{type:c,key:e.key(...t),args:t,endpoint:e}}function P(e,{args:t}){return{type:l,key:e.key(...t),args:t,endpoint:e}}var q="undefined"!=typeof FormData?e=>e instanceof FormData?Object.fromEntries(e.entries()):e:e=>e;function D(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(q),endpoint:e,meta:s(l,i),error:o}}function M(e,{args:t,fetchedAt:i,value:r}){return{type:n,value:r,args:t.map(q),schema:e,meta:s(6e4,i)}}function C(){return{type:a,date:Date.now()}}function N(e){return{type:d,testKey:e}}function H(e,{args:t}){return{type:h,key:e.key(...t)}}function F(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 B(e){return{type:u,testKey:e}}var z=Object.freeze({__proto__:null,createSubscription:_,createUnsubscription:P,createSetResponse:D,createSet:M,createReset:C,createOptimistic:x,createMeta:s,createInvalidateAll:N,createInvalidate:H,createFetch:F,createExpireAll:B});function U(e,t){return e.meta[t]}const V=e=>{throw new Error("Dispatching while constructing your middleware is not allowed. Other middleware would not be applied to this dispatch.")},Y=()=>T;class K{constructor({dispatch:e=V,getState:s=Y,memo:i=new t.MemoCache}={}){this.fetch=(e,...s)=>{const i=F(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(H(e,{args:t})):Promise.resolve(),this.invalidateAll=e=>this.dispatch(N((t=>e.testKey(t)))),this.expireAll=e=>this.dispatch(B((t=>e.testKey(t)))),this.resetEntireStore=()=>this.dispatch(C()),this.setResponse=(e,...t)=>{const s=t[t.length-1],i=D(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=D(e,{args:t.slice(0,t.length-1),response:s,error:!0});return this.dispatch(i)},this.resolve=(e,t)=>this.dispatch(D(e,t)),this.subscribe=(e,...t)=>null!==t[0]?this.dispatch(_(e,{args:t})):Promise.resolve(),this.unsubscribe=(e,...t)=>null!==t[0]?this.dispatch(P(e,{args:t})):Promise.resolve(),this.snapshot=(e,t)=>new $(this,e,t),this.dispatch=e,this.getState=s,this.memo=i}set(e,...t){const s=t[t.length-1],i=M(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=U(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(q),r=1!==n.length||null!==n[0],o=r?e.key(...n):"",a=r?i.endpoints[o]:void 0,c=e.schema,l=U(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||!X(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(q);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 X(e){if(t.isEntity(e))return!0;if(Array.isArray(e))return 0!==e.length&&X(e[0]);if(e&&("object"==typeof e||"function"==typeof e)){const t="schema"in e?e.schema:e;return"function"==typeof t?X(t):Object.values(t).some((e=>X(e)))}return!1}class ${constructor(e,t,s=0){this.state=void 0,this.controller=void 0,this.fetchedAt=void 0,this.abort=$.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)}}$.abort=new w;class G 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 J{isOnline(){return!0}addOnlineListener(){}removeOnlineListener(){}addOfflineListener(){}removeOfflineListener(){}}let W;W="undefined"!=typeof navigator&&"function"==typeof addEventListener?Q:J;var Z=W;let ee={};class te{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({},ee,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(){}}te.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=K,e.DefaultConnectionListener=Z,e.DevToolsManager=te,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 K,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(D(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 G)}))}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 Z,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=G,e.SubscriptionManager=class{constructor(e){this.subscriptions={},this.controller=new K,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__=j,e.actionTypes=A,e.actions=z,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=T),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=x(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 k(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===w)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:R(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),k(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({},T,{lastReset:c.date});default:return s}}},e.initialState=T,Object.defineProperty(e,"__esModule",{value:!0})}));
@@ -229,7 +229,7 @@ export default class Controller {
229
229
  }
230
230
 
231
231
  // second argument is false if any entities are missing
232
- // eslint-disable-next-line prefer-const
232
+
233
233
  const {
234
234
  data,
235
235
  paths
@@ -335,4 +335,4 @@ class Snapshot {
335
335
  }
336
336
  }
337
337
  Snapshot.abort = new AbortOptimistic();
338
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ExpiryStatus","MemoCache","isEntity","denormalize","validateQueryKey","AbortOptimistic","createUnsubscription","createSubscription","createExpireAll","createFetch","createInvalidate","createInvalidateAll","createReset","createSet","createSetResponse","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","set","value","getError","endpoints","undefined","errorPolicy","map","isActive","cacheEndpoints","shouldQuery","buildQueryKey","entities","indexes","Valid","Infinity","isInvalid","schemaHasEntity","invalidated","invalidIfStale","InvalidIfStale","paths","getSchemaResponse","entityMeta","get","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 {\n  createUnsubscription,\n  createSubscription,\n} from './actions/createSubscription.js';\nimport {\n  createExpireAll,\n  createFetch,\n  createInvalidate,\n  createInvalidateAll,\n  createReset,\n  createSet,\n  createSetResponse,\n} from './actions/index.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(endpoint.schema, input, {}, 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>, (previousValue: Denormalize<S>) => {}]\n  ): Promise<void>;\n\n  set<S extends Queryable>(\n    schema: S,\n    ...rest: readonly [...SchemaArgs<S>, {}]\n  ): Promise<void>;\n\n  set<S extends Queryable>(\n    schema: S,\n    ...rest: readonly [...SchemaArgs<S>, any]\n  ): Promise<void> {\n    const value = 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.\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          schema,\n          args,\n          state.entities as any,\n          state.indexes,\n          key,\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      schema,\n      input,\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    return this.memo.query(schema, args, state.entities as any, state.indexes);\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":[]}
338
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ExpiryStatus","MemoCache","isEntity","denormalize","validateQueryKey","AbortOptimistic","createUnsubscription","createSubscription","createExpireAll","createFetch","createInvalidate","createInvalidateAll","createReset","createSet","createSetResponse","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","set","value","getError","endpoints","undefined","errorPolicy","map","isActive","cacheEndpoints","shouldQuery","buildQueryKey","entities","indexes","Valid","Infinity","isInvalid","schemaHasEntity","invalidated","invalidIfStale","InvalidIfStale","paths","getSchemaResponse","entityMeta","get","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 {\n  createUnsubscription,\n  createSubscription,\n} from './actions/createSubscription.js';\nimport {\n  createExpireAll,\n  createFetch,\n  createInvalidate,\n  createInvalidateAll,\n  createReset,\n  createSet,\n  createSetResponse,\n} from './actions/index.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(endpoint.schema, input, {}, 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>, (previousValue: Denormalize<S>) => {}]\n  ): Promise<void>;\n\n  set<S extends Queryable>(\n    schema: S,\n    ...rest: readonly [...SchemaArgs<S>, {}]\n  ): Promise<void>;\n\n  set<S extends Queryable>(\n    schema: S,\n    ...rest: readonly [...SchemaArgs<S>, any]\n  ): Promise<void> {\n    const value = 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.\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          schema,\n          args,\n          state.entities as any,\n          state.indexes,\n          key,\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\n    const { data, paths } = this.memo.denormalize(\n      schema,\n      input,\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    return this.memo.query(schema, args, state.entities as any, state.indexes);\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":[]}
@@ -4,9 +4,9 @@ export function createSubscription(endpoint, {
4
4
  }) {
5
5
  return {
6
6
  type: SUBSCRIBE,
7
- endpoint,
7
+ key: endpoint.key(...args),
8
8
  args,
9
- key: endpoint.key(...args)
9
+ endpoint
10
10
  };
11
11
  }
12
12
  export function createUnsubscription(endpoint, {
@@ -19,4 +19,4 @@ export function createUnsubscription(endpoint, {
19
19
  endpoint
20
20
  };
21
21
  }
22
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVUJTQ1JJQkUiLCJVTlNVQlNDUklCRSIsImNyZWF0ZVN1YnNjcmlwdGlvbiIsImVuZHBvaW50IiwiYXJncyIsInR5cGUiLCJrZXkiLCJjcmVhdGVVbnN1YnNjcmlwdGlvbiJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlU3Vic2NyaXB0aW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRW5kcG9pbnRJbnRlcmZhY2UgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgU1VCU0NSSUJFLCBVTlNVQlNDUklCRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgU3Vic2NyaWJlQWN0aW9uLCBVbnN1YnNjcmliZUFjdGlvbiB9IGZyb20gJy4uLy4uL3R5cGVzLmpzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVN1YnNjcmlwdGlvbjxFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2U+KFxuICBlbmRwb2ludDogRSxcbiAgeyBhcmdzIH06IHsgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dIH0sXG4pOiBTdWJzY3JpYmVBY3Rpb248RT4ge1xuICByZXR1cm4ge1xuICAgIHR5cGU6IFNVQlNDUklCRSxcbiAgICBlbmRwb2ludCxcbiAgICBhcmdzLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlVW5zdWJzY3JpcHRpb248RSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlPihcbiAgZW5kcG9pbnQ6IEUsXG4gIHsgYXJncyB9OiB7IGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XSB9LFxuKTogVW5zdWJzY3JpYmVBY3Rpb248RT4ge1xuICByZXR1cm4ge1xuICAgIHR5cGU6IFVOU1VCU0NSSUJFLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICAgIGFyZ3MsXG4gICAgZW5kcG9pbnQsXG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiJBQUVBLFNBQVNBLFNBQVMsRUFBRUMsV0FBVyxRQUFRLHNCQUFzQjtBQUc3RCxPQUFPLFNBQVNDLGtCQUFrQkEsQ0FDaENDLFFBQVcsRUFDWDtFQUFFQztBQUE0QyxDQUFDLEVBQzNCO0VBQ3BCLE9BQU87SUFDTEMsSUFBSSxFQUFFTCxTQUFTO0lBQ2ZHLFFBQVE7SUFDUkMsSUFBSTtJQUNKRSxHQUFHLEVBQUVILFFBQVEsQ0FBQ0csR0FBRyxDQUFDLEdBQUdGLElBQUk7RUFDM0IsQ0FBQztBQUNIO0FBRUEsT0FBTyxTQUFTRyxvQkFBb0JBLENBQ2xDSixRQUFXLEVBQ1g7RUFBRUM7QUFBNEMsQ0FBQyxFQUN6QjtFQUN0QixPQUFPO0lBQ0xDLElBQUksRUFBRUosV0FBVztJQUNqQkssR0FBRyxFQUFFSCxRQUFRLENBQUNHLEdBQUcsQ0FBQyxHQUFHRixJQUFJLENBQUM7SUFDMUJBLElBQUk7SUFDSkQ7RUFDRixDQUFDO0FBQ0giLCJpZ25vcmVMaXN0IjpbXX0=
22
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVUJTQ1JJQkUiLCJVTlNVQlNDUklCRSIsImNyZWF0ZVN1YnNjcmlwdGlvbiIsImVuZHBvaW50IiwiYXJncyIsInR5cGUiLCJrZXkiLCJjcmVhdGVVbnN1YnNjcmlwdGlvbiJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlU3Vic2NyaXB0aW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRW5kcG9pbnRJbnRlcmZhY2UgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgU1VCU0NSSUJFLCBVTlNVQlNDUklCRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgU3Vic2NyaWJlQWN0aW9uLCBVbnN1YnNjcmliZUFjdGlvbiB9IGZyb20gJy4uLy4uL3R5cGVzLmpzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVN1YnNjcmlwdGlvbjxFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2U+KFxuICBlbmRwb2ludDogRSxcbiAgeyBhcmdzIH06IHsgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dIH0sXG4pOiBTdWJzY3JpYmVBY3Rpb248RT4ge1xuICByZXR1cm4ge1xuICAgIHR5cGU6IFNVQlNDUklCRSxcbiAgICBrZXk6IGVuZHBvaW50LmtleSguLi5hcmdzKSxcbiAgICBhcmdzLFxuICAgIGVuZHBvaW50LFxuICB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlVW5zdWJzY3JpcHRpb248RSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlPihcbiAgZW5kcG9pbnQ6IEUsXG4gIHsgYXJncyB9OiB7IGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XSB9LFxuKTogVW5zdWJzY3JpYmVBY3Rpb248RT4ge1xuICByZXR1cm4ge1xuICAgIHR5cGU6IFVOU1VCU0NSSUJFLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICAgIGFyZ3MsXG4gICAgZW5kcG9pbnQsXG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiJBQUVBLFNBQVNBLFNBQVMsRUFBRUMsV0FBVyxRQUFRLHNCQUFzQjtBQUc3RCxPQUFPLFNBQVNDLGtCQUFrQkEsQ0FDaENDLFFBQVcsRUFDWDtFQUFFQztBQUE0QyxDQUFDLEVBQzNCO0VBQ3BCLE9BQU87SUFDTEMsSUFBSSxFQUFFTCxTQUFTO0lBQ2ZNLEdBQUcsRUFBRUgsUUFBUSxDQUFDRyxHQUFHLENBQUMsR0FBR0YsSUFBSSxDQUFDO0lBQzFCQSxJQUFJO0lBQ0pEO0VBQ0YsQ0FBQztBQUNIO0FBRUEsT0FBTyxTQUFTSSxvQkFBb0JBLENBQ2xDSixRQUFXLEVBQ1g7RUFBRUM7QUFBNEMsQ0FBQyxFQUN6QjtFQUN0QixPQUFPO0lBQ0xDLElBQUksRUFBRUosV0FBVztJQUNqQkssR0FBRyxFQUFFSCxRQUFRLENBQUNHLEdBQUcsQ0FBQyxHQUFHRixJQUFJLENBQUM7SUFDMUJBLElBQUk7SUFDSkQ7RUFDRixDQUFDO0FBQ0giLCJpZ25vcmVMaXN0IjpbXX0=
@@ -1,6 +1,4 @@
1
1
  var _DevToolsManager;
2
- /* eslint-disable no-inner-declarations */
3
-
4
2
  import createReducer from '../state/reducer/createReducer.js';
5
3
  let DEFAULT_CONFIG = {};
6
4
  if (process.env.NODE_ENV !== 'production') {
@@ -158,4 +156,4 @@ _DevToolsManager = DevToolsManager;
158
156
  _DevToolsManager.prototype.middleware = () => next => action => next(action);
159
157
  }
160
158
  })();
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":[]}
159
+ //# 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":["import 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  declare protected devTools: undefined | any;\n  protected started = false;\n  protected actions: [ActionTypes, State<unknown>][] = [];\n  declare protected 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":";AAGA,OAAOA,aAAa,MAAM,mCAAmC;AAK7D,IAAIC,cAAc,GAAG,CAAC,CAAC;AAEvB,IAAIC,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;EAAA,IAAAC,oBAAA;EACzC,MAAMC,iBAAiB,GAAG,CACxB,kBAAkB,EAClB,mBAAmB,EACnB,aAAa,EACb,gBAAgB,EAChB,eAAe,EACf,uBAAuB,EACvB,QAAQ,CACT;EAED,SAASC,iBAAiBA,CAACC,QAA2B,EAAE;IAAA,IAAAC,OAAA,EAAAC,gBAAA;IACtD,MAAMC,MAAW,GAAG;MAClBC,IAAI,EAAEJ,QAAQ,CAACI,IAAI;MACnBC,MAAM,GAAAJ,OAAA,IAAAC,gBAAA,GAAGF,QAAQ,CAACK,MAAM,aAAhBH,gBAAA,CAA0BI,MAAM,oBAAhCJ,gBAAA,CAA0BI,MAAM,CAAG,CAAC,YAAAL,OAAA,GAAID,QAAQ,CAACK,MAAM;MAC/DE,UAAU,EAAEP,QAAQ,CAACO;IACvB,CAAC;IACDT,iBAAiB,CAACU,OAAO,CAACC,GAAG,IAAI;MAC/B,IAAIA,GAAG,IAAIT,QAAQ,EACjBG,MAAM,CAACM,GAAG,CAAC,GAAGT,QAAQ,CAACS,GAAG,CAA4B;IAC1D,CAAC,CAAC;IACF,OAAON,MAAM;EACf;EAEA,MAAMO,OAAO,GAAG,OAAOC,IAAI,KAAK,WAAW;EAC3ClB,cAAc,GAAG;IACfW,IAAI,EAAE,iBAAAP,oBAAA,GAAgBe,UAAU,CAACC,QAAQ,qBAAnBhB,oBAAA,CAAqBiB,KAAK,EAAE;IAClDC,SAAS,EAAE,IAAI;IACfC,QAAQ,EAAE;MACRC,KAAK,EAAE,IAAI;MAAE;MACbC,IAAI,EAAE,IAAI;MAAE;MACZC,OAAO,EAAE,KAAK;MAAE;MAChBC,MAAM,EAAE,IAAI;MAAE;MACdC,MAAM,EAAE,QAAQ;MAAE;MAClBC,IAAI,EAAE,IAAI;MAAE;MACZC,IAAI,EAAE,IAAI;MAAE;MACZC,OAAO,EAAE,IAAI;MAAE;MACfC,QAAQ,EAAE,KAAK;MAAE;MACjBC,IAAI,EAAE,KAAK,CAAE;IACf,CAAC;IACDC,eAAe,EAAGC,MAAmB,IAAK;MACxC,IAAI,EAAE,UAAU,IAAIA,MAAM,CAAC,EAAE,OAAOA,MAAM;MAC1C,OAAAC,MAAA,CAAAC,MAAA,KACKF,MAAM;QACT5B,QAAQ,EAAED,iBAAiB,CAAC6B,MAAM,CAAC5B,QAAQ;MAAC;IAEhD,CAAC;IACD+B,SAAS,EAAE;MACTC,OAAO,EAAEC,SAAS;MAClB;MACAC,QAAQ,EACNxB,OAAO,GACL,CAACD,GAA6B,EAAE0B,KAAc,KAAK;QACjD,IACE,OAAOA,KAAK,KAAK,QAAQ,IACzB,OAAO1B,GAAG,KAAK,QAAQ,IACvB2B,QAAQ,CAACD,KAAK,CAAC,KACd1B,GAAG,KAAK,MAAM,IAAIA,GAAG,CAAC4B,QAAQ,CAAC,IAAI,CAAC,CAAC,EACtC;UACA,OAAO1B,IAAI,CAAC2B,cAAc,CAAC,OAAO,EAAE;YAClCC,IAAI,EAAE,SAAS;YACfC,MAAM,EAAE,SAAS;YACjBC,MAAM,EAAE,SAAS;YACjBC,sBAAsB,EAAE;UAC1B,CAAC,CAAC,CAACC,MAAM,CAACR,KAAK,CAAC;QAClB;QACA,OAAOA,KAAK;MACd,CAAC,GACDF;IACN;EACF,CAAC;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,MAAMW,eAAe,CAAoB;EAStDC,WAAWA,CACTC,MAAuB,EACvBC,WAA8C,EAC9C;IAAA,KATQC,OAAO,GAAG,KAAK;IAAA,KACfC,OAAO,GAAoC,EAAE;IAAA,KAGvDC,eAAe,GAAG,GAAG;IAMnB;IACA,IAAI,CAACC,QAAQ,GACX,OAAOC,MAAM,KAAK,WAAW,IAC5BA,MAAM,CAASC,4BAA4B,IAC3CD,MAAM,CAASC,4BAA4B,CAACC,OAAO,CAAAzB,MAAA,CAAAC,MAAA,KAC/CrC,cAAc,EACdqD,MAAM,CACV,CAAC;IACJ;IACA,IAAIA,MAAM,YAANA,MAAM,CAAES,MAAM,EAAE,IAAI,CAACL,eAAe,GAAGJ,MAAM,CAACS,MAAM,GAAG,CAAC;IAC5D,IAAIR,WAAW,EAAE,IAAI,CAACA,WAAW,GAAGA,WAAW;EACjD;EAgCAS,YAAYA,CAAC5B,MAAW,EAAE6B,KAAU,EAAE;IACpC,IAAI,IAAI,CAACT,OAAO,EAAE;MAChB,IAAI,CAACG,QAAQ,CAACO,IAAI,CAAC9B,MAAM,EAAE6B,KAAK,CAAC;IACnC,CAAC,MAAM;MACL;MACA;MACA,IAAI,IAAI,CAACR,OAAO,CAACU,MAAM,GAAG,IAAI,CAACT,eAAe,EAC5C,IAAI,CAACD,OAAO,GAAG,IAAI,CAACA,OAAO,CAACW,KAAK,CAAC,IAAI,CAACV,eAAe,GAAG,CAAC,CAAC;MAC7D;MACA,IAAI,CAACD,OAAO,CAACY,IAAI,CAAC,CAACjC,MAAM,EAAE6B,KAAK,CAAC,CAAC;IACpC;EACF;;EAEA;EACAK,IAAIA,CAACL,KAAiB,EAAE;IACtB,IAAI/D,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,IAAI,IAAI,CAACuD,QAAQ,EAAE;MAC1D,IAAI,CAACA,QAAQ,CAACW,IAAI,CAACL,KAAK,CAAC;MACzB,IAAI,CAACN,QAAQ,CAACY,SAAS,CAAEC,GAAQ,IAAK;QACpC,QAAQA,GAAG,CAACC,IAAI;UACd,KAAK,OAAO;YACV,IAAI,CAACjB,OAAO,GAAG,IAAI;YAEnB,IAAI,IAAI,CAACC,OAAO,CAACU,MAAM,EAAE;cACvB,IAAI,CAACV,OAAO,CAACzC,OAAO,CAAC,CAAC,CAACoB,MAAM,EAAE6B,KAAK,CAAC,KAAK;gBACxC,IAAI,CAACD,YAAY,CAAC5B,MAAM,EAAE6B,KAAK,CAAC;cAClC,CAAC,CAAC;cACF,IAAI,CAACR,OAAO,GAAG,EAAE;YACnB;YACA;UACF,KAAK,MAAM;YACT,IAAI,CAACD,OAAO,GAAG,KAAK;YACpB;UACF,KAAK,UAAU;YACb,IAAIgB,GAAG,CAACE,OAAO,CAACD,IAAI,KAAK,OAAO,EAAE;cAChC,IAAI,CAACE,UAAU,CAACC,gBAAgB,CAAC,CAAC;YACpC;YACA;QACJ;MACF,CAAC,CAAC;IACJ;EACF;;EAEA;EACAC,OAAOA,CAAA,EAAG,CAAC;AACb;AAACC,gBAAA,GApGoB1B,eAAe;AAAA;EA2BhC;EACA;EACA,IAAIlD,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;IACzC0E,gBAAA,CAAKC,SAAS,CAACC,UAAU,GAAG,UAAUL,UAAU,EAAE;MAChD,IAAI,CAAC,IAAI,CAAChB,QAAQ,EAAE,OAAOsB,IAAI,IAAI7C,MAAM,IAAI6C,IAAI,CAAC7C,MAAM,CAAC;MACzD,IAAI,CAACuC,UAAU,GAAGA,UAAU;MAC5B,MAAMO,OAAO,GAAGlF,aAAa,CAAC2E,UAAiB,CAAC;MAChD,IAAIV,KAAK,GAAGU,UAAU,CAACQ,QAAQ,CAAC,CAAC;MACjC,OAAOF,IAAI,IAAI7C,MAAM,IAAI;QAAA,IAAAgD,iBAAA;QACvB,MAAMC,UAAU,IAAAD,iBAAA,GAAG,IAAI,CAAC7B,WAAW,qBAAhB6B,iBAAA,CAAAE,IAAA,KAAI,EAAelD,MAAM,CAAC;QAC7C,MAAMmD,GAAG,GAAGN,IAAI,CAAC7C,MAAM,CAAC;QACxB,IAAI,IAAI,CAACoB,OAAO,EAAE;UAChB;UACAS,KAAK,GAAGiB,OAAO,CAACjB,KAAK,EAAE7B,MAAM,CAAC;QAChC,CAAC,MAAM;UACL6B,KAAK,GAAGU,UAAU,CAACQ,QAAQ,CAAC,CAAC;QAC/B;QACAI,GAAG,CAACC,IAAI,CAAC,MAAM;UACb,IAAIH,UAAU,EAAE;UAChB,IAAI,CAACrB,YAAY,CAAC5B,MAAM,EAAE6B,KAAK,CAACwB,UAAU,CAACC,MAAM,CAACR,OAAO,EAAEjB,KAAK,CAAC,CAAC;QACpE,CAAC,CAAC;QACF,OAAOsB,GAAG;MACZ,CAAC;IACH,CAAC;EACH,CAAC,MAAM;IACLT,gBAAA,CAAKC,SAAS,CAACC,UAAU,GAAG,MAAMC,IAAI,IAAI7C,MAAM,IAAI6C,IAAI,CAAC7C,MAAM,CAAC;EAClE;AAAC","ignoreList":[]}
@@ -147,4 +147,4 @@ export default class PollingSubscription {
147
147
  return (_this$controller$getS = (_this$controller$getS2 = this.controller.getState().meta[this.key]) == null ? void 0 : _this$controller$getS2.date) != null ? _this$controller$getS : 0;
148
148
  }
149
149
  }
150
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DefaultConnectionListener","PollingSubscription","constructor","action","controller","connectionListener","frequencyHistogram","Map","offlineListener","cleanup","addOnlineListener","onlineListener","removeOnlineListener","now","Date","startId","setTimeout","update","run","process","env","NODE_ENV","console","warn","key","Math","max","lastFetchTime","frequency","addOfflineListener","endpoint","pollFrequency","undefined","Error","args","set","isOnline","add","has","get","remove","delete","size","min","keys","error","intervalId","clearInterval","lastIntervalId","clearTimeout","removeOfflineListener","sup","call","Object","assign","dataExpiryLength","errorExpiryLength","errorPolicy","fetch","catch","setInterval","_this$controller$getS","_this$controller$getS2","getState","meta","date"],"sources":["../../src/manager/PollingSubscription.ts"],"sourcesContent":["import type { EndpointInterface } from '@data-client/normalizr';\n\nimport ConnectionListener from './ConnectionListener.js';\nimport DefaultConnectionListener from './DefaultConnectionListener.js';\nimport type { Subscription } from './SubscriptionManager.js';\nimport type Controller from '../controller/Controller.js';\nimport type { SubscribeAction } from '../types.js';\n\n/**\n * PollingSubscription keeps a given resource updated by\n * dispatching a fetch at a rate equal to the minimum update\n * interval requested.\n *\n * @see https://dataclient.io/docs/api/PollingSubscription\n */\nexport default class PollingSubscription implements Subscription {\n  protected declare readonly endpoint: EndpointInterface;\n  protected declare readonly args: readonly any[];\n  protected declare readonly key: string;\n  protected declare frequency: number;\n  protected frequencyHistogram: Map<number, number> = new Map();\n  protected declare controller: Controller;\n  protected declare intervalId?: ReturnType<typeof setInterval>;\n  protected declare lastIntervalId?: ReturnType<typeof setInterval>;\n  protected declare startId?: ReturnType<typeof setTimeout>;\n  private declare connectionListener: ConnectionListener;\n\n  constructor(\n    action: Omit<SubscribeAction, 'type'>,\n    controller: Controller,\n    connectionListener?: ConnectionListener,\n  ) {\n    if (action.endpoint.pollFrequency === undefined)\n      throw new Error('frequency needed for polling subscription');\n    this.endpoint = action.endpoint;\n    this.frequency = action.endpoint.pollFrequency;\n    this.args = action.args;\n    this.key = action.key;\n    this.frequencyHistogram.set(this.frequency, 1);\n    this.controller = controller;\n    this.connectionListener =\n      connectionListener || new DefaultConnectionListener();\n\n    // Kickstart running since this is initialized after the online notif is sent\n    if (this.connectionListener.isOnline()) {\n      this.onlineListener();\n    } else {\n      this.offlineListener();\n    }\n  }\n\n  /** Subscribe to a frequency */\n  add(frequency?: number) {\n    if (frequency === undefined) return;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) + 1,\n      );\n    } else {\n      this.frequencyHistogram.set(frequency, 1);\n\n      // new min so restart service\n      if (frequency < this.frequency) {\n        this.frequency = frequency;\n        this.run();\n      }\n    }\n  }\n\n  /** Unsubscribe from a frequency */\n  remove(frequency?: number) {\n    if (frequency === undefined) return false;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) - 1,\n      );\n      if ((this.frequencyHistogram.get(frequency) as number) < 1) {\n        this.frequencyHistogram.delete(frequency);\n\n        // nothing subscribed to this anymore...it is invalid\n        if (this.frequencyHistogram.size === 0) {\n          this.cleanup();\n          return true;\n        }\n\n        // this was the min, so find the next size\n        if (frequency <= this.frequency) {\n          this.frequency = Math.min(...this.frequencyHistogram.keys());\n          this.run();\n        }\n      }\n    } /* istanbul ignore next */ else if (\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.error(\n        `Mismatched remove: ${frequency} is not subscribed for ${this.key}`,\n      );\n    }\n    return false;\n  }\n\n  /** Cleanup means clearing out background interval. */\n  cleanup() {\n    if (this.intervalId) {\n      clearInterval(this.intervalId);\n      delete this.intervalId;\n    }\n    if (this.lastIntervalId) {\n      clearInterval(this.lastIntervalId);\n      delete this.lastIntervalId;\n    }\n    if (this.startId) {\n      clearTimeout(this.startId);\n      delete this.startId;\n    }\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    this.connectionListener.removeOfflineListener(this.offlineListener);\n  }\n\n  /** Trigger request for latest resource */\n  protected update() {\n    const sup = this.endpoint;\n    const endpoint = function (this: any, ...args: any[]) {\n      return sup.call(this, ...args);\n    };\n    Object.assign(endpoint, this.endpoint);\n    endpoint.dataExpiryLength = this.frequency / 2;\n    endpoint.errorExpiryLength = this.frequency / 10;\n    endpoint.errorPolicy = () => 'soft' as const;\n    endpoint.key = () => this.key;\n    // stop any errors here from bubbling\n    this.controller.fetch(endpoint, ...this.args).catch(() => null);\n  }\n\n  /** What happens when browser goes offline */\n  protected offlineListener = () => {\n    // this clears existing listeners, so no need to clear offline listener\n    this.cleanup();\n    this.connectionListener.addOnlineListener(this.onlineListener);\n  };\n\n  /** What happens when browser comes online */\n  protected onlineListener = () => {\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    const now = Date.now();\n    this.startId = setTimeout(\n      () => {\n        if (this.startId) {\n          delete this.startId;\n          this.update();\n          this.run();\n        } else if (process.env.NODE_ENV !== 'production') {\n          console.warn(\n            `Poll setTimeout for ${this.key} still running, but timeoutId deleted`,\n          );\n        }\n      },\n      Math.max(0, this.lastFetchTime() - now + this.frequency),\n    );\n    this.connectionListener.addOfflineListener(this.offlineListener);\n  };\n\n  /** Run polling process with current frequency\n   *\n   * Will clean up old poll interval on next run\n   */\n  protected run() {\n    if (this.startId) return;\n    if (this.intervalId) this.lastIntervalId = this.intervalId;\n    this.intervalId = setInterval(() => {\n      // since we don't know how long into the last poll it was before resetting\n      // we wait til the next fetch to clear old intervals\n      if (this.lastIntervalId) {\n        clearInterval(this.lastIntervalId);\n        delete this.lastIntervalId;\n      }\n      if (this.intervalId) this.update();\n      else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll intervalId for ${this.key} still running, but intervalId deleted`,\n        );\n      }\n    }, this.frequency);\n  }\n\n  /** Last fetch time */\n  protected lastFetchTime() {\n    return this.controller.getState().meta[this.key]?.date ?? 0;\n  }\n}\n"],"mappings":"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","ignoreList":[]}
150
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DefaultConnectionListener","PollingSubscription","constructor","action","controller","connectionListener","frequencyHistogram","Map","offlineListener","cleanup","addOnlineListener","onlineListener","removeOnlineListener","now","Date","startId","setTimeout","update","run","process","env","NODE_ENV","console","warn","key","Math","max","lastFetchTime","frequency","addOfflineListener","endpoint","pollFrequency","undefined","Error","args","set","isOnline","add","has","get","remove","delete","size","min","keys","error","intervalId","clearInterval","lastIntervalId","clearTimeout","removeOfflineListener","sup","call","Object","assign","dataExpiryLength","errorExpiryLength","errorPolicy","fetch","catch","setInterval","_this$controller$getS","_this$controller$getS2","getState","meta","date"],"sources":["../../src/manager/PollingSubscription.ts"],"sourcesContent":["import type { EndpointInterface } from '@data-client/normalizr';\n\nimport ConnectionListener from './ConnectionListener.js';\nimport DefaultConnectionListener from './DefaultConnectionListener.js';\nimport type { Subscription } from './SubscriptionManager.js';\nimport type Controller from '../controller/Controller.js';\nimport type { SubscribeAction } from '../types.js';\n\n/**\n * PollingSubscription keeps a given resource updated by\n * dispatching a fetch at a rate equal to the minimum update\n * interval requested.\n *\n * @see https://dataclient.io/docs/api/PollingSubscription\n */\nexport default class PollingSubscription implements Subscription {\n  declare protected readonly endpoint: EndpointInterface;\n  declare protected readonly args: readonly any[];\n  declare protected readonly key: string;\n  declare protected frequency: number;\n  protected frequencyHistogram: Map<number, number> = new Map();\n  declare protected controller: Controller;\n  declare protected intervalId?: ReturnType<typeof setInterval>;\n  declare protected lastIntervalId?: ReturnType<typeof setInterval>;\n  declare protected startId?: ReturnType<typeof setTimeout>;\n  declare private connectionListener: ConnectionListener;\n\n  constructor(\n    action: Omit<SubscribeAction, 'type'>,\n    controller: Controller,\n    connectionListener?: ConnectionListener,\n  ) {\n    if (action.endpoint.pollFrequency === undefined)\n      throw new Error('frequency needed for polling subscription');\n    this.endpoint = action.endpoint;\n    this.frequency = action.endpoint.pollFrequency;\n    this.args = action.args;\n    this.key = action.key;\n    this.frequencyHistogram.set(this.frequency, 1);\n    this.controller = controller;\n    this.connectionListener =\n      connectionListener || new DefaultConnectionListener();\n\n    // Kickstart running since this is initialized after the online notif is sent\n    if (this.connectionListener.isOnline()) {\n      this.onlineListener();\n    } else {\n      this.offlineListener();\n    }\n  }\n\n  /** Subscribe to a frequency */\n  add(frequency?: number) {\n    if (frequency === undefined) return;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) + 1,\n      );\n    } else {\n      this.frequencyHistogram.set(frequency, 1);\n\n      // new min so restart service\n      if (frequency < this.frequency) {\n        this.frequency = frequency;\n        this.run();\n      }\n    }\n  }\n\n  /** Unsubscribe from a frequency */\n  remove(frequency?: number) {\n    if (frequency === undefined) return false;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) - 1,\n      );\n      if ((this.frequencyHistogram.get(frequency) as number) < 1) {\n        this.frequencyHistogram.delete(frequency);\n\n        // nothing subscribed to this anymore...it is invalid\n        if (this.frequencyHistogram.size === 0) {\n          this.cleanup();\n          return true;\n        }\n\n        // this was the min, so find the next size\n        if (frequency <= this.frequency) {\n          this.frequency = Math.min(...this.frequencyHistogram.keys());\n          this.run();\n        }\n      }\n    } /* istanbul ignore next */ else if (\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.error(\n        `Mismatched remove: ${frequency} is not subscribed for ${this.key}`,\n      );\n    }\n    return false;\n  }\n\n  /** Cleanup means clearing out background interval. */\n  cleanup() {\n    if (this.intervalId) {\n      clearInterval(this.intervalId);\n      delete this.intervalId;\n    }\n    if (this.lastIntervalId) {\n      clearInterval(this.lastIntervalId);\n      delete this.lastIntervalId;\n    }\n    if (this.startId) {\n      clearTimeout(this.startId);\n      delete this.startId;\n    }\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    this.connectionListener.removeOfflineListener(this.offlineListener);\n  }\n\n  /** Trigger request for latest resource */\n  protected update() {\n    const sup = this.endpoint;\n    const endpoint = function (this: any, ...args: any[]) {\n      return sup.call(this, ...args);\n    };\n    Object.assign(endpoint, this.endpoint);\n    endpoint.dataExpiryLength = this.frequency / 2;\n    endpoint.errorExpiryLength = this.frequency / 10;\n    endpoint.errorPolicy = () => 'soft' as const;\n    endpoint.key = () => this.key;\n    // stop any errors here from bubbling\n    this.controller.fetch(endpoint, ...this.args).catch(() => null);\n  }\n\n  /** What happens when browser goes offline */\n  protected offlineListener = () => {\n    // this clears existing listeners, so no need to clear offline listener\n    this.cleanup();\n    this.connectionListener.addOnlineListener(this.onlineListener);\n  };\n\n  /** What happens when browser comes online */\n  protected onlineListener = () => {\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    const now = Date.now();\n    this.startId = setTimeout(\n      () => {\n        if (this.startId) {\n          delete this.startId;\n          this.update();\n          this.run();\n        } else if (process.env.NODE_ENV !== 'production') {\n          console.warn(\n            `Poll setTimeout for ${this.key} still running, but timeoutId deleted`,\n          );\n        }\n      },\n      Math.max(0, this.lastFetchTime() - now + this.frequency),\n    );\n    this.connectionListener.addOfflineListener(this.offlineListener);\n  };\n\n  /** Run polling process with current frequency\n   *\n   * Will clean up old poll interval on next run\n   */\n  protected run() {\n    if (this.startId) return;\n    if (this.intervalId) this.lastIntervalId = this.intervalId;\n    this.intervalId = setInterval(() => {\n      // since we don't know how long into the last poll it was before resetting\n      // we wait til the next fetch to clear old intervals\n      if (this.lastIntervalId) {\n        clearInterval(this.lastIntervalId);\n        delete this.lastIntervalId;\n      }\n      if (this.intervalId) this.update();\n      else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll intervalId for ${this.key} still running, but intervalId deleted`,\n        );\n      }\n    }, this.frequency);\n  }\n\n  /** Last fetch time */\n  protected lastFetchTime() {\n    return this.controller.getState().meta[this.key]?.date ?? 0;\n  }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -75,4 +75,4 @@ export default class SubscriptionManager {
75
75
  }
76
76
  }
77
77
  }
78
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVUJTQ1JJQkUiLCJVTlNVQlNDUklCRSIsIkNvbnRyb2xsZXIiLCJTdWJzY3JpcHRpb25NYW5hZ2VyIiwiY29uc3RydWN0b3IiLCJTdWJzY3JpcHRpb24iLCJzdWJzY3JpcHRpb25zIiwiY29udHJvbGxlciIsIm1pZGRsZXdhcmUiLCJuZXh0IiwiYWN0aW9uIiwidHlwZSIsImhhbmRsZVN1YnNjcmliZSIsImUiLCJjb25zb2xlIiwiZXJyb3IiLCJQcm9taXNlIiwicmVzb2x2ZSIsImhhbmRsZVVuc3Vic2NyaWJlIiwiY2xlYW51cCIsImtleSIsImZyZXF1ZW5jeSIsImVuZHBvaW50IiwicG9sbEZyZXF1ZW5jeSIsImFkZCIsImVtcHR5IiwicmVtb3ZlIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL21hbmFnZXIvU3Vic2NyaXB0aW9uTWFuYWdlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTVUJTQ1JJQkUsIFVOU1VCU0NSSUJFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IENvbnRyb2xsZXIgZnJvbSAnLi4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmltcG9ydCB0eXBlIHtcbiAgTWFuYWdlcixcbiAgTWlkZGxld2FyZUFQSSxcbiAgTWlkZGxld2FyZSxcbiAgVW5zdWJzY3JpYmVBY3Rpb24sXG4gIFN1YnNjcmliZUFjdGlvbixcbn0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG50eXBlIEFjdGlvbnMgPSBVbnN1YnNjcmliZUFjdGlvbiB8IFN1YnNjcmliZUFjdGlvbjtcblxuLyoqIEludGVyZmFjZSBoYW5kbGluZyBhIHNpbmdsZSByZXNvdXJjZSBzdWJzY3JpcHRpb24gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3Vic2NyaXB0aW9uIHtcbiAgYWRkKGZyZXF1ZW5jeT86IG51bWJlcik6IHZvaWQ7XG4gIHJlbW92ZShmcmVxdWVuY3k/OiBudW1iZXIpOiBib29sZWFuO1xuICBjbGVhbnVwKCk6IHZvaWQ7XG59XG5cbi8qKiBUaGUgc3RhdGljIGNsYXNzIHRoYXQgY29uc3RydWN0cyBTdWJzY3JpcHRpb24gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3Vic2NyaXB0aW9uQ29uc3RydWN0YWJsZSB7XG4gIG5ldyAoXG4gICAgYWN0aW9uOiBPbWl0PFN1YnNjcmliZUFjdGlvbiwgJ3R5cGUnPixcbiAgICBjb250cm9sbGVyOiBDb250cm9sbGVyLFxuICApOiBTdWJzY3JpcHRpb247XG59XG5cbi8qKiBIYW5kbGVzIHN1YnNjcmlwdGlvbiBhY3Rpb25zIC0+IGZldGNoIG9yIHNldCBhY3Rpb25zXG4gKlxuICogQ29uc3RydWN0b3IgdGFrZXMgYSBTdWJzY3JpcHRpb25Db25zdHJ1Y3RhYmxlIGNsYXNzIHRvIGNvbnRyb2wgaG93XG4gKiBzdWJzY3JpcHRpb25zIGFyZSBoYW5kbGVkLiAoZS5nLiwgcG9sbGluZywgd2Vic29ja2V0cylcbiAqXG4gKiBAc2VlIGh0dHBzOi8vZGF0YWNsaWVudC5pby9kb2NzL2FwaS9TdWJzY3JpcHRpb25NYW5hZ2VyXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFN1YnNjcmlwdGlvbk1hbmFnZXI8XG4gIFMgZXh0ZW5kcyBTdWJzY3JpcHRpb25Db25zdHJ1Y3RhYmxlID0gU3Vic2NyaXB0aW9uQ29uc3RydWN0YWJsZSxcbj4gaW1wbGVtZW50cyBNYW5hZ2VyPEFjdGlvbnM+XG57XG4gIHByb3RlY3RlZCBzdWJzY3JpcHRpb25zOiB7XG4gICAgW2tleTogc3RyaW5nXTogSW5zdGFuY2VUeXBlPFM+O1xuICB9ID0ge307XG5cbiAgcHJvdGVjdGVkIGRlY2xhcmUgcmVhZG9ubHkgU3Vic2NyaXB0aW9uOiBTO1xuICBwcm90ZWN0ZWQgY29udHJvbGxlcjogQ29udHJvbGxlciA9IG5ldyBDb250cm9sbGVyKCk7XG5cbiAgY29uc3RydWN0b3IoU3Vic2NyaXB0aW9uOiBTKSB7XG4gICAgdGhpcy5TdWJzY3JpcHRpb24gPSBTdWJzY3JpcHRpb247XG4gIH1cblxuICBtaWRkbGV3YXJlOiBNaWRkbGV3YXJlID0gY29udHJvbGxlciA9PiB7XG4gICAgdGhpcy5jb250cm9sbGVyID0gY29udHJvbGxlcjtcbiAgICByZXR1cm4gbmV4dCA9PiBhY3Rpb24gPT4ge1xuICAgICAgc3dpdGNoIChhY3Rpb24udHlwZSkge1xuICAgICAgICBjYXNlIFNVQlNDUklCRTpcbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgdGhpcy5oYW5kbGVTdWJzY3JpYmUoYWN0aW9uKTtcbiAgICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgICBjb25zb2xlLmVycm9yKGUpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKCk7XG4gICAgICAgIGNhc2UgVU5TVUJTQ1JJQkU6XG4gICAgICAgICAgdGhpcy5oYW5kbGVVbnN1YnNjcmliZShhY3Rpb24pO1xuICAgICAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoKTtcbiAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICByZXR1cm4gbmV4dChhY3Rpb24pO1xuICAgICAgfVxuICAgIH07XG4gIH07XG5cbiAgLyoqIEVuc3VyZXMgYWxsIHN1YnNjcmlwdGlvbnMgYXJlIGNsZWFuZWQgdXAuICovXG4gIGNsZWFudXAoKSB7XG4gICAgZm9yIChjb25zdCBrZXkgaW4gdGhpcy5zdWJzY3JpcHRpb25zKSB7XG4gICAgICB0aGlzLnN1YnNjcmlwdGlvbnNba2V5XS5jbGVhbnVwKCk7XG4gICAgfVxuICB9XG5cbiAgLyoqIENhbGxlZCB3aGVuIG1pZGRsZXdhcmUgaW50ZXJjZXB0cyAncmRjL3N1YnNjcmliZScgYWN0aW9uLlxuICAgKlxuICAgKi9cbiAgcHJvdGVjdGVkIGhhbmRsZVN1YnNjcmliZShhY3Rpb246IFN1YnNjcmliZUFjdGlvbikge1xuICAgIGNvbnN0IGtleSA9IGFjdGlvbi5rZXk7XG5cbiAgICBpZiAoa2V5IGluIHRoaXMuc3Vic2NyaXB0aW9ucykge1xuICAgICAgY29uc3QgZnJlcXVlbmN5ID0gYWN0aW9uLmVuZHBvaW50LnBvbGxGcmVxdWVuY3k7XG4gICAgICB0aGlzLnN1YnNjcmlwdGlvbnNba2V5XS5hZGQoZnJlcXVlbmN5KTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5zdWJzY3JpcHRpb25zW2tleV0gPSBuZXcgdGhpcy5TdWJzY3JpcHRpb24oXG4gICAgICAgIGFjdGlvbixcbiAgICAgICAgdGhpcy5jb250cm9sbGVyLFxuICAgICAgKSBhcyBJbnN0YW5jZVR5cGU8Uz47XG4gICAgfVxuICB9XG5cbiAgLyoqIENhbGxlZCB3aGVuIG1pZGRsZXdhcmUgaW50ZXJjZXB0cyAncmRjL3Vuc3Vic2NyaWJlJyBhY3Rpb24uXG4gICAqXG4gICAqL1xuICBwcm90ZWN0ZWQgaGFuZGxlVW5zdWJzY3JpYmUoYWN0aW9uOiBVbnN1YnNjcmliZUFjdGlvbikge1xuICAgIGNvbnN0IGtleSA9IGFjdGlvbi5rZXk7XG5cbiAgICAvKiBpc3RhbmJ1bCBpZ25vcmUgZWxzZSAqL1xuICAgIGlmIChrZXkgaW4gdGhpcy5zdWJzY3JpcHRpb25zKSB7XG4gICAgICBjb25zdCBmcmVxdWVuY3kgPSBhY3Rpb24uZW5kcG9pbnQucG9sbEZyZXF1ZW5jeTtcbiAgICAgIGNvbnN0IGVtcHR5ID0gdGhpcy5zdWJzY3JpcHRpb25zW2tleV0ucmVtb3ZlKGZyZXF1ZW5jeSk7XG4gICAgICBpZiAoZW1wdHkpIHtcbiAgICAgICAgZGVsZXRlIHRoaXMuc3Vic2NyaXB0aW9uc1trZXldO1xuICAgICAgfVxuICAgIH0gZWxzZSBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJykge1xuICAgICAgY29uc29sZS5lcnJvcihgTWlzbWF0Y2hlZCB1bnN1YnNjcmliZTogJHtrZXl9IGlzIG5vdCBzdWJzY3JpYmVkYCk7XG4gICAgfVxuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFNBQVMsRUFBRUMsV0FBVyxRQUFRLG1CQUFtQjtBQUMxRCxPQUFPQyxVQUFVLE1BQU0sNkJBQTZCOztBQVdwRDs7QUFPQTs7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsTUFBTUMsbUJBQW1CLENBR3hDO0VBUUVDLFdBQVdBLENBQUNDLFlBQWUsRUFBRTtJQUFBLEtBUG5CQyxhQUFhLEdBRW5CLENBQUMsQ0FBQztJQUFBLEtBR0lDLFVBQVUsR0FBZSxJQUFJTCxVQUFVLENBQUMsQ0FBQztJQUFBLEtBTW5ETSxVQUFVLEdBQWVELFVBQVUsSUFBSTtNQUNyQyxJQUFJLENBQUNBLFVBQVUsR0FBR0EsVUFBVTtNQUM1QixPQUFPRSxJQUFJLElBQUlDLE1BQU0sSUFBSTtRQUN2QixRQUFRQSxNQUFNLENBQUNDLElBQUk7VUFDakIsS0FBS1gsU0FBUztZQUNaLElBQUk7Y0FDRixJQUFJLENBQUNZLGVBQWUsQ0FBQ0YsTUFBTSxDQUFDO1lBQzlCLENBQUMsQ0FBQyxPQUFPRyxDQUFDLEVBQUU7Y0FDVkMsT0FBTyxDQUFDQyxLQUFLLENBQUNGLENBQUMsQ0FBQztZQUNsQjtZQUNBLE9BQU9HLE9BQU8sQ0FBQ0MsT0FBTyxDQUFDLENBQUM7VUFDMUIsS0FBS2hCLFdBQVc7WUFDZCxJQUFJLENBQUNpQixpQkFBaUIsQ0FBQ1IsTUFBTSxDQUFDO1lBQzlCLE9BQU9NLE9BQU8sQ0FBQ0MsT0FBTyxDQUFDLENBQUM7VUFDMUI7WUFDRSxPQUFPUixJQUFJLENBQUNDLE1BQU0sQ0FBQztRQUN2QjtNQUNGLENBQUM7SUFDSCxDQUFDO0lBckJDLElBQUksQ0FBQ0wsWUFBWSxHQUFHQSxZQUFZO0VBQ2xDO0VBc0JBO0VBQ0FjLE9BQU9BLENBQUEsRUFBRztJQUNSLEtBQUssTUFBTUMsR0FBRyxJQUFJLElBQUksQ0FBQ2QsYUFBYSxFQUFFO01BQ3BDLElBQUksQ0FBQ0EsYUFBYSxDQUFDYyxHQUFHLENBQUMsQ0FBQ0QsT0FBTyxDQUFDLENBQUM7SUFDbkM7RUFDRjs7RUFFQTtBQUNGO0FBQ0E7RUFDWVAsZUFBZUEsQ0FBQ0YsTUFBdUIsRUFBRTtJQUNqRCxNQUFNVSxHQUFHLEdBQUdWLE1BQU0sQ0FBQ1UsR0FBRztJQUV0QixJQUFJQSxHQUFHLElBQUksSUFBSSxDQUFDZCxhQUFhLEVBQUU7TUFDN0IsTUFBTWUsU0FBUyxHQUFHWCxNQUFNLENBQUNZLFFBQVEsQ0FBQ0MsYUFBYTtNQUMvQyxJQUFJLENBQUNqQixhQUFhLENBQUNjLEdBQUcsQ0FBQyxDQUFDSSxHQUFHLENBQUNILFNBQVMsQ0FBQztJQUN4QyxDQUFDLE1BQU07TUFDTCxJQUFJLENBQUNmLGFBQWEsQ0FBQ2MsR0FBRyxDQUFDLEdBQUcsSUFBSSxJQUFJLENBQUNmLFlBQVksQ0FDN0NLLE1BQU0sRUFDTixJQUFJLENBQUNILFVBQ1AsQ0FBb0I7SUFDdEI7RUFDRjs7RUFFQTtBQUNGO0FBQ0E7RUFDWVcsaUJBQWlCQSxDQUFDUixNQUF5QixFQUFFO0lBQ3JELE1BQU1VLEdBQUcsR0FBR1YsTUFBTSxDQUFDVSxHQUFHOztJQUV0QjtJQUNBLElBQUlBLEdBQUcsSUFBSSxJQUFJLENBQUNkLGFBQWEsRUFBRTtNQUM3QixNQUFNZSxTQUFTLEdBQUdYLE1BQU0sQ0FBQ1ksUUFBUSxDQUFDQyxhQUFhO01BQy9DLE1BQU1FLEtBQUssR0FBRyxJQUFJLENBQUNuQixhQUFhLENBQUNjLEdBQUcsQ0FBQyxDQUFDTSxNQUFNLENBQUNMLFNBQVMsQ0FBQztNQUN2RCxJQUFJSSxLQUFLLEVBQUU7UUFDVCxPQUFPLElBQUksQ0FBQ25CLGFBQWEsQ0FBQ2MsR0FBRyxDQUFDO01BQ2hDO0lBQ0YsQ0FBQyxNQUFNLElBQUlPLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDQyxRQUFRLEtBQUssWUFBWSxFQUFFO01BQ2hEZixPQUFPLENBQUNDLEtBQUssQ0FBQywyQkFBMkJLLEdBQUcsb0JBQW9CLENBQUM7SUFDbkU7RUFDRjtBQUNGIiwiaWdub3JlTGlzdCI6W119
78
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVUJTQ1JJQkUiLCJVTlNVQlNDUklCRSIsIkNvbnRyb2xsZXIiLCJTdWJzY3JpcHRpb25NYW5hZ2VyIiwiY29uc3RydWN0b3IiLCJTdWJzY3JpcHRpb24iLCJzdWJzY3JpcHRpb25zIiwiY29udHJvbGxlciIsIm1pZGRsZXdhcmUiLCJuZXh0IiwiYWN0aW9uIiwidHlwZSIsImhhbmRsZVN1YnNjcmliZSIsImUiLCJjb25zb2xlIiwiZXJyb3IiLCJQcm9taXNlIiwicmVzb2x2ZSIsImhhbmRsZVVuc3Vic2NyaWJlIiwiY2xlYW51cCIsImtleSIsImZyZXF1ZW5jeSIsImVuZHBvaW50IiwicG9sbEZyZXF1ZW5jeSIsImFkZCIsImVtcHR5IiwicmVtb3ZlIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL21hbmFnZXIvU3Vic2NyaXB0aW9uTWFuYWdlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTVUJTQ1JJQkUsIFVOU1VCU0NSSUJFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IENvbnRyb2xsZXIgZnJvbSAnLi4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmltcG9ydCB0eXBlIHtcbiAgTWFuYWdlcixcbiAgTWlkZGxld2FyZUFQSSxcbiAgTWlkZGxld2FyZSxcbiAgVW5zdWJzY3JpYmVBY3Rpb24sXG4gIFN1YnNjcmliZUFjdGlvbixcbn0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG50eXBlIEFjdGlvbnMgPSBVbnN1YnNjcmliZUFjdGlvbiB8IFN1YnNjcmliZUFjdGlvbjtcblxuLyoqIEludGVyZmFjZSBoYW5kbGluZyBhIHNpbmdsZSByZXNvdXJjZSBzdWJzY3JpcHRpb24gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3Vic2NyaXB0aW9uIHtcbiAgYWRkKGZyZXF1ZW5jeT86IG51bWJlcik6IHZvaWQ7XG4gIHJlbW92ZShmcmVxdWVuY3k/OiBudW1iZXIpOiBib29sZWFuO1xuICBjbGVhbnVwKCk6IHZvaWQ7XG59XG5cbi8qKiBUaGUgc3RhdGljIGNsYXNzIHRoYXQgY29uc3RydWN0cyBTdWJzY3JpcHRpb24gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3Vic2NyaXB0aW9uQ29uc3RydWN0YWJsZSB7XG4gIG5ldyAoXG4gICAgYWN0aW9uOiBPbWl0PFN1YnNjcmliZUFjdGlvbiwgJ3R5cGUnPixcbiAgICBjb250cm9sbGVyOiBDb250cm9sbGVyLFxuICApOiBTdWJzY3JpcHRpb247XG59XG5cbi8qKiBIYW5kbGVzIHN1YnNjcmlwdGlvbiBhY3Rpb25zIC0+IGZldGNoIG9yIHNldCBhY3Rpb25zXG4gKlxuICogQ29uc3RydWN0b3IgdGFrZXMgYSBTdWJzY3JpcHRpb25Db25zdHJ1Y3RhYmxlIGNsYXNzIHRvIGNvbnRyb2wgaG93XG4gKiBzdWJzY3JpcHRpb25zIGFyZSBoYW5kbGVkLiAoZS5nLiwgcG9sbGluZywgd2Vic29ja2V0cylcbiAqXG4gKiBAc2VlIGh0dHBzOi8vZGF0YWNsaWVudC5pby9kb2NzL2FwaS9TdWJzY3JpcHRpb25NYW5hZ2VyXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFN1YnNjcmlwdGlvbk1hbmFnZXI8XG4gIFMgZXh0ZW5kcyBTdWJzY3JpcHRpb25Db25zdHJ1Y3RhYmxlID0gU3Vic2NyaXB0aW9uQ29uc3RydWN0YWJsZSxcbj4gaW1wbGVtZW50cyBNYW5hZ2VyPEFjdGlvbnM+XG57XG4gIHByb3RlY3RlZCBzdWJzY3JpcHRpb25zOiB7XG4gICAgW2tleTogc3RyaW5nXTogSW5zdGFuY2VUeXBlPFM+O1xuICB9ID0ge307XG5cbiAgZGVjbGFyZSBwcm90ZWN0ZWQgcmVhZG9ubHkgU3Vic2NyaXB0aW9uOiBTO1xuICBwcm90ZWN0ZWQgY29udHJvbGxlcjogQ29udHJvbGxlciA9IG5ldyBDb250cm9sbGVyKCk7XG5cbiAgY29uc3RydWN0b3IoU3Vic2NyaXB0aW9uOiBTKSB7XG4gICAgdGhpcy5TdWJzY3JpcHRpb24gPSBTdWJzY3JpcHRpb247XG4gIH1cblxuICBtaWRkbGV3YXJlOiBNaWRkbGV3YXJlID0gY29udHJvbGxlciA9PiB7XG4gICAgdGhpcy5jb250cm9sbGVyID0gY29udHJvbGxlcjtcbiAgICByZXR1cm4gbmV4dCA9PiBhY3Rpb24gPT4ge1xuICAgICAgc3dpdGNoIChhY3Rpb24udHlwZSkge1xuICAgICAgICBjYXNlIFNVQlNDUklCRTpcbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgdGhpcy5oYW5kbGVTdWJzY3JpYmUoYWN0aW9uKTtcbiAgICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgICBjb25zb2xlLmVycm9yKGUpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKCk7XG4gICAgICAgIGNhc2UgVU5TVUJTQ1JJQkU6XG4gICAgICAgICAgdGhpcy5oYW5kbGVVbnN1YnNjcmliZShhY3Rpb24pO1xuICAgICAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoKTtcbiAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICByZXR1cm4gbmV4dChhY3Rpb24pO1xuICAgICAgfVxuICAgIH07XG4gIH07XG5cbiAgLyoqIEVuc3VyZXMgYWxsIHN1YnNjcmlwdGlvbnMgYXJlIGNsZWFuZWQgdXAuICovXG4gIGNsZWFudXAoKSB7XG4gICAgZm9yIChjb25zdCBrZXkgaW4gdGhpcy5zdWJzY3JpcHRpb25zKSB7XG4gICAgICB0aGlzLnN1YnNjcmlwdGlvbnNba2V5XS5jbGVhbnVwKCk7XG4gICAgfVxuICB9XG5cbiAgLyoqIENhbGxlZCB3aGVuIG1pZGRsZXdhcmUgaW50ZXJjZXB0cyAncmRjL3N1YnNjcmliZScgYWN0aW9uLlxuICAgKlxuICAgKi9cbiAgcHJvdGVjdGVkIGhhbmRsZVN1YnNjcmliZShhY3Rpb246IFN1YnNjcmliZUFjdGlvbikge1xuICAgIGNvbnN0IGtleSA9IGFjdGlvbi5rZXk7XG5cbiAgICBpZiAoa2V5IGluIHRoaXMuc3Vic2NyaXB0aW9ucykge1xuICAgICAgY29uc3QgZnJlcXVlbmN5ID0gYWN0aW9uLmVuZHBvaW50LnBvbGxGcmVxdWVuY3k7XG4gICAgICB0aGlzLnN1YnNjcmlwdGlvbnNba2V5XS5hZGQoZnJlcXVlbmN5KTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5zdWJzY3JpcHRpb25zW2tleV0gPSBuZXcgdGhpcy5TdWJzY3JpcHRpb24oXG4gICAgICAgIGFjdGlvbixcbiAgICAgICAgdGhpcy5jb250cm9sbGVyLFxuICAgICAgKSBhcyBJbnN0YW5jZVR5cGU8Uz47XG4gICAgfVxuICB9XG5cbiAgLyoqIENhbGxlZCB3aGVuIG1pZGRsZXdhcmUgaW50ZXJjZXB0cyAncmRjL3Vuc3Vic2NyaWJlJyBhY3Rpb24uXG4gICAqXG4gICAqL1xuICBwcm90ZWN0ZWQgaGFuZGxlVW5zdWJzY3JpYmUoYWN0aW9uOiBVbnN1YnNjcmliZUFjdGlvbikge1xuICAgIGNvbnN0IGtleSA9IGFjdGlvbi5rZXk7XG5cbiAgICAvKiBpc3RhbmJ1bCBpZ25vcmUgZWxzZSAqL1xuICAgIGlmIChrZXkgaW4gdGhpcy5zdWJzY3JpcHRpb25zKSB7XG4gICAgICBjb25zdCBmcmVxdWVuY3kgPSBhY3Rpb24uZW5kcG9pbnQucG9sbEZyZXF1ZW5jeTtcbiAgICAgIGNvbnN0IGVtcHR5ID0gdGhpcy5zdWJzY3JpcHRpb25zW2tleV0ucmVtb3ZlKGZyZXF1ZW5jeSk7XG4gICAgICBpZiAoZW1wdHkpIHtcbiAgICAgICAgZGVsZXRlIHRoaXMuc3Vic2NyaXB0aW9uc1trZXldO1xuICAgICAgfVxuICAgIH0gZWxzZSBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJykge1xuICAgICAgY29uc29sZS5lcnJvcihgTWlzbWF0Y2hlZCB1bnN1YnNjcmliZTogJHtrZXl9IGlzIG5vdCBzdWJzY3JpYmVkYCk7XG4gICAgfVxuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFNBQVMsRUFBRUMsV0FBVyxRQUFRLG1CQUFtQjtBQUMxRCxPQUFPQyxVQUFVLE1BQU0s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
@@ -1 +1 @@
1
- {"version":3,"file":"actionTypes.d.ts","sourceRoot":"","sources":["../src/actionTypes.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,KAAK,aAAuB,CAAC;AAC1C,eAAO,MAAM,GAAG,WAAqB,CAAC;AACtC,eAAO,MAAM,YAAY,mBAA6B,CAAC;AACvD,eAAO,MAAM,UAAU,kBAA4B,CAAC;AACpD,eAAO,MAAM,KAAK,aAAuB,CAAC;AAC1C,eAAO,MAAM,SAAS,iBAA2B,CAAC;AAClD,eAAO,MAAM,WAAW,mBAA6B,CAAC;AACtD,eAAO,MAAM,UAAU,kBAA4B,CAAC;AACpD,eAAO,MAAM,aAAa,qBAA+B,CAAC;AAC1D,eAAO,MAAM,SAAS,iBAA2B,CAAC;AAClD,eAAO,MAAM,EAAE,UAAoB,CAAC;AAEpC,eAAO,MAAM,UAAU,aAAQ,CAAC;AAChC,eAAO,MAAM,QAAQ,WAAM,CAAC;AAC5B,eAAO,MAAM,iBAAiB,mBAAe,CAAC;AAC9C,eAAO,MAAM,eAAe,kBAAa,CAAC;AAC1C,eAAO,MAAM,UAAU,aAAQ,CAAC;AAChC,eAAO,MAAM,cAAc,iBAAY,CAAC;AACxC,eAAO,MAAM,gBAAgB,mBAAc,CAAC;AAC5C,eAAO,MAAM,eAAe,kBAAa,CAAC;AAC1C,eAAO,MAAM,kBAAkB,qBAAgB,CAAC;AAChD,eAAO,MAAM,cAAc,iBAAY,CAAC;AACxC,eAAO,MAAM,OAAO,UAAK,CAAC"}
1
+ {"version":3,"file":"actionTypes.d.ts","sourceRoot":"","sources":["../src/actionTypes.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,KAAK,EAAG,WAAoB,CAAC;AAC1C,eAAO,MAAM,GAAG,EAAG,SAAkB,CAAC;AACtC,eAAO,MAAM,YAAY,EAAG,iBAA0B,CAAC;AACvD,eAAO,MAAM,UAAU,EAAG,gBAAyB,CAAC;AACpD,eAAO,MAAM,KAAK,EAAG,WAAoB,CAAC;AAC1C,eAAO,MAAM,SAAS,EAAG,eAAwB,CAAC;AAClD,eAAO,MAAM,WAAW,EAAG,iBAA0B,CAAC;AACtD,eAAO,MAAM,UAAU,EAAG,gBAAyB,CAAC;AACpD,eAAO,MAAM,aAAa,EAAG,mBAA4B,CAAC;AAC1D,eAAO,MAAM,SAAS,EAAG,eAAwB,CAAC;AAClD,eAAO,MAAM,EAAE,EAAG,QAAiB,CAAC;AAEpC,eAAO,MAAM,UAAU,aAAQ,CAAC;AAChC,eAAO,MAAM,QAAQ,WAAM,CAAC;AAC5B,eAAO,MAAM,iBAAiB,mBAAe,CAAC;AAC9C,eAAO,MAAM,eAAe,kBAAa,CAAC;AAC1C,eAAO,MAAM,UAAU,aAAQ,CAAC;AAChC,eAAO,MAAM,cAAc,iBAAY,CAAC;AACxC,eAAO,MAAM,gBAAgB,mBAAc,CAAC;AAC5C,eAAO,MAAM,eAAe,kBAAa,CAAC;AAC1C,eAAO,MAAM,kBAAkB,qBAAgB,CAAC;AAChD,eAAO,MAAM,cAAc,iBAAY,CAAC;AACxC,eAAO,MAAM,OAAO,UAAK,CAAC"}
@@ -229,7 +229,7 @@ export default class Controller {
229
229
  }
230
230
 
231
231
  // second argument is false if any entities are missing
232
- // eslint-disable-next-line prefer-const
232
+
233
233
  const {
234
234
  data,
235
235
  paths
@@ -335,4 +335,4 @@ class Snapshot {
335
335
  }
336
336
  }
337
337
  Snapshot.abort = new AbortOptimistic();
338
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ExpiryStatus","MemoCache","isEntity","denormalize","validateQueryKey","AbortOptimistic","createUnsubscription","createSubscription","createExpireAll","createFetch","createInvalidate","createInvalidateAll","createReset","createSet","createSetResponse","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","set","value","getError","endpoints","undefined","errorPolicy","map","isActive","cacheEndpoints","shouldQuery","buildQueryKey","entities","indexes","Valid","Infinity","isInvalid","schemaHasEntity","invalidated","invalidIfStale","InvalidIfStale","paths","getSchemaResponse","entityMeta","get","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 {\n  createUnsubscription,\n  createSubscription,\n} from './actions/createSubscription.js';\nimport {\n  createExpireAll,\n  createFetch,\n  createInvalidate,\n  createInvalidateAll,\n  createReset,\n  createSet,\n  createSetResponse,\n} from './actions/index.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(endpoint.schema, input, {}, 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>, (previousValue: Denormalize<S>) => {}]\n  ): Promise<void>;\n\n  set<S extends Queryable>(\n    schema: S,\n    ...rest: readonly [...SchemaArgs<S>, {}]\n  ): Promise<void>;\n\n  set<S extends Queryable>(\n    schema: S,\n    ...rest: readonly [...SchemaArgs<S>, any]\n  ): Promise<void> {\n    const value = 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.\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          schema,\n          args,\n          state.entities as any,\n          state.indexes,\n          key,\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      schema,\n      input,\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    return this.memo.query(schema, args, state.entities as any, state.indexes);\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":[]}
338
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ExpiryStatus","MemoCache","isEntity","denormalize","validateQueryKey","AbortOptimistic","createUnsubscription","createSubscription","createExpireAll","createFetch","createInvalidate","createInvalidateAll","createReset","createSet","createSetResponse","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","set","value","getError","endpoints","undefined","errorPolicy","map","isActive","cacheEndpoints","shouldQuery","buildQueryKey","entities","indexes","Valid","Infinity","isInvalid","schemaHasEntity","invalidated","invalidIfStale","InvalidIfStale","paths","getSchemaResponse","entityMeta","get","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 {\n  createUnsubscription,\n  createSubscription,\n} from './actions/createSubscription.js';\nimport {\n  createExpireAll,\n  createFetch,\n  createInvalidate,\n  createInvalidateAll,\n  createReset,\n  createSet,\n  createSetResponse,\n} from './actions/index.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(endpoint.schema, input, {}, 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>, (previousValue: Denormalize<S>) => {}]\n  ): Promise<void>;\n\n  set<S extends Queryable>(\n    schema: S,\n    ...rest: readonly [...SchemaArgs<S>, {}]\n  ): Promise<void>;\n\n  set<S extends Queryable>(\n    schema: S,\n    ...rest: readonly [...SchemaArgs<S>, any]\n  ): Promise<void> {\n    const value = 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.\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          schema,\n          args,\n          state.entities as any,\n          state.indexes,\n          key,\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\n    const { data, paths } = this.memo.denormalize(\n      schema,\n      input,\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    return this.memo.query(schema, args, state.entities as any, state.indexes);\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":"AAQA,SACEA,YAAY,EAMZC,SAAS,EACTC,QAAQ,EACRC,WAAW,EACXC,gBAAgB,QACX,wBAAwB;AAE/B,OAAOC,eAAe,MAAM,sBAAsB;AAClD,SACEC,oBAAoB,EACpBC,kBAAkB,QACb,iCAAiC;AACxC,SACEC,eAAe,EACfC,WAAW,EACXC,gBAAgB,EAChBC,mBAAmB,EACnBC,WAAW,EACXC,SAAS,EACTC,iBAAiB,QACZ,oBAAoB;AAC3B,OAAOC,UAAU,MAAM,iBAAiB;AAExC,SAASC,YAAY,QAAQ,mCAAmC;AAChE,OAAOC,UAAU,MAAM,wBAAwB;AAY/C,MAAMC,aAAa,GAAIC,MAAe,IAAoB;EACxD,MAAM,IAAIC,KAAK,CACb,iEAAiE,GAC/D,yDACJ,CAAC;AACH,CAAC;AACD,MAAMC,UAAU,GAAGA,CAAA,KAAsB;EACvC;EACA;EACA,OAAOL,YAAY;AACrB,CAAC;;AAED;AACA;AACA;AACA;AACA,eAAe,MAAMM,UAAU,CAE7B;EACA;AACF;AACA;AACA;AACA;;EAEE;AACF;AACA;AACA;AACA;AACA;AACA;;EAEE;AACF;AACA;;EAMEC,WAAWA,CAAC;IACVC,QAAQ,GAAGN,aAAoB;IAC/BO,QAAQ,GAAGJ,UAAU;IACrBK,IAAI,GAAG,IAAIzB,SAAS,CAAC;EACF,CAAC,GAAG,CAAC,CAAC,EAAE;IAM7B;IAEA;AACF;AACA;AACA;IAHE,KAIA0B,KAAK,GAAG,CAGNC,QAAW,EACX,GAAGC,IAAiC,KAEC;MACrC,MAAMV,MAAM,GAAGV,WAAW,CAACmB,QAAQ,EAAE;QACnCC;MACF,CAAC,CAAC;MACF,IAAI,CAACL,QAAQ,CAACL,MAAM,CAAC;MAErB,IAAIS,QAAQ,CAACE,MAAM,EAAE;QACnB,OAAOX,MAAM,CAACY,IAAI,CAACC,OAAO,CAACC,IAAI,CAACC,KAAK,IACnC/B,WAAW,CAACyB,QAAQ,CAACE,MAAM,EAAEI,KAAK,EAAE,CAAC,CAAC,EAAEL,IAAI,CAC9C,CAAC;MACH;MACA,OAAOV,MAAM,CAACY,IAAI,CAACC,OAAO;IAC5B,CAAC;IAED;AACF;AACA;AACA;IAHE,KAIAG,YAAY,GAAG,CAGbP,QAAW,EACX,GAAGC,IAAiC,KAE4B;MAChE,MAAM;QAAEO,IAAI;QAAEC,SAAS;QAAEC;MAAa,CAAC,GAAG,IAAI,CAACC,WAAW,CACxDX,QAAQ,EACR,GAAGC,IAAI,EACP,IAAI,CAACJ,QAAQ,CAAC,CAChB,CAAC;MACD,IAAIa,YAAY,KAAKtC,YAAY,CAACwC,OAAO,IAAIC,IAAI,CAACC,GAAG,CAAC,CAAC,IAAIL,SAAS,EAClE,OAAOD,IAAI;MACb,OAAO,IAAI,CAACT,KAAK,CAACC,QAAQ,EAAE,GAAGC,IAAI,CAAC;IACtC,CAAC;IAED;AACF;AACA;AACA;IAHE,KAIAc,UAAU,GAAG,CACXf,QAAW,EACX,GAAGC,IAAmD,KAEtDA,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,GACd,IAAI,CAACL,QAAQ,CACXd,gBAAgB,CAACkB,QAAQ,EAAE;MACzBC,IAAI,EAAEA;IACR,CAAC,CACH,CAAC,GACDe,OAAO,CAACC,OAAO,CAAC,CAAC;IAErB;AACF;AACA;AACA;AACA;IAJE,KAKAC,aAAa,GAAIC,OAA8C,IAC7D,IAAI,CAACvB,QAAQ,CAACb,mBAAmB,CAAEqC,GAAW,IAAKD,OAAO,CAACE,OAAO,CAACD,GAAG,CAAC,CAAC,CAAC;IAE3E;AACF;AACA;AACA;AACA;IAJE,KAKAE,SAAS,GAAIH,OAA8C,IACzD,IAAI,CAACvB,QAAQ,CAAChB,eAAe,CAAEwC,GAAW,IAAKD,OAAO,CAACE,OAAO,CAACD,GAAG,CAAC,CAAC,CAAC;IAEvE;AACF;AACA;AACA;IAHE,KAIAG,gBAAgB,GAAG,MAAqB,IAAI,CAAC3B,QAAQ,CAACZ,WAAW,CAAC,CAAC,CAAC;IA6BpE;AACF;AACA;AACA;IAHE,KAIAwC,WAAW,GAAG,CAKZxB,QAAW,EACX,GAAGyB,IAAsC,KACvB;MAClB,MAAMC,QAAwB,GAAGD,IAAI,CAACA,IAAI,CAACE,MAAM,GAAG,CAAC,CAAC;MACtD,MAAMpC,MAAM,GAAGL,iBAAiB,CAACc,QAAQ,EAAE;QACzCC,IAAI,EAAEwB,IAAI,CAACG,KAAK,CAAC,CAAC,EAAEH,IAAI,CAACE,MAAM,GAAG,CAAC,CAAkB;QACrDD;MACF,CAAC,CAAC;MACF,OAAO,IAAI,CAAC9B,QAAQ,CAACL,MAAM,CAAC;IAC9B,CAAC;IAED;AACF;AACA;AACA;IAHE,KAIAsC,QAAQ,GAAG,CAKT7B,QAAW,EACX,GAAGyB,IAAwC,KACzB;MAClB,MAAMC,QAAe,GAAGD,IAAI,CAACA,IAAI,CAACE,MAAM,GAAG,CAAC,CAAC;MAC7C,MAAMpC,MAAM,GAAGL,iBAAiB,CAACc,QAAQ,EAAE;QACzCC,IAAI,EAAEwB,IAAI,CAACG,KAAK,CAAC,CAAC,EAAEH,IAAI,CAACE,MAAM,GAAG,CAAC,CAAkB;QACrDD,QAAQ;QACRI,KAAK,EAAE;MACT,CAAC,CAAC;MACF,OAAO,IAAI,CAAClC,QAAQ,CAACL,MAAM,CAAC;IAC9B,CAAC;IAED;AACF;AACA;AACA;IAHE,KAIA0B,OAAO,GAAG,CAKRjB,QAAW,EACXG,IAYK,KACa;MAClB,OAAO,IAAI,CAACP,QAAQ,CAACV,iBAAiB,CAACc,QAAQ,EAAEG,IAAW,CAAC,CAAC;IAChE,CAAC;IAED;AACF;AACA;AACA;IAHE,KAIA4B,SAAS,GAAG,CAOV/B,QAAW,EACX,GAAGC,IAAmD,KAEtDA,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,GACd,IAAI,CAACL,QAAQ,CACXjB,kBAAkB,CAACqB,QAAQ,EAAE;MAC3BC,IAAI,EAAEA;IACR,CAAC,CACH,CAAC,GACDe,OAAO,CAACC,OAAO,CAAC,CAAC;IAErB;AACF;AACA;AACA;IAHE,KAIAe,WAAW,GAAG,CAOZhC,QAAW,EACX,GAAGC,IAAmD,KAEtDA,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,GACd,IAAI,CAACL,QAAQ,CACXlB,oBAAoB,CAACsB,QAAQ,EAAE;MAC7BC,IAAI,EAAEA;IACR,CAAC,CACH,CAAC,GACDe,OAAO,CAACC,OAAO,CAAC,CAAC;IAErB;IAEA;AACF;AACA;AACA;AACA;AACA;IAEE;AACF;AACA;AACA;IAHE,KAIAgB,QAAQ,GAAG,CAACC,KAAqB,EAAEC,SAAkB,KAAwB;MAC3E,OAAO,IAAIC,QAAQ,CAAC,IAAI,EAAEF,KAAK,EAAEC,SAAS,CAAC;IAC7C,CAAC;IApPC,IAAI,CAACvC,QAAQ,GAAGA,QAAQ;IACxB,IAAI,CAACC,QAAQ,GAAGA,QAAQ;IACxB,IAAI,CAACC,IAAI,GAAGA,IAAI;EAClB;EAuFA;AACF;AACA;AACA;EAWEuC,GAAGA,CACDnC,MAAS,EACT,GAAGuB,IAAsC,EAC1B;IACf,MAAMa,KAAK,GAAGb,IAAI,CAACA,IAAI,CAACE,MAAM,GAAG,CAAC,CAAC;IACnC,MAAMpC,MAAM,GAAGN,SAAS,CAACiB,MAAM,EAAE;MAC/BD,IAAI,EAAEwB,IAAI,CAACG,KAAK,CAAC,CAAC,EAAEH,IAAI,CAACE,MAAM,GAAG,CAAC,CAAkB;MACrDW;IACF,CAAC,CAAC;IACF;IACA,OAAO,IAAI,CAAC1C,QAAQ,CAACL,MAAM,CAAC;EAC9B;EAmIA;AACF;AACA;AACA;EAeEgD,QAAQA,CACNvC,QAA2B,EAC3B,GAAGyB,IAA6C,EACxB;IACxB,IAAIA,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE;IACtB,MAAMS,KAAK,GAAGT,IAAI,CAACA,IAAI,CAACE,MAAM,GAAG,CAAC,CAAmB;IACrD;IACA,MAAM1B,IAAS,GAAGwB,IAAI,CAACG,KAAK,CAAC,CAAC,EAAEH,IAAI,CAACE,MAAM,GAAG,CAAC,CAAC;IAChD,MAAMP,GAAG,GAAGpB,QAAQ,CAACoB,GAAG,CAAC,GAAGnB,IAAI,CAAC;IAEjC,MAAME,IAAI,GAAGd,UAAU,CAAC6C,KAAK,EAAEd,GAAG,CAAC;IACnC,MAAMU,KAAK,GAAGI,KAAK,CAACM,SAAS,CAACpB,GAAG,CAAC;IAElC,IAAIU,KAAK,KAAKW,SAAS,IAAI,CAAAtC,IAAI,oBAAJA,IAAI,CAAEuC,WAAW,MAAK,MAAM,EAAE;IAEzD,OAAOvC,IAAI,oBAAJA,IAAI,CAAE2B,KAAK;EACpB;;EAEA;AACF;AACA;AACA;;EA0BEnB,WAAWA,CACTX,QAA2B,EAC3B,GAAGyB,IAA6C,EAKhD;IACA,MAAMS,KAAK,GAAGT,IAAI,CAACA,IAAI,CAACE,MAAM,GAAG,CAAC,CAAmB;IACrD;IACA,MAAM1B,IAAS,GAAGwB,IAAI,CACnBG,KAAK,CAAC,CAAC,EAAEH,IAAI,CAACE,MAAM,GAAG,CAAC;IACzB;IAAA,CACCgB,GAAG,CAACxD,UAAU,CAAC;IAClB,MAAMyD,QAAQ,GAAG3C,IAAI,CAAC0B,MAAM,KAAK,CAAC,IAAI1B,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI;IACtD,MAAMmB,GAAG,GAAGwB,QAAQ,GAAG5C,QAAQ,CAACoB,GAAG,CAAC,GAAGnB,IAAI,CAAC,GAAG,EAAE;IACjD,MAAM4C,cAAc,GAAGD,QAAQ,GAAGV,KAAK,CAACM,SAAS,CAACpB,GAAG,CAAC,GAAGqB,SAAS;IAClE,MAAMvC,MAAM,GAAGF,QAAQ,CAACE,MAAM;IAC9B,MAAMC,IAAI,GAAGd,UAAU,CAAC6C,KAAK,EAAEd,GAAG,CAAC;IACnC,IAAIX,SAAS,GAAGN,IAAI,oBAAJA,IAAI,CAAEM,SAAS;IAC/B;IACA,MAAMqC,WAAW,GAAGD,cAAc,KAAKJ,SAAS,IAAIvC,MAAM,KAAKuC,SAAS;IAExE,MAAMnC,KAAK,GACTwC,WAAW;IACT;IACA,IAAI,CAAChD,IAAI,CAACiD,aAAa,CACrB7C,MAAM,EACND,IAAI,EACJiC,KAAK,CAACc,QAAQ,EACdd,KAAK,CAACe,OAAO,EACb7B,GACF,CAAC,GACDyB,cAAc;IAElB,IAAI,CAACD,QAAQ,EAAE;MACb;MACA,OAAO;QACLpC,IAAI,EAAEF,KAAY;QAClBI,YAAY,EAAEtC,YAAY,CAAC8E,KAAK;QAChCzC,SAAS,EAAE0C;MACb,CAAC;IACH;IAEA,IAAIC,SAAS,GAAG,KAAK;IACrB,IAAIN,WAAW,EAAE;MACfM,SAAS,GAAG,CAAC5E,gBAAgB,CAAC8B,KAAK,CAAC;IACtC,CAAC,MAAM,IAAI,CAACJ,MAAM,IAAI,CAACmD,eAAe,CAACnD,MAAM,CAAC,EAAE;MAC9C,OAAO;QACLM,IAAI,EAAEqC,cAAc;QACpBnC,YAAY,EACVP,IAAI,YAAJA,IAAI,CAAEmD,WAAW,GAAGlF,YAAY,CAACwC,OAAO,GACtCiC,cAAc,IAAI,CAAC7C,QAAQ,CAACuD,cAAc,GAAGnF,YAAY,CAAC8E,KAAK,GAC/D9E,YAAY,CAACoF,cAAc;QAC/B/C,SAAS,EAAEA,SAAS,IAAI;MAC1B,CAAC;IACH;;IAEA;;IAEA,MAAM;MAAED,IAAI;MAAEiD;IAAM,CAAC,GAAG,IAAI,CAAC3D,IAAI,CAACvB,WAAW,CAC3C2B,MAAM,EACNI,KAAK,EACL4B,KAAK,CAACc,QAAQ,EACd/C,IACF,CAAuC;;IAEvC;IACA,IAAI,CAACQ,SAAS,IAAI2C,SAAS,EAAE3C,SAAS,GAAG,CAAC;IAE1C,OAAO,IAAI,CAACiD,iBAAiB,CAC3BlD,IAAI,EACJiD,KAAK,EACLvB,KAAK,CAACyB,UAAU,EAChBlD,SAAS,EACTT,QAAQ,CAACuD,cAAc,IAAIH,SAAS,EACpCjD,IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;EACEyD,GAAGA,CACD1D,MAAS,EACT,GAAGuB,IAGF,EACmC;IACpC,MAAMS,KAAK,GAAGT,IAAI,CAACA,IAAI,CAACE,MAAM,GAAG,CAAC,CAAe;IACjD;IACA,MAAM1B,IAAS,GAAGwB,IAAI,CACnBG,KAAK,CAAC,CAAC,EAAEH,IAAI,CAACE,MAAM,GAAG,CAAC,CAAC,CACzBgB,GAAG,CAACxD,UAAU,CAAkB;IAEnC,OAAO,IAAI,CAACW,IAAI,CAAC+D,KAAK,CAAC3D,MAAM,EAAED,IAAI,EAAEiC,KAAK,CAACc,QAAQ,EAASd,KAAK,CAACe,OAAO,CAAC;EAC5E;EAEQS,iBAAiBA,CACvBlD,IAAO,EACPiD,KAAmB,EACnBE,UAAwC,EACxClD,SAAiB,EACjB8C,cAAuB,EACvBpD,IAAgD,GAAG,CAAC,CAAC,EAKrD;IACA,MAAM2D,kBAAkB,GAAG,OAAOtD,IAAI,KAAK,QAAQ;;IAEnD;IACA,IAAI,CAACC,SAAS,EAAE;MACdA,SAAS,GAAGsD,eAAe,CAACN,KAAK,EAAEE,UAAU,CAAC;IAChD;;IAEA;IACA;IACA;IACA,MAAMjD,YAAY,GAChBP,IAAI,YAAJA,IAAI,CAAEmD,WAAW,IAAKQ,kBAAkB,IAAI,EAAC3D,IAAI,YAAJA,IAAI,CAAE2B,KAAK,CAAC,GACvD1D,YAAY,CAACwC,OAAO,GACpBkD,kBAAkB,IAAIP,cAAc,GAAGnF,YAAY,CAACoF,cAAc,GAClEpF,YAAY,CAAC8E,KAAK;IAEtB,OAAO;MAAE1C,IAAI;MAAEE,YAAY;MAAED;IAAU,CAAC;EAC1C;AACF;;AAEA;AACA;AACA,SAASsD,eAAeA,CACtBN,KAAmB,EACnBE,UAQC,EACD;EACA,IAAIlD,SAAS,GAAG0C,QAAQ;EACxB,KAAK,MAAM;IAAEa,EAAE;IAAE5C;EAAI,CAAC,IAAIqC,KAAK,EAAE;IAAA,IAAAQ,eAAA;IAC/B,MAAMC,YAAY,IAAAD,eAAA,GAAGN,UAAU,CAACvC,GAAG,CAAC,cAAA6C,eAAA,GAAfA,eAAA,CAAkBD,EAAE,CAAC,qBAArBC,eAAA,CAAuBxD,SAAS;IACrD;IACA,IAAIyD,YAAY,GAAGzD,SAAS,EAAEA,SAAS,GAAGyD,YAAY;EACxD;EACA,OAAOzD,SAAS;AAClB;;AAEA;AACA;AACA;AACA;AACA,SAAS4C,eAAeA,CAACnD,MAAc,EAAW;EAChD,IAAI5B,QAAQ,CAAC4B,MAAM,CAAC,EAAE,OAAO,IAAI;EACjC,IAAIiE,KAAK,CAACC,OAAO,CAAClE,MAAM,CAAC,EACvB,OAAOA,MAAM,CAACyB,MAAM,KAAK,CAAC,IAAI0B,eAAe,CAACnD,MAAM,CAAC,CAAC,CAAC,CAAC;EAC1D,IAAIA,MAAM,KAAK,OAAOA,MAAM,KAAK,QAAQ,IAAI,OAAOA,MAAM,KAAK,UAAU,CAAC,EAAE;IAC1E,MAAMmE,YAAY,GAChB,QAAQ,IAAInE,MAAM,GAAIA,MAAM,CAACA,MAAM,GAA8BA,MAAM;IACzE,IAAI,OAAOmE,YAAY,KAAK,UAAU,EAAE;MACtC,OAAOhB,eAAe,CAACgB,YAAY,CAAC;IACtC;IACA,OAAOC,MAAM,CAACC,MAAM,CAACF,YAAY,CAAC,CAACG,IAAI,CAACC,CAAC,IAAIpB,eAAe,CAACoB,CAAC,CAAC,CAAC;EAClE;EACA,OAAO,KAAK;AACd;AAIA,MAAMrC,QAAQ,CAA2C;EAQvDzC,WAAWA,CAAC+E,UAAsB,EAAExC,KAAe,EAAEC,SAAS,GAAG,CAAC,EAAE;IAAA,KAL5DD,KAAK;IAAA,KACLwC,UAAU;IAAA,KACTvC,SAAS;IAAA,KACTwC,KAAK,GAAGvC,QAAQ,CAACuC,KAAK;IAG7B,IAAI,CAACzC,KAAK,GAAGA,KAAK;IAClB,IAAI,CAACwC,UAAU,GAAGA,UAAU;IAC5B,IAAI,CAACvC,SAAS,GAAGA,SAAS;EAC5B;;EAEA;EACA;;EA8BAxB,WAAWA,CAGTX,QAAW,EACX,GAAGC,IAA0D,EAK7D;IACA,OAAO,IAAI,CAACyE,UAAU,CAAC/D,WAAW,CAACX,QAAQ,EAAE,GAAGC,IAAI,EAAE,IAAI,CAACiC,KAAK,CAAC;EACnE;;EAEA;;EAWAK,QAAQA,CACNvC,QAAW,EACX,GAAGC,IAA0D,EACrC;IACxB,OAAO,IAAI,CAACyE,UAAU,CAACnC,QAAQ,CAACvC,QAAQ,EAAE,GAAGC,IAAI,EAAE,IAAI,CAACiC,KAAK,CAAC;EAChE;;EAEA;AACF;AACA;AACA;EACE0B,GAAGA,CACD1D,MAAS,EACT,GAAGD,IAAmB,EACc;IACpC,OAAO,IAAI,CAACyE,UAAU,CAACd,GAAG,CAAC1D,MAAM,EAAE,GAAGD,IAAI,EAAE,IAAI,CAACiC,KAAK,CAAC;EACzD;AACF;AAtFME,QAAQ,CACIuC,KAAK,GAAG,IAAIlG,eAAe,CAAC,CAAC","ignoreList":[]}
@@ -4,9 +4,9 @@ export function createSubscription(endpoint, {
4
4
  }) {
5
5
  return {
6
6
  type: SUBSCRIBE,
7
- endpoint,
7
+ key: endpoint.key(...args),
8
8
  args,
9
- key: endpoint.key(...args)
9
+ endpoint
10
10
  };
11
11
  }
12
12
  export function createUnsubscription(endpoint, {
@@ -19,4 +19,4 @@ export function createUnsubscription(endpoint, {
19
19
  endpoint
20
20
  };
21
21
  }
22
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVUJTQ1JJQkUiLCJVTlNVQlNDUklCRSIsImNyZWF0ZVN1YnNjcmlwdGlvbiIsImVuZHBvaW50IiwiYXJncyIsInR5cGUiLCJrZXkiLCJjcmVhdGVVbnN1YnNjcmlwdGlvbiJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlU3Vic2NyaXB0aW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRW5kcG9pbnRJbnRlcmZhY2UgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgU1VCU0NSSUJFLCBVTlNVQlNDUklCRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgU3Vic2NyaWJlQWN0aW9uLCBVbnN1YnNjcmliZUFjdGlvbiB9IGZyb20gJy4uLy4uL3R5cGVzLmpzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVN1YnNjcmlwdGlvbjxFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2U+KFxuICBlbmRwb2ludDogRSxcbiAgeyBhcmdzIH06IHsgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dIH0sXG4pOiBTdWJzY3JpYmVBY3Rpb248RT4ge1xuICByZXR1cm4ge1xuICAgIHR5cGU6IFNVQlNDUklCRSxcbiAgICBlbmRwb2ludCxcbiAgICBhcmdzLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlVW5zdWJzY3JpcHRpb248RSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlPihcbiAgZW5kcG9pbnQ6IEUsXG4gIHsgYXJncyB9OiB7IGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XSB9LFxuKTogVW5zdWJzY3JpYmVBY3Rpb248RT4ge1xuICByZXR1cm4ge1xuICAgIHR5cGU6IFVOU1VCU0NSSUJFLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICAgIGFyZ3MsXG4gICAgZW5kcG9pbnQsXG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiJBQUVBLFNBQVNBLFNBQVMsRUFBRUMsV0FBVyxRQUFRLHNCQUFzQjtBQUc3RCxPQUFPLFNBQVNDLGtCQUFrQkEsQ0FDaENDLFFBQVcsRUFDWDtFQUFFQztBQUE0QyxDQUFDLEVBQzNCO0VBQ3BCLE9BQU87SUFDTEMsSUFBSSxFQUFFTCxTQUFTO0lBQ2ZHLFFBQVE7SUFDUkMsSUFBSTtJQUNKRSxHQUFHLEVBQUVILFFBQVEsQ0FBQ0csR0FBRyxDQUFDLEdBQUdGLElBQUk7RUFDM0IsQ0FBQztBQUNIO0FBRUEsT0FBTyxTQUFTRyxvQkFBb0JBLENBQ2xDSixRQUFXLEVBQ1g7RUFBRUM7QUFBNEMsQ0FBQyxFQUN6QjtFQUN0QixPQUFPO0lBQ0xDLElBQUksRUFBRUosV0FBVztJQUNqQkssR0FBRyxFQUFFSCxRQUFRLENBQUNHLEdBQUcsQ0FBQyxHQUFHRixJQUFJLENBQUM7SUFDMUJBLElBQUk7SUFDSkQ7RUFDRixDQUFDO0FBQ0giLCJpZ25vcmVMaXN0IjpbXX0=
22
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVUJTQ1JJQkUiLCJVTlNVQlNDUklCRSIsImNyZWF0ZVN1YnNjcmlwdGlvbiIsImVuZHBvaW50IiwiYXJncyIsInR5cGUiLCJrZXkiLCJjcmVhdGVVbnN1YnNjcmlwdGlvbiJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlU3Vic2NyaXB0aW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRW5kcG9pbnRJbnRlcmZhY2UgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgU1VCU0NSSUJFLCBVTlNVQlNDUklCRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgU3Vic2NyaWJlQWN0aW9uLCBVbnN1YnNjcmliZUFjdGlvbiB9IGZyb20gJy4uLy4uL3R5cGVzLmpzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVN1YnNjcmlwdGlvbjxFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2U+KFxuICBlbmRwb2ludDogRSxcbiAgeyBhcmdzIH06IHsgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dIH0sXG4pOiBTdWJzY3JpYmVBY3Rpb248RT4ge1xuICByZXR1cm4ge1xuICAgIHR5cGU6IFNVQlNDUklCRSxcbiAgICBrZXk6IGVuZHBvaW50LmtleSguLi5hcmdzKSxcbiAgICBhcmdzLFxuICAgIGVuZHBvaW50LFxuICB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlVW5zdWJzY3JpcHRpb248RSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlPihcbiAgZW5kcG9pbnQ6IEUsXG4gIHsgYXJncyB9OiB7IGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XSB9LFxuKTogVW5zdWJzY3JpYmVBY3Rpb248RT4ge1xuICByZXR1cm4ge1xuICAgIHR5cGU6IFVOU1VCU0NSSUJFLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICAgIGFyZ3MsXG4gICAgZW5kcG9pbnQsXG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiJBQUVBLFNBQVNBLFNBQVMsRUFBRUMsV0FBVyxRQUFRLHNCQUFzQjtBQUc3RCxPQUFPLFNBQVNDLGtCQUFrQkEsQ0FDaENDLFFBQVcsRUFDWDtFQUFFQztBQUE0QyxDQUFDLEVBQzNCO0VBQ3BCLE9BQU87SUFDTEMsSUFBSSxFQUFFTCxTQUFTO0lBQ2ZNLEdBQUcsRUFBRUgsUUFBUSxDQUFDRyxHQUFHLENBQUMsR0FBR0YsSUFBSSxDQUFDO0lBQzFCQSxJQUFJO0lBQ0pEO0VBQ0YsQ0FBQztBQUNIO0FBRUEsT0FBTyxTQUFTSSxvQkFBb0JBLENBQ2xDSixRQUFXLEVBQ1g7RUFBRUM7QUFBNEMsQ0FBQyxFQUN6QjtFQUN0QixPQUFPO0lBQ0xDLElBQUksRUFBRUosV0FBVztJQUNqQkssR0FBRyxFQUFFSCxRQUFRLENBQUNHLEdBQUcsQ0FBQyxHQUFHRixJQUFJLENBQUM7SUFDMUJBLElBQUk7SUFDSkQ7RUFDRixDQUFDO0FBQ0giLCJpZ25vcmVMaXN0IjpbXX0=
@@ -1 +1 @@
1
- {"version":3,"file":"DevtoolsManager.d.ts","sourceRoot":"","sources":["../../src/manager/DevtoolsManager.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,KAAK,EAAE,UAAU,EAAqB,MAAM,aAAa,CAAC;AACjE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE/D,YAAY,EAAE,cAAc,EAAE,CAAC;AA6E/B;;;;;GAKG;AACH,MAAM,CAAC,OAAO,OAAO,eAAgB,YAAW,OAAO;IAC7C,UAAU,EAAE,UAAU,CAAC;IAC/B,UAAkB,QAAQ,EAAE,SAAS,GAAG,GAAG,CAAC;IAC5C,SAAS,CAAC,OAAO,UAAS;IAC1B,SAAS,CAAC,OAAO,EAAE,CAAC,WAAW,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,EAAE,CAAM;IACxD,UAAkB,UAAU,EAAE,UAAU,CAAC;IACjC,WAAW,CAAC,EAAE,CAAC,MAAM,EAAE,WAAW,KAAK,OAAO,CAAC;IACvD,eAAe,SAAO;gBAGpB,MAAM,CAAC,EAAE,cAAc,EACvB,WAAW,CAAC,EAAE,CAAC,MAAM,EAAE,WAAW,KAAK,OAAO;IA6ChD,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG;IAapC,yCAAyC;IACzC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC;IA4BtB,gDAAgD;IAChD,OAAO;CACR"}
1
+ {"version":3,"file":"DevtoolsManager.d.ts","sourceRoot":"","sources":["../../src/manager/DevtoolsManager.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,KAAK,EAAE,UAAU,EAAqB,MAAM,aAAa,CAAC;AACjE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE/D,YAAY,EAAE,cAAc,EAAE,CAAC;AA6E/B;;;;;GAKG;AACH,MAAM,CAAC,OAAO,OAAO,eAAgB,YAAW,OAAO;IAC7C,UAAU,EAAE,UAAU,CAAC;IAC/B,UAAkB,QAAQ,EAAE,SAAS,GAAG,GAAG,CAAC;IAC5C,SAAS,CAAC,OAAO,UAAS;IAC1B,SAAS,CAAC,OAAO,EAAE,CAAC,WAAW,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,EAAE,CAAM;IACxD,UAAkB,UAAU,EAAE,UAAU,CAAC;IACjC,WAAW,CAAC,EAAE,CAAC,MAAM,EAAE,WAAW,KAAK,OAAO,CAAC;IACvD,eAAe,SAAO;gBAGpB,MAAM,CAAC,EAAE,cAAc,EACvB,WAAW,CAAC,EAAE,CAAC,MAAM,EAAE,WAAW,KAAK,OAAO;IA6ChD,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG;IAapC,yCAAyC;IACzC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC;IA4BtB,gDAAgD;IAChD,OAAO;CACR"}
@@ -1,6 +1,4 @@
1
1
  var _DevToolsManager;
2
- /* eslint-disable no-inner-declarations */
3
-
4
2
  import createReducer from '../state/reducer/createReducer.js';
5
3
  let DEFAULT_CONFIG = {};
6
4
  if (process.env.NODE_ENV !== 'production') {
@@ -162,4 +160,4 @@ _DevToolsManager = DevToolsManager;
162
160
  _DevToolsManager.prototype.middleware = () => next => action => next(action);
163
161
  }
164
162
  })();
165
- //# 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","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":[]}
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","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":["import 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  declare protected devTools: undefined | any;\n  protected started = false;\n  protected actions: [ActionTypes, State<unknown>][] = [];\n  declare protected 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":";AAGA,OAAOA,aAAa,MAAM,mCAAmC;AAK7D,IAAIC,cAAc,GAAG,CAAC,CAAC;AAEvB,IAAIC,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;EAAA,IAAAC,oBAAA;EACzC,MAAMC,iBAAiB,GAAG,CACxB,kBAAkB,EAClB,mBAAmB,EACnB,aAAa,EACb,gBAAgB,EAChB,eAAe,EACf,uBAAuB,EACvB,QAAQ,CACT;EAED,SAASC,iBAAiBA,CAACC,QAA2B,EAAE;IAAA,IAAAC,OAAA,EAAAC,gBAAA;IACtD,MAAMC,MAAW,GAAG;MAClBC,IAAI,EAAEJ,QAAQ,CAACI,IAAI;MACnBC,MAAM,GAAAJ,OAAA,IAAAC,gBAAA,GAAGF,QAAQ,CAACK,MAAM,aAAhBH,gBAAA,CAA0BI,MAAM,oBAAhCJ,gBAAA,CAA0BI,MAAM,CAAG,CAAC,YAAAL,OAAA,GAAID,QAAQ,CAACK,MAAM;MAC/DE,UAAU,EAAEP,QAAQ,CAACO;IACvB,CAAC;IACDT,iBAAiB,CAACU,OAAO,CAACC,GAAG,IAAI;MAC/B,IAAIA,GAAG,IAAIT,QAAQ,EACjBG,MAAM,CAACM,GAAG,CAAC,GAAGT,QAAQ,CAACS,GAAG,CAA4B;IAC1D,CAAC,CAAC;IACF,OAAON,MAAM;EACf;EAEA,MAAMO,OAAO,GAAG,OAAOC,IAAI,KAAK,WAAW;EAC3ClB,cAAc,GAAG;IACfW,IAAI,EAAE,iBAAAP,oBAAA,GAAgBe,UAAU,CAACC,QAAQ,qBAAnBhB,oBAAA,CAAqBiB,KAAK,EAAE;IAClDC,SAAS,EAAE,IAAI;IACfC,QAAQ,EAAE;MACRC,KAAK,EAAE,IAAI;MAAE;MACbC,IAAI,EAAE,IAAI;MAAE;MACZC,OAAO,EAAE,KAAK;MAAE;MAChBC,MAAM,EAAE,IAAI;MAAE;MACdC,MAAM,EAAE,QAAQ;MAAE;MAClBC,IAAI,EAAE,IAAI;MAAE;MACZC,IAAI,EAAE,IAAI;MAAE;MACZC,OAAO,EAAE,IAAI;MAAE;MACfC,QAAQ,EAAE,KAAK;MAAE;MACjBC,IAAI,EAAE,KAAK,CAAE;IACf,CAAC;IACDC,eAAe,EAAGC,MAAmB,IAAK;MACxC,IAAI,EAAE,UAAU,IAAIA,MAAM,CAAC,EAAE,OAAOA,MAAM;MAC1C,OAAO;QACL,GAAGA,MAAM;QACT5B,QAAQ,EAAED,iBAAiB,CAAC6B,MAAM,CAAC5B,QAAQ;MAC7C,CAAC;IACH,CAAC;IACD6B,SAAS,EAAE;MACTC,OAAO,EAAEC,SAAS;MAClB;MACAC,QAAQ,EACNtB,OAAO,GACL,CAACD,GAA6B,EAAEwB,KAAc,KAAK;QACjD,IACE,OAAOA,KAAK,KAAK,QAAQ,IACzB,OAAOxB,GAAG,KAAK,QAAQ,IACvByB,QAAQ,CAACD,KAAK,CAAC,KACdxB,GAAG,KAAK,MAAM,IAAIA,GAAG,CAAC0B,QAAQ,CAAC,IAAI,CAAC,CAAC,EACtC;UACA,OAAOxB,IAAI,CAACyB,cAAc,CAAC,OAAO,EAAE;YAClCC,IAAI,EAAE,SAAS;YACfC,MAAM,EAAE,SAAS;YACjBC,MAAM,EAAE,SAAS;YACjBC,sBAAsB,EAAE;UAC1B,CAAC,CAAC,CAACC,MAAM,CAACR,KAAK,CAAC;QAClB;QACA,OAAOA,KAAK;MACd,CAAC,GACDF;IACN;EACF,CAAC;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,MAAMW,eAAe,CAAoB;EAStDC,WAAWA,CACTC,MAAuB,EACvBC,WAA8C,EAC9C;IAAA,KATQC,OAAO,GAAG,KAAK;IAAA,KACfC,OAAO,GAAoC,EAAE;IAAA,KAGvDC,eAAe,GAAG,GAAG;IAMnB;IACA,IAAI,CAACC,QAAQ,GACX,OAAOC,MAAM,KAAK,WAAW,IAC5BA,MAAM,CAASC,4BAA4B,IAC3CD,MAAM,CAASC,4BAA4B,CAACC,OAAO,CAAC;MACnD,GAAG3D,cAAc;MACjB,GAAGmD;IACL,CAAC,CAAC;IACJ;IACA,IAAIA,MAAM,YAANA,MAAM,CAAES,MAAM,EAAE,IAAI,CAACL,eAAe,GAAGJ,MAAM,CAACS,MAAM,GAAG,CAAC;IAC5D,IAAIR,WAAW,EAAE,IAAI,CAACA,WAAW,GAAGA,WAAW;EACjD;EAgCAS,YAAYA,CAAC1B,MAAW,EAAE2B,KAAU,EAAE;IACpC,IAAI,IAAI,CAACT,OAAO,EAAE;MAChB,IAAI,CAACG,QAAQ,CAACO,IAAI,CAAC5B,MAAM,EAAE2B,KAAK,CAAC;IACnC,CAAC,MAAM;MACL;MACA;MACA,IAAI,IAAI,CAACR,OAAO,CAACU,MAAM,GAAG,IAAI,CAACT,eAAe,EAC5C,IAAI,CAACD,OAAO,GAAG,IAAI,CAACA,OAAO,CAACW,KAAK,CAAC,IAAI,CAACV,eAAe,GAAG,CAAC,CAAC;MAC7D;MACA,IAAI,CAACD,OAAO,CAACY,IAAI,CAAC,CAAC/B,MAAM,EAAE2B,KAAK,CAAC,CAAC;IACpC;EACF;;EAEA;EACAK,IAAIA,CAACL,KAAiB,EAAE;IACtB,IAAI7D,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,IAAI,IAAI,CAACqD,QAAQ,EAAE;MAC1D,IAAI,CAACA,QAAQ,CAACW,IAAI,CAACL,KAAK,CAAC;MACzB,IAAI,CAACN,QAAQ,CAACY,SAAS,CAAEC,GAAQ,IAAK;QACpC,QAAQA,GAAG,CAACC,IAAI;UACd,KAAK,OAAO;YACV,IAAI,CAACjB,OAAO,GAAG,IAAI;YAEnB,IAAI,IAAI,CAACC,OAAO,CAACU,MAAM,EAAE;cACvB,IAAI,CAACV,OAAO,CAACvC,OAAO,CAAC,CAAC,CAACoB,MAAM,EAAE2B,KAAK,CAAC,KAAK;gBACxC,IAAI,CAACD,YAAY,CAAC1B,MAAM,EAAE2B,KAAK,CAAC;cAClC,CAAC,CAAC;cACF,IAAI,CAACR,OAAO,GAAG,EAAE;YACnB;YACA;UACF,KAAK,MAAM;YACT,IAAI,CAACD,OAAO,GAAG,KAAK;YACpB;UACF,KAAK,UAAU;YACb,IAAIgB,GAAG,CAACE,OAAO,CAACD,IAAI,KAAK,OAAO,EAAE;cAChC,IAAI,CAACE,UAAU,CAACC,gBAAgB,CAAC,CAAC;YACpC;YACA;QACJ;MACF,CAAC,CAAC;IACJ;EACF;;EAEA;EACAC,OAAOA,CAAA,EAAG,CAAC;AACb;AAACC,gBAAA,GApGoB1B,eAAe;AAAA;EA2BhC;EACA;EACA,IAAIhD,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;IACzCwE,gBAAA,CAAKC,SAAS,CAACC,UAAU,GAAG,UAAUL,UAAU,EAAE;MAChD,IAAI,CAAC,IAAI,CAAChB,QAAQ,EAAE,OAAOsB,IAAI,IAAI3C,MAAM,IAAI2C,IAAI,CAAC3C,MAAM,CAAC;MACzD,IAAI,CAACqC,UAAU,GAAGA,UAAU;MAC5B,MAAMO,OAAO,GAAGhF,aAAa,CAACyE,UAAiB,CAAC;MAChD,IAAIV,KAAK,GAAGU,UAAU,CAACQ,QAAQ,CAAC,CAAC;MACjC,OAAOF,IAAI,IAAI3C,MAAM,IAAI;QAAA,IAAA8C,iBAAA;QACvB,MAAMC,UAAU,IAAAD,iBAAA,GAAG,IAAI,CAAC7B,WAAW,qBAAhB6B,iBAAA,CAAAE,IAAA,KAAI,EAAehD,MAAM,CAAC;QAC7C,MAAMiD,GAAG,GAAGN,IAAI,CAAC3C,MAAM,CAAC;QACxB,IAAI,IAAI,CAACkB,OAAO,EAAE;UAChB;UACAS,KAAK,GAAGiB,OAAO,CAACjB,KAAK,EAAE3B,MAAM,CAAC;QAChC,CAAC,MAAM;UACL2B,KAAK,GAAGU,UAAU,CAACQ,QAAQ,CAAC,CAAC;QAC/B;QACAI,GAAG,CAACC,IAAI,CAAC,MAAM;UACb,IAAIH,UAAU,EAAE;UAChB,IAAI,CAACrB,YAAY,CAAC1B,MAAM,EAAE2B,KAAK,CAACwB,UAAU,CAACC,MAAM,CAACR,OAAO,EAAEjB,KAAK,CAAC,CAAC;QACpE,CAAC,CAAC;QACF,OAAOsB,GAAG;MACZ,CAAC;IACH,CAAC;EACH,CAAC,MAAM;IACLT,gBAAA,CAAKC,SAAS,CAACC,UAAU,GAAG,MAAMC,IAAI,IAAI3C,MAAM,IAAI2C,IAAI,CAAC3C,MAAM,CAAC;EAClE;AAAC","ignoreList":[]}
@@ -147,4 +147,4 @@ export default class PollingSubscription {
147
147
  return (_this$controller$getS = (_this$controller$getS2 = this.controller.getState().meta[this.key]) == null ? void 0 : _this$controller$getS2.date) != null ? _this$controller$getS : 0;
148
148
  }
149
149
  }
150
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DefaultConnectionListener","PollingSubscription","constructor","action","controller","connectionListener","frequencyHistogram","Map","offlineListener","cleanup","addOnlineListener","onlineListener","removeOnlineListener","now","Date","startId","setTimeout","update","run","process","env","NODE_ENV","console","warn","key","Math","max","lastFetchTime","frequency","addOfflineListener","endpoint","pollFrequency","undefined","Error","args","set","isOnline","add","has","get","remove","delete","size","min","keys","error","intervalId","clearInterval","lastIntervalId","clearTimeout","removeOfflineListener","sup","call","Object","assign","dataExpiryLength","errorExpiryLength","errorPolicy","fetch","catch","setInterval","_this$controller$getS","_this$controller$getS2","getState","meta","date"],"sources":["../../src/manager/PollingSubscription.ts"],"sourcesContent":["import type { EndpointInterface } from '@data-client/normalizr';\n\nimport ConnectionListener from './ConnectionListener.js';\nimport DefaultConnectionListener from './DefaultConnectionListener.js';\nimport type { Subscription } from './SubscriptionManager.js';\nimport type Controller from '../controller/Controller.js';\nimport type { SubscribeAction } from '../types.js';\n\n/**\n * PollingSubscription keeps a given resource updated by\n * dispatching a fetch at a rate equal to the minimum update\n * interval requested.\n *\n * @see https://dataclient.io/docs/api/PollingSubscription\n */\nexport default class PollingSubscription implements Subscription {\n  protected declare readonly endpoint: EndpointInterface;\n  protected declare readonly args: readonly any[];\n  protected declare readonly key: string;\n  protected declare frequency: number;\n  protected frequencyHistogram: Map<number, number> = new Map();\n  protected declare controller: Controller;\n  protected declare intervalId?: ReturnType<typeof setInterval>;\n  protected declare lastIntervalId?: ReturnType<typeof setInterval>;\n  protected declare startId?: ReturnType<typeof setTimeout>;\n  private declare connectionListener: ConnectionListener;\n\n  constructor(\n    action: Omit<SubscribeAction, 'type'>,\n    controller: Controller,\n    connectionListener?: ConnectionListener,\n  ) {\n    if (action.endpoint.pollFrequency === undefined)\n      throw new Error('frequency needed for polling subscription');\n    this.endpoint = action.endpoint;\n    this.frequency = action.endpoint.pollFrequency;\n    this.args = action.args;\n    this.key = action.key;\n    this.frequencyHistogram.set(this.frequency, 1);\n    this.controller = controller;\n    this.connectionListener =\n      connectionListener || new DefaultConnectionListener();\n\n    // Kickstart running since this is initialized after the online notif is sent\n    if (this.connectionListener.isOnline()) {\n      this.onlineListener();\n    } else {\n      this.offlineListener();\n    }\n  }\n\n  /** Subscribe to a frequency */\n  add(frequency?: number) {\n    if (frequency === undefined) return;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) + 1,\n      );\n    } else {\n      this.frequencyHistogram.set(frequency, 1);\n\n      // new min so restart service\n      if (frequency < this.frequency) {\n        this.frequency = frequency;\n        this.run();\n      }\n    }\n  }\n\n  /** Unsubscribe from a frequency */\n  remove(frequency?: number) {\n    if (frequency === undefined) return false;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) - 1,\n      );\n      if ((this.frequencyHistogram.get(frequency) as number) < 1) {\n        this.frequencyHistogram.delete(frequency);\n\n        // nothing subscribed to this anymore...it is invalid\n        if (this.frequencyHistogram.size === 0) {\n          this.cleanup();\n          return true;\n        }\n\n        // this was the min, so find the next size\n        if (frequency <= this.frequency) {\n          this.frequency = Math.min(...this.frequencyHistogram.keys());\n          this.run();\n        }\n      }\n    } /* istanbul ignore next */ else if (\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.error(\n        `Mismatched remove: ${frequency} is not subscribed for ${this.key}`,\n      );\n    }\n    return false;\n  }\n\n  /** Cleanup means clearing out background interval. */\n  cleanup() {\n    if (this.intervalId) {\n      clearInterval(this.intervalId);\n      delete this.intervalId;\n    }\n    if (this.lastIntervalId) {\n      clearInterval(this.lastIntervalId);\n      delete this.lastIntervalId;\n    }\n    if (this.startId) {\n      clearTimeout(this.startId);\n      delete this.startId;\n    }\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    this.connectionListener.removeOfflineListener(this.offlineListener);\n  }\n\n  /** Trigger request for latest resource */\n  protected update() {\n    const sup = this.endpoint;\n    const endpoint = function (this: any, ...args: any[]) {\n      return sup.call(this, ...args);\n    };\n    Object.assign(endpoint, this.endpoint);\n    endpoint.dataExpiryLength = this.frequency / 2;\n    endpoint.errorExpiryLength = this.frequency / 10;\n    endpoint.errorPolicy = () => 'soft' as const;\n    endpoint.key = () => this.key;\n    // stop any errors here from bubbling\n    this.controller.fetch(endpoint, ...this.args).catch(() => null);\n  }\n\n  /** What happens when browser goes offline */\n  protected offlineListener = () => {\n    // this clears existing listeners, so no need to clear offline listener\n    this.cleanup();\n    this.connectionListener.addOnlineListener(this.onlineListener);\n  };\n\n  /** What happens when browser comes online */\n  protected onlineListener = () => {\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    const now = Date.now();\n    this.startId = setTimeout(\n      () => {\n        if (this.startId) {\n          delete this.startId;\n          this.update();\n          this.run();\n        } else if (process.env.NODE_ENV !== 'production') {\n          console.warn(\n            `Poll setTimeout for ${this.key} still running, but timeoutId deleted`,\n          );\n        }\n      },\n      Math.max(0, this.lastFetchTime() - now + this.frequency),\n    );\n    this.connectionListener.addOfflineListener(this.offlineListener);\n  };\n\n  /** Run polling process with current frequency\n   *\n   * Will clean up old poll interval on next run\n   */\n  protected run() {\n    if (this.startId) return;\n    if (this.intervalId) this.lastIntervalId = this.intervalId;\n    this.intervalId = setInterval(() => {\n      // since we don't know how long into the last poll it was before resetting\n      // we wait til the next fetch to clear old intervals\n      if (this.lastIntervalId) {\n        clearInterval(this.lastIntervalId);\n        delete this.lastIntervalId;\n      }\n      if (this.intervalId) this.update();\n      else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll intervalId for ${this.key} still running, but intervalId deleted`,\n        );\n      }\n    }, this.frequency);\n  }\n\n  /** Last fetch time */\n  protected lastFetchTime() {\n    return this.controller.getState().meta[this.key]?.date ?? 0;\n  }\n}\n"],"mappings":"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","ignoreList":[]}
150
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DefaultConnectionListener","PollingSubscription","constructor","action","controller","connectionListener","frequencyHistogram","Map","offlineListener","cleanup","addOnlineListener","onlineListener","removeOnlineListener","now","Date","startId","setTimeout","update","run","process","env","NODE_ENV","console","warn","key","Math","max","lastFetchTime","frequency","addOfflineListener","endpoint","pollFrequency","undefined","Error","args","set","isOnline","add","has","get","remove","delete","size","min","keys","error","intervalId","clearInterval","lastIntervalId","clearTimeout","removeOfflineListener","sup","call","Object","assign","dataExpiryLength","errorExpiryLength","errorPolicy","fetch","catch","setInterval","_this$controller$getS","_this$controller$getS2","getState","meta","date"],"sources":["../../src/manager/PollingSubscription.ts"],"sourcesContent":["import type { EndpointInterface } from '@data-client/normalizr';\n\nimport ConnectionListener from './ConnectionListener.js';\nimport DefaultConnectionListener from './DefaultConnectionListener.js';\nimport type { Subscription } from './SubscriptionManager.js';\nimport type Controller from '../controller/Controller.js';\nimport type { SubscribeAction } from '../types.js';\n\n/**\n * PollingSubscription keeps a given resource updated by\n * dispatching a fetch at a rate equal to the minimum update\n * interval requested.\n *\n * @see https://dataclient.io/docs/api/PollingSubscription\n */\nexport default class PollingSubscription implements Subscription {\n  declare protected readonly endpoint: EndpointInterface;\n  declare protected readonly args: readonly any[];\n  declare protected readonly key: string;\n  declare protected frequency: number;\n  protected frequencyHistogram: Map<number, number> = new Map();\n  declare protected controller: Controller;\n  declare protected intervalId?: ReturnType<typeof setInterval>;\n  declare protected lastIntervalId?: ReturnType<typeof setInterval>;\n  declare protected startId?: ReturnType<typeof setTimeout>;\n  declare private connectionListener: ConnectionListener;\n\n  constructor(\n    action: Omit<SubscribeAction, 'type'>,\n    controller: Controller,\n    connectionListener?: ConnectionListener,\n  ) {\n    if (action.endpoint.pollFrequency === undefined)\n      throw new Error('frequency needed for polling subscription');\n    this.endpoint = action.endpoint;\n    this.frequency = action.endpoint.pollFrequency;\n    this.args = action.args;\n    this.key = action.key;\n    this.frequencyHistogram.set(this.frequency, 1);\n    this.controller = controller;\n    this.connectionListener =\n      connectionListener || new DefaultConnectionListener();\n\n    // Kickstart running since this is initialized after the online notif is sent\n    if (this.connectionListener.isOnline()) {\n      this.onlineListener();\n    } else {\n      this.offlineListener();\n    }\n  }\n\n  /** Subscribe to a frequency */\n  add(frequency?: number) {\n    if (frequency === undefined) return;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) + 1,\n      );\n    } else {\n      this.frequencyHistogram.set(frequency, 1);\n\n      // new min so restart service\n      if (frequency < this.frequency) {\n        this.frequency = frequency;\n        this.run();\n      }\n    }\n  }\n\n  /** Unsubscribe from a frequency */\n  remove(frequency?: number) {\n    if (frequency === undefined) return false;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) - 1,\n      );\n      if ((this.frequencyHistogram.get(frequency) as number) < 1) {\n        this.frequencyHistogram.delete(frequency);\n\n        // nothing subscribed to this anymore...it is invalid\n        if (this.frequencyHistogram.size === 0) {\n          this.cleanup();\n          return true;\n        }\n\n        // this was the min, so find the next size\n        if (frequency <= this.frequency) {\n          this.frequency = Math.min(...this.frequencyHistogram.keys());\n          this.run();\n        }\n      }\n    } /* istanbul ignore next */ else if (\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.error(\n        `Mismatched remove: ${frequency} is not subscribed for ${this.key}`,\n      );\n    }\n    return false;\n  }\n\n  /** Cleanup means clearing out background interval. */\n  cleanup() {\n    if (this.intervalId) {\n      clearInterval(this.intervalId);\n      delete this.intervalId;\n    }\n    if (this.lastIntervalId) {\n      clearInterval(this.lastIntervalId);\n      delete this.lastIntervalId;\n    }\n    if (this.startId) {\n      clearTimeout(this.startId);\n      delete this.startId;\n    }\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    this.connectionListener.removeOfflineListener(this.offlineListener);\n  }\n\n  /** Trigger request for latest resource */\n  protected update() {\n    const sup = this.endpoint;\n    const endpoint = function (this: any, ...args: any[]) {\n      return sup.call(this, ...args);\n    };\n    Object.assign(endpoint, this.endpoint);\n    endpoint.dataExpiryLength = this.frequency / 2;\n    endpoint.errorExpiryLength = this.frequency / 10;\n    endpoint.errorPolicy = () => 'soft' as const;\n    endpoint.key = () => this.key;\n    // stop any errors here from bubbling\n    this.controller.fetch(endpoint, ...this.args).catch(() => null);\n  }\n\n  /** What happens when browser goes offline */\n  protected offlineListener = () => {\n    // this clears existing listeners, so no need to clear offline listener\n    this.cleanup();\n    this.connectionListener.addOnlineListener(this.onlineListener);\n  };\n\n  /** What happens when browser comes online */\n  protected onlineListener = () => {\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    const now = Date.now();\n    this.startId = setTimeout(\n      () => {\n        if (this.startId) {\n          delete this.startId;\n          this.update();\n          this.run();\n        } else if (process.env.NODE_ENV !== 'production') {\n          console.warn(\n            `Poll setTimeout for ${this.key} still running, but timeoutId deleted`,\n          );\n        }\n      },\n      Math.max(0, this.lastFetchTime() - now + this.frequency),\n    );\n    this.connectionListener.addOfflineListener(this.offlineListener);\n  };\n\n  /** Run polling process with current frequency\n   *\n   * Will clean up old poll interval on next run\n   */\n  protected run() {\n    if (this.startId) return;\n    if (this.intervalId) this.lastIntervalId = this.intervalId;\n    this.intervalId = setInterval(() => {\n      // since we don't know how long into the last poll it was before resetting\n      // we wait til the next fetch to clear old intervals\n      if (this.lastIntervalId) {\n        clearInterval(this.lastIntervalId);\n        delete this.lastIntervalId;\n      }\n      if (this.intervalId) this.update();\n      else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll intervalId for ${this.key} still running, but intervalId deleted`,\n        );\n      }\n    }, this.frequency);\n  }\n\n  /** Last fetch time */\n  protected lastFetchTime() {\n    return this.controller.getState().meta[this.key]?.date ?? 0;\n  }\n}\n"],"mappings":"AAGA,OAAOA,yBAAyB,MAAM,gCAAgC;AAKtE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,MAAMC,mBAAmB,CAAyB;EAY/DC,WAAWA,CACTC,MAAqC,EACrCC,UAAsB,EACtBC,kBAAuC,EACvC;IAAA,KAXQC,kBAAkB,GAAwB,IAAIC,GAAG,CAAC,CAAC;IAoH7D;IAAA,KACUC,eAAe,GAAG,MAAM;MAChC;MACA,IAAI,CAACC,OAAO,CAAC,CAAC;MACd,IAAI,CAACJ,kBAAkB,CAACK,iBAAiB,CAAC,IAAI,CAACC,cAAc,CAAC;IAChE,CAAC;IAED;IAAA,KACUA,cAAc,GAAG,MAAM;MAC/B,IAAI,CAACN,kBAAkB,CAACO,oBAAoB,CAAC,IAAI,CAACD,cAAc,CAAC;MACjE,MAAME,GAAG,GAAGC,IAAI,CAACD,GAAG,CAAC,CAAC;MACtB,IAAI,CAACE,OAAO,GAAGC,UAAU,CACvB,MAAM;QACJ,IAAI,IAAI,CAACD,OAAO,EAAE;UAChB,OAAO,IAAI,CAACA,OAAO;UACnB,IAAI,CAACE,MAAM,CAAC,CAAC;UACb,IAAI,CAACC,GAAG,CAAC,CAAC;QACZ,CAAC,MAAM,IAAIC,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;UAChDC,OAAO,CAACC,IAAI,CACV,uBAAuB,IAAI,CAACC,GAAG,uCACjC,CAAC;QACH;MACF,CAAC,EACDC,IAAI,CAACC,GAAG,CAAC,CAAC,EAAE,IAAI,CAACC,aAAa,CAAC,CAAC,GAAGd,GAAG,GAAG,IAAI,CAACe,SAAS,CACzD,CAAC;MACD,IAAI,CAACvB,kBAAkB,CAACwB,kBAAkB,CAAC,IAAI,CAACrB,eAAe,CAAC;IAClE,CAAC;IAlIC,IAAIL,MAAM,CAAC2B,QAAQ,CAACC,aAAa,KAAKC,SAAS,EAC7C,MAAM,IAAIC,KAAK,CAAC,2CAA2C,CAAC;IAC9D,IAAI,CAACH,QAAQ,GAAG3B,MAAM,CAAC2B,QAAQ;IAC/B,IAAI,CAACF,SAAS,GAAGzB,MAAM,CAAC2B,QAAQ,CAACC,aAAa;IAC9C,IAAI,CAACG,IAAI,GAAG/B,MAAM,CAAC+B,IAAI;IACvB,IAAI,CAACV,GAAG,GAAGrB,MAAM,CAACqB,GAAG;IACrB,IAAI,CAAClB,kBAAkB,CAAC6B,GAAG,CAAC,IAAI,CAACP,SAAS,EAAE,CAAC,CAAC;IAC9C,IAAI,CAACxB,UAAU,GAAGA,UAAU;IAC5B,IAAI,CAACC,kBAAkB,GACrBA,kBAAkB,IAAI,IAAIL,yBAAyB,CAAC,CAAC;;IAEvD;IACA,IAAI,IAAI,CAACK,kBAAkB,CAAC+B,QAAQ,CAAC,CAAC,EAAE;MACtC,IAAI,CAACzB,cAAc,CAAC,CAAC;IACvB,CAAC,MAAM;MACL,IAAI,CAACH,eAAe,CAAC,CAAC;IACxB;EACF;;EAEA;EACA6B,GAAGA,CAACT,SAAkB,EAAE;IACtB,IAAIA,SAAS,KAAKI,SAAS,EAAE;IAC7B,IAAI,IAAI,CAAC1B,kBAAkB,CAACgC,GAAG,CAACV,SAAS,CAAC,EAAE;MAC1C,IAAI,CAACtB,kBAAkB,CAAC6B,GAAG,CACzBP,SAAS,EACR,IAAI,CAACtB,kBAAkB,CAACiC,GAAG,CAACX,SAAS,CAAC,GAAc,CACvD,CAAC;IACH,CAAC,MAAM;MACL,IAAI,CAACtB,kBAAkB,CAAC6B,GAAG,CAACP,SAAS,EAAE,CAAC,CAAC;;MAEzC;MACA,IAAIA,SAAS,GAAG,IAAI,CAACA,SAAS,EAAE;QAC9B,IAAI,CAACA,SAAS,GAAGA,SAAS;QAC1B,IAAI,CAACV,GAAG,CAAC,CAAC;MACZ;IACF;EACF;;EAEA;EACAsB,MAAMA,CAACZ,SAAkB,EAAE;IACzB,IAAIA,SAAS,KAAKI,SAAS,EAAE,OAAO,KAAK;IACzC,IAAI,IAAI,CAAC1B,kBAAkB,CAACgC,GAAG,CAACV,SAAS,CAAC,EAAE;MAC1C,IAAI,CAACtB,kBAAkB,CAAC6B,GAAG,CACzBP,SAAS,EACR,IAAI,CAACtB,kBAAkB,CAACiC,GAAG,CAACX,SAAS,CAAC,GAAc,CACvD,CAAC;MACD,IAAK,IAAI,CAACtB,kBAAkB,CAACiC,GAAG,CAACX,SAAS,CAAC,GAAc,CAAC,EAAE;QAC1D,IAAI,CAACtB,kBAAkB,CAACmC,MAAM,CAACb,SAAS,CAAC;;QAEzC;QACA,IAAI,IAAI,CAACtB,kBAAkB,CAACoC,IAAI,KAAK,CAAC,EAAE;UACtC,IAAI,CAACjC,OAAO,CAAC,CAAC;UACd,OAAO,IAAI;QACb;;QAEA;QACA,IAAImB,SAAS,IAAI,IAAI,CAACA,SAAS,EAAE;UAC/B,IAAI,CAACA,SAAS,GAAGH,IAAI,CAACkB,GAAG,CAAC,GAAG,IAAI,CAACrC,kBAAkB,CAACsC,IAAI,CAAC,CAAC,CAAC;UAC5D,IAAI,CAAC1B,GAAG,CAAC,CAAC;QACZ;MACF;IACF,CAAC,CAAC,+BAAgC,IAChCC,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EACrC;MACAC,OAAO,CAACuB,KAAK,CACX,sBAAsBjB,SAAS,0BAA0B,IAAI,CAACJ,GAAG,EACnE,CAAC;IACH;IACA,OAAO,KAAK;EACd;;EAEA;EACAf,OAAOA,CAAA,EAAG;IACR,IAAI,IAAI,CAACqC,UAAU,EAAE;MACnBC,aAAa,CAAC,IAAI,CAACD,UAAU,CAAC;MAC9B,OAAO,IAAI,CAACA,UAAU;IACxB;IACA,IAAI,IAAI,CAACE,cAAc,EAAE;MACvBD,aAAa,CAAC,IAAI,CAACC,cAAc,CAAC;MAClC,OAAO,IAAI,CAACA,cAAc;IAC5B;IACA,IAAI,IAAI,CAACjC,OAAO,EAAE;MAChBkC,YAAY,CAAC,IAAI,CAAClC,OAAO,CAAC;MAC1B,OAAO,IAAI,CAACA,OAAO;IACrB;IACA,IAAI,CAACV,kBAAkB,CAACO,oBAAoB,CAAC,IAAI,CAACD,cAAc,CAAC;IACjE,IAAI,CAACN,kBAAkB,CAAC6C,qBAAqB,CAAC,IAAI,CAAC1C,eAAe,CAAC;EACrE;;EAEA;EACUS,MAAMA,CAAA,EAAG;IACjB,MAAMkC,GAAG,GAAG,IAAI,CAACrB,QAAQ;IACzB,MAAMA,QAAQ,GAAG,SAAAA,CAAqB,GAAGI,IAAW,EAAE;MACpD,OAAOiB,GAAG,CAACC,IAAI,CAAC,IAAI,EAAE,GAAGlB,IAAI,CAAC;IAChC,CAAC;IACDmB,MAAM,CAACC,MAAM,CAACxB,QAAQ,EAAE,IAAI,CAACA,QAAQ,CAAC;IACtCA,QAAQ,CAACyB,gBAAgB,GAAG,IAAI,CAAC3B,SAAS,GAAG,CAAC;IAC9CE,QAAQ,CAAC0B,iBAAiB,GAAG,IAAI,CAAC5B,SAAS,GAAG,EAAE;IAChDE,QAAQ,CAAC2B,WAAW,GAAG,MAAM,MAAe;IAC5C3B,QAAQ,CAACN,GAAG,GAAG,MAAM,IAAI,CAACA,GAAG;IAC7B;IACA,IAAI,CAACpB,UAAU,CAACsD,KAAK,CAAC5B,QAAQ,EAAE,GAAG,IAAI,CAACI,IAAI,CAAC,CAACyB,KAAK,CAAC,MAAM,IAAI,CAAC;EACjE;EA8BA;AACF;AACA;AACA;EACYzC,GAAGA,CAAA,EAAG;IACd,IAAI,IAAI,CAACH,OAAO,EAAE;IAClB,IAAI,IAAI,CAAC+B,UAAU,EAAE,IAAI,CAACE,cAAc,GAAG,IAAI,CAACF,UAAU;IAC1D,IAAI,CAACA,UAAU,GAAGc,WAAW,CAAC,MAAM;MAClC;MACA;MACA,IAAI,IAAI,CAACZ,cAAc,EAAE;QACvBD,aAAa,CAAC,IAAI,CAACC,cAAc,CAAC;QAClC,OAAO,IAAI,CAACA,cAAc;MAC5B;MACA,IAAI,IAAI,CAACF,UAAU,EAAE,IAAI,CAAC7B,MAAM,CAAC,CAAC,CAAC,KAC9B,IAAIE,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;QAC9CC,OAAO,CAACC,IAAI,CACV,uBAAuB,IAAI,CAACC,GAAG,wCACjC,CAAC;MACH;IACF,CAAC,EAAE,IAAI,CAACI,SAAS,CAAC;EACpB;;EAEA;EACUD,aAAaA,CAAA,EAAG;IAAA,IAAAkC,qBAAA,EAAAC,sBAAA;IACxB,QAAAD,qBAAA,IAAAC,sBAAA,GAAO,IAAI,CAAC1D,UAAU,CAAC2D,QAAQ,CAAC,CAAC,CAACC,IAAI,CAAC,IAAI,CAACxC,GAAG,CAAC,qBAAzCsC,sBAAA,CAA2CG,IAAI,YAAAJ,qBAAA,GAAI,CAAC;EAC7D;AACF","ignoreList":[]}
@@ -75,4 +75,4 @@ export default class SubscriptionManager {
75
75
  }
76
76
  }
77
77
  }
78
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVUJTQ1JJQkUiLCJVTlNVQlNDUklCRSIsIkNvbnRyb2xsZXIiLCJTdWJzY3JpcHRpb25NYW5hZ2VyIiwiY29uc3RydWN0b3IiLCJTdWJzY3JpcHRpb24iLCJzdWJzY3JpcHRpb25zIiwiY29udHJvbGxlciIsIm1pZGRsZXdhcmUiLCJuZXh0IiwiYWN0aW9uIiwidHlwZSIsImhhbmRsZVN1YnNjcmliZSIsImUiLCJjb25zb2xlIiwiZXJyb3IiLCJQcm9taXNlIiwicmVzb2x2ZSIsImhhbmRsZVVuc3Vic2NyaWJlIiwiY2xlYW51cCIsImtleSIsImZyZXF1ZW5jeSIsImVuZHBvaW50IiwicG9sbEZyZXF1ZW5jeSIsImFkZCIsImVtcHR5IiwicmVtb3ZlIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL21hbmFnZXIvU3Vic2NyaXB0aW9uTWFuYWdlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTVUJTQ1JJQkUsIFVOU1VCU0NSSUJFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IENvbnRyb2xsZXIgZnJvbSAnLi4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmltcG9ydCB0eXBlIHtcbiAgTWFuYWdlcixcbiAgTWlkZGxld2FyZUFQSSxcbiAgTWlkZGxld2FyZSxcbiAgVW5zdWJzY3JpYmVBY3Rpb24sXG4gIFN1YnNjcmliZUFjdGlvbixcbn0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG50eXBlIEFjdGlvbnMgPSBVbnN1YnNjcmliZUFjdGlvbiB8IFN1YnNjcmliZUFjdGlvbjtcblxuLyoqIEludGVyZmFjZSBoYW5kbGluZyBhIHNpbmdsZSByZXNvdXJjZSBzdWJzY3JpcHRpb24gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3Vic2NyaXB0aW9uIHtcbiAgYWRkKGZyZXF1ZW5jeT86IG51bWJlcik6IHZvaWQ7XG4gIHJlbW92ZShmcmVxdWVuY3k/OiBudW1iZXIpOiBib29sZWFuO1xuICBjbGVhbnVwKCk6IHZvaWQ7XG59XG5cbi8qKiBUaGUgc3RhdGljIGNsYXNzIHRoYXQgY29uc3RydWN0cyBTdWJzY3JpcHRpb24gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3Vic2NyaXB0aW9uQ29uc3RydWN0YWJsZSB7XG4gIG5ldyAoXG4gICAgYWN0aW9uOiBPbWl0PFN1YnNjcmliZUFjdGlvbiwgJ3R5cGUnPixcbiAgICBjb250cm9sbGVyOiBDb250cm9sbGVyLFxuICApOiBTdWJzY3JpcHRpb247XG59XG5cbi8qKiBIYW5kbGVzIHN1YnNjcmlwdGlvbiBhY3Rpb25zIC0+IGZldGNoIG9yIHNldCBhY3Rpb25zXG4gKlxuICogQ29uc3RydWN0b3IgdGFrZXMgYSBTdWJzY3JpcHRpb25Db25zdHJ1Y3RhYmxlIGNsYXNzIHRvIGNvbnRyb2wgaG93XG4gKiBzdWJzY3JpcHRpb25zIGFyZSBoYW5kbGVkLiAoZS5nLiwgcG9sbGluZywgd2Vic29ja2V0cylcbiAqXG4gKiBAc2VlIGh0dHBzOi8vZGF0YWNsaWVudC5pby9kb2NzL2FwaS9TdWJzY3JpcHRpb25NYW5hZ2VyXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFN1YnNjcmlwdGlvbk1hbmFnZXI8XG4gIFMgZXh0ZW5kcyBTdWJzY3JpcHRpb25Db25zdHJ1Y3RhYmxlID0gU3Vic2NyaXB0aW9uQ29uc3RydWN0YWJsZSxcbj4gaW1wbGVtZW50cyBNYW5hZ2VyPEFjdGlvbnM+XG57XG4gIHByb3RlY3RlZCBzdWJzY3JpcHRpb25zOiB7XG4gICAgW2tleTogc3RyaW5nXTogSW5zdGFuY2VUeXBlPFM+O1xuICB9ID0ge307XG5cbiAgcHJvdGVjdGVkIGRlY2xhcmUgcmVhZG9ubHkgU3Vic2NyaXB0aW9uOiBTO1xuICBwcm90ZWN0ZWQgY29udHJvbGxlcjogQ29udHJvbGxlciA9IG5ldyBDb250cm9sbGVyKCk7XG5cbiAgY29uc3RydWN0b3IoU3Vic2NyaXB0aW9uOiBTKSB7XG4gICAgdGhpcy5TdWJzY3JpcHRpb24gPSBTdWJzY3JpcHRpb247XG4gIH1cblxuICBtaWRkbGV3YXJlOiBNaWRkbGV3YXJlID0gY29udHJvbGxlciA9PiB7XG4gICAgdGhpcy5jb250cm9sbGVyID0gY29udHJvbGxlcjtcbiAgICByZXR1cm4gbmV4dCA9PiBhY3Rpb24gPT4ge1xuICAgICAgc3dpdGNoIChhY3Rpb24udHlwZSkge1xuICAgICAgICBjYXNlIFNVQlNDUklCRTpcbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgdGhpcy5oYW5kbGVTdWJzY3JpYmUoYWN0aW9uKTtcbiAgICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgICBjb25zb2xlLmVycm9yKGUpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKCk7XG4gICAgICAgIGNhc2UgVU5TVUJTQ1JJQkU6XG4gICAgICAgICAgdGhpcy5oYW5kbGVVbnN1YnNjcmliZShhY3Rpb24pO1xuICAgICAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoKTtcbiAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICByZXR1cm4gbmV4dChhY3Rpb24pO1xuICAgICAgfVxuICAgIH07XG4gIH07XG5cbiAgLyoqIEVuc3VyZXMgYWxsIHN1YnNjcmlwdGlvbnMgYXJlIGNsZWFuZWQgdXAuICovXG4gIGNsZWFudXAoKSB7XG4gICAgZm9yIChjb25zdCBrZXkgaW4gdGhpcy5zdWJzY3JpcHRpb25zKSB7XG4gICAgICB0aGlzLnN1YnNjcmlwdGlvbnNba2V5XS5jbGVhbnVwKCk7XG4gICAgfVxuICB9XG5cbiAgLyoqIENhbGxlZCB3aGVuIG1pZGRsZXdhcmUgaW50ZXJjZXB0cyAncmRjL3N1YnNjcmliZScgYWN0aW9uLlxuICAgKlxuICAgKi9cbiAgcHJvdGVjdGVkIGhhbmRsZVN1YnNjcmliZShhY3Rpb246IFN1YnNjcmliZUFjdGlvbikge1xuICAgIGNvbnN0IGtleSA9IGFjdGlvbi5rZXk7XG5cbiAgICBpZiAoa2V5IGluIHRoaXMuc3Vic2NyaXB0aW9ucykge1xuICAgICAgY29uc3QgZnJlcXVlbmN5ID0gYWN0aW9uLmVuZHBvaW50LnBvbGxGcmVxdWVuY3k7XG4gICAgICB0aGlzLnN1YnNjcmlwdGlvbnNba2V5XS5hZGQoZnJlcXVlbmN5KTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5zdWJzY3JpcHRpb25zW2tleV0gPSBuZXcgdGhpcy5TdWJzY3JpcHRpb24oXG4gICAgICAgIGFjdGlvbixcbiAgICAgICAgdGhpcy5jb250cm9sbGVyLFxuICAgICAgKSBhcyBJbnN0YW5jZVR5cGU8Uz47XG4gICAgfVxuICB9XG5cbiAgLyoqIENhbGxlZCB3aGVuIG1pZGRsZXdhcmUgaW50ZXJjZXB0cyAncmRjL3Vuc3Vic2NyaWJlJyBhY3Rpb24uXG4gICAqXG4gICAqL1xuICBwcm90ZWN0ZWQgaGFuZGxlVW5zdWJzY3JpYmUoYWN0aW9uOiBVbnN1YnNjcmliZUFjdGlvbikge1xuICAgIGNvbnN0IGtleSA9IGFjdGlvbi5rZXk7XG5cbiAgICAvKiBpc3RhbmJ1bCBpZ25vcmUgZWxzZSAqL1xuICAgIGlmIChrZXkgaW4gdGhpcy5zdWJzY3JpcHRpb25zKSB7XG4gICAgICBjb25zdCBmcmVxdWVuY3kgPSBhY3Rpb24uZW5kcG9pbnQucG9sbEZyZXF1ZW5jeTtcbiAgICAgIGNvbnN0IGVtcHR5ID0gdGhpcy5zdWJzY3JpcHRpb25zW2tleV0ucmVtb3ZlKGZyZXF1ZW5jeSk7XG4gICAgICBpZiAoZW1wdHkpIHtcbiAgICAgICAgZGVsZXRlIHRoaXMuc3Vic2NyaXB0aW9uc1trZXldO1xuICAgICAgfVxuICAgIH0gZWxzZSBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJykge1xuICAgICAgY29uc29sZS5lcnJvcihgTWlzbWF0Y2hlZCB1bnN1YnNjcmliZTogJHtrZXl9IGlzIG5vdCBzdWJzY3JpYmVkYCk7XG4gICAgfVxuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFNBQVMsRUFBRUMsV0FBVyxRQUFRLG1CQUFtQjtBQUMxRCxPQUFPQyxVQUFVLE1BQU0s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
78
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVUJTQ1JJQkUiLCJVTlNVQlNDUklCRSIsIkNvbnRyb2xsZXIiLCJTdWJzY3JpcHRpb25NYW5hZ2VyIiwiY29uc3RydWN0b3IiLCJTdWJzY3JpcHRpb24iLCJzdWJzY3JpcHRpb25zIiwiY29udHJvbGxlciIsIm1pZGRsZXdhcmUiLCJuZXh0IiwiYWN0aW9uIiwidHlwZSIsImhhbmRsZVN1YnNjcmliZSIsImUiLCJjb25zb2xlIiwiZXJyb3IiLCJQcm9taXNlIiwicmVzb2x2ZSIsImhhbmRsZVVuc3Vic2NyaWJlIiwiY2xlYW51cCIsImtleSIsImZyZXF1ZW5jeSIsImVuZHBvaW50IiwicG9sbEZyZXF1ZW5jeSIsImFkZCIsImVtcHR5IiwicmVtb3ZlIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL21hbmFnZXIvU3Vic2NyaXB0aW9uTWFuYWdlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTVUJTQ1JJQkUsIFVOU1VCU0NSSUJFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IENvbnRyb2xsZXIgZnJvbSAnLi4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmltcG9ydCB0eXBlIHtcbiAgTWFuYWdlcixcbiAgTWlkZGxld2FyZUFQSSxcbiAgTWlkZGxld2FyZSxcbiAgVW5zdWJzY3JpYmVBY3Rpb24sXG4gIFN1YnNjcmliZUFjdGlvbixcbn0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG50eXBlIEFjdGlvbnMgPSBVbnN1YnNjcmliZUFjdGlvbiB8IFN1YnNjcmliZUFjdGlvbjtcblxuLyoqIEludGVyZmFjZSBoYW5kbGluZyBhIHNpbmdsZSByZXNvdXJjZSBzdWJzY3JpcHRpb24gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3Vic2NyaXB0aW9uIHtcbiAgYWRkKGZyZXF1ZW5jeT86IG51bWJlcik6IHZvaWQ7XG4gIHJlbW92ZShmcmVxdWVuY3k/OiBudW1iZXIpOiBib29sZWFuO1xuICBjbGVhbnVwKCk6IHZvaWQ7XG59XG5cbi8qKiBUaGUgc3RhdGljIGNsYXNzIHRoYXQgY29uc3RydWN0cyBTdWJzY3JpcHRpb24gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3Vic2NyaXB0aW9uQ29uc3RydWN0YWJsZSB7XG4gIG5ldyAoXG4gICAgYWN0aW9uOiBPbWl0PFN1YnNjcmliZUFjdGlvbiwgJ3R5cGUnPixcbiAgICBjb250cm9sbGVyOiBDb250cm9sbGVyLFxuICApOiBTdWJzY3JpcHRpb247XG59XG5cbi8qKiBIYW5kbGVzIHN1YnNjcmlwdGlvbiBhY3Rpb25zIC0+IGZldGNoIG9yIHNldCBhY3Rpb25zXG4gKlxuICogQ29uc3RydWN0b3IgdGFrZXMgYSBTdWJzY3JpcHRpb25Db25zdHJ1Y3RhYmxlIGNsYXNzIHRvIGNvbnRyb2wgaG93XG4gKiBzdWJzY3JpcHRpb25zIGFyZSBoYW5kbGVkLiAoZS5nLiwgcG9sbGluZywgd2Vic29ja2V0cylcbiAqXG4gKiBAc2VlIGh0dHBzOi8vZGF0YWNsaWVudC5pby9kb2NzL2FwaS9TdWJzY3JpcHRpb25NYW5hZ2VyXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFN1YnNjcmlwdGlvbk1hbmFnZXI8XG4gIFMgZXh0ZW5kcyBTdWJzY3JpcHRpb25Db25zdHJ1Y3RhYmxlID0gU3Vic2NyaXB0aW9uQ29uc3RydWN0YWJsZSxcbj4gaW1wbGVtZW50cyBNYW5hZ2VyPEFjdGlvbnM+XG57XG4gIHByb3RlY3RlZCBzdWJzY3JpcHRpb25zOiB7XG4gICAgW2tleTogc3RyaW5nXTogSW5zdGFuY2VUeXBlPFM+O1xuICB9ID0ge307XG5cbiAgZGVjbGFyZSBwcm90ZWN0ZWQgcmVhZG9ubHkgU3Vic2NyaXB0aW9uOiBTO1xuICBwcm90ZWN0ZWQgY29udHJvbGxlcjogQ29udHJvbGxlciA9IG5ldyBDb250cm9sbGVyKCk7XG5cbiAgY29uc3RydWN0b3IoU3Vic2NyaXB0aW9uOiBTKSB7XG4gICAgdGhpcy5TdWJzY3JpcHRpb24gPSBTdWJzY3JpcHRpb247XG4gIH1cblxuICBtaWRkbGV3YXJlOiBNaWRkbGV3YXJlID0gY29udHJvbGxlciA9PiB7XG4gICAgdGhpcy5jb250cm9sbGVyID0gY29udHJvbGxlcjtcbiAgICByZXR1cm4gbmV4dCA9PiBhY3Rpb24gPT4ge1xuICAgICAgc3dpdGNoIChhY3Rpb24udHlwZSkge1xuICAgICAgICBjYXNlIFNVQlNDUklCRTpcbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgdGhpcy5oYW5kbGVTdWJzY3JpYmUoYWN0aW9uKTtcbiAgICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgICBjb25zb2xlLmVycm9yKGUpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKCk7XG4gICAgICAgIGNhc2UgVU5TVUJTQ1JJQkU6XG4gICAgICAgICAgdGhpcy5oYW5kbGVVbnN1YnNjcmliZShhY3Rpb24pO1xuICAgICAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoKTtcbiAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICByZXR1cm4gbmV4dChhY3Rpb24pO1xuICAgICAgfVxuICAgIH07XG4gIH07XG5cbiAgLyoqIEVuc3VyZXMgYWxsIHN1YnNjcmlwdGlvbnMgYXJlIGNsZWFuZWQgdXAuICovXG4gIGNsZWFudXAoKSB7XG4gICAgZm9yIChjb25zdCBrZXkgaW4gdGhpcy5zdWJzY3JpcHRpb25zKSB7XG4gICAgICB0aGlzLnN1YnNjcmlwdGlvbnNba2V5XS5jbGVhbnVwKCk7XG4gICAgfVxuICB9XG5cbiAgLyoqIENhbGxlZCB3aGVuIG1pZGRsZXdhcmUgaW50ZXJjZXB0cyAncmRjL3N1YnNjcmliZScgYWN0aW9uLlxuICAgKlxuICAgKi9cbiAgcHJvdGVjdGVkIGhhbmRsZVN1YnNjcmliZShhY3Rpb246IFN1YnNjcmliZUFjdGlvbikge1xuICAgIGNvbnN0IGtleSA9IGFjdGlvbi5rZXk7XG5cbiAgICBpZiAoa2V5IGluIHRoaXMuc3Vic2NyaXB0aW9ucykge1xuICAgICAgY29uc3QgZnJlcXVlbmN5ID0gYWN0aW9uLmVuZHBvaW50LnBvbGxGcmVxdWVuY3k7XG4gICAgICB0aGlzLnN1YnNjcmlwdGlvbnNba2V5XS5hZGQoZnJlcXVlbmN5KTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5zdWJzY3JpcHRpb25zW2tleV0gPSBuZXcgdGhpcy5TdWJzY3JpcHRpb24oXG4gICAgICAgIGFjdGlvbixcbiAgICAgICAgdGhpcy5jb250cm9sbGVyLFxuICAgICAgKSBhcyBJbnN0YW5jZVR5cGU8Uz47XG4gICAgfVxuICB9XG5cbiAgLyoqIENhbGxlZCB3aGVuIG1pZGRsZXdhcmUgaW50ZXJjZXB0cyAncmRjL3Vuc3Vic2NyaWJlJyBhY3Rpb24uXG4gICAqXG4gICAqL1xuICBwcm90ZWN0ZWQgaGFuZGxlVW5zdWJzY3JpYmUoYWN0aW9uOiBVbnN1YnNjcmliZUFjdGlvbikge1xuICAgIGNvbnN0IGtleSA9IGFjdGlvbi5rZXk7XG5cbiAgICAvKiBpc3RhbmJ1bCBpZ25vcmUgZWxzZSAqL1xuICAgIGlmIChrZXkgaW4gdGhpcy5zdWJzY3JpcHRpb25zKSB7XG4gICAgICBjb25zdCBmcmVxdWVuY3kgPSBhY3Rpb24uZW5kcG9pbnQucG9sbEZyZXF1ZW5jeTtcbiAgICAgIGNvbnN0IGVtcHR5ID0gdGhpcy5zdWJzY3JpcHRpb25zW2tleV0ucmVtb3ZlKGZyZXF1ZW5jeSk7XG4gICAgICBpZiAoZW1wdHkpIHtcbiAgICAgICAgZGVsZXRlIHRoaXMuc3Vic2NyaXB0aW9uc1trZXldO1xuICAgICAgfVxuICAgIH0gZWxzZSBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJykge1xuICAgICAgY29uc29sZS5lcnJvcihgTWlzbWF0Y2hlZCB1bnN1YnNjcmliZTogJHtrZXl9IGlzIG5vdCBzdWJzY3JpYmVkYCk7XG4gICAgfVxuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFNBQVMsRUFBRUMsV0FBVyxRQUFRLG1CQUFtQjtBQUMxRCxPQUFPQyxVQUFVLE1BQU0s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
@@ -2,7 +2,7 @@ import Controller from '../../controller/Controller.js';
2
2
  import type { State, SetAction } from '../../types.js';
3
3
  export declare function setReducer(state: State<unknown>, action: SetAction, controller: Controller): State<unknown> | {
4
4
  entities: {
5
- [x: string]: any;
5
+ [x: string]: /*elided*/ any;
6
6
  };
7
7
  endpoints: {
8
8
  readonly [key: string]: unknown;
@@ -19,7 +19,7 @@ export declare function setReducer(state: State<unknown>, action: SetAction, con
19
19
  };
20
20
  };
21
21
  entityMeta: import("packages/normalizr/lib/types.js").EntitiesToMeta<{
22
- [x: string]: any;
22
+ [x: string]: /*elided*/ any;
23
23
  }>;
24
24
  optimistic: (import("../../actions.js").SetResponseAction | import("../../actions.js").OptimisticAction<import("@data-client/normalizr").EndpointInterface<import("@data-client/normalizr").FetchFunction, import("@data-client/normalizr").Schema | undefined, boolean | undefined> & {
25
25
  update?: import("../../index.js").EndpointUpdateFunction<import("@data-client/normalizr").EndpointInterface>;
@@ -2,7 +2,7 @@ import type Controller from '../../controller/Controller.js';
2
2
  import type { State, SetResponseAction, OptimisticAction } from '../../types.js';
3
3
  export declare function setResponseReducer(state: State<unknown>, action: OptimisticAction | SetResponseAction, controller: Controller): State<unknown> | {
4
4
  entities: {
5
- [x: string]: any;
5
+ [x: string]: /*elided*/ any;
6
6
  };
7
7
  endpoints: Record<string, unknown>;
8
8
  indexes: import("@data-client/normalizr").NormalizedIndex;
@@ -21,7 +21,7 @@ export declare function setResponseReducer(state: State<unknown>, action: Optimi
21
21
  };
22
22
  };
23
23
  entityMeta: import("packages/normalizr/lib/types.js").EntitiesToMeta<{
24
- [x: string]: any;
24
+ [x: string]: /*elided*/ any;
25
25
  }>;
26
26
  optimistic: (SetResponseAction | OptimisticAction<import("@data-client/normalizr").EndpointInterface<import("@data-client/normalizr").FetchFunction, import("@data-client/normalizr").Schema | undefined, boolean | undefined> & {
27
27
  update?: import("../../index.js").EndpointUpdateFunction<import("@data-client/normalizr").EndpointInterface>;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@data-client/core",
3
- "version": "0.14.16",
3
+ "version": "0.14.18",
4
4
  "description": "Async State Management without the Management. REST, GraphQL, SSE, Websockets, Fetch",
5
5
  "sideEffects": false,
6
6
  "main": "dist/index.js",
@@ -126,6 +126,9 @@
126
126
  },
127
127
  "devDependencies": {
128
128
  "@anansi/browserslist-config": "^1.4.2",
129
- "@types/node": "^22.0.0"
129
+ "@data-client/endpoint": "workspace:*",
130
+ "@types/jest": "^29.5.14",
131
+ "@types/node": "^22.0.0",
132
+ "rollup-plugins": "workspace:*"
130
133
  }
131
134
  }
@@ -464,7 +464,7 @@ export default class Controller<
464
464
  }
465
465
 
466
466
  // second argument is false if any entities are missing
467
- // eslint-disable-next-line prefer-const
467
+
468
468
  const { data, paths } = this.memo.denormalize(
469
469
  schema,
470
470
  input,
@@ -9,9 +9,9 @@ export function createSubscription<E extends EndpointInterface>(
9
9
  ): SubscribeAction<E> {
10
10
  return {
11
11
  type: SUBSCRIBE,
12
- endpoint,
13
- args,
14
12
  key: endpoint.key(...args),
13
+ args,
14
+ endpoint,
15
15
  };
16
16
  }
17
17
 
@@ -1,4 +1,3 @@
1
- /* eslint-disable no-inner-declarations */
2
1
  import type { DevToolsConfig } from './devtoolsTypes.js';
3
2
  import type { Controller, EndpointInterface } from '../index.js';
4
3
  import type { Middleware } from '../middlewareTypes.js';
@@ -90,10 +89,10 @@ if (process.env.NODE_ENV !== 'production') {
90
89
  */
91
90
  export default class DevToolsManager implements Manager {
92
91
  declare middleware: Middleware;
93
- protected declare devTools: undefined | any;
92
+ declare protected devTools: undefined | any;
94
93
  protected started = false;
95
94
  protected actions: [ActionTypes, State<unknown>][] = [];
96
- protected declare controller: Controller;
95
+ declare protected controller: Controller;
97
96
  declare skipLogging?: (action: ActionTypes) => boolean;
98
97
  maxBufferLength = 100;
99
98
 
@@ -14,16 +14,16 @@ import type { SubscribeAction } from '../types.js';
14
14
  * @see https://dataclient.io/docs/api/PollingSubscription
15
15
  */
16
16
  export default class PollingSubscription implements Subscription {
17
- protected declare readonly endpoint: EndpointInterface;
18
- protected declare readonly args: readonly any[];
19
- protected declare readonly key: string;
20
- protected declare frequency: number;
17
+ declare protected readonly endpoint: EndpointInterface;
18
+ declare protected readonly args: readonly any[];
19
+ declare protected readonly key: string;
20
+ declare protected frequency: number;
21
21
  protected frequencyHistogram: Map<number, number> = new Map();
22
- protected declare controller: Controller;
23
- protected declare intervalId?: ReturnType<typeof setInterval>;
24
- protected declare lastIntervalId?: ReturnType<typeof setInterval>;
25
- protected declare startId?: ReturnType<typeof setTimeout>;
26
- private declare connectionListener: ConnectionListener;
22
+ declare protected controller: Controller;
23
+ declare protected intervalId?: ReturnType<typeof setInterval>;
24
+ declare protected lastIntervalId?: ReturnType<typeof setInterval>;
25
+ declare protected startId?: ReturnType<typeof setTimeout>;
26
+ declare private connectionListener: ConnectionListener;
27
27
 
28
28
  constructor(
29
29
  action: Omit<SubscribeAction, 'type'>,
@@ -40,7 +40,7 @@ export default class SubscriptionManager<
40
40
  [key: string]: InstanceType<S>;
41
41
  } = {};
42
42
 
43
- protected declare readonly Subscription: S;
43
+ declare protected readonly Subscription: S;
44
44
  protected controller: Controller = new Controller();
45
45
 
46
46
  constructor(Subscription: S) {