New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@data-client/core

Package Overview
Dependencies
Maintainers
0
Versions
36
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@data-client/core - npm Package Compare versions

Comparing version 0.14.1 to 0.14.2

src/manager/__tests__/applyManager.ts

64

dist/index.js

@@ -70,5 +70,5 @@ 'use strict';

type: OPTIMISTIC_TYPE,
key: endpoint.key(...args),
args,
endpoint,
args,
key: endpoint.key(...args),
meta: createMeta((_endpoint$dataExpiryL2 = endpoint.dataExpiryLength) != null ? _endpoint$dataExpiryL2 : 60000, fetchedAt)

@@ -85,11 +85,4 @@ };

};
} else {
// If 'fetch' action reaches the reducer there are no middlewares installed to handle it
/* istanbul ignore next */
if (process.env.NODE_ENV !== 'production') {
console.warn('Fetch appears unhandled - you are likely missing the NetworkManager middleware');
console.warn('See https://dataclient.io/docs/guides/redux for hooking up redux');
}
return state;
}
return state;
}

@@ -349,5 +342,5 @@

type: UNSUBSCRIBE_TYPE,
endpoint,
key: endpoint.key(...args),
args,
key: endpoint.key(...args)
endpoint
};

@@ -376,6 +369,6 @@ }

type: SET_RESPONSE_TYPE,
endpoint,
key: endpoint.key(...args),
response,
args: args.map(ensurePojo$1),
key: endpoint.key(...args),
endpoint,
meta: createMeta(expiryLength, fetchedAt),

@@ -393,5 +386,5 @@ error

type: SET_TYPE,
schema,
value,
args: args.map(ensurePojo$1),
schema,
meta: createMeta(60000, fetchedAt)

@@ -443,5 +436,5 @@ };

type: FETCH_TYPE,
key: endpoint.key(...args),
args,
endpoint,
args,
key: endpoint.key(...args),
meta

@@ -1072,3 +1065,8 @@ };

function applyManager(managers, controller) {
return managers.map(manager => {
/* istanbul ignore next */
if (process.env.NODE_ENV !== 'production' && !managers.find(mgr => mgr instanceof NetworkManager)) {
console.warn('NetworkManager not found; this is a required manager.');
console.warn('See https://dataclient.io/docs/guides/redux for hooking up redux');
}
return managers.map((manager, i) => {
const middleware = manager.getMiddleware();

@@ -1079,4 +1077,6 @@ return ({

}) => {
controller.dispatch = dispatch;
controller.getState = getState;
if (i === 0) {
controller.dispatch = dispatch;
controller.getState = getState;
}
// controller is a superset of the middleware API

@@ -1388,2 +1388,23 @@ return middleware(controller);

autoPause: true,
features: {
pause: true,
// start/pause recording of dispatched actions
lock: true,
// lock/unlock dispatching actions and side effects
persist: false,
// persist states on page reloading
export: true,
// export history of actions in a file
import: 'custom',
// import history of actions from a file
jump: true,
// jump back and forth (time travelling)
skip: true,
// skip (cancel) actions
reorder: true,
// drag and drop actions in the history list
dispatch: false,
// dispatch custom actions or action creators
test: false // generate tests for the selected actions
},
actionSanitizer: action => {

@@ -1464,2 +1485,3 @@ if (!('endpoint' in action)) return action;

return next => action => {
const shouldSkip = skipLogging == null ? void 0 : skipLogging(action);
const ret = next(action);

@@ -1473,3 +1495,3 @@ if (this.started) {

ret.then(() => {
if (skipLogging != null && skipLogging(action)) return;
if (shouldSkip) return;
this.handleAction(action, state.optimistic.reduce(reducer, state));

@@ -1476,0 +1498,0 @@ });

@@ -1,1 +0,1 @@

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@data-client/normalizr")):"function"==typeof define&&define.amd?define(["exports","@data-client/normalizr"],t):t(((e="undefined"!=typeof globalThis?globalThis:e||self).RDC=e.RDC||{},e.RDC.Core={}),e.normalizr)}(this,(function(e,t){"use strict";function s(e,t){const s=Date.now();return{fetchedAt:null!=t?t:s,date:s,expiresAt:s+e}}const i="rdc/fetch",n="rdc/set",r="rdc/setresponse",o="rdc/optimistic",a="rdc/reset",c="rdc/subscribe",l="rdc/unsubscribe",h="rdc/invalidate",d="rdc/invalidateall",u="rdc/expireall",p="rdc/gc";var f=Object.freeze({__proto__:null,FETCH_TYPE:i,SET_TYPE:n,SET_RESPONSE_TYPE:r,OPTIMISTIC_TYPE:o,RESET_TYPE:a,SUBSCRIBE_TYPE:c,UNSUBSCRIBE_TYPE:l,INVALIDATE_TYPE:h,INVALIDATEALL_TYPE:d,EXPIREALL_TYPE:u,GC_TYPE:p});function g(e,t,i){var n;return{type:o,endpoint:e,args:t,key:e.key(...t),meta:s(null!=(n=e.dataExpiryLength)?n:6e4,i)}}class y extends Error{}function m(e,t,s){return"AbortError"===s.name?Object.assign({},e,{optimistic:v(e,t)}):Object.assign({},e,{meta:Object.assign({},e.meta,{[t.key]:{date:t.meta.date,error:s,expiresAt:t.meta.expiresAt,errorPolicy:null==t.endpoint.errorPolicy?void 0:t.endpoint.errorPolicy(s)}}),optimistic:v(e,t)})}function v(e,t){return e.optimistic.filter((e=>e.key!==t.key||(e.type===o?e.meta.fetchedAt!==t.meta.fetchedAt:e.meta.date>t.meta.date)))}function E(e){return function(s,c){switch(s||(s=b),c.type){case p:return c.entities.forEach((([e,t])=>{var i,n;null==(i=s.entities[e])||delete i[t],null==(n=s.entityMeta[e])||delete n[t]})),c.endpoints.forEach((e=>{delete s.endpoints[e],delete s.meta[e]})),s;case i:return function(e,t){if(t.endpoint.getOptimisticResponse&&t.endpoint.sideEffect){const s=g(t.endpoint,t.args,t.meta.fetchedAt);return Object.assign({},e,{optimistic:[...e.optimistic,s]})}return e}(s,c);case o:case r:return function(e,s,i){if(s.error)return m(e,s,s.response);try{var n;let r;if(s.type===o){if(!s.endpoint.getOptimisticResponse)return e;try{r=s.endpoint.getOptimisticResponse.call(s.endpoint,i.snapshot(e,s.meta.fetchedAt),...s.args)}catch(t){if(t.constructor===y)return e;throw t}}else r=s.response;const{result:a,entities:c,indexes:l,entityMeta:h}=t.normalize(s.endpoint.schema,r,s.args,e,s.meta),d=Object.assign({},e.endpoints,{[s.key]:a});try{if(s.endpoint.update){const e=s.endpoint.update(a,...s.args);Object.keys(e).forEach((t=>{d[t]=e[t](d[t])}))}}catch(e){console.error(`The following error occured during Endpoint.update() for ${s.key}`),console.error(e)}return{entities:c,indexes:l,endpoints:d,entityMeta:h,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}}),optimistic:v(e,s),lastReset:e.lastReset}}catch(t){return"object"==typeof t&&(t.message=`Error processing ${s.key}\n\nFull Schema: ${JSON.stringify(s.endpoint.schema,void 0,2)}\n\nError:\n${t.message}`,"response"in s&&(t.response=s.response),t.status=400),m(e,s,t)}}(s,c,e);case n:return function(e,s,i){let n;if("function"==typeof s.value){const t=i.get(s.schema,...s.args,e);if(void 0===t)return e;n=s.value(t)}else n=s.value;try{const{entities:i,indexes:r,entityMeta:o}=t.normalize(s.schema,n,s.args,e,s.meta);return{entities:i,indexes:r,endpoints:e.endpoints,entityMeta:o,meta:e.meta,optimistic:e.optimistic,lastReset:e.lastReset}}catch(t){return e}}(s,c,e);case d:case h:return function(e,t){const s=Object.assign({},e.endpoints),i=Object.assign({},e.meta),n=e=>{delete s[e];const t=Object.assign({},i[e],{expiresAt:0,invalidated:!0});delete t.error,i[e]=t};return t.type===h?n(t.key):Object.keys(s).forEach((e=>{t.testKey(e)&&n(e)})),Object.assign({},e,{endpoints:s,meta:i})}(s,c);case u:return function(e,t){const s=Object.assign({},e.meta);return Object.keys(s).forEach((e=>{t.testKey(e)&&(s[e]=Object.assign({},s[e],{expiresAt:1}))})),Object.assign({},e,{meta:s})}(s,c);case a:return Object.assign({},b,{lastReset:c.date});default:return s}}}const b={entities:{},indexes:{},endpoints:{},meta:{},entityMeta:{},optimistic:[],lastReset:0};var L=Object.freeze({__proto__:null,MemoCache:t.MemoCache,INVALID:t.INVALID,initialState:b});function O(e,{args:t}){return{type:c,endpoint:e,args:t,key:e.key(...t)}}function S(e,{args:t}){return{type:l,endpoint:e,args:t,key:e.key(...t)}}var I="undefined"!=typeof FormData?e=>e instanceof FormData?Object.fromEntries(e.entries()):e:e=>e;function w(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,endpoint:e,response:n,args:t.map(I),key:e.key(...t),meta:s(l,i),error:o}}function x(e,{args:t,fetchedAt:i,value:r}){return{type:n,schema:e,value:r,args:t.map(I),meta:s(6e4,i)}}function A(){return{type:a,date:Date.now()}}function k(e){return{type:d,testKey:e}}function j(e,{args:t}){return{type:h,key:e.key(...t)}}function _(e,{args:t}){let s=0,n=0;const r=new Promise(((e,t)=>{[s,n]=[e,t]})),o={fetchedAt:Date.now(),resolve:s,reject:n,promise:r};return{type:i,endpoint:e,args:t,key:e.key(...t),meta:o}}function R(e){return{type:u,testKey:e}}var T=Object.freeze({__proto__:null,createSubscription:O,createUnsubscription:S,createSetResponse:w,createSet:x,createReset:A,createOptimistic:g,createMeta:s,createInvalidateAll:k,createInvalidate:j,createFetch:_,createExpireAll:R});function P(e,t){return e.meta[t]}const q=e=>{throw new Error("Dispatching while constructing your middleware is not allowed. Other middleware would not be applied to this dispatch.")},D=()=>b;class M{constructor({dispatch:e=q,getState:s=D,memo:i=new t.MemoCache}={}){this.fetch=(e,...s)=>{const i=_(e,{args:s});return this.dispatch(i),e.schema?i.meta.promise.then((i=>t.denormalize(e.schema,i,{},s))):i.meta.promise},this.fetchIfStale=(e,...s)=>{const{data:i,expiresAt:n,expiryStatus:r}=this.getResponse(e,...s,this.getState());return r!==t.ExpiryStatus.Invalid&&Date.now()<=n?i:this.fetch(e,...s)},this.invalidate=(e,...t)=>null!==t[0]?this.dispatch(j(e,{args:t})):Promise.resolve(),this.invalidateAll=e=>this.dispatch(k((t=>e.testKey(t)))),this.expireAll=e=>this.dispatch(R((t=>e.testKey(t)))),this.resetEntireStore=()=>this.dispatch(A()),this.setResponse=(e,...t)=>{const s=t[t.length-1],i=w(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=w(e,{args:t.slice(0,t.length-1),response:s,error:!0});return this.dispatch(i)},this.resolve=(e,t)=>this.dispatch(w(e,t)),this.subscribe=(e,...t)=>null!==t[0]?this.dispatch(O(e,{args:t})):Promise.resolve(),this.unsubscribe=(e,...t)=>null!==t[0]?this.dispatch(S(e,{args:t})):Promise.resolve(),this.snapshot=(e,t)=>new H(this,e,t),this.dispatch=e,this.getState=s,this.memo=i}set(e,...t){const s=t[t.length-1],i=x(e,{args:t.slice(0,t.length-1),value:s});return this.dispatch(i)}getError(e,...t){if(null===t[0])return;const s=t[t.length-1],i=t.slice(0,t.length-1),n=e.key(...i),r=P(s,n);return void 0===s.endpoints[n]||"soft"!==(null==r?void 0:r.errorPolicy)?null==r?void 0:r.error:void 0}getResponse(e,...s){const i=s[s.length-1],n=s.slice(0,s.length-1).map(I),r=1!==n.length||null!==n[0],o=r?e.key(...n):"",a=r?i.endpoints[o]:void 0,c=e.schema,l=P(i,o);let h=null==l?void 0:l.expiresAt;const d=void 0===a&&void 0!==c,u=d?this.memo.buildQueryKey(c,n,i.entities,i.indexes,o):a;if(!r)return{data:u,expiryStatus:t.ExpiryStatus.Valid,expiresAt:1/0};let p=!1;if(d)p=!t.validateQueryKey(u);else if(!c||!C(c))return{data:a,expiryStatus:null!=l&&l.invalidated?t.ExpiryStatus.Invalid:a&&!e.invalidIfStale?t.ExpiryStatus.Valid:t.ExpiryStatus.InvalidIfStale,expiresAt:h||0};const{data:f,paths:g}=this.memo.denormalize(c,u,i.entities,n);return!h&&p&&(h=1),this.getSchemaResponse(f,g,i.entityMeta,h,e.invalidIfStale||p,l)}get(e,...t){const s=t[t.length-1],i=t.slice(0,t.length-1).map(I);return this.memo.query(e,i,s.entities,s.indexes)}getSchemaResponse(e,s,i,n,r,o={}){const a="symbol"==typeof e;n||(n=function(e,t){let s=1/0;for(const{pk:n,key:r}of e){var i;const e=null==(i=t[r])||null==(i=i[n])?void 0:i.expiresAt;e<s&&(s=e)}return s}(s,i));return{data:e,expiryStatus:null!=o&&o.invalidated||a&&(null==o||!o.error)?t.ExpiryStatus.Invalid:a||r?t.ExpiryStatus.InvalidIfStale:t.ExpiryStatus.Valid,expiresAt:n}}}function C(e){if(t.isEntity(e))return!0;if(Array.isArray(e))return 0!==e.length&&C(e[0]);if(e&&("object"==typeof e||"function"==typeof e)){const t="schema"in e?e.schema:e;return"function"==typeof t?C(t):Object.values(t).some((e=>C(e)))}return!1}class H{constructor(e,t,s=0){this.state=void 0,this.controller=void 0,this.fetchedAt=void 0,this.abort=H.abort,this.state=t,this.controller=e,this.fetchedAt=s}getResponse(e,...t){return this.controller.getResponse(e,...t,this.state)}getError(e,...t){return this.controller.getError(e,...t,this.state)}get(e,...t){return this.controller.get(e,...t,this.state)}}H.abort=new y;class N extends Error{constructor(){super("Aborted due to RESET"),this.name="ResetError"}}class F{isOnline(){return void 0===navigator.onLine||navigator.onLine}addOnlineListener(e){addEventListener("online",e)}removeOnlineListener(e){removeEventListener("online",e)}addOfflineListener(e){addEventListener("offline",e)}removeOfflineListener(e){removeEventListener("offline",e)}}class z{isOnline(){return!0}addOnlineListener(){}removeOnlineListener(){}addOfflineListener(){}removeOfflineListener(){}}let Y;Y="undefined"!=typeof navigator&&"function"==typeof addEventListener?F:z;var V=Y;let B={};Object.hasOwn=Object.hasOwn||function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},Object.defineProperty(e,"ExpiryStatus",{enumerable:!0,get:function(){return t.ExpiryStatus}}),e.Controller=M,e.DefaultConnectionListener=V,e.DevToolsManager=class{constructor(e,t){this.started=!1,this.actions=[],this.maxBufferLength=100,this.devTools="undefined"!=typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__&&window.__REDUX_DEVTOOLS_EXTENSION__.connect(Object.assign({},B,e)),null!=e&&e.maxAge&&(this.maxBufferLength=2*e.maxAge),this.devTools?this.middleware=e=>{this.controller=e;const s=E(e);let i=e.getState();return n=>r=>{const o=n(r);return i=this.started?s(i,r):e.getState(),o.then((()=>{null!=t&&t(r)||this.handleAction(r,i.optimistic.reduce(s,i))})),o}}:this.middleware=()=>e=>t=>e(t)}handleAction(e,t){this.started?this.devTools.send(e,t):(this.actions.length>this.maxBufferLength&&(this.actions=this.actions.slice(this.maxBufferLength/2)),this.actions.push([e,t]))}init(e){this.devTools&&this.devTools.init(e)}cleanup(){}getMiddleware(){return this.middleware}},e.LogoutManager=class{constructor({handleLogout:e,shouldLogout:t}={}){e&&(this.handleLogout=e),t&&(this.shouldLogout=t),this.middleware=e=>t=>async s=>{await t(s),s.type===r&&s.error&&this.shouldLogout(s.response)&&this.handleLogout(e)}}cleanup(){}getMiddleware(){return this.middleware}shouldLogout(e){return 401===e.status}handleLogout(e){e.resetEntireStore()}},e.NetworkManager=class{constructor(e=6e4,t=1e3){this.fetched=Object.create(null),this.resolvers={},this.rejectors={},this.fetchedAt={},this.controller=new M,this.dataExpiryLength=e,this.errorExpiryLength=t,this.middleware=e=>(this.controller=e,t=>s=>{switch(s.type){case i:return this.handleFetch(s),void 0!==s.endpoint.getOptimisticResponse&&s.endpoint.sideEffect?t(s):Promise.resolve();case r:return t(s).then((()=>{if(s.key in this.fetched){var t;const i=null==(t=e.getState().meta[s.key])?void 0:t.error;i?this.handleSet(w(s.endpoint,{args:s.args,response:i,fetchedAt:s.meta.fetchedAt,error:!0})):this.handleSet(s)}}));case a:{const e=Object.assign({},this.rejectors);return this.clearAll(),t(s).then((()=>{for(const t in e)e[t](new N)}))}default:return t(s)}})}skipLogging(e){return e.type===i&&e.key in this.fetched}init(){delete this.cleanupDate}cleanup(){this.cleanupDate=Date.now()}allSettled(){const e=Object.values(this.fetched);if(e.length)return Promise.allSettled(e)}clearAll(){for(const e in this.rejectors)this.clear(e)}clear(e){this.fetched[e].catch((()=>{})),delete this.resolvers[e],delete this.rejectors[e],delete this.fetched[e],delete this.fetchedAt[e]}getLastReset(){return this.cleanupDate?this.cleanupDate:this.controller.getState().lastReset}handleFetch(e){const{resolve:t,reject:s,fetchedAt:i}=e.meta,n=!e.endpoint.sideEffect,r=()=>{let r=e.endpoint(...e.args);return n||(r=(e=>e.then((e=>(t(e),e))).catch((e=>{throw s(e),e})))(r)),r=r.then((t=>{let s=this.getLastReset();return i>=s&&this.controller.resolve(e.endpoint,{args:e.args,response:t,fetchedAt:i}),t})).catch((t=>{const s=this.getLastReset();throw i>=s&&this.controller.resolve(e.endpoint,{args:e.args,response:t,fetchedAt:i,error:!0}),t})),r};return n?this.throttle(e.key,r,i).then((e=>t(e))).catch((e=>s(e))):r().catch((()=>{}))}handleSet(e){if(e.key in this.fetched){let t;t=e.error?this.rejectors[e.key]:this.resolvers[e.key],t(e.response),this.clear(e.key)}}getMiddleware(){return this.middleware}throttle(e,t,s){const i=this.getLastReset();return e in this.fetched&&this.fetchedAt[e]>i||(this.fetched[e]=new Promise(((t,s)=>{this.resolvers[e]=t,this.rejectors[e]=s})),this.fetchedAt[e]=s,this.idleCallback((()=>{t().catch((()=>null))}),{timeout:500})),this.fetched[e]}idleCallback(e,t){e()}},e.PollingSubscription=class{constructor(e,t,s){if(this.frequencyHistogram=new Map,this.offlineListener=()=>{this.cleanup(),this.connectionListener.addOnlineListener(this.onlineListener)},this.onlineListener=()=>{this.connectionListener.removeOnlineListener(this.onlineListener);const e=Date.now();this.startId=setTimeout((()=>{this.startId&&(delete this.startId,this.update(),this.run())}),Math.max(0,this.lastFetchTime()-e+this.frequency)),this.connectionListener.addOfflineListener(this.offlineListener)},void 0===e.endpoint.pollFrequency)throw new Error("frequency needed for polling subscription");this.endpoint=e.endpoint,this.frequency=e.endpoint.pollFrequency,this.args=e.args,this.key=e.key,this.frequencyHistogram.set(this.frequency,1),this.controller=t,this.connectionListener=s||new V,this.connectionListener.isOnline()?this.onlineListener():this.offlineListener()}add(e){void 0!==e&&(this.frequencyHistogram.has(e)?this.frequencyHistogram.set(e,this.frequencyHistogram.get(e)+1):(this.frequencyHistogram.set(e,1),e<this.frequency&&(this.frequency=e,this.run())))}remove(e){if(void 0===e)return!1;if(this.frequencyHistogram.has(e)&&(this.frequencyHistogram.set(e,this.frequencyHistogram.get(e)-1),this.frequencyHistogram.get(e)<1)){if(this.frequencyHistogram.delete(e),0===this.frequencyHistogram.size)return this.cleanup(),!0;e<=this.frequency&&(this.frequency=Math.min(...this.frequencyHistogram.keys()),this.run())}return!1}cleanup(){this.intervalId&&(clearInterval(this.intervalId),delete this.intervalId),this.lastIntervalId&&(clearInterval(this.lastIntervalId),delete this.lastIntervalId),this.startId&&(clearTimeout(this.startId),delete this.startId),this.connectionListener.removeOnlineListener(this.onlineListener),this.connectionListener.removeOfflineListener(this.offlineListener)}update(){const e=this.endpoint,t=function(...t){return e.call(this,...t)};Object.assign(t,this.endpoint),t.dataExpiryLength=this.frequency/2,t.errorExpiryLength=this.frequency/10,t.errorPolicy=()=>"soft",t.key=()=>this.key,this.controller.fetch(t,...this.args).catch((()=>null))}run(){this.startId||(this.intervalId&&(this.lastIntervalId=this.intervalId),this.intervalId=setInterval((()=>{this.lastIntervalId&&(clearInterval(this.lastIntervalId),delete this.lastIntervalId),this.intervalId&&this.update()}),this.frequency))}lastFetchTime(){var e,t;return null!=(e=null==(t=this.controller.getState().meta[this.key])?void 0:t.date)?e:0}},e.ResetError=N,e.SubscriptionManager=class{constructor(e){this.subscriptions={},this.controller=new M,this.Subscription=e,this.middleware=e=>(this.controller=e,e=>t=>{switch(t.type){case c:try{this.handleSubscribe(t)}catch(e){console.error(e)}return Promise.resolve();case l:return this.handleUnsubscribe(t),Promise.resolve();default:return e(t)}})}cleanup(){for(const e in this.subscriptions)this.subscriptions[e].cleanup()}handleSubscribe(e){const t=e.key;if(t in this.subscriptions){const s=e.endpoint.pollFrequency;this.subscriptions[t].add(s)}else this.subscriptions[t]=new this.Subscription(e,this.controller)}handleUnsubscribe(e){const t=e.key;if(t in this.subscriptions){const s=e.endpoint.pollFrequency;this.subscriptions[t].remove(s)&&delete this.subscriptions[t]}}getMiddleware(){return this.middleware}},e.__INTERNAL__=L,e.actionTypes=f,e.actions=T,e.applyManager=function(e,t){return e.map((e=>{const s=e.getMiddleware();return({dispatch:e,getState:i})=>(t.dispatch=e,t.getState=i,s(t))}))},e.createReducer=E,e.initialState=b,Object.defineProperty(e,"__esModule",{value:!0})}));
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@data-client/normalizr")):"function"==typeof define&&define.amd?define(["exports","@data-client/normalizr"],t):t(((e="undefined"!=typeof globalThis?globalThis:e||self).RDC=e.RDC||{},e.RDC.Core={}),e.normalizr)}(this,(function(e,t){"use strict";function s(e,t){const s=Date.now();return{fetchedAt:null!=t?t:s,date:s,expiresAt:s+e}}const i="rdc/fetch",n="rdc/set",r="rdc/setresponse",o="rdc/optimistic",a="rdc/reset",c="rdc/subscribe",l="rdc/unsubscribe",h="rdc/invalidate",d="rdc/invalidateall",u="rdc/expireall",p="rdc/gc";var f=Object.freeze({__proto__:null,FETCH_TYPE:i,SET_TYPE:n,SET_RESPONSE_TYPE:r,OPTIMISTIC_TYPE:o,RESET_TYPE:a,SUBSCRIBE_TYPE:c,UNSUBSCRIBE_TYPE:l,INVALIDATE_TYPE:h,INVALIDATEALL_TYPE:d,EXPIREALL_TYPE:u,GC_TYPE:p});function g(e,t,i){var n;return{type:o,key:e.key(...t),args:t,endpoint:e,meta:s(null!=(n=e.dataExpiryLength)?n:6e4,i)}}class y extends Error{}function m(e,t,s){return"AbortError"===s.name?Object.assign({},e,{optimistic:v(e,t)}):Object.assign({},e,{meta:Object.assign({},e.meta,{[t.key]:{date:t.meta.date,error:s,expiresAt:t.meta.expiresAt,errorPolicy:null==t.endpoint.errorPolicy?void 0:t.endpoint.errorPolicy(s)}}),optimistic:v(e,t)})}function v(e,t){return e.optimistic.filter((e=>e.key!==t.key||(e.type===o?e.meta.fetchedAt!==t.meta.fetchedAt:e.meta.date>t.meta.date)))}function E(e){return function(s,c){switch(s||(s=b),c.type){case p:return c.entities.forEach((([e,t])=>{var i,n;null==(i=s.entities[e])||delete i[t],null==(n=s.entityMeta[e])||delete n[t]})),c.endpoints.forEach((e=>{delete s.endpoints[e],delete s.meta[e]})),s;case i:return function(e,t){if(t.endpoint.getOptimisticResponse&&t.endpoint.sideEffect){const s=g(t.endpoint,t.args,t.meta.fetchedAt);return Object.assign({},e,{optimistic:[...e.optimistic,s]})}return e}(s,c);case o:case r:return function(e,s,i){if(s.error)return m(e,s,s.response);try{var n;let r;if(s.type===o){if(!s.endpoint.getOptimisticResponse)return e;try{r=s.endpoint.getOptimisticResponse.call(s.endpoint,i.snapshot(e,s.meta.fetchedAt),...s.args)}catch(t){if(t.constructor===y)return e;throw t}}else r=s.response;const{result:a,entities:c,indexes:l,entityMeta:h}=t.normalize(s.endpoint.schema,r,s.args,e,s.meta),d=Object.assign({},e.endpoints,{[s.key]:a});try{if(s.endpoint.update){const e=s.endpoint.update(a,...s.args);Object.keys(e).forEach((t=>{d[t]=e[t](d[t])}))}}catch(e){console.error(`The following error occured during Endpoint.update() for ${s.key}`),console.error(e)}return{entities:c,indexes:l,endpoints:d,entityMeta:h,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}}),optimistic:v(e,s),lastReset:e.lastReset}}catch(t){return"object"==typeof t&&(t.message=`Error processing ${s.key}\n\nFull Schema: ${JSON.stringify(s.endpoint.schema,void 0,2)}\n\nError:\n${t.message}`,"response"in s&&(t.response=s.response),t.status=400),m(e,s,t)}}(s,c,e);case n:return function(e,s,i){let n;if("function"==typeof s.value){const t=i.get(s.schema,...s.args,e);if(void 0===t)return e;n=s.value(t)}else n=s.value;try{const{entities:i,indexes:r,entityMeta:o}=t.normalize(s.schema,n,s.args,e,s.meta);return{entities:i,indexes:r,endpoints:e.endpoints,entityMeta:o,meta:e.meta,optimistic:e.optimistic,lastReset:e.lastReset}}catch(t){return e}}(s,c,e);case d:case h:return function(e,t){const s=Object.assign({},e.endpoints),i=Object.assign({},e.meta),n=e=>{delete s[e];const t=Object.assign({},i[e],{expiresAt:0,invalidated:!0});delete t.error,i[e]=t};return t.type===h?n(t.key):Object.keys(s).forEach((e=>{t.testKey(e)&&n(e)})),Object.assign({},e,{endpoints:s,meta:i})}(s,c);case u:return function(e,t){const s=Object.assign({},e.meta);return Object.keys(s).forEach((e=>{t.testKey(e)&&(s[e]=Object.assign({},s[e],{expiresAt:1}))})),Object.assign({},e,{meta:s})}(s,c);case a:return Object.assign({},b,{lastReset:c.date});default:return s}}}const b={entities:{},indexes:{},endpoints:{},meta:{},entityMeta:{},optimistic:[],lastReset:0};var L=Object.freeze({__proto__:null,MemoCache:t.MemoCache,INVALID:t.INVALID,initialState:b});function O(e,{args:t}){return{type:c,endpoint:e,args:t,key:e.key(...t)}}function S(e,{args:t}){return{type:l,key:e.key(...t),args:t,endpoint:e}}var I="undefined"!=typeof FormData?e=>e instanceof FormData?Object.fromEntries(e.entries()):e:e=>e;function w(e,{args:t,fetchedAt:i,response:n,error:o=!1}){var a,c;const l=o?null!=(a=e.errorExpiryLength)?a:1e3:null!=(c=e.dataExpiryLength)?c:6e4;return{type:r,key:e.key(...t),response:n,args:t.map(I),endpoint:e,meta:s(l,i),error:o}}function x(e,{args:t,fetchedAt:i,value:r}){return{type:n,value:r,args:t.map(I),schema:e,meta:s(6e4,i)}}function A(){return{type:a,date:Date.now()}}function k(e){return{type:d,testKey:e}}function j(e,{args:t}){return{type:h,key:e.key(...t)}}function _(e,{args:t}){let s=0,n=0;const r=new Promise(((e,t)=>{[s,n]=[e,t]})),o={fetchedAt:Date.now(),resolve:s,reject:n,promise:r};return{type:i,key:e.key(...t),args:t,endpoint:e,meta:o}}function R(e){return{type:u,testKey:e}}var T=Object.freeze({__proto__:null,createSubscription:O,createUnsubscription:S,createSetResponse:w,createSet:x,createReset:A,createOptimistic:g,createMeta:s,createInvalidateAll:k,createInvalidate:j,createFetch:_,createExpireAll:R});function P(e,t){return e.meta[t]}const q=e=>{throw new Error("Dispatching while constructing your middleware is not allowed. Other middleware would not be applied to this dispatch.")},D=()=>b;class M{constructor({dispatch:e=q,getState:s=D,memo:i=new t.MemoCache}={}){this.fetch=(e,...s)=>{const i=_(e,{args:s});return this.dispatch(i),e.schema?i.meta.promise.then((i=>t.denormalize(e.schema,i,{},s))):i.meta.promise},this.fetchIfStale=(e,...s)=>{const{data:i,expiresAt:n,expiryStatus:r}=this.getResponse(e,...s,this.getState());return r!==t.ExpiryStatus.Invalid&&Date.now()<=n?i:this.fetch(e,...s)},this.invalidate=(e,...t)=>null!==t[0]?this.dispatch(j(e,{args:t})):Promise.resolve(),this.invalidateAll=e=>this.dispatch(k((t=>e.testKey(t)))),this.expireAll=e=>this.dispatch(R((t=>e.testKey(t)))),this.resetEntireStore=()=>this.dispatch(A()),this.setResponse=(e,...t)=>{const s=t[t.length-1],i=w(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=w(e,{args:t.slice(0,t.length-1),response:s,error:!0});return this.dispatch(i)},this.resolve=(e,t)=>this.dispatch(w(e,t)),this.subscribe=(e,...t)=>null!==t[0]?this.dispatch(O(e,{args:t})):Promise.resolve(),this.unsubscribe=(e,...t)=>null!==t[0]?this.dispatch(S(e,{args:t})):Promise.resolve(),this.snapshot=(e,t)=>new H(this,e,t),this.dispatch=e,this.getState=s,this.memo=i}set(e,...t){const s=t[t.length-1],i=x(e,{args:t.slice(0,t.length-1),value:s});return this.dispatch(i)}getError(e,...t){if(null===t[0])return;const s=t[t.length-1],i=t.slice(0,t.length-1),n=e.key(...i),r=P(s,n);return void 0===s.endpoints[n]||"soft"!==(null==r?void 0:r.errorPolicy)?null==r?void 0:r.error:void 0}getResponse(e,...s){const i=s[s.length-1],n=s.slice(0,s.length-1).map(I),r=1!==n.length||null!==n[0],o=r?e.key(...n):"",a=r?i.endpoints[o]:void 0,c=e.schema,l=P(i,o);let h=null==l?void 0:l.expiresAt;const d=void 0===a&&void 0!==c,u=d?this.memo.buildQueryKey(c,n,i.entities,i.indexes,o):a;if(!r)return{data:u,expiryStatus:t.ExpiryStatus.Valid,expiresAt:1/0};let p=!1;if(d)p=!t.validateQueryKey(u);else if(!c||!C(c))return{data:a,expiryStatus:null!=l&&l.invalidated?t.ExpiryStatus.Invalid:a&&!e.invalidIfStale?t.ExpiryStatus.Valid:t.ExpiryStatus.InvalidIfStale,expiresAt:h||0};const{data:f,paths:g}=this.memo.denormalize(c,u,i.entities,n);return!h&&p&&(h=1),this.getSchemaResponse(f,g,i.entityMeta,h,e.invalidIfStale||p,l)}get(e,...t){const s=t[t.length-1],i=t.slice(0,t.length-1).map(I);return this.memo.query(e,i,s.entities,s.indexes)}getSchemaResponse(e,s,i,n,r,o={}){const a="symbol"==typeof e;n||(n=function(e,t){let s=1/0;for(const{pk:n,key:r}of e){var i;const e=null==(i=t[r])||null==(i=i[n])?void 0:i.expiresAt;e<s&&(s=e)}return s}(s,i));return{data:e,expiryStatus:null!=o&&o.invalidated||a&&(null==o||!o.error)?t.ExpiryStatus.Invalid:a||r?t.ExpiryStatus.InvalidIfStale:t.ExpiryStatus.Valid,expiresAt:n}}}function C(e){if(t.isEntity(e))return!0;if(Array.isArray(e))return 0!==e.length&&C(e[0]);if(e&&("object"==typeof e||"function"==typeof e)){const t="schema"in e?e.schema:e;return"function"==typeof t?C(t):Object.values(t).some((e=>C(e)))}return!1}class H{constructor(e,t,s=0){this.state=void 0,this.controller=void 0,this.fetchedAt=void 0,this.abort=H.abort,this.state=t,this.controller=e,this.fetchedAt=s}getResponse(e,...t){return this.controller.getResponse(e,...t,this.state)}getError(e,...t){return this.controller.getError(e,...t,this.state)}get(e,...t){return this.controller.get(e,...t,this.state)}}H.abort=new y;class N extends Error{constructor(){super("Aborted due to RESET"),this.name="ResetError"}}class F{isOnline(){return void 0===navigator.onLine||navigator.onLine}addOnlineListener(e){addEventListener("online",e)}removeOnlineListener(e){removeEventListener("online",e)}addOfflineListener(e){addEventListener("offline",e)}removeOfflineListener(e){removeEventListener("offline",e)}}class z{isOnline(){return!0}addOnlineListener(){}removeOnlineListener(){}addOfflineListener(){}removeOfflineListener(){}}let Y;Y="undefined"!=typeof navigator&&"function"==typeof addEventListener?F:z;var V=Y;let B={};Object.hasOwn=Object.hasOwn||function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},Object.defineProperty(e,"ExpiryStatus",{enumerable:!0,get:function(){return t.ExpiryStatus}}),e.Controller=M,e.DefaultConnectionListener=V,e.DevToolsManager=class{constructor(e,t){this.started=!1,this.actions=[],this.maxBufferLength=100,this.devTools="undefined"!=typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__&&window.__REDUX_DEVTOOLS_EXTENSION__.connect(Object.assign({},B,e)),null!=e&&e.maxAge&&(this.maxBufferLength=2*e.maxAge),this.devTools?this.middleware=e=>{this.controller=e;const s=E(e);let i=e.getState();return n=>r=>{const o=null==t?void 0:t(r),a=n(r);return i=this.started?s(i,r):e.getState(),a.then((()=>{o||this.handleAction(r,i.optimistic.reduce(s,i))})),a}}:this.middleware=()=>e=>t=>e(t)}handleAction(e,t){this.started?this.devTools.send(e,t):(this.actions.length>this.maxBufferLength&&(this.actions=this.actions.slice(this.maxBufferLength/2)),this.actions.push([e,t]))}init(e){this.devTools&&this.devTools.init(e)}cleanup(){}getMiddleware(){return this.middleware}},e.LogoutManager=class{constructor({handleLogout:e,shouldLogout:t}={}){e&&(this.handleLogout=e),t&&(this.shouldLogout=t),this.middleware=e=>t=>async s=>{await t(s),s.type===r&&s.error&&this.shouldLogout(s.response)&&this.handleLogout(e)}}cleanup(){}getMiddleware(){return this.middleware}shouldLogout(e){return 401===e.status}handleLogout(e){e.resetEntireStore()}},e.NetworkManager=class{constructor(e=6e4,t=1e3){this.fetched=Object.create(null),this.resolvers={},this.rejectors={},this.fetchedAt={},this.controller=new M,this.dataExpiryLength=e,this.errorExpiryLength=t,this.middleware=e=>(this.controller=e,t=>s=>{switch(s.type){case i:return this.handleFetch(s),void 0!==s.endpoint.getOptimisticResponse&&s.endpoint.sideEffect?t(s):Promise.resolve();case r:return t(s).then((()=>{if(s.key in this.fetched){var t;const i=null==(t=e.getState().meta[s.key])?void 0:t.error;i?this.handleSet(w(s.endpoint,{args:s.args,response:i,fetchedAt:s.meta.fetchedAt,error:!0})):this.handleSet(s)}}));case a:{const e=Object.assign({},this.rejectors);return this.clearAll(),t(s).then((()=>{for(const t in e)e[t](new N)}))}default:return t(s)}})}skipLogging(e){return e.type===i&&e.key in this.fetched}init(){delete this.cleanupDate}cleanup(){this.cleanupDate=Date.now()}allSettled(){const e=Object.values(this.fetched);if(e.length)return Promise.allSettled(e)}clearAll(){for(const e in this.rejectors)this.clear(e)}clear(e){this.fetched[e].catch((()=>{})),delete this.resolvers[e],delete this.rejectors[e],delete this.fetched[e],delete this.fetchedAt[e]}getLastReset(){return this.cleanupDate?this.cleanupDate:this.controller.getState().lastReset}handleFetch(e){const{resolve:t,reject:s,fetchedAt:i}=e.meta,n=!e.endpoint.sideEffect,r=()=>{let r=e.endpoint(...e.args);return n||(r=(e=>e.then((e=>(t(e),e))).catch((e=>{throw s(e),e})))(r)),r=r.then((t=>{let s=this.getLastReset();return i>=s&&this.controller.resolve(e.endpoint,{args:e.args,response:t,fetchedAt:i}),t})).catch((t=>{const s=this.getLastReset();throw i>=s&&this.controller.resolve(e.endpoint,{args:e.args,response:t,fetchedAt:i,error:!0}),t})),r};return n?this.throttle(e.key,r,i).then((e=>t(e))).catch((e=>s(e))):r().catch((()=>{}))}handleSet(e){if(e.key in this.fetched){let t;t=e.error?this.rejectors[e.key]:this.resolvers[e.key],t(e.response),this.clear(e.key)}}getMiddleware(){return this.middleware}throttle(e,t,s){const i=this.getLastReset();return e in this.fetched&&this.fetchedAt[e]>i||(this.fetched[e]=new Promise(((t,s)=>{this.resolvers[e]=t,this.rejectors[e]=s})),this.fetchedAt[e]=s,this.idleCallback((()=>{t().catch((()=>null))}),{timeout:500})),this.fetched[e]}idleCallback(e,t){e()}},e.PollingSubscription=class{constructor(e,t,s){if(this.frequencyHistogram=new Map,this.offlineListener=()=>{this.cleanup(),this.connectionListener.addOnlineListener(this.onlineListener)},this.onlineListener=()=>{this.connectionListener.removeOnlineListener(this.onlineListener);const e=Date.now();this.startId=setTimeout((()=>{this.startId&&(delete this.startId,this.update(),this.run())}),Math.max(0,this.lastFetchTime()-e+this.frequency)),this.connectionListener.addOfflineListener(this.offlineListener)},void 0===e.endpoint.pollFrequency)throw new Error("frequency needed for polling subscription");this.endpoint=e.endpoint,this.frequency=e.endpoint.pollFrequency,this.args=e.args,this.key=e.key,this.frequencyHistogram.set(this.frequency,1),this.controller=t,this.connectionListener=s||new V,this.connectionListener.isOnline()?this.onlineListener():this.offlineListener()}add(e){void 0!==e&&(this.frequencyHistogram.has(e)?this.frequencyHistogram.set(e,this.frequencyHistogram.get(e)+1):(this.frequencyHistogram.set(e,1),e<this.frequency&&(this.frequency=e,this.run())))}remove(e){if(void 0===e)return!1;if(this.frequencyHistogram.has(e)&&(this.frequencyHistogram.set(e,this.frequencyHistogram.get(e)-1),this.frequencyHistogram.get(e)<1)){if(this.frequencyHistogram.delete(e),0===this.frequencyHistogram.size)return this.cleanup(),!0;e<=this.frequency&&(this.frequency=Math.min(...this.frequencyHistogram.keys()),this.run())}return!1}cleanup(){this.intervalId&&(clearInterval(this.intervalId),delete this.intervalId),this.lastIntervalId&&(clearInterval(this.lastIntervalId),delete this.lastIntervalId),this.startId&&(clearTimeout(this.startId),delete this.startId),this.connectionListener.removeOnlineListener(this.onlineListener),this.connectionListener.removeOfflineListener(this.offlineListener)}update(){const e=this.endpoint,t=function(...t){return e.call(this,...t)};Object.assign(t,this.endpoint),t.dataExpiryLength=this.frequency/2,t.errorExpiryLength=this.frequency/10,t.errorPolicy=()=>"soft",t.key=()=>this.key,this.controller.fetch(t,...this.args).catch((()=>null))}run(){this.startId||(this.intervalId&&(this.lastIntervalId=this.intervalId),this.intervalId=setInterval((()=>{this.lastIntervalId&&(clearInterval(this.lastIntervalId),delete this.lastIntervalId),this.intervalId&&this.update()}),this.frequency))}lastFetchTime(){var e,t;return null!=(e=null==(t=this.controller.getState().meta[this.key])?void 0:t.date)?e:0}},e.ResetError=N,e.SubscriptionManager=class{constructor(e){this.subscriptions={},this.controller=new M,this.Subscription=e,this.middleware=e=>(this.controller=e,e=>t=>{switch(t.type){case c:try{this.handleSubscribe(t)}catch(e){console.error(e)}return Promise.resolve();case l:return this.handleUnsubscribe(t),Promise.resolve();default:return e(t)}})}cleanup(){for(const e in this.subscriptions)this.subscriptions[e].cleanup()}handleSubscribe(e){const t=e.key;if(t in this.subscriptions){const s=e.endpoint.pollFrequency;this.subscriptions[t].add(s)}else this.subscriptions[t]=new this.Subscription(e,this.controller)}handleUnsubscribe(e){const t=e.key;if(t in this.subscriptions){const s=e.endpoint.pollFrequency;this.subscriptions[t].remove(s)&&delete this.subscriptions[t]}}getMiddleware(){return this.middleware}},e.__INTERNAL__=L,e.actionTypes=f,e.actions=T,e.applyManager=function(e,t){return e.map(((e,s)=>{const i=e.getMiddleware();return({dispatch:e,getState:n})=>(0===s&&(t.dispatch=e,t.getState=n),i(t))}))},e.createReducer=E,e.initialState=b,Object.defineProperty(e,"__esModule",{value:!0})}));

@@ -21,8 +21,8 @@ import { FETCH_TYPE } from '../../actionTypes.js';

type: FETCH_TYPE,
key: endpoint.key(...args),
args,
endpoint,
args,
key: endpoint.key(...args),
meta
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiY3JlYXRlRmV0Y2giLCJlbmRwb2ludCIsImFyZ3MiLCJyZXNvbHZlIiwicmVqZWN0IiwicHJvbWlzZSIsIlByb21pc2UiLCJhIiwiYiIsIm1ldGEiLCJmZXRjaGVkQXQiLCJEYXRlIiwibm93IiwidHlwZSIsImtleSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlRmV0Y2gudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbmRwb2ludEludGVyZmFjZSwgTkkgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgRkVUQ0hfVFlQRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgRmV0Y2hBY3Rpb24sIEZldGNoTWV0YSB9IGZyb20gJy4uLy4uL3R5cGVzLmpzJztcbmltcG9ydCB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbi8qKlxuICogUmVxdWVzdGluZyBhIGZldGNoIHRvIGJlZ2luXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVGZXRjaDxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYgeyB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEU+IH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgeyBhcmdzIH06IHsgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dIH0sXG4pOiBGZXRjaEFjdGlvbjxFPiB7XG4gIGxldCByZXNvbHZlOiAodmFsdWU/OiBhbnkgfCBQcm9taXNlTGlrZTxhbnk+KSA9PiB2b2lkID0gMCBhcyBhbnk7XG4gIGxldCByZWplY3Q6IChyZWFzb24/OiBhbnkpID0+IHZvaWQgPSAwIGFzIGFueTtcbiAgY29uc3QgcHJvbWlzZSA9IG5ldyBQcm9taXNlPGFueT4oKGEsIGIpID0+IHtcbiAgICBbcmVzb2x2ZSwgcmVqZWN0XSA9IFthLCBiXTtcbiAgfSk7XG4gIGNvbnN0IG1ldGE6IEZldGNoTWV0YSA9IHtcbiAgICBmZXRjaGVkQXQ6IERhdGUubm93KCksXG4gICAgcmVzb2x2ZSxcbiAgICByZWplY3QsXG4gICAgcHJvbWlzZSxcbiAgfTtcblxuICByZXR1cm4ge1xuICAgIHR5cGU6IEZFVENIX1RZUEUsXG4gICAgZW5kcG9pbnQsXG4gICAgYXJncyxcbiAgICBrZXk6IGVuZHBvaW50LmtleSguLi5hcmdzKSxcbiAgICBtZXRhLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFFQSxTQUFTQSxVQUFVLFFBQVEsc0JBQXNCO0FBSWpEO0FBQ0E7QUFDQTtBQUNBLE9BQU8sU0FBU0MsV0FBV0EsQ0FHekJDLFFBQVcsRUFDWDtFQUFFQztBQUE0QyxDQUFDLEVBQy9CO0VBQ2hCLElBQUlDLE9BQWlELEdBQUcsQ0FBUTtFQUNoRSxJQUFJQyxNQUE4QixHQUFHLENBQVE7RUFDN0MsTUFBTUMsT0FBTyxHQUFHLElBQUlDLE9BQU8sQ0FBTSxDQUFDQyxDQUFDLEVBQUVDLENBQUMsS0FBSztJQUN6QyxDQUFDTCxPQUFPLEVBQUVDLE1BQU0sQ0FBQyxHQUFHLENBQUNHLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0VBQzVCLENBQUMsQ0FBQztFQUNGLE1BQU1DLElBQWUsR0FBRztJQUN0QkMsU0FBUyxFQUFFQyxJQUFJLENBQUNDLEdBQUcsQ0FBQyxDQUFDO0lBQ3JCVCxPQUFPO0lBQ1BDLE1BQU07SUFDTkM7RUFDRixDQUFDO0VBRUQsT0FBTztJQUNMUSxJQUFJLEVBQUVkLFVBQVU7SUFDaEJFLFFBQVE7SUFDUkMsSUFBSTtJQUNKWSxHQUFHLEVBQUViLFFBQVEsQ0FBQ2EsR0FBRyxDQUFDLEdBQUdaLElBQUksQ0FBQztJQUMxQk87RUFDRixDQUFDO0FBQ0giLCJpZ25vcmVMaXN0IjpbXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiY3JlYXRlRmV0Y2giLCJlbmRwb2ludCIsImFyZ3MiLCJyZXNvbHZlIiwicmVqZWN0IiwicHJvbWlzZSIsIlByb21pc2UiLCJhIiwiYiIsIm1ldGEiLCJmZXRjaGVkQXQiLCJEYXRlIiwibm93IiwidHlwZSIsImtleSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlRmV0Y2gudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbmRwb2ludEludGVyZmFjZSwgTkkgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgRkVUQ0hfVFlQRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgRmV0Y2hBY3Rpb24sIEZldGNoTWV0YSB9IGZyb20gJy4uLy4uL3R5cGVzLmpzJztcbmltcG9ydCB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbi8qKlxuICogUmVxdWVzdGluZyBhIGZldGNoIHRvIGJlZ2luXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVGZXRjaDxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYgeyB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEU+IH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgeyBhcmdzIH06IHsgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dIH0sXG4pOiBGZXRjaEFjdGlvbjxFPiB7XG4gIGxldCByZXNvbHZlOiAodmFsdWU/OiBhbnkgfCBQcm9taXNlTGlrZTxhbnk+KSA9PiB2b2lkID0gMCBhcyBhbnk7XG4gIGxldCByZWplY3Q6IChyZWFzb24/OiBhbnkpID0+IHZvaWQgPSAwIGFzIGFueTtcbiAgY29uc3QgcHJvbWlzZSA9IG5ldyBQcm9taXNlPGFueT4oKGEsIGIpID0+IHtcbiAgICBbcmVzb2x2ZSwgcmVqZWN0XSA9IFthLCBiXTtcbiAgfSk7XG4gIGNvbnN0IG1ldGE6IEZldGNoTWV0YSA9IHtcbiAgICBmZXRjaGVkQXQ6IERhdGUubm93KCksXG4gICAgcmVzb2x2ZSxcbiAgICByZWplY3QsXG4gICAgcHJvbWlzZSxcbiAgfTtcblxuICByZXR1cm4ge1xuICAgIHR5cGU6IEZFVENIX1RZUEUsXG4gICAga2V5OiBlbmRwb2ludC5rZXkoLi4uYXJncyksXG4gICAgYXJncyxcbiAgICBlbmRwb2ludCxcbiAgICBtZXRhLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFFQSxTQUFTQSxVQUFVLFFBQVEsc0JBQXNCO0FBSWpEO0FBQ0E7QUFDQTtBQUNBLE9BQU8sU0FBU0MsV0FBV0EsQ0FHekJDLFFBQVcsRUFDWDtFQUFFQztBQUE0QyxDQUFDLEVBQy9CO0VBQ2hCLElBQUlDLE9BQWlELEdBQUcsQ0FBUTtFQUNoRSxJQUFJQyxNQUE4QixHQUFHLENBQVE7RUFDN0MsTUFBTUMsT0FBTyxHQUFHLElBQUlDLE9BQU8sQ0FBTSxDQUFDQyxDQUFDLEVBQUVDLENBQUMsS0FBSztJQUN6QyxDQUFDTCxPQUFPLEVBQUVDLE1BQU0sQ0FBQyxHQUFHLENBQUNHLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0VBQzVCLENBQUMsQ0FBQztFQUNGLE1BQU1DLElBQWUsR0FBRztJQUN0QkMsU0FBUyxFQUFFQyxJQUFJLENBQUNDLEdBQUcsQ0FBQyxDQUFDO0lBQ3JCVCxPQUFPO0lBQ1BDLE1BQU07SUFDTkM7RUFDRixDQUFDO0VBRUQsT0FBTztJQUNMUSxJQUFJLEVBQUVkLFVBQVU7SUFDaEJlLEdBQUcsRUFBRWIsUUFBUSxDQUFDYSxHQUFHLENBQUMsR0FBR1osSUFBSSxDQUFDO0lBQzFCQSxJQUFJO0lBQ0pELFFBQVE7SUFDUlE7RUFDRixDQUFDO0FBQ0giLCJpZ25vcmVMaXN0IjpbXX0=

@@ -11,8 +11,8 @@ import { createMeta } from './createMeta.js';

type: OPTIMISTIC_TYPE,
key: endpoint.key(...args),
args,
endpoint,
args,
key: endpoint.key(...args),
meta: createMeta((_endpoint$dataExpiryL2 = endpoint.dataExpiryLength) != null ? _endpoint$dataExpiryL2 : 60000, fetchedAt)
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVNZXRhIiwiT1BUSU1JU1RJQ19UWVBFIiwiY3JlYXRlT3B0aW1pc3RpYyIsImVuZHBvaW50IiwiYXJncyIsImZldGNoZWRBdCIsIl9lbmRwb2ludCRkYXRhRXhwaXJ5TCIsIl9lbmRwb2ludCRkYXRhRXhwaXJ5TDIiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwiRXJyb3IiLCJ0eXBlIiwia2V5IiwibWV0YSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlT3B0aW1pc3RpYy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlIH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB7IGNyZWF0ZU1ldGEgfSBmcm9tICcuL2NyZWF0ZU1ldGEuanMnO1xuaW1wb3J0IHsgT1BUSU1JU1RJQ19UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBPcHRpbWlzdGljQWN0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlT3B0aW1pc3RpYzxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYge1xuICAgIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG4gIH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dLFxuICBmZXRjaGVkQXQ6IG51bWJlcixcbik6IE9wdGltaXN0aWNBY3Rpb248RT4ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAoXG4gICAgcHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiZcbiAgICAoZW5kcG9pbnQuZGF0YUV4cGlyeUxlbmd0aCA/PyAwKSA8IDBcbiAgKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdOZWdhdGl2ZSBleHBpcnkgbGVuZ3RoIGFyZSBub3QgYWxsb3dlZC4nKTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgdHlwZTogT1BUSU1JU1RJQ19UWVBFLFxuICAgIGVuZHBvaW50LFxuICAgIGFyZ3MsXG4gICAga2V5OiBlbmRwb2ludC5rZXkoLi4uYXJncyksXG4gICAgbWV0YTogY3JlYXRlTWV0YShlbmRwb2ludC5kYXRhRXhwaXJ5TGVuZ3RoID8/IDYwMDAwLCBmZXRjaGVkQXQpLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFFQSxTQUFTQSxVQUFVLFFBQVEsaUJBQWlCO0FBQzVDLFNBQVNDLGVBQWUsUUFBUSxzQkFBc0I7QUFJdEQsT0FBTyxTQUFTQyxnQkFBZ0JBLENBSzlCQyxRQUFXLEVBQ1hDLElBQWlDLEVBQ2pDQyxTQUFpQixFQUNJO0VBQUEsSUFBQUMscUJBQUEsRUFBQUMsc0JBQUE7RUFDckI7RUFDQSxJQUNFQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLGFBQWEsSUFDdEMsRUFBQUoscUJBQUEsR0FBQ0gsUUFBUSxDQUFDUSxnQkFBZ0IsWUFBQUwscUJBQUEsR0FBSSxDQUFDLElBQUksQ0FBQyxFQUNwQztJQUNBLE1BQU0sSUFBSU0sS0FBSyxDQUFDLHlDQUF5QyxDQUFDO0VBQzVEO0VBRUEsT0FBTztJQUNMQyxJQUFJLEVBQUVaLGVBQWU7SUFDckJFLFFBQVE7SUFDUkMsSUFBSTtJQUNKVSxHQUFHLEVBQUVYLFFBQVEsQ0FBQ1csR0FBRyxDQUFDLEdBQUdWLElBQUksQ0FBQztJQUMxQlcsSUFBSSxFQUFFZixVQUFVLEVBQUFPLHNCQUFBLEdBQUNKLFFBQVEsQ0FBQ1EsZ0JBQWdCLFlBQUFKLHNCQUFBLEdBQUksS0FBSyxFQUFFRixTQUFTO0VBQ2hFLENBQUM7QUFDSCIsImlnbm9yZUxpc3QiOltdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVNZXRhIiwiT1BUSU1JU1RJQ19UWVBFIiwiY3JlYXRlT3B0aW1pc3RpYyIsImVuZHBvaW50IiwiYXJncyIsImZldGNoZWRBdCIsIl9lbmRwb2ludCRkYXRhRXhwaXJ5TCIsIl9lbmRwb2ludCRkYXRhRXhwaXJ5TDIiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwiRXJyb3IiLCJ0eXBlIiwia2V5IiwibWV0YSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlT3B0aW1pc3RpYy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlIH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB7IGNyZWF0ZU1ldGEgfSBmcm9tICcuL2NyZWF0ZU1ldGEuanMnO1xuaW1wb3J0IHsgT1BUSU1JU1RJQ19UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBPcHRpbWlzdGljQWN0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlT3B0aW1pc3RpYzxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYge1xuICAgIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG4gIH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dLFxuICBmZXRjaGVkQXQ6IG51bWJlcixcbik6IE9wdGltaXN0aWNBY3Rpb248RT4ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAoXG4gICAgcHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiZcbiAgICAoZW5kcG9pbnQuZGF0YUV4cGlyeUxlbmd0aCA/PyAwKSA8IDBcbiAgKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdOZWdhdGl2ZSBleHBpcnkgbGVuZ3RoIGFyZSBub3QgYWxsb3dlZC4nKTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgdHlwZTogT1BUSU1JU1RJQ19UWVBFLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICAgIGFyZ3MsXG4gICAgZW5kcG9pbnQsXG4gICAgbWV0YTogY3JlYXRlTWV0YShlbmRwb2ludC5kYXRhRXhwaXJ5TGVuZ3RoID8/IDYwMDAwLCBmZXRjaGVkQXQpLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFFQSxTQUFTQSxVQUFVLFFBQVEsaUJBQWlCO0FBQzVDLFNBQVNDLGVBQWUsUUFBUSxzQkFBc0I7QUFJdEQsT0FBTyxTQUFTQyxnQkFBZ0JBLENBSzlCQyxRQUFXLEVBQ1hDLElBQWlDLEVBQ2pDQyxTQUFpQixFQUNJO0VBQUEsSUFBQUMscUJBQUEsRUFBQUMsc0JBQUE7RUFDckI7RUFDQSxJQUNFQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLGFBQWEsSUFDdEMsRUFBQUoscUJBQUEsR0FBQ0gsUUFBUSxDQUFDUSxnQkFBZ0IsWUFBQUwscUJBQUEsR0FBSSxDQUFDLElBQUksQ0FBQyxFQUNwQztJQUNBLE1BQU0sSUFBSU0sS0FBSyxDQUFDLHlDQUF5QyxDQUFDO0VBQzVEO0VBRUEsT0FBTztJQUNMQyxJQUFJLEVBQUVaLGVBQWU7SUFDckJhLEdBQUcsRUFBRVgsUUFBUSxDQUFDVyxHQUFHLENBQUMsR0FBR1YsSUFBSSxDQUFDO0lBQzFCQSxJQUFJO0lBQ0pELFFBQVE7SUFDUlksSUFBSSxFQUFFZixVQUFVLEVBQUFPLHNCQUFBLEdBQUNKLFFBQVEsQ0FBQ1EsZ0JBQWdCLFlBQUFKLHNCQUFBLEdBQUksS0FBSyxFQUFFRixTQUFTO0VBQ2hFLENBQUM7QUFDSCIsImlnbm9yZUxpc3QiOltdfQ==

@@ -11,8 +11,8 @@ import { createMeta } from './createMeta.js';

type: SET_TYPE,
schema,
value,
args: args.map(ensurePojo),
schema,
meta: createMeta(60000, fetchedAt)
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVNZXRhIiwiU0VUX1RZUEUiLCJlbnN1cmVQb2pvIiwiY3JlYXRlU2V0Iiwic2NoZW1hIiwiYXJncyIsImZldGNoZWRBdCIsInZhbHVlIiwidHlwZSIsIm1hcCIsIm1ldGEiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udHJvbGxlci9hY3Rpb25zL2NyZWF0ZVNldC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIERlbm9ybWFsaXplLFxuICBRdWVyeWFibGUsXG4gIFNjaGVtYUFyZ3MsXG59IGZyb20gJ0BkYXRhLWNsaWVudC9ub3JtYWxpenInO1xuXG5pbXBvcnQgeyBjcmVhdGVNZXRhIH0gZnJvbSAnLi9jcmVhdGVNZXRhLmpzJztcbmltcG9ydCB7IFNFVF9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBTZXRBY3Rpb24gfSBmcm9tICcuLi8uLi90eXBlcy5qcyc7XG5pbXBvcnQgZW5zdXJlUG9qbyBmcm9tICcuLi9lbnN1cmVQb2pvLmpzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVNldDxTIGV4dGVuZHMgUXVlcnlhYmxlPihcbiAgc2NoZW1hOiBTLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gICAgdmFsdWUsXG4gIH06IHtcbiAgICBhcmdzOiByZWFkb25seSBbLi4uU2NoZW1hQXJnczxTPl07XG4gICAgdmFsdWU6IHt9IHwgKChwcmV2aW91c1ZhbHVlOiBEZW5vcm1hbGl6ZTxTPikgPT4ge30pO1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgfSxcbik6IFNldEFjdGlvbjxTPiB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogU0VUX1RZUEUsXG4gICAgc2NoZW1hLFxuICAgIHZhbHVlLFxuICAgIGFyZ3M6IGFyZ3MubWFwKGVuc3VyZVBvam8pIGFzIFNjaGVtYUFyZ3M8Uz4sXG4gICAgbWV0YTogY3JlYXRlTWV0YSg2MDAwMCwgZmV0Y2hlZEF0KSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBTUEsU0FBU0EsVUFBVSxRQUFRLGlCQUFpQjtBQUM1QyxTQUFTQyxRQUFRLFFBQVEsc0JBQXNCO0FBRS9DLE9BQU9DLFVBQVUsTUFBTSxrQkFBa0I7QUFFekMsT0FBTyxTQUFTQyxTQUFTQSxDQUN2QkMsTUFBUyxFQUNUO0VBQ0VDLElBQUk7RUFDSkMsU0FBUztFQUNUQztBQUtGLENBQUMsRUFDYTtFQUNkLE9BQU87SUFDTEMsSUFBSSxFQUFFUCxRQUFRO0lBQ2RHLE1BQU07SUFDTkcsS0FBSztJQUNMRixJQUFJLEVBQUVBLElBQUksQ0FBQ0ksR0FBRyxDQUFDUCxVQUFVLENBQWtCO0lBQzNDUSxJQUFJLEVBQUVWLFVBQVUsQ0FBQyxLQUFLLEVBQUVNLFNBQVM7RUFDbkMsQ0FBQztBQUNIIiwiaWdub3JlTGlzdCI6W119
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVNZXRhIiwiU0VUX1RZUEUiLCJlbnN1cmVQb2pvIiwiY3JlYXRlU2V0Iiwic2NoZW1hIiwiYXJncyIsImZldGNoZWRBdCIsInZhbHVlIiwidHlwZSIsIm1hcCIsIm1ldGEiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udHJvbGxlci9hY3Rpb25zL2NyZWF0ZVNldC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIERlbm9ybWFsaXplLFxuICBRdWVyeWFibGUsXG4gIFNjaGVtYUFyZ3MsXG59IGZyb20gJ0BkYXRhLWNsaWVudC9ub3JtYWxpenInO1xuXG5pbXBvcnQgeyBjcmVhdGVNZXRhIH0gZnJvbSAnLi9jcmVhdGVNZXRhLmpzJztcbmltcG9ydCB7IFNFVF9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBTZXRBY3Rpb24gfSBmcm9tICcuLi8uLi90eXBlcy5qcyc7XG5pbXBvcnQgZW5zdXJlUG9qbyBmcm9tICcuLi9lbnN1cmVQb2pvLmpzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVNldDxTIGV4dGVuZHMgUXVlcnlhYmxlPihcbiAgc2NoZW1hOiBTLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gICAgdmFsdWUsXG4gIH06IHtcbiAgICBhcmdzOiByZWFkb25seSBbLi4uU2NoZW1hQXJnczxTPl07XG4gICAgdmFsdWU6IHt9IHwgKChwcmV2aW91c1ZhbHVlOiBEZW5vcm1hbGl6ZTxTPikgPT4ge30pO1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgfSxcbik6IFNldEFjdGlvbjxTPiB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogU0VUX1RZUEUsXG4gICAgdmFsdWUsXG4gICAgYXJnczogYXJncy5tYXAoZW5zdXJlUG9qbykgYXMgU2NoZW1hQXJnczxTPixcbiAgICBzY2hlbWEsXG4gICAgbWV0YTogY3JlYXRlTWV0YSg2MDAwMCwgZmV0Y2hlZEF0KSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBTUEsU0FBU0EsVUFBVSxRQUFRLGlCQUFpQjtBQUM1QyxTQUFTQyxRQUFRLFFBQVEsc0JBQXNCO0FBRS9DLE9BQU9DLFVBQVUsTUFBTSxrQkFBa0I7QUFFekMsT0FBTyxTQUFTQyxTQUFTQSxDQUN2QkMsTUFBUyxFQUNUO0VBQ0VDLElBQUk7RUFDSkMsU0FBUztFQUNUQztBQUtGLENBQUMsRUFDYTtFQUNkLE9BQU87SUFDTEMsSUFBSSxFQUFFUCxRQUFRO0lBQ2RNLEtBQUs7SUFDTEYsSUFBSSxFQUFFQSxJQUFJLENBQUNJLEdBQUcsQ0FBQ1AsVUFBVSxDQUFrQjtJQUMzQ0UsTUFBTTtJQUNOTSxJQUFJLEVBQUVWLFVBQVUsQ0FBQyxLQUFLLEVBQUVNLFNBQVM7RUFDbkMsQ0FBQztBQUNIIiwiaWdub3JlTGlzdCI6W119

@@ -18,6 +18,6 @@ import { createMeta } from './createMeta.js';

type: SET_RESPONSE_TYPE,
endpoint,
key: endpoint.key(...args),
response,
args: args.map(ensurePojo),
key: endpoint.key(...args),
endpoint,
meta: createMeta(expiryLength, fetchedAt),

@@ -27,2 +27,2 @@ error

}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVNZXRhIiwiU0VUX1JFU1BPTlNFX1RZUEUiLCJlbnN1cmVQb2pvIiwiY3JlYXRlU2V0UmVzcG9uc2UiLCJlbmRwb2ludCIsImFyZ3MiLCJmZXRjaGVkQXQiLCJyZXNwb25zZSIsImVycm9yIiwiX2VuZHBvaW50JGVycm9yRXhwaXJ5IiwiX2VuZHBvaW50JGRhdGFFeHBpcnlMIiwiZXhwaXJ5TGVuZ3RoIiwiZXJyb3JFeHBpcnlMZW5ndGgiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiRXJyb3IiLCJ0eXBlIiwibWFwIiwia2V5IiwibWV0YSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlU2V0UmVzcG9uc2UudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbmRwb2ludEludGVyZmFjZSwgUmVzb2x2ZVR5cGUgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgY3JlYXRlTWV0YSB9IGZyb20gJy4vY3JlYXRlTWV0YS5qcyc7XG5pbXBvcnQgeyBTRVRfUkVTUE9OU0VfVFlQRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgU2V0UmVzcG9uc2VBY3Rpb24gfSBmcm9tICcuLi8uLi90eXBlcy5qcyc7XG5pbXBvcnQgZW5zdXJlUG9qbyBmcm9tICcuLi9lbnN1cmVQb2pvLmpzJztcbmltcG9ydCB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTZXRSZXNwb25zZTxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYge1xuICAgIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG4gIH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgb3B0aW9uczoge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogRXJyb3I7XG4gICAgZmV0Y2hlZEF0PzogbnVtYmVyO1xuICAgIGVycm9yOiB0cnVlO1xuICB9LFxuKTogU2V0UmVzcG9uc2VBY3Rpb248RT47XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTZXRSZXNwb25zZTxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYge1xuICAgIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG4gIH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgb3B0aW9uczoge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogUmVzb2x2ZVR5cGU8RT47XG4gICAgZmV0Y2hlZEF0PzogbnVtYmVyO1xuICAgIGVycm9yPzogZmFsc2U7XG4gIH0sXG4pOiBTZXRSZXNwb25zZUFjdGlvbjxFPjtcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVNldFJlc3BvbnNlPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gICAgcmVzcG9uc2UsXG4gICAgZXJyb3IgPSBmYWxzZSxcbiAgfToge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogYW55O1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgICBlcnJvcj86IGJvb2xlYW47XG4gIH0sXG4pOiBTZXRSZXNwb25zZUFjdGlvbjxFPiB7XG4gIGNvbnN0IGV4cGlyeUxlbmd0aDogbnVtYmVyID1cbiAgICBlcnJvciA/XG4gICAgICAoZW5kcG9pbnQuZXJyb3JFeHBpcnlMZW5ndGggPz8gMTAwMClcbiAgICA6IChlbmRwb2ludC5kYXRhRXhwaXJ5TGVuZ3RoID8/IDYwMDAwKTtcbiAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WID09PSAnZGV2ZWxvcG1lbnQnICYmIGV4cGlyeUxlbmd0aCA8IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ05lZ2F0aXZlIGV4cGlyeSBsZW5ndGggYXJlIG5vdCBhbGxvd2VkLicpO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBTRVRfUkVTUE9OU0VfVFlQRSxcbiAgICBlbmRwb2ludCxcbiAgICByZXNwb25zZSxcbiAgICBhcmdzOiBhcmdzLm1hcChlbnN1cmVQb2pvKSxcbiAgICBrZXk6IGVuZHBvaW50LmtleSguLi5hcmdzKSxcbiAgICBtZXRhOiBjcmVhdGVNZXRhKGV4cGlyeUxlbmd0aCwgZmV0Y2hlZEF0KSxcbiAgICBlcnJvcixcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBRUEsU0FBU0EsVUFBVSxRQUFRLGlCQUFpQjtBQUM1QyxTQUFTQyxpQkFBaUIsUUFBUSxzQkFBc0I7QUFFeEQsT0FBT0MsVUFBVSxNQUFNLGtCQUFrQjtBQStCekMsT0FBTyxTQUFTQyxpQkFBaUJBLENBSy9CQyxRQUFXLEVBQ1g7RUFDRUMsSUFBSTtFQUNKQyxTQUFTO0VBQ1RDLFFBQVE7RUFDUkMsS0FBSyxHQUFHO0FBTVYsQ0FBQyxFQUNxQjtFQUFBLElBQUFDLHFCQUFBLEVBQUFDLHFCQUFBO0VBQ3RCLE1BQU1DLFlBQW9CLEdBQ3hCSCxLQUFLLElBQUFDLHFCQUFBLEdBQ0ZMLFFBQVEsQ0FBQ1EsaUJBQWlCLFlBQUFILHFCQUFBLEdBQUksSUFBSSxJQUFBQyxxQkFBQSxHQUNsQ04sUUFBUSxDQUFDUyxnQkFBZ0IsWUFBQUgscUJBQUEsR0FBSSxLQUFNO0VBQ3hDO0VBQ0EsSUFBSUksT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlMLFlBQVksR0FBRyxDQUFDLEVBQUU7SUFDOUQsTUFBTSxJQUFJTSxLQUFLLENBQUMseUNBQXlDLENBQUM7RUFDNUQ7RUFFQSxPQUFPO0lBQ0xDLElBQUksRUFBRWpCLGlCQUFpQjtJQUN2QkcsUUFBUTtJQUNSRyxRQUFRO0lBQ1JGLElBQUksRUFBRUEsSUFBSSxDQUFDYyxHQUFHLENBQUNqQixVQUFVLENBQUM7SUFDMUJrQixHQUFHLEVBQUVoQixRQUFRLENBQUNnQixHQUFHLENBQUMsR0FBR2YsSUFBSSxDQUFDO0lBQzFCZ0IsSUFBSSxFQUFFckIsVUFBVSxDQUFDVyxZQUFZLEVBQUVMLFNBQVMsQ0FBQztJQUN6Q0U7RUFDRixDQUFDO0FBQ0giLCJpZ25vcmVMaXN0IjpbXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVNZXRhIiwiU0VUX1JFU1BPTlNFX1RZUEUiLCJlbnN1cmVQb2pvIiwiY3JlYXRlU2V0UmVzcG9uc2UiLCJlbmRwb2ludCIsImFyZ3MiLCJmZXRjaGVkQXQiLCJyZXNwb25zZSIsImVycm9yIiwiX2VuZHBvaW50JGVycm9yRXhwaXJ5IiwiX2VuZHBvaW50JGRhdGFFeHBpcnlMIiwiZXhwaXJ5TGVuZ3RoIiwiZXJyb3JFeHBpcnlMZW5ndGgiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiRXJyb3IiLCJ0eXBlIiwia2V5IiwibWFwIiwibWV0YSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlU2V0UmVzcG9uc2UudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbmRwb2ludEludGVyZmFjZSwgUmVzb2x2ZVR5cGUgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgY3JlYXRlTWV0YSB9IGZyb20gJy4vY3JlYXRlTWV0YS5qcyc7XG5pbXBvcnQgeyBTRVRfUkVTUE9OU0VfVFlQRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgU2V0UmVzcG9uc2VBY3Rpb24gfSBmcm9tICcuLi8uLi90eXBlcy5qcyc7XG5pbXBvcnQgZW5zdXJlUG9qbyBmcm9tICcuLi9lbnN1cmVQb2pvLmpzJztcbmltcG9ydCB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTZXRSZXNwb25zZTxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYge1xuICAgIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG4gIH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgb3B0aW9uczoge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogRXJyb3I7XG4gICAgZmV0Y2hlZEF0PzogbnVtYmVyO1xuICAgIGVycm9yOiB0cnVlO1xuICB9LFxuKTogU2V0UmVzcG9uc2VBY3Rpb248RT47XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTZXRSZXNwb25zZTxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYge1xuICAgIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG4gIH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgb3B0aW9uczoge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogUmVzb2x2ZVR5cGU8RT47XG4gICAgZmV0Y2hlZEF0PzogbnVtYmVyO1xuICAgIGVycm9yPzogZmFsc2U7XG4gIH0sXG4pOiBTZXRSZXNwb25zZUFjdGlvbjxFPjtcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVNldFJlc3BvbnNlPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gICAgcmVzcG9uc2UsXG4gICAgZXJyb3IgPSBmYWxzZSxcbiAgfToge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogYW55O1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgICBlcnJvcj86IGJvb2xlYW47XG4gIH0sXG4pOiBTZXRSZXNwb25zZUFjdGlvbjxFPiB7XG4gIGNvbnN0IGV4cGlyeUxlbmd0aDogbnVtYmVyID1cbiAgICBlcnJvciA/XG4gICAgICAoZW5kcG9pbnQuZXJyb3JFeHBpcnlMZW5ndGggPz8gMTAwMClcbiAgICA6IChlbmRwb2ludC5kYXRhRXhwaXJ5TGVuZ3RoID8/IDYwMDAwKTtcbiAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WID09PSAnZGV2ZWxvcG1lbnQnICYmIGV4cGlyeUxlbmd0aCA8IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ05lZ2F0aXZlIGV4cGlyeSBsZW5ndGggYXJlIG5vdCBhbGxvd2VkLicpO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBTRVRfUkVTUE9OU0VfVFlQRSxcbiAgICBrZXk6IGVuZHBvaW50LmtleSguLi5hcmdzKSxcbiAgICByZXNwb25zZSxcbiAgICBhcmdzOiBhcmdzLm1hcChlbnN1cmVQb2pvKSxcbiAgICBlbmRwb2ludCxcbiAgICBtZXRhOiBjcmVhdGVNZXRhKGV4cGlyeUxlbmd0aCwgZmV0Y2hlZEF0KSxcbiAgICBlcnJvcixcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBRUEsU0FBU0EsVUFBVSxRQUFRLGlCQUFpQjtBQUM1QyxTQUFTQyxpQkFBaUIsUUFBUSxzQkFBc0I7QUFFeEQsT0FBT0MsVUFBVSxNQUFNLGtCQUFrQjtBQStCekMsT0FBTyxTQUFTQyxpQkFBaUJBLENBSy9CQyxRQUFXLEVBQ1g7RUFDRUMsSUFBSTtFQUNKQyxTQUFTO0VBQ1RDLFFBQVE7RUFDUkMsS0FBSyxHQUFHO0FBTVYsQ0FBQyxFQUNxQjtFQUFBLElBQUFDLHFCQUFBLEVBQUFDLHFCQUFBO0VBQ3RCLE1BQU1DLFlBQW9CLEdBQ3hCSCxLQUFLLElBQUFDLHFCQUFBLEdBQ0ZMLFFBQVEsQ0FBQ1EsaUJBQWlCLFlBQUFILHFCQUFBLEdBQUksSUFBSSxJQUFBQyxxQkFBQSxHQUNsQ04sUUFBUSxDQUFDUyxnQkFBZ0IsWUFBQUgscUJBQUEsR0FBSSxLQUFNO0VBQ3hDO0VBQ0EsSUFBSUksT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlMLFlBQVksR0FBRyxDQUFDLEVBQUU7SUFDOUQsTUFBTSxJQUFJTSxLQUFLLENBQUMseUNBQXlDLENBQUM7RUFDNUQ7RUFFQSxPQUFPO0lBQ0xDLElBQUksRUFBRWpCLGlCQUFpQjtJQUN2QmtCLEdBQUcsRUFBRWYsUUFBUSxDQUFDZSxHQUFHLENBQUMsR0FBR2QsSUFBSSxDQUFDO0lBQzFCRSxRQUFRO0lBQ1JGLElBQUksRUFBRUEsSUFBSSxDQUFDZSxHQUFHLENBQUNsQixVQUFVLENBQUM7SUFDMUJFLFFBQVE7SUFDUmlCLElBQUksRUFBRXJCLFVBQVUsQ0FBQ1csWUFBWSxFQUFFTCxTQUFTLENBQUM7SUFDekNFO0VBQ0YsQ0FBQztBQUNIIiwiaWdub3JlTGlzdCI6W119

@@ -17,7 +17,7 @@ import { SUBSCRIBE_TYPE, UNSUBSCRIBE_TYPE } from '../../actionTypes.js';

type: UNSUBSCRIBE_TYPE,
endpoint,
key: endpoint.key(...args),
args,
key: endpoint.key(...args)
endpoint
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVUJTQ1JJQkVfVFlQRSIsIlVOU1VCU0NSSUJFX1RZUEUiLCJjcmVhdGVTdWJzY3JpcHRpb24iLCJlbmRwb2ludCIsImFyZ3MiLCJ0eXBlIiwia2V5IiwiY3JlYXRlVW5zdWJzY3JpcHRpb24iXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udHJvbGxlci9hY3Rpb25zL2NyZWF0ZVN1YnNjcmlwdGlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlIH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB7IFNVQlNDUklCRV9UWVBFLCBVTlNVQlNDUklCRV9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBTdWJzY3JpYmVBY3Rpb24sIFVuc3Vic2NyaWJlQWN0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlU3Vic2NyaXB0aW9uPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4oXG4gIGVuZHBvaW50OiBFLFxuICB7IGFyZ3MgfTogeyBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl0gfSxcbik6IFN1YnNjcmliZUFjdGlvbjxFPiB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogU1VCU0NSSUJFX1RZUEUsXG4gICAgZW5kcG9pbnQsXG4gICAgYXJncyxcbiAgICBrZXk6IGVuZHBvaW50LmtleSguLi5hcmdzKSxcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVVuc3Vic2NyaXB0aW9uPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4oXG4gIGVuZHBvaW50OiBFLFxuICB7IGFyZ3MgfTogeyBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl0gfSxcbik6IFVuc3Vic2NyaWJlQWN0aW9uPEU+IHtcbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBVTlNVQlNDUklCRV9UWVBFLFxuICAgIGVuZHBvaW50LFxuICAgIGFyZ3MsXG4gICAga2V5OiBlbmRwb2ludC5rZXkoLi4uYXJncyksXG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiJBQUVBLFNBQVNBLGNBQWMsRUFBRUMsZ0JBQWdCLFFBQVEsc0JBQXNCO0FBR3ZFLE9BQU8sU0FBU0Msa0JBQWtCQSxDQUNoQ0MsUUFBVyxFQUNYO0VBQUVDO0FBQTRDLENBQUMsRUFDM0I7RUFDcEIsT0FBTztJQUNMQyxJQUFJLEVBQUVMLGNBQWM7SUFDcEJHLFFBQVE7SUFDUkMsSUFBSTtJQUNKRSxHQUFHLEVBQUVILFFBQVEsQ0FBQ0csR0FBRyxDQUFDLEdBQUdGLElBQUk7RUFDM0IsQ0FBQztBQUNIO0FBRUEsT0FBTyxTQUFTRyxvQkFBb0JBLENBQ2xDSixRQUFXLEVBQ1g7RUFBRUM7QUFBNEMsQ0FBQyxFQUN6QjtFQUN0QixPQUFPO0lBQ0xDLElBQUksRUFBRUosZ0JBQWdCO0lBQ3RCRSxRQUFRO0lBQ1JDLElBQUk7SUFDSkUsR0FBRyxFQUFFSCxRQUFRLENBQUNHLEdBQUcsQ0FBQyxHQUFHRixJQUFJO0VBQzNCLENBQUM7QUFDSCIsImlnbm9yZUxpc3QiOltdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVUJTQ1JJQkVfVFlQRSIsIlVOU1VCU0NSSUJFX1RZUEUiLCJjcmVhdGVTdWJzY3JpcHRpb24iLCJlbmRwb2ludCIsImFyZ3MiLCJ0eXBlIiwia2V5IiwiY3JlYXRlVW5zdWJzY3JpcHRpb24iXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udHJvbGxlci9hY3Rpb25zL2NyZWF0ZVN1YnNjcmlwdGlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlIH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB7IFNVQlNDUklCRV9UWVBFLCBVTlNVQlNDUklCRV9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBTdWJzY3JpYmVBY3Rpb24sIFVuc3Vic2NyaWJlQWN0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlU3Vic2NyaXB0aW9uPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4oXG4gIGVuZHBvaW50OiBFLFxuICB7IGFyZ3MgfTogeyBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl0gfSxcbik6IFN1YnNjcmliZUFjdGlvbjxFPiB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogU1VCU0NSSUJFX1RZUEUsXG4gICAgZW5kcG9pbnQsXG4gICAgYXJncyxcbiAgICBrZXk6IGVuZHBvaW50LmtleSguLi5hcmdzKSxcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVVuc3Vic2NyaXB0aW9uPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4oXG4gIGVuZHBvaW50OiBFLFxuICB7IGFyZ3MgfTogeyBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl0gfSxcbik6IFVuc3Vic2NyaWJlQWN0aW9uPEU+IHtcbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBVTlNVQlNDUklCRV9UWVBFLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICAgIGFyZ3MsXG4gICAgZW5kcG9pbnQsXG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiJBQUVBLFNBQVNBLGNBQWMsRUFBRUMsZ0JBQWdCLFFBQVEsc0JBQXNCO0FBR3ZFLE9BQU8sU0FBU0Msa0JBQWtCQSxDQUNoQ0MsUUFBVyxFQUNYO0VBQUVDO0FBQTRDLENBQUMsRUFDM0I7RUFDcEIsT0FBTztJQUNMQyxJQUFJLEVBQUVMLGNBQWM7SUFDcEJHLFFBQVE7SUFDUkMsSUFBSTtJQUNKRSxHQUFHLEVBQUVILFFBQVEsQ0FBQ0csR0FBRyxDQUFDLEdBQUdGLElBQUk7RUFDM0IsQ0FBQztBQUNIO0FBRUEsT0FBTyxTQUFTRyxvQkFBb0JBLENBQ2xDSixRQUFXLEVBQ1g7RUFBRUM7QUFBNEMsQ0FBQyxFQUN6QjtFQUN0QixPQUFPO0lBQ0xDLElBQUksRUFBRUosZ0JBQWdCO0lBQ3RCSyxHQUFHLEVBQUVILFFBQVEsQ0FBQ0csR0FBRyxDQUFDLEdBQUdGLElBQUksQ0FBQztJQUMxQkEsSUFBSTtJQUNKRDtFQUNGLENBQUM7QUFDSCIsImlnbm9yZUxpc3QiOltdfQ==

@@ -0,3 +1,9 @@

import NetworkManager from './NetworkManager.js';
export default function applyManager(managers, controller) {
return managers.map(manager => {
/* istanbul ignore next */
if (process.env.NODE_ENV !== 'production' && !managers.find(mgr => mgr instanceof NetworkManager)) {
console.warn('NetworkManager not found; this is a required manager.');
console.warn('See https://dataclient.io/docs/guides/redux for hooking up redux');
}
return managers.map((manager, i) => {
const middleware = manager.getMiddleware();

@@ -8,4 +14,6 @@ return ({

}) => {
controller.dispatch = dispatch;
controller.getState = getState;
if (i === 0) {
controller.dispatch = dispatch;
controller.getState = getState;
}
// controller is a superset of the middleware API

@@ -18,2 +26,2 @@ return middleware(controller);

/* These should be compatible with redux */
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBseU1hbmFnZXIiLCJtYW5hZ2VycyIsImNvbnRyb2xsZXIiLCJtYXAiLCJtYW5hZ2VyIiwibWlkZGxld2FyZSIsImdldE1pZGRsZXdhcmUiLCJkaXNwYXRjaCIsImdldFN0YXRlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL21hbmFnZXIvYXBwbHlNYW5hZ2VyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIENvbnRyb2xsZXIgZnJvbSAnLi4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmltcG9ydCB0eXBlIHsgUmVkdWNlciwgRGlzcGF0Y2gsIFJlZHVjZXJTdGF0ZSB9IGZyb20gJy4uL21pZGRsZXdhcmVUeXBlcy5qcyc7XG5pbXBvcnQgeyBNYW5hZ2VyIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBhcHBseU1hbmFnZXIoXG4gIG1hbmFnZXJzOiBNYW5hZ2VyW10sXG4gIGNvbnRyb2xsZXI6IENvbnRyb2xsZXIsXG4pOiBNaWRkbGV3YXJlW10ge1xuICByZXR1cm4gbWFuYWdlcnMubWFwKG1hbmFnZXIgPT4ge1xuICAgIGNvbnN0IG1pZGRsZXdhcmUgPSBtYW5hZ2VyLmdldE1pZGRsZXdhcmUoKTtcbiAgICByZXR1cm4gKHsgZGlzcGF0Y2gsIGdldFN0YXRlIH0pID0+IHtcbiAgICAgIChjb250cm9sbGVyIGFzIGFueSkuZGlzcGF0Y2ggPSBkaXNwYXRjaDtcbiAgICAgIChjb250cm9sbGVyIGFzIGFueSkuZ2V0U3RhdGUgPSBnZXRTdGF0ZTtcbiAgICAgIC8vIGNvbnRyb2xsZXIgaXMgYSBzdXBlcnNldCBvZiB0aGUgbWlkZGxld2FyZSBBUElcbiAgICAgIHJldHVybiBtaWRkbGV3YXJlKGNvbnRyb2xsZXIgYXMgQ29udHJvbGxlcjxhbnk+KTtcbiAgICB9O1xuICB9KTtcbn1cblxuLyogVGhlc2Ugc2hvdWxkIGJlIGNvbXBhdGlibGUgd2l0aCByZWR1eCAqL1xuZXhwb3J0IGludGVyZmFjZSBNaWRkbGV3YXJlQVBJPFxuICBSIGV4dGVuZHMgUmVkdWNlcjxhbnksIGFueT4gPSBSZWR1Y2VyPGFueSwgYW55Pixcbj4ge1xuICBnZXRTdGF0ZTogKCkgPT4gUmVkdWNlclN0YXRlPFI+O1xuICBkaXNwYXRjaDogRGlzcGF0Y2g8Uj47XG59XG5leHBvcnQgdHlwZSBNaWRkbGV3YXJlID0gPFIgZXh0ZW5kcyBSZWR1Y2VyPGFueSwgYW55Pj4oe1xuICBkaXNwYXRjaCxcbn06IE1pZGRsZXdhcmVBUEk8Uj4pID0+IChuZXh0OiBEaXNwYXRjaDxSPikgPT4gRGlzcGF0Y2g8Uj47XG4iXSwibWFwcGluZ3MiOiJBQUlBLGVBQWUsU0FBU0EsWUFBWUEsQ0FDbENDLFFBQW1CLEVBQ25CQyxVQUFzQixFQUNSO0VBQ2QsT0FBT0QsUUFBUSxDQUFDRSxHQUFHLENBQUNDLE9BQU8sSUFBSTtJQUM3QixNQUFNQyxVQUFVLEdBQUdELE9BQU8sQ0FBQ0UsYUFBYSxDQUFDLENBQUM7SUFDMUMsT0FBTyxDQUFDO01BQUVDLFFBQVE7TUFBRUM7SUFBUyxDQUFDLEtBQUs7TUFDaENOLFVBQVUsQ0FBU0ssUUFBUSxHQUFHQSxRQUFRO01BQ3RDTCxVQUFVLENBQVNNLFFBQVEsR0FBR0EsUUFBUTtNQUN2QztNQUNBLE9BQU9ILFVBQVUsQ0FBQ0gsVUFBNkIsQ0FBQztJQUNsRCxDQUFDO0VBQ0gsQ0FBQyxDQUFDO0FBQ0o7O0FBRUEiLCJpZ25vcmVMaXN0IjpbXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJOZXR3b3JrTWFuYWdlciIsImFwcGx5TWFuYWdlciIsIm1hbmFnZXJzIiwiY29udHJvbGxlciIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsImZpbmQiLCJtZ3IiLCJjb25zb2xlIiwid2FybiIsIm1hcCIsIm1hbmFnZXIiLCJpIiwibWlkZGxld2FyZSIsImdldE1pZGRsZXdhcmUiLCJkaXNwYXRjaCIsImdldFN0YXRlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL21hbmFnZXIvYXBwbHlNYW5hZ2VyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBOZXR3b3JrTWFuYWdlciBmcm9tICcuL05ldHdvcmtNYW5hZ2VyLmpzJztcbmltcG9ydCB0eXBlIENvbnRyb2xsZXIgZnJvbSAnLi4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmltcG9ydCB0eXBlIHsgUmVkdWNlciwgRGlzcGF0Y2gsIFJlZHVjZXJTdGF0ZSB9IGZyb20gJy4uL21pZGRsZXdhcmVUeXBlcy5qcyc7XG5pbXBvcnQgeyBNYW5hZ2VyIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBhcHBseU1hbmFnZXIoXG4gIG1hbmFnZXJzOiBNYW5hZ2VyW10sXG4gIGNvbnRyb2xsZXI6IENvbnRyb2xsZXIsXG4pOiBNaWRkbGV3YXJlW10ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAoXG4gICAgcHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJyAmJlxuICAgICFtYW5hZ2Vycy5maW5kKG1nciA9PiBtZ3IgaW5zdGFuY2VvZiBOZXR3b3JrTWFuYWdlcilcbiAgKSB7XG4gICAgY29uc29sZS53YXJuKCdOZXR3b3JrTWFuYWdlciBub3QgZm91bmQ7IHRoaXMgaXMgYSByZXF1aXJlZCBtYW5hZ2VyLicpO1xuICAgIGNvbnNvbGUud2FybihcbiAgICAgICdTZWUgaHR0cHM6Ly9kYXRhY2xpZW50LmlvL2RvY3MvZ3VpZGVzL3JlZHV4IGZvciBob29raW5nIHVwIHJlZHV4JyxcbiAgICApO1xuICB9XG4gIHJldHVybiBtYW5hZ2Vycy5tYXAoKG1hbmFnZXIsIGkpID0+IHtcbiAgICBjb25zdCBtaWRkbGV3YXJlID0gbWFuYWdlci5nZXRNaWRkbGV3YXJlKCk7XG4gICAgcmV0dXJuICh7IGRpc3BhdGNoLCBnZXRTdGF0ZSB9KSA9PiB7XG4gICAgICBpZiAoaSA9PT0gMCkge1xuICAgICAgICAoY29udHJvbGxlciBhcyBhbnkpLmRpc3BhdGNoID0gZGlzcGF0Y2g7XG4gICAgICAgIChjb250cm9sbGVyIGFzIGFueSkuZ2V0U3RhdGUgPSBnZXRTdGF0ZTtcbiAgICAgIH1cbiAgICAgIC8vIGNvbnRyb2xsZXIgaXMgYSBzdXBlcnNldCBvZiB0aGUgbWlkZGxld2FyZSBBUElcbiAgICAgIHJldHVybiBtaWRkbGV3YXJlKGNvbnRyb2xsZXIgYXMgQ29udHJvbGxlcjxhbnk+KTtcbiAgICB9O1xuICB9KTtcbn1cblxuLyogVGhlc2Ugc2hvdWxkIGJlIGNvbXBhdGlibGUgd2l0aCByZWR1eCAqL1xuZXhwb3J0IGludGVyZmFjZSBNaWRkbGV3YXJlQVBJPFxuICBSIGV4dGVuZHMgUmVkdWNlcjxhbnksIGFueT4gPSBSZWR1Y2VyPGFueSwgYW55Pixcbj4ge1xuICBnZXRTdGF0ZTogKCkgPT4gUmVkdWNlclN0YXRlPFI+O1xuICBkaXNwYXRjaDogRGlzcGF0Y2g8Uj47XG59XG5leHBvcnQgdHlwZSBNaWRkbGV3YXJlID0gPFIgZXh0ZW5kcyBSZWR1Y2VyPGFueSwgYW55Pj4oe1xuICBkaXNwYXRjaCxcbn06IE1pZGRsZXdhcmVBUEk8Uj4pID0+IChuZXh0OiBEaXNwYXRjaDxSPikgPT4gRGlzcGF0Y2g8Uj47XG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLGNBQWMsTUFBTSxxQkFBcUI7QUFLaEQsZUFBZSxTQUFTQyxZQUFZQSxDQUNsQ0MsUUFBbUIsRUFDbkJDLFVBQXNCLEVBQ1I7RUFDZDtFQUNBLElBQ0VDLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDQyxRQUFRLEtBQUssWUFBWSxJQUNyQyxDQUFDSixRQUFRLENBQUNLLElBQUksQ0FBQ0MsR0FBRyxJQUFJQSxHQUFHLFlBQVlSLGNBQWMsQ0FBQyxFQUNwRDtJQUNBUyxPQUFPLENBQUNDLElBQUksQ0FBQyx1REFBdUQsQ0FBQztJQUNyRUQsT0FBTyxDQUFDQyxJQUFJLENBQ1Ysa0VBQ0YsQ0FBQztFQUNIO0VBQ0EsT0FBT1IsUUFBUSxDQUFDUyxHQUFHLENBQUMsQ0FBQ0MsT0FBTyxFQUFFQyxDQUFDLEtBQUs7SUFDbEMsTUFBTUMsVUFBVSxHQUFHRixPQUFPLENBQUNHLGFBQWEsQ0FBQyxDQUFDO0lBQzFDLE9BQU8sQ0FBQztNQUFFQyxRQUFRO01BQUVDO0lBQVMsQ0FBQyxLQUFLO01BQ2pDLElBQUlKLENBQUMsS0FBSyxDQUFDLEVBQUU7UUFDVlYsVUFBVSxDQUFTYSxRQUFRLEdBQUdBLFFBQVE7UUFDdENiLFVBQVUsQ0FBU2MsUUFBUSxHQUFHQSxRQUFRO01BQ3pDO01BQ0E7TUFDQSxPQUFPSCxVQUFVLENBQUNYLFVBQTZCLENBQUM7SUFDbEQsQ0FBQztFQUNILENBQUMsQ0FBQztBQUNKOztBQUVBIiwiaWdub3JlTGlzdCI6W119

@@ -24,2 +24,23 @@ /* eslint-disable no-inner-declarations */

autoPause: true,
features: {
pause: true,
// start/pause recording of dispatched actions
lock: true,
// lock/unlock dispatching actions and side effects
persist: false,
// persist states on page reloading
export: true,
// export history of actions in a file
import: 'custom',
// import history of actions from a file
jump: true,
// jump back and forth (time travelling)
skip: true,
// skip (cancel) actions
reorder: true,
// drag and drop actions in the history list
dispatch: false,
// dispatch custom actions or action creators
test: false // generate tests for the selected actions
},
actionSanitizer: action => {

@@ -96,2 +117,3 @@ if (!('endpoint' in action)) return action;

return next => action => {
const shouldSkip = skipLogging == null ? void 0 : skipLogging(action);
const ret = next(action);

@@ -105,3 +127,3 @@ if (this.started) {

ret.then(() => {
if (skipLogging != null && skipLogging(action)) return;
if (shouldSkip) return;
this.handleAction(action, state.optimistic.reduce(reducer, state));

@@ -144,2 +166,2 @@ });

}
//# 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","actionSanitizer","action","Object","assign","serialize","options","undefined","replacer","value","isFinite","endsWith","DateTimeFormat","hour","minute","second","fractionalSecondDigits","format","DevToolsManager","constructor","config","skipLogging","started","actions","maxBufferLength","devTools","window","__REDUX_DEVTOOLS_EXTENSION__","connect","maxAge","subscribe","msg","type","length","state","handleAction","payload","controller","resetEntireStore","middleware","reducer","getState","next","ret","then","optimistic","reduce","send","slice","push","init","cleanup","getMiddleware"],"sources":["../../src/manager/DevtoolsManager.ts"],"sourcesContent":["/* eslint-disable no-inner-declarations */\nimport type { DevToolsConfig } from './devtoolsTypes.js';\nimport type { Middleware } from './LogoutManager.js';\nimport { Controller, EndpointInterface } from '../index.js';\nimport createReducer from '../state/reducer/createReducer.js';\nimport type { Manager, State, ActionTypes } from '../types.js';\n\nexport type { DevToolsConfig };\n\nlet DEFAULT_CONFIG = {};\n\nif (process.env.NODE_ENV !== 'production') {\n  const extraEndpointKeys = [\n    'dataExpiryLength',\n    'errorExpiryLength',\n    'errorPolicy',\n    'invalidIfStale',\n    'pollFrequency',\n    'getOptimisticResponse',\n    'update',\n  ];\n\n  function serializeEndpoint(endpoint: EndpointInterface) {\n    const serial: any = {\n      name: endpoint.name,\n      schema: (endpoint.schema as any)?.toJSON?.() ?? endpoint.schema,\n      sideEffect: endpoint.sideEffect,\n    };\n    extraEndpointKeys.forEach(key => {\n      if (key in endpoint)\n        serial[key] = endpoint[key as keyof EndpointInterface];\n    });\n    return serial;\n  }\n\n  const HASINTL = typeof Intl !== 'undefined';\n  DEFAULT_CONFIG = {\n    name: `Data Client: ${globalThis.document?.title}`,\n    autoPause: true,\n    actionSanitizer: (action: ActionTypes) => {\n      if (!('endpoint' in action)) return action;\n      return {\n        ...action,\n        endpoint: serializeEndpoint(action.endpoint),\n      };\n    },\n    serialize: {\n      options: undefined,\n      /* istanbul ignore next */\n      replacer:\n        HASINTL ?\n          (key: string | number | symbol, value: unknown) => {\n            if (\n              typeof value === 'number' &&\n              typeof key === 'string' &&\n              isFinite(value) &&\n              (key === 'date' || key.endsWith('At'))\n            ) {\n              return Intl.DateTimeFormat('en-US', {\n                hour: 'numeric',\n                minute: 'numeric',\n                second: 'numeric',\n                fractionalSecondDigits: 3,\n              }).format(value);\n            }\n            return value;\n          }\n        : undefined,\n    },\n  };\n}\n\n/** Integrates with https://github.com/reduxjs/redux-devtools\n *\n * Options: https://github.com/reduxjs/redux-devtools/blob/main/extension/docs/API/Arguments.md\n *\n * @see https://dataclient.io/docs/api/DevToolsManager\n */\nexport default class DevToolsManager implements Manager {\n  protected declare middleware: Middleware;\n  protected declare devTools: undefined | any;\n  protected started = false;\n  protected actions: [ActionTypes, State<unknown>][] = [];\n  protected declare controller: Controller;\n  maxBufferLength = 100;\n\n  constructor(\n    config?: DevToolsConfig,\n    skipLogging?: (action: ActionTypes) => boolean,\n  ) {\n    /* istanbul ignore next */\n    this.devTools =\n      typeof window !== 'undefined' &&\n      (window as any).__REDUX_DEVTOOLS_EXTENSION__ &&\n      (window as any).__REDUX_DEVTOOLS_EXTENSION__.connect({\n        ...DEFAULT_CONFIG,\n        ...config,\n      });\n    // we cut it in half so we should double so we don't lose\n    if (config?.maxAge) this.maxBufferLength = config.maxAge * 2;\n    if (process.env.NODE_ENV !== 'production' && this.devTools) {\n      this.devTools.subscribe((msg: any) => {\n        switch (msg.type) {\n          case 'START':\n            this.started = true;\n\n            if (this.actions.length) {\n              this.actions.forEach(([action, state]) => {\n                this.handleAction(action, state);\n              });\n              this.actions = [];\n            }\n            break;\n          case 'STOP':\n            this.started = false;\n            break;\n          case 'DISPATCH':\n            if (msg.payload.type === 'RESET') {\n              this.controller.resetEntireStore();\n            }\n            break;\n        }\n      });\n    }\n\n    /* istanbul ignore if */\n    /* istanbul ignore next */\n    if (this.devTools) {\n      this.middleware = controller => {\n        this.controller = controller;\n        const reducer = createReducer(controller as any);\n        let state = controller.getState();\n        return next => action => {\n          const 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 (skipLogging?.(action)) return;\n            this.handleAction(action, state.optimistic.reduce(reducer, state));\n          });\n          return ret;\n        };\n      };\n    } else {\n      this.middleware = () => next => action => next(action);\n    }\n  }\n\n  handleAction(action: any, state: any) {\n    if (this.started) {\n      this.devTools.send(action, state);\n    } else {\n      // avoid this getting too big in case this is long running\n      // we cut in half so we aren't constantly reallocating\n      if (this.actions.length > this.maxBufferLength)\n        this.actions = this.actions.slice(this.maxBufferLength / 2);\n      // queue actions\n      this.actions.push([action, state]);\n    }\n  }\n\n  /** Called when initial state is ready */\n  init(state: State<any>) {\n    /* istanbul ignore if */\n    if (this.devTools) this.devTools.init(state);\n  }\n\n  /** Ensures all subscriptions are cleaned up. */\n  cleanup() {}\n\n  /** Attaches Manager to store\n   *\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n}\n"],"mappings":"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","ignoreList":[]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["createReducer","DEFAULT_CONFIG","process","env","NODE_ENV","_globalThis$document","extraEndpointKeys","serializeEndpoint","endpoint","_toJSON","_endpoint$schema","serial","name","schema","toJSON","sideEffect","forEach","key","HASINTL","Intl","globalThis","document","title","autoPause","features","pause","lock","persist","export","import","jump","skip","reorder","dispatch","test","actionSanitizer","action","Object","assign","serialize","options","undefined","replacer","value","isFinite","endsWith","DateTimeFormat","hour","minute","second","fractionalSecondDigits","format","DevToolsManager","constructor","config","skipLogging","started","actions","maxBufferLength","devTools","window","__REDUX_DEVTOOLS_EXTENSION__","connect","maxAge","subscribe","msg","type","length","state","handleAction","payload","controller","resetEntireStore","middleware","reducer","getState","next","shouldSkip","ret","then","optimistic","reduce","send","slice","push","init","cleanup","getMiddleware"],"sources":["../../src/manager/DevtoolsManager.ts"],"sourcesContent":["/* eslint-disable no-inner-declarations */\nimport type { DevToolsConfig } from './devtoolsTypes.js';\nimport type { Middleware } from './LogoutManager.js';\nimport { Controller, EndpointInterface } from '../index.js';\nimport createReducer from '../state/reducer/createReducer.js';\nimport type { Manager, State, ActionTypes } from '../types.js';\n\nexport type { DevToolsConfig };\n\nlet DEFAULT_CONFIG = {};\n\nif (process.env.NODE_ENV !== 'production') {\n  const extraEndpointKeys = [\n    'dataExpiryLength',\n    'errorExpiryLength',\n    'errorPolicy',\n    'invalidIfStale',\n    'pollFrequency',\n    'getOptimisticResponse',\n    'update',\n  ];\n\n  function serializeEndpoint(endpoint: EndpointInterface) {\n    const serial: any = {\n      name: endpoint.name,\n      schema: (endpoint.schema as any)?.toJSON?.() ?? endpoint.schema,\n      sideEffect: endpoint.sideEffect,\n    };\n    extraEndpointKeys.forEach(key => {\n      if (key in endpoint)\n        serial[key] = endpoint[key as keyof EndpointInterface];\n    });\n    return serial;\n  }\n\n  const HASINTL = typeof Intl !== 'undefined';\n  DEFAULT_CONFIG = {\n    name: `Data Client: ${globalThis.document?.title}`,\n    autoPause: true,\n    features: {\n      pause: true, // start/pause recording of dispatched actions\n      lock: true, // lock/unlock dispatching actions and side effects\n      persist: false, // persist states on page reloading\n      export: true, // export history of actions in a file\n      import: 'custom', // import history of actions from a file\n      jump: true, // jump back and forth (time travelling)\n      skip: true, // skip (cancel) actions\n      reorder: true, // drag and drop actions in the history list\n      dispatch: false, // dispatch custom actions or action creators\n      test: false, // generate tests for the selected actions\n    },\n    actionSanitizer: (action: ActionTypes) => {\n      if (!('endpoint' in action)) return action;\n      return {\n        ...action,\n        endpoint: serializeEndpoint(action.endpoint),\n      };\n    },\n    serialize: {\n      options: undefined,\n      /* istanbul ignore next */\n      replacer:\n        HASINTL ?\n          (key: string | number | symbol, value: unknown) => {\n            if (\n              typeof value === 'number' &&\n              typeof key === 'string' &&\n              isFinite(value) &&\n              (key === 'date' || key.endsWith('At'))\n            ) {\n              return Intl.DateTimeFormat('en-US', {\n                hour: 'numeric',\n                minute: 'numeric',\n                second: 'numeric',\n                fractionalSecondDigits: 3,\n              }).format(value);\n            }\n            return value;\n          }\n        : undefined,\n    },\n  };\n}\n\n/** Integrates with https://github.com/reduxjs/redux-devtools\n *\n * Options: https://github.com/reduxjs/redux-devtools/blob/main/extension/docs/API/Arguments.md\n *\n * @see https://dataclient.io/docs/api/DevToolsManager\n */\nexport default class DevToolsManager implements Manager {\n  protected declare middleware: Middleware;\n  protected declare devTools: undefined | any;\n  protected started = false;\n  protected actions: [ActionTypes, State<unknown>][] = [];\n  protected declare controller: Controller;\n  maxBufferLength = 100;\n\n  constructor(\n    config?: DevToolsConfig,\n    skipLogging?: (action: ActionTypes) => boolean,\n  ) {\n    /* istanbul ignore next */\n    this.devTools =\n      typeof window !== 'undefined' &&\n      (window as any).__REDUX_DEVTOOLS_EXTENSION__ &&\n      (window as any).__REDUX_DEVTOOLS_EXTENSION__.connect({\n        ...DEFAULT_CONFIG,\n        ...config,\n      });\n    // we cut it in half so we should double so we don't lose\n    if (config?.maxAge) this.maxBufferLength = config.maxAge * 2;\n    if (process.env.NODE_ENV !== 'production' && this.devTools) {\n      this.devTools.subscribe((msg: any) => {\n        switch (msg.type) {\n          case 'START':\n            this.started = true;\n\n            if (this.actions.length) {\n              this.actions.forEach(([action, state]) => {\n                this.handleAction(action, state);\n              });\n              this.actions = [];\n            }\n            break;\n          case 'STOP':\n            this.started = false;\n            break;\n          case 'DISPATCH':\n            if (msg.payload.type === 'RESET') {\n              this.controller.resetEntireStore();\n            }\n            break;\n        }\n      });\n    }\n\n    /* istanbul ignore if */\n    /* istanbul ignore next */\n    if (this.devTools) {\n      this.middleware = controller => {\n        this.controller = controller;\n        const reducer = createReducer(controller as any);\n        let state = controller.getState();\n        return next => action => {\n          const shouldSkip = skipLogging?.(action);\n          const ret = next(action);\n          if (this.started) {\n            // we track state changes here since getState() will only update after a batch commit\n            state = reducer(state, action);\n          } else {\n            state = controller.getState();\n          }\n          ret.then(() => {\n            if (shouldSkip) return;\n            this.handleAction(action, state.optimistic.reduce(reducer, state));\n          });\n          return ret;\n        };\n      };\n    } else {\n      this.middleware = () => next => action => next(action);\n    }\n  }\n\n  handleAction(action: any, state: any) {\n    if (this.started) {\n      this.devTools.send(action, state);\n    } else {\n      // avoid this getting too big in case this is long running\n      // we cut in half so we aren't constantly reallocating\n      if (this.actions.length > this.maxBufferLength)\n        this.actions = this.actions.slice(this.maxBufferLength / 2);\n      // queue actions\n      this.actions.push([action, state]);\n    }\n  }\n\n  /** Called when initial state is ready */\n  init(state: State<any>) {\n    /* istanbul ignore if */\n    if (this.devTools) this.devTools.init(state);\n  }\n\n  /** Ensures all subscriptions are cleaned up. */\n  cleanup() {}\n\n  /** Attaches Manager to store\n   *\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n}\n"],"mappings":"AAAA;;AAIA,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;EAQtDC,WAAWA,CACTC,MAAuB,EACvBC,WAA8C,EAC9C;IAAA,KARQC,OAAO,GAAG,KAAK;IAAA,KACfC,OAAO,GAAoC,EAAE;IAAA,KAEvDC,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,IAAI7D,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,IAAI,IAAI,CAACuD,QAAQ,EAAE;MAC1D,IAAI,CAACA,QAAQ,CAACK,SAAS,CAAEC,GAAQ,IAAK;QACpC,QAAQA,GAAG,CAACC,IAAI;UACd,KAAK,OAAO;YACV,IAAI,CAACV,OAAO,GAAG,IAAI;YAEnB,IAAI,IAAI,CAACC,OAAO,CAACU,MAAM,EAAE;cACvB,IAAI,CAACV,OAAO,CAACzC,OAAO,CAAC,CAAC,CAACoB,MAAM,EAAEgC,KAAK,CAAC,KAAK;gBACxC,IAAI,CAACC,YAAY,CAACjC,MAAM,EAAEgC,KAAK,CAAC;cAClC,CAAC,CAAC;cACF,IAAI,CAACX,OAAO,GAAG,EAAE;YACnB;YACA;UACF,KAAK,MAAM;YACT,IAAI,CAACD,OAAO,GAAG,KAAK;YACpB;UACF,KAAK,UAAU;YACb,IAAIS,GAAG,CAACK,OAAO,CAACJ,IAAI,KAAK,OAAO,EAAE;cAChC,IAAI,CAACK,UAAU,CAACC,gBAAgB,CAAC,CAAC;YACpC;YACA;QACJ;MACF,CAAC,CAAC;IACJ;;IAEA;IACA;IACA,IAAI,IAAI,CAACb,QAAQ,EAAE;MACjB,IAAI,CAACc,UAAU,GAAGF,UAAU,IAAI;QAC9B,IAAI,CAACA,UAAU,GAAGA,UAAU;QAC5B,MAAMG,OAAO,GAAG1E,aAAa,CAACuE,UAAiB,CAAC;QAChD,IAAIH,KAAK,GAAGG,UAAU,CAACI,QAAQ,CAAC,CAAC;QACjC,OAAOC,IAAI,IAAIxC,MAAM,IAAI;UACvB,MAAMyC,UAAU,GAAGtB,WAAW,oBAAXA,WAAW,CAAGnB,MAAM,CAAC;UACxC,MAAM0C,GAAG,GAAGF,IAAI,CAACxC,MAAM,CAAC;UACxB,IAAI,IAAI,CAACoB,OAAO,EAAE;YAChB;YACAY,KAAK,GAAGM,OAAO,CAACN,KAAK,EAAEhC,MAAM,CAAC;UAChC,CAAC,MAAM;YACLgC,KAAK,GAAGG,UAAU,CAACI,QAAQ,CAAC,CAAC;UAC/B;UACAG,GAAG,CAACC,IAAI,CAAC,MAAM;YACb,IAAIF,UAAU,EAAE;YAChB,IAAI,CAACR,YAAY,CAACjC,MAAM,EAAEgC,KAAK,CAACY,UAAU,CAACC,MAAM,CAACP,OAAO,EAAEN,KAAK,CAAC,CAAC;UACpE,CAAC,CAAC;UACF,OAAOU,GAAG;QACZ,CAAC;MACH,CAAC;IACH,CAAC,MAAM;MACL,IAAI,CAACL,UAAU,GAAG,MAAMG,IAAI,IAAIxC,MAAM,IAAIwC,IAAI,CAACxC,MAAM,CAAC;IACxD;EACF;EAEAiC,YAAYA,CAACjC,MAAW,EAAEgC,KAAU,EAAE;IACpC,IAAI,IAAI,CAACZ,OAAO,EAAE;MAChB,IAAI,CAACG,QAAQ,CAACuB,IAAI,CAAC9C,MAAM,EAAEgC,KAAK,CAAC;IACnC,CAAC,MAAM;MACL;MACA;MACA,IAAI,IAAI,CAACX,OAAO,CAACU,MAAM,GAAG,IAAI,CAACT,eAAe,EAC5C,IAAI,CAACD,OAAO,GAAG,IAAI,CAACA,OAAO,CAAC0B,KAAK,CAAC,IAAI,CAACzB,eAAe,GAAG,CAAC,CAAC;MAC7D;MACA,IAAI,CAACD,OAAO,CAAC2B,IAAI,CAAC,CAAChD,MAAM,EAAEgC,KAAK,CAAC,CAAC;IACpC;EACF;;EAEA;EACAiB,IAAIA,CAACjB,KAAiB,EAAE;IACtB;IACA,IAAI,IAAI,CAACT,QAAQ,EAAE,IAAI,CAACA,QAAQ,CAAC0B,IAAI,CAACjB,KAAK,CAAC;EAC9C;;EAEA;EACAkB,OAAOA,CAAA,EAAG,CAAC;;EAEX;AACF;AACA;EACEC,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAACd,UAAU;EACxB;AACF","ignoreList":[]}
export {};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":[],"sources":["../../src/manager/devtoolsTypes.ts"],"sourcesContent":["type Action = any;\ntype ActionCreator<T> = any;\n\n// taken from https://github.com/reduxjs/redux-devtools/blob/main/packages/redux-devtools-extension/src/index.ts\n\nexport interface EnhancerOptions {\n  /**\n   * the instance name to be showed on the monitor page. Default value is `document.title`.\n   * If not specified and there's no document title, it will consist of `tabId` and `instanceId`.\n   */\n  name?: string;\n  /**\n   * action creators functions to be available in the Dispatcher.\n   */\n  actionCreators?: ActionCreator<any>[] | { [key: string]: ActionCreator<any> };\n  /**\n   * if more than one action is dispatched in the indicated interval, all new actions will be collected and sent at once.\n   * It is the joint between performance and speed. When set to `0`, all actions will be sent instantly.\n   * Set it to a higher value when experiencing perf issues (also `maxAge` to a lower value).\n   *\n   * @default 500 ms.\n   */\n  latency?: number;\n  /**\n   * (> 1) - maximum allowed actions to be stored in the history tree. The oldest actions are removed once maxAge is reached. It's critical for performance.\n   *\n   * @default 50\n   */\n  maxAge?: number;\n  /**\n   * Customizes how actions and state are serialized and deserialized. Can be a boolean or object. If given a boolean, the behavior is the same as if you\n   * were to pass an object and specify `options` as a boolean. Giving an object allows fine-grained customization using the `replacer` and `reviver`\n   * functions.\n   */\n  serialize?:\n    | boolean\n    | {\n        /**\n         * - `undefined` - will use regular `JSON.stringify` to send data (it's the fast mode).\n         * - `false` - will handle also circular references.\n         * - `true` - will handle also date, regex, undefined, error objects, symbols, maps, sets and functions.\n         * - object, which contains `date`, `regex`, `undefined`, `error`, `symbol`, `map`, `set` and `function` keys.\n         *   For each of them you can indicate if to include (by setting as `true`).\n         *   For `function` key you can also specify a custom function which handles serialization.\n         *   See [`jsan`](https://github.com/kolodny/jsan) for more details.\n         */\n        options?:\n          | undefined\n          | boolean\n          | {\n              date?: true;\n              regex?: true;\n              undefined?: true;\n              error?: true;\n              symbol?: true;\n              map?: true;\n              set?: true;\n              function?: true | ((fn: (...args: any[]) => any) => string);\n            };\n        /**\n         * [JSON replacer function](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#The_replacer_parameter) used for both actions and states stringify.\n         * In addition, you can specify a data type by adding a [`__serializedType__`](https://github.com/zalmoxisus/remotedev-serialize/blob/master/helpers/index.js#L4)\n         * key. So you can deserialize it back while importing or persisting data.\n         * Moreover, it will also [show a nice preview showing the provided custom type](https://cloud.githubusercontent.com/assets/7957859/21814330/a17d556a-d761-11e6-85ef-159dd12f36c5.png):\n         */\n        replacer?: (key: string, value: unknown) => any;\n        /**\n         * [JSON `reviver` function](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse#Using_the_reviver_parameter)\n         * used for parsing the imported actions and states. See [`remotedev-serialize`](https://github.com/zalmoxisus/remotedev-serialize/blob/master/immutable/serialize.js#L8-L41)\n         * as an example on how to serialize special data types and get them back.\n         */\n        reviver?: (key: string, value: unknown) => any;\n      };\n  /**\n   * function which takes `action` object and id number as arguments, and should return `action` object back.\n   */\n  actionSanitizer?: <A extends Action>(action: A, id: number) => A;\n  /**\n   * function which takes `state` object and index as arguments, and should return `state` object back.\n   */\n  stateSanitizer?: <S>(state: S, index: number) => S;\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsWhitelist` specified, `actionsBlacklist` is ignored.\n   * @deprecated Use actionsDenylist instead.\n   */\n  actionsBlacklist?: string | string[];\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsWhitelist` specified, `actionsBlacklist` is ignored.\n   * @deprecated Use actionsAllowlist instead.\n   */\n  actionsWhitelist?: string | string[];\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsAllowlist` specified, `actionsDenylist` is ignored.\n   */\n  actionsDenylist?: string | string[];\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsAllowlist` specified, `actionsDenylist` is ignored.\n   */\n  actionsAllowlist?: string | string[];\n  /**\n   * called for every action before sending, takes `state` and `action` object, and returns `true` in case it allows sending the current data to the monitor.\n   * Use it as a more advanced version of `actionsDenylist`/`actionsAllowlist` parameters.\n   */\n  predicate?: <S, A extends Action>(state: S, action: A) => boolean;\n  /**\n   * if specified as `false`, it will not record the changes till clicking on `Start recording` button.\n   * Available only for Redux enhancer, for others use `autoPause`.\n   *\n   * @default true\n   */\n  shouldRecordChanges?: boolean;\n  /**\n   * if specified, whenever clicking on `Pause recording` button and there are actions in the history log, will add this action type.\n   * If not specified, will commit when paused. Available only for Redux enhancer.\n   *\n   * @default \"@@PAUSED\"\"\n   */\n  pauseActionType?: string;\n  /**\n   * auto pauses when the extension’s window is not opened, and so has zero impact on your app when not in use.\n   * Not available for Redux enhancer (as it already does it but storing the data to be sent).\n   *\n   * @default false\n   */\n  autoPause?: boolean;\n  /**\n   * if specified as `true`, it will not allow any non-monitor actions to be dispatched till clicking on `Unlock changes` button.\n   * Available only for Redux enhancer.\n   *\n   * @default false\n   */\n  shouldStartLocked?: boolean;\n  /**\n   * if set to `false`, will not recompute the states on hot reloading (or on replacing the reducers). Available only for Redux enhancer.\n   *\n   * @default true\n   */\n  shouldHotReload?: boolean;\n  /**\n   * if specified as `true`, whenever there's an exception in reducers, the monitors will show the error message, and next actions will not be dispatched.\n   *\n   * @default false\n   */\n  shouldCatchErrors?: boolean;\n  /**\n   * If you want to restrict the extension, specify the features you allow.\n   * If not specified, all of the features are enabled. When set as an object, only those included as `true` will be allowed.\n   * Note that except `true`/`false`, `import` and `export` can be set as `custom` (which is by default for Redux enhancer), meaning that the importing/exporting occurs on the client side.\n   * Otherwise, you'll get/set the data right from the monitor part.\n   */\n  features?: {\n    /**\n     * start/pause recording of dispatched actions\n     */\n    pause?: boolean;\n    /**\n     * lock/unlock dispatching actions and side effects\n     */\n    lock?: boolean;\n    /**\n     * persist states on page reloading\n     */\n    persist?: boolean;\n    /**\n     * export history of actions in a file\n     */\n    export?: boolean | 'custom';\n    /**\n     * import history of actions from a file\n     */\n    import?: boolean | 'custom';\n    /**\n     * jump back and forth (time travelling)\n     */\n    jump?: boolean;\n    /**\n     * skip (cancel) actions\n     */\n    skip?: boolean;\n    /**\n     * drag and drop actions in the history list\n     */\n    reorder?: boolean;\n    /**\n     * dispatch custom actions or action creators\n     */\n    dispatch?: boolean;\n    /**\n     * generate tests for the selected actions\n     */\n    test?: boolean;\n  };\n  /**\n   * Set to true or a stacktrace-returning function to record call stack traces for dispatched actions.\n   * Defaults to false.\n   */\n  trace?: boolean | (<A extends Action>(action: A) => string);\n  /**\n   * The maximum number of stack trace entries to record per action. Defaults to 10.\n   */\n  traceLimit?: number;\n}\n\nexport interface DevToolsConfig extends EnhancerOptions {\n  type?: string;\n}\n"],"mappings":"","ignoreList":[]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":[],"sources":["../../src/manager/devtoolsTypes.ts"],"sourcesContent":["import { ActionTypes } from '../actions.js';\nimport { State } from '../types.js';\n\ntype Action = ActionTypes;\ntype ActionCreator<T> = any;\n\n// taken from https://github.com/reduxjs/redux-devtools/blob/main/packages/redux-devtools-extension/src/index.ts\n\nexport interface EnhancerOptions {\n  /**\n   * the instance name to be showed on the monitor page. Default value is `document.title`.\n   * If not specified and there's no document title, it will consist of `tabId` and `instanceId`.\n   */\n  name?: string;\n  /**\n   * action creators functions to be available in the Dispatcher.\n   */\n  actionCreators?: ActionCreator<any>[] | { [key: string]: ActionCreator<any> };\n  /**\n   * if more than one action is dispatched in the indicated interval, all new actions will be collected and sent at once.\n   * It is the joint between performance and speed. When set to `0`, all actions will be sent instantly.\n   * Set it to a higher value when experiencing perf issues (also `maxAge` to a lower value).\n   *\n   * @default 500 ms.\n   */\n  latency?: number;\n  /**\n   * (> 1) - maximum allowed actions to be stored in the history tree. The oldest actions are removed once maxAge is reached. It's critical for performance.\n   *\n   * @default 50\n   */\n  maxAge?: number;\n  /**\n   * Customizes how actions and state are serialized and deserialized. Can be a boolean or object. If given a boolean, the behavior is the same as if you\n   * were to pass an object and specify `options` as a boolean. Giving an object allows fine-grained customization using the `replacer` and `reviver`\n   * functions.\n   */\n  serialize?:\n    | boolean\n    | {\n        /**\n         * - `undefined` - will use regular `JSON.stringify` to send data (it's the fast mode).\n         * - `false` - will handle also circular references.\n         * - `true` - will handle also date, regex, undefined, error objects, symbols, maps, sets and functions.\n         * - object, which contains `date`, `regex`, `undefined`, `error`, `symbol`, `map`, `set` and `function` keys.\n         *   For each of them you can indicate if to include (by setting as `true`).\n         *   For `function` key you can also specify a custom function which handles serialization.\n         *   See [`jsan`](https://github.com/kolodny/jsan) for more details.\n         */\n        options?:\n          | undefined\n          | boolean\n          | {\n              date?: true;\n              regex?: true;\n              undefined?: true;\n              error?: true;\n              symbol?: true;\n              map?: true;\n              set?: true;\n              function?: true | ((fn: (...args: any[]) => any) => string);\n            };\n        /**\n         * [JSON replacer function](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#The_replacer_parameter) used for both actions and states stringify.\n         * In addition, you can specify a data type by adding a [`__serializedType__`](https://github.com/zalmoxisus/remotedev-serialize/blob/master/helpers/index.js#L4)\n         * key. So you can deserialize it back while importing or persisting data.\n         * Moreover, it will also [show a nice preview showing the provided custom type](https://cloud.githubusercontent.com/assets/7957859/21814330/a17d556a-d761-11e6-85ef-159dd12f36c5.png):\n         */\n        replacer?: (key: string, value: unknown) => any;\n        /**\n         * [JSON `reviver` function](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse#Using_the_reviver_parameter)\n         * used for parsing the imported actions and states. See [`remotedev-serialize`](https://github.com/zalmoxisus/remotedev-serialize/blob/master/immutable/serialize.js#L8-L41)\n         * as an example on how to serialize special data types and get them back.\n         */\n        reviver?: (key: string, value: unknown) => any;\n      };\n  /**\n   * function which takes `action` object and id number as arguments, and should return `action` object back.\n   */\n  actionSanitizer?: <A extends Action>(action: A, id: number) => A;\n  /**\n   * function which takes `state` object and index as arguments, and should return `state` object back.\n   */\n  stateSanitizer?: <S extends State<unknown>>(state: S, index: number) => S;\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsWhitelist` specified, `actionsBlacklist` is ignored.\n   * @deprecated Use actionsDenylist instead.\n   */\n  actionsBlacklist?: string | string[];\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsWhitelist` specified, `actionsBlacklist` is ignored.\n   * @deprecated Use actionsAllowlist instead.\n   */\n  actionsWhitelist?: string | string[];\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsAllowlist` specified, `actionsDenylist` is ignored.\n   */\n  actionsDenylist?: string | string[];\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsAllowlist` specified, `actionsDenylist` is ignored.\n   */\n  actionsAllowlist?: string | string[];\n  /**\n   * called for every action before sending, takes `state` and `action` object, and returns `true` in case it allows sending the current data to the monitor.\n   * Use it as a more advanced version of `actionsDenylist`/`actionsAllowlist` parameters.\n   */\n  predicate?: <S extends State<unknown>, A extends Action>(\n    state: S,\n    action: A,\n  ) => boolean;\n  /**\n   * if specified as `false`, it will not record the changes till clicking on `Start recording` button.\n   * Available only for Redux enhancer, for others use `autoPause`.\n   *\n   * @default true\n   */\n  shouldRecordChanges?: boolean;\n  /**\n   * if specified, whenever clicking on `Pause recording` button and there are actions in the history log, will add this action type.\n   * If not specified, will commit when paused. Available only for Redux enhancer.\n   *\n   * @default \"@@PAUSED\"\"\n   */\n  pauseActionType?: string;\n  /**\n   * auto pauses when the extension’s window is not opened, and so has zero impact on your app when not in use.\n   * Not available for Redux enhancer (as it already does it but storing the data to be sent).\n   *\n   * @default false\n   */\n  autoPause?: boolean;\n  /**\n   * if specified as `true`, it will not allow any non-monitor actions to be dispatched till clicking on `Unlock changes` button.\n   * Available only for Redux enhancer.\n   *\n   * @default false\n   */\n  shouldStartLocked?: boolean;\n  /**\n   * if set to `false`, will not recompute the states on hot reloading (or on replacing the reducers). Available only for Redux enhancer.\n   *\n   * @default true\n   */\n  shouldHotReload?: boolean;\n  /**\n   * if specified as `true`, whenever there's an exception in reducers, the monitors will show the error message, and next actions will not be dispatched.\n   *\n   * @default false\n   */\n  shouldCatchErrors?: boolean;\n  /**\n   * If you want to restrict the extension, specify the features you allow.\n   * If not specified, all of the features are enabled. When set as an object, only those included as `true` will be allowed.\n   * Note that except `true`/`false`, `import` and `export` can be set as `custom` (which is by default for Redux enhancer), meaning that the importing/exporting occurs on the client side.\n   * Otherwise, you'll get/set the data right from the monitor part.\n   */\n  features?: {\n    /**\n     * start/pause recording of dispatched actions\n     */\n    pause?: boolean;\n    /**\n     * lock/unlock dispatching actions and side effects\n     */\n    lock?: boolean;\n    /**\n     * persist states on page reloading\n     */\n    persist?: boolean;\n    /**\n     * export history of actions in a file\n     */\n    export?: boolean | 'custom';\n    /**\n     * import history of actions from a file\n     */\n    import?: boolean | 'custom';\n    /**\n     * jump back and forth (time travelling)\n     */\n    jump?: boolean;\n    /**\n     * skip (cancel) actions\n     */\n    skip?: boolean;\n    /**\n     * drag and drop actions in the history list\n     */\n    reorder?: boolean;\n    /**\n     * dispatch custom actions or action creators\n     */\n    dispatch?: boolean;\n    /**\n     * generate tests for the selected actions\n     */\n    test?: boolean;\n  };\n  /**\n   * Set to true or a stacktrace-returning function to record call stack traces for dispatched actions.\n   * Defaults to false.\n   */\n  trace?: boolean | (<A extends Action>(action: A) => string);\n  /**\n   * The maximum number of stack trace entries to record per action. Defaults to 10.\n   */\n  traceLimit?: number;\n}\n\nexport interface DevToolsConfig extends EnhancerOptions {\n  type?: string;\n}\n"],"mappings":"","ignoreList":[]}

@@ -8,12 +8,5 @@ import { createOptimistic } from '../../controller/actions/createOptimistic.js';

});
} else {
// If 'fetch' action reaches the reducer there are no middlewares installed to handle it
/* istanbul ignore next */
if (process.env.NODE_ENV !== 'production') {
console.warn('Fetch appears unhandled - you are likely missing the NetworkManager middleware');
console.warn('See https://dataclient.io/docs/guides/redux for hooking up redux');
}
return state;
}
return state;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVPcHRpbWlzdGljIiwiZmV0Y2hSZWR1Y2VyIiwic3RhdGUiLCJhY3Rpb24iLCJlbmRwb2ludCIsImdldE9wdGltaXN0aWNSZXNwb25zZSIsInNpZGVFZmZlY3QiLCJzZXRBY3Rpb24iLCJhcmdzIiwibWV0YSIsImZldGNoZWRBdCIsIk9iamVjdCIsImFzc2lnbiIsIm9wdGltaXN0aWMiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJjb25zb2xlIiwid2FybiJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zdGF0ZS9yZWR1Y2VyL2ZldGNoUmVkdWNlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVPcHRpbWlzdGljIH0gZnJvbSAnLi4vLi4vY29udHJvbGxlci9hY3Rpb25zL2NyZWF0ZU9wdGltaXN0aWMuanMnO1xuaW1wb3J0IHR5cGUgeyBTdGF0ZSwgRmV0Y2hBY3Rpb24gfSBmcm9tICcuLi8uLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBmZXRjaFJlZHVjZXIoc3RhdGU6IFN0YXRlPHVua25vd24+LCBhY3Rpb246IEZldGNoQWN0aW9uKSB7XG4gIGlmIChhY3Rpb24uZW5kcG9pbnQuZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlICYmIGFjdGlvbi5lbmRwb2ludC5zaWRlRWZmZWN0KSB7XG4gICAgY29uc3Qgc2V0QWN0aW9uID0gY3JlYXRlT3B0aW1pc3RpYyhcbiAgICAgIGFjdGlvbi5lbmRwb2ludCxcbiAgICAgIGFjdGlvbi5hcmdzLFxuICAgICAgYWN0aW9uLm1ldGEuZmV0Y2hlZEF0LFxuICAgICk7XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnN0YXRlLFxuICAgICAgb3B0aW1pc3RpYzogWy4uLnN0YXRlLm9wdGltaXN0aWMsIHNldEFjdGlvbl0sXG4gICAgfTtcbiAgfSBlbHNlIHtcbiAgICAvLyBJZiAnZmV0Y2gnIGFjdGlvbiByZWFjaGVzIHRoZSByZWR1Y2VyIHRoZXJlIGFyZSBubyBtaWRkbGV3YXJlcyBpbnN0YWxsZWQgdG8gaGFuZGxlIGl0XG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJykge1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICAnRmV0Y2ggYXBwZWFycyB1bmhhbmRsZWQgLSB5b3UgYXJlIGxpa2VseSBtaXNzaW5nIHRoZSBOZXR3b3JrTWFuYWdlciBtaWRkbGV3YXJlJyxcbiAgICAgICk7XG4gICAgICBjb25zb2xlLndhcm4oXG4gICAgICAgICdTZWUgaHR0cHM6Ly9kYXRhY2xpZW50LmlvL2RvY3MvZ3VpZGVzL3JlZHV4IGZvciBob29raW5nIHVwIHJlZHV4JyxcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHN0YXRlO1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLGdCQUFnQixRQUFRLDhDQUE4QztBQUcvRSxPQUFPLFNBQVNDLFlBQVlBLENBQUNDLEtBQXFCLEVBQUVDLE1BQW1CLEVBQUU7RUFDdkUsSUFBSUEsTUFBTSxDQUFDQyxRQUFRLENBQUNDLHFCQUFxQixJQUFJRixNQUFNLENBQUNDLFFBQVEsQ0FBQ0UsVUFBVSxFQUFFO0lBQ3ZFLE1BQU1DLFNBQVMsR0FBR1AsZ0JBQWdCLENBQ2hDRyxNQUFNLENBQUNDLFFBQVEsRUFDZkQsTUFBTSxDQUFDSyxJQUFJLEVBQ1hMLE1BQU0sQ0FBQ00sSUFBSSxDQUFDQyxTQUNkLENBQUM7SUFDRCxPQUFBQyxNQUFBLENBQUFDLE1BQUEsS0FDS1YsS0FBSztNQUNSVyxVQUFVLEVBQUUsQ0FBQyxHQUFHWCxLQUFLLENBQUNXLFVBQVUsRUFBRU4sU0FBUztJQUFDO0VBRWhELENBQUMsTUFBTTtJQUNMO0lBQ0E7SUFDQSxJQUFJTyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLFlBQVksRUFBRTtNQUN6Q0MsT0FBTyxDQUFDQyxJQUFJLENBQ1YsZ0ZBQ0YsQ0FBQztNQUNERCxPQUFPLENBQUNDLElBQUksQ0FDVixrRUFDRixDQUFDO0lBQ0g7SUFFQSxPQUFPaEIsS0FBSztFQUNkO0FBQ0YiLCJpZ25vcmVMaXN0IjpbXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVPcHRpbWlzdGljIiwiZmV0Y2hSZWR1Y2VyIiwic3RhdGUiLCJhY3Rpb24iLCJlbmRwb2ludCIsImdldE9wdGltaXN0aWNSZXNwb25zZSIsInNpZGVFZmZlY3QiLCJzZXRBY3Rpb24iLCJhcmdzIiwibWV0YSIsImZldGNoZWRBdCIsIk9iamVjdCIsImFzc2lnbiIsIm9wdGltaXN0aWMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc3RhdGUvcmVkdWNlci9mZXRjaFJlZHVjZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlT3B0aW1pc3RpYyB9IGZyb20gJy4uLy4uL2NvbnRyb2xsZXIvYWN0aW9ucy9jcmVhdGVPcHRpbWlzdGljLmpzJztcbmltcG9ydCB0eXBlIHsgU3RhdGUsIEZldGNoQWN0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZmV0Y2hSZWR1Y2VyKHN0YXRlOiBTdGF0ZTx1bmtub3duPiwgYWN0aW9uOiBGZXRjaEFjdGlvbikge1xuICBpZiAoYWN0aW9uLmVuZHBvaW50LmdldE9wdGltaXN0aWNSZXNwb25zZSAmJiBhY3Rpb24uZW5kcG9pbnQuc2lkZUVmZmVjdCkge1xuICAgIGNvbnN0IHNldEFjdGlvbiA9IGNyZWF0ZU9wdGltaXN0aWMoXG4gICAgICBhY3Rpb24uZW5kcG9pbnQsXG4gICAgICBhY3Rpb24uYXJncyxcbiAgICAgIGFjdGlvbi5tZXRhLmZldGNoZWRBdCxcbiAgICApO1xuICAgIHJldHVybiB7XG4gICAgICAuLi5zdGF0ZSxcbiAgICAgIG9wdGltaXN0aWM6IFsuLi5zdGF0ZS5vcHRpbWlzdGljLCBzZXRBY3Rpb25dLFxuICAgIH07XG4gIH1cbiAgcmV0dXJuIHN0YXRlO1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxnQkFBZ0IsUUFBUSw4Q0FBOEM7QUFHL0UsT0FBTyxTQUFTQyxZQUFZQSxDQUFDQyxLQUFxQixFQUFFQyxNQUFtQixFQUFFO0VBQ3ZFLElBQUlBLE1BQU0sQ0FBQ0MsUUFBUSxDQUFDQyxxQkFBcUIsSUFBSUYsTUFBTSxDQUFDQyxRQUFRLENBQUNFLFVBQVUsRUFBRTtJQUN2RSxNQUFNQyxTQUFTLEdBQUdQLGdCQUFnQixDQUNoQ0csTUFBTSxDQUFDQyxRQUFRLEVBQ2ZELE1BQU0sQ0FBQ0ssSUFBSSxFQUNYTCxNQUFNLENBQUNNLElBQUksQ0FBQ0MsU0FDZCxDQUFDO0lBQ0QsT0FBQUMsTUFBQSxDQUFBQyxNQUFBLEtBQ0tWLEtBQUs7TUFDUlcsVUFBVSxFQUFFLENBQUMsR0FBR1gsS0FBSyxDQUFDVyxVQUFVLEVBQUVOLFNBQVM7SUFBQztFQUVoRDtFQUNBLE9BQU9MLEtBQUs7QUFDZCIsImlnbm9yZUxpc3QiOltdfQ==

@@ -21,8 +21,8 @@ import { FETCH_TYPE } from '../../actionTypes.js';

type: FETCH_TYPE,
key: endpoint.key(...args),
args,
endpoint,
args,
key: endpoint.key(...args),
meta
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiY3JlYXRlRmV0Y2giLCJlbmRwb2ludCIsImFyZ3MiLCJyZXNvbHZlIiwicmVqZWN0IiwicHJvbWlzZSIsIlByb21pc2UiLCJhIiwiYiIsIm1ldGEiLCJmZXRjaGVkQXQiLCJEYXRlIiwibm93IiwidHlwZSIsImtleSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlRmV0Y2gudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbmRwb2ludEludGVyZmFjZSwgTkkgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgRkVUQ0hfVFlQRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgRmV0Y2hBY3Rpb24sIEZldGNoTWV0YSB9IGZyb20gJy4uLy4uL3R5cGVzLmpzJztcbmltcG9ydCB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbi8qKlxuICogUmVxdWVzdGluZyBhIGZldGNoIHRvIGJlZ2luXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVGZXRjaDxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYgeyB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEU+IH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgeyBhcmdzIH06IHsgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dIH0sXG4pOiBGZXRjaEFjdGlvbjxFPiB7XG4gIGxldCByZXNvbHZlOiAodmFsdWU/OiBhbnkgfCBQcm9taXNlTGlrZTxhbnk+KSA9PiB2b2lkID0gMCBhcyBhbnk7XG4gIGxldCByZWplY3Q6IChyZWFzb24/OiBhbnkpID0+IHZvaWQgPSAwIGFzIGFueTtcbiAgY29uc3QgcHJvbWlzZSA9IG5ldyBQcm9taXNlPGFueT4oKGEsIGIpID0+IHtcbiAgICBbcmVzb2x2ZSwgcmVqZWN0XSA9IFthLCBiXTtcbiAgfSk7XG4gIGNvbnN0IG1ldGE6IEZldGNoTWV0YSA9IHtcbiAgICBmZXRjaGVkQXQ6IERhdGUubm93KCksXG4gICAgcmVzb2x2ZSxcbiAgICByZWplY3QsXG4gICAgcHJvbWlzZSxcbiAgfTtcblxuICByZXR1cm4ge1xuICAgIHR5cGU6IEZFVENIX1RZUEUsXG4gICAgZW5kcG9pbnQsXG4gICAgYXJncyxcbiAgICBrZXk6IGVuZHBvaW50LmtleSguLi5hcmdzKSxcbiAgICBtZXRhLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFFQSxTQUFTQSxVQUFVLFFBQVEsc0JBQXNCO0FBSWpEO0FBQ0E7QUFDQTtBQUNBLE9BQU8sU0FBU0MsV0FBV0EsQ0FHekJDLFFBQVcsRUFDWDtFQUFFQztBQUE0QyxDQUFDLEVBQy9CO0VBQ2hCLElBQUlDLE9BQWlELEdBQUcsQ0FBUTtFQUNoRSxJQUFJQyxNQUE4QixHQUFHLENBQVE7RUFDN0MsTUFBTUMsT0FBTyxHQUFHLElBQUlDLE9BQU8sQ0FBTSxDQUFDQyxDQUFDLEVBQUVDLENBQUMsS0FBSztJQUN6QyxDQUFDTCxPQUFPLEVBQUVDLE1BQU0sQ0FBQyxHQUFHLENBQUNHLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0VBQzVCLENBQUMsQ0FBQztFQUNGLE1BQU1DLElBQWUsR0FBRztJQUN0QkMsU0FBUyxFQUFFQyxJQUFJLENBQUNDLEdBQUcsQ0FBQyxDQUFDO0lBQ3JCVCxPQUFPO0lBQ1BDLE1BQU07SUFDTkM7RUFDRixDQUFDO0VBRUQsT0FBTztJQUNMUSxJQUFJLEVBQUVkLFVBQVU7SUFDaEJFLFFBQVE7SUFDUkMsSUFBSTtJQUNKWSxHQUFHLEVBQUViLFFBQVEsQ0FBQ2EsR0FBRyxDQUFDLEdBQUdaLElBQUksQ0FBQztJQUMxQk87RUFDRixDQUFDO0FBQ0giLCJpZ25vcmVMaXN0IjpbXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiY3JlYXRlRmV0Y2giLCJlbmRwb2ludCIsImFyZ3MiLCJyZXNvbHZlIiwicmVqZWN0IiwicHJvbWlzZSIsIlByb21pc2UiLCJhIiwiYiIsIm1ldGEiLCJmZXRjaGVkQXQiLCJEYXRlIiwibm93IiwidHlwZSIsImtleSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlRmV0Y2gudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbmRwb2ludEludGVyZmFjZSwgTkkgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgRkVUQ0hfVFlQRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgRmV0Y2hBY3Rpb24sIEZldGNoTWV0YSB9IGZyb20gJy4uLy4uL3R5cGVzLmpzJztcbmltcG9ydCB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbi8qKlxuICogUmVxdWVzdGluZyBhIGZldGNoIHRvIGJlZ2luXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVGZXRjaDxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYgeyB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEU+IH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgeyBhcmdzIH06IHsgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dIH0sXG4pOiBGZXRjaEFjdGlvbjxFPiB7XG4gIGxldCByZXNvbHZlOiAodmFsdWU/OiBhbnkgfCBQcm9taXNlTGlrZTxhbnk+KSA9PiB2b2lkID0gMCBhcyBhbnk7XG4gIGxldCByZWplY3Q6IChyZWFzb24/OiBhbnkpID0+IHZvaWQgPSAwIGFzIGFueTtcbiAgY29uc3QgcHJvbWlzZSA9IG5ldyBQcm9taXNlPGFueT4oKGEsIGIpID0+IHtcbiAgICBbcmVzb2x2ZSwgcmVqZWN0XSA9IFthLCBiXTtcbiAgfSk7XG4gIGNvbnN0IG1ldGE6IEZldGNoTWV0YSA9IHtcbiAgICBmZXRjaGVkQXQ6IERhdGUubm93KCksXG4gICAgcmVzb2x2ZSxcbiAgICByZWplY3QsXG4gICAgcHJvbWlzZSxcbiAgfTtcblxuICByZXR1cm4ge1xuICAgIHR5cGU6IEZFVENIX1RZUEUsXG4gICAga2V5OiBlbmRwb2ludC5rZXkoLi4uYXJncyksXG4gICAgYXJncyxcbiAgICBlbmRwb2ludCxcbiAgICBtZXRhLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFFQSxTQUFTQSxVQUFVLFFBQVEsc0JBQXNCO0FBSWpEO0FBQ0E7QUFDQTtBQUNBLE9BQU8sU0FBU0MsV0FBV0EsQ0FHekJDLFFBQVcsRUFDWDtFQUFFQztBQUE0QyxDQUFDLEVBQy9CO0VBQ2hCLElBQUlDLE9BQWlELEdBQUcsQ0FBUTtFQUNoRSxJQUFJQyxNQUE4QixHQUFHLENBQVE7RUFDN0MsTUFBTUMsT0FBTyxHQUFHLElBQUlDLE9BQU8sQ0FBTSxDQUFDQyxDQUFDLEVBQUVDLENBQUMsS0FBSztJQUN6QyxDQUFDTCxPQUFPLEVBQUVDLE1BQU0sQ0FBQyxHQUFHLENBQUNHLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0VBQzVCLENBQUMsQ0FBQztFQUNGLE1BQU1DLElBQWUsR0FBRztJQUN0QkMsU0FBUyxFQUFFQyxJQUFJLENBQUNDLEdBQUcsQ0FBQyxDQUFDO0lBQ3JCVCxPQUFPO0lBQ1BDLE1BQU07SUFDTkM7RUFDRixDQUFDO0VBRUQsT0FBTztJQUNMUSxJQUFJLEVBQUVkLFVBQVU7SUFDaEJlLEdBQUcsRUFBRWIsUUFBUSxDQUFDYSxHQUFHLENBQUMsR0FBR1osSUFBSSxDQUFDO0lBQzFCQSxJQUFJO0lBQ0pELFFBQVE7SUFDUlE7RUFDRixDQUFDO0FBQ0giLCJpZ25vcmVMaXN0IjpbXX0=

@@ -11,8 +11,8 @@ import { createMeta } from './createMeta.js';

type: OPTIMISTIC_TYPE,
key: endpoint.key(...args),
args,
endpoint,
args,
key: endpoint.key(...args),
meta: createMeta((_endpoint$dataExpiryL2 = endpoint.dataExpiryLength) != null ? _endpoint$dataExpiryL2 : 60000, fetchedAt)
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVNZXRhIiwiT1BUSU1JU1RJQ19UWVBFIiwiY3JlYXRlT3B0aW1pc3RpYyIsImVuZHBvaW50IiwiYXJncyIsImZldGNoZWRBdCIsIl9lbmRwb2ludCRkYXRhRXhwaXJ5TCIsIl9lbmRwb2ludCRkYXRhRXhwaXJ5TDIiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwiRXJyb3IiLCJ0eXBlIiwia2V5IiwibWV0YSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlT3B0aW1pc3RpYy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlIH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB7IGNyZWF0ZU1ldGEgfSBmcm9tICcuL2NyZWF0ZU1ldGEuanMnO1xuaW1wb3J0IHsgT1BUSU1JU1RJQ19UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBPcHRpbWlzdGljQWN0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlT3B0aW1pc3RpYzxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYge1xuICAgIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG4gIH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dLFxuICBmZXRjaGVkQXQ6IG51bWJlcixcbik6IE9wdGltaXN0aWNBY3Rpb248RT4ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAoXG4gICAgcHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiZcbiAgICAoZW5kcG9pbnQuZGF0YUV4cGlyeUxlbmd0aCA/PyAwKSA8IDBcbiAgKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdOZWdhdGl2ZSBleHBpcnkgbGVuZ3RoIGFyZSBub3QgYWxsb3dlZC4nKTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgdHlwZTogT1BUSU1JU1RJQ19UWVBFLFxuICAgIGVuZHBvaW50LFxuICAgIGFyZ3MsXG4gICAga2V5OiBlbmRwb2ludC5rZXkoLi4uYXJncyksXG4gICAgbWV0YTogY3JlYXRlTWV0YShlbmRwb2ludC5kYXRhRXhwaXJ5TGVuZ3RoID8/IDYwMDAwLCBmZXRjaGVkQXQpLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFFQSxTQUFTQSxVQUFVLFFBQVEsaUJBQWlCO0FBQzVDLFNBQVNDLGVBQWUsUUFBUSxzQkFBc0I7QUFJdEQsT0FBTyxTQUFTQyxnQkFBZ0JBLENBSzlCQyxRQUFXLEVBQ1hDLElBQWlDLEVBQ2pDQyxTQUFpQixFQUNJO0VBQUEsSUFBQUMscUJBQUEsRUFBQUMsc0JBQUE7RUFDckI7RUFDQSxJQUNFQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLGFBQWEsSUFDdEMsRUFBQUoscUJBQUEsR0FBQ0gsUUFBUSxDQUFDUSxnQkFBZ0IsWUFBQUwscUJBQUEsR0FBSSxDQUFDLElBQUksQ0FBQyxFQUNwQztJQUNBLE1BQU0sSUFBSU0sS0FBSyxDQUFDLHlDQUF5QyxDQUFDO0VBQzVEO0VBRUEsT0FBTztJQUNMQyxJQUFJLEVBQUVaLGVBQWU7SUFDckJFLFFBQVE7SUFDUkMsSUFBSTtJQUNKVSxHQUFHLEVBQUVYLFFBQVEsQ0FBQ1csR0FBRyxDQUFDLEdBQUdWLElBQUksQ0FBQztJQUMxQlcsSUFBSSxFQUFFZixVQUFVLEVBQUFPLHNCQUFBLEdBQUNKLFFBQVEsQ0FBQ1EsZ0JBQWdCLFlBQUFKLHNCQUFBLEdBQUksS0FBSyxFQUFFRixTQUFTO0VBQ2hFLENBQUM7QUFDSCIsImlnbm9yZUxpc3QiOltdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVNZXRhIiwiT1BUSU1JU1RJQ19UWVBFIiwiY3JlYXRlT3B0aW1pc3RpYyIsImVuZHBvaW50IiwiYXJncyIsImZldGNoZWRBdCIsIl9lbmRwb2ludCRkYXRhRXhwaXJ5TCIsIl9lbmRwb2ludCRkYXRhRXhwaXJ5TDIiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwiRXJyb3IiLCJ0eXBlIiwia2V5IiwibWV0YSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlT3B0aW1pc3RpYy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlIH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB7IGNyZWF0ZU1ldGEgfSBmcm9tICcuL2NyZWF0ZU1ldGEuanMnO1xuaW1wb3J0IHsgT1BUSU1JU1RJQ19UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBPcHRpbWlzdGljQWN0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlT3B0aW1pc3RpYzxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYge1xuICAgIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG4gIH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dLFxuICBmZXRjaGVkQXQ6IG51bWJlcixcbik6IE9wdGltaXN0aWNBY3Rpb248RT4ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAoXG4gICAgcHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiZcbiAgICAoZW5kcG9pbnQuZGF0YUV4cGlyeUxlbmd0aCA/PyAwKSA8IDBcbiAgKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdOZWdhdGl2ZSBleHBpcnkgbGVuZ3RoIGFyZSBub3QgYWxsb3dlZC4nKTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgdHlwZTogT1BUSU1JU1RJQ19UWVBFLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICAgIGFyZ3MsXG4gICAgZW5kcG9pbnQsXG4gICAgbWV0YTogY3JlYXRlTWV0YShlbmRwb2ludC5kYXRhRXhwaXJ5TGVuZ3RoID8/IDYwMDAwLCBmZXRjaGVkQXQpLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFFQSxTQUFTQSxVQUFVLFFBQVEsaUJBQWlCO0FBQzVDLFNBQVNDLGVBQWUsUUFBUSxzQkFBc0I7QUFJdEQsT0FBTyxTQUFTQyxnQkFBZ0JBLENBSzlCQyxRQUFXLEVBQ1hDLElBQWlDLEVBQ2pDQyxTQUFpQixFQUNJO0VBQUEsSUFBQUMscUJBQUEsRUFBQUMsc0JBQUE7RUFDckI7RUFDQSxJQUNFQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLGFBQWEsSUFDdEMsRUFBQUoscUJBQUEsR0FBQ0gsUUFBUSxDQUFDUSxnQkFBZ0IsWUFBQUwscUJBQUEsR0FBSSxDQUFDLElBQUksQ0FBQyxFQUNwQztJQUNBLE1BQU0sSUFBSU0sS0FBSyxDQUFDLHlDQUF5QyxDQUFDO0VBQzVEO0VBRUEsT0FBTztJQUNMQyxJQUFJLEVBQUVaLGVBQWU7SUFDckJhLEdBQUcsRUFBRVgsUUFBUSxDQUFDVyxHQUFHLENBQUMsR0FBR1YsSUFBSSxDQUFDO0lBQzFCQSxJQUFJO0lBQ0pELFFBQVE7SUFDUlksSUFBSSxFQUFFZixVQUFVLEVBQUFPLHNCQUFBLEdBQUNKLFFBQVEsQ0FBQ1EsZ0JBQWdCLFlBQUFKLHNCQUFBLEdBQUksS0FBSyxFQUFFRixTQUFTO0VBQ2hFLENBQUM7QUFDSCIsImlnbm9yZUxpc3QiOltdfQ==

@@ -11,8 +11,8 @@ import { createMeta } from './createMeta.js';

type: SET_TYPE,
schema,
value,
args: args.map(ensurePojo),
schema,
meta: createMeta(60000, fetchedAt)
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVNZXRhIiwiU0VUX1RZUEUiLCJlbnN1cmVQb2pvIiwiY3JlYXRlU2V0Iiwic2NoZW1hIiwiYXJncyIsImZldGNoZWRBdCIsInZhbHVlIiwidHlwZSIsIm1hcCIsIm1ldGEiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udHJvbGxlci9hY3Rpb25zL2NyZWF0ZVNldC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIERlbm9ybWFsaXplLFxuICBRdWVyeWFibGUsXG4gIFNjaGVtYUFyZ3MsXG59IGZyb20gJ0BkYXRhLWNsaWVudC9ub3JtYWxpenInO1xuXG5pbXBvcnQgeyBjcmVhdGVNZXRhIH0gZnJvbSAnLi9jcmVhdGVNZXRhLmpzJztcbmltcG9ydCB7IFNFVF9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBTZXRBY3Rpb24gfSBmcm9tICcuLi8uLi90eXBlcy5qcyc7XG5pbXBvcnQgZW5zdXJlUG9qbyBmcm9tICcuLi9lbnN1cmVQb2pvLmpzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVNldDxTIGV4dGVuZHMgUXVlcnlhYmxlPihcbiAgc2NoZW1hOiBTLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gICAgdmFsdWUsXG4gIH06IHtcbiAgICBhcmdzOiByZWFkb25seSBbLi4uU2NoZW1hQXJnczxTPl07XG4gICAgdmFsdWU6IHt9IHwgKChwcmV2aW91c1ZhbHVlOiBEZW5vcm1hbGl6ZTxTPikgPT4ge30pO1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgfSxcbik6IFNldEFjdGlvbjxTPiB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogU0VUX1RZUEUsXG4gICAgc2NoZW1hLFxuICAgIHZhbHVlLFxuICAgIGFyZ3M6IGFyZ3MubWFwKGVuc3VyZVBvam8pIGFzIFNjaGVtYUFyZ3M8Uz4sXG4gICAgbWV0YTogY3JlYXRlTWV0YSg2MDAwMCwgZmV0Y2hlZEF0KSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBTUEsU0FBU0EsVUFBVSxRQUFRLGlCQUFpQjtBQUM1QyxTQUFTQyxRQUFRLFFBQVEsc0JBQXNCO0FBRS9DLE9BQU9DLFVBQVUsTUFBTSxrQkFBa0I7QUFFekMsT0FBTyxTQUFTQyxTQUFTQSxDQUN2QkMsTUFBUyxFQUNUO0VBQ0VDLElBQUk7RUFDSkMsU0FBUztFQUNUQztBQUtGLENBQUMsRUFDYTtFQUNkLE9BQU87SUFDTEMsSUFBSSxFQUFFUCxRQUFRO0lBQ2RHLE1BQU07SUFDTkcsS0FBSztJQUNMRixJQUFJLEVBQUVBLElBQUksQ0FBQ0ksR0FBRyxDQUFDUCxVQUFVLENBQWtCO0lBQzNDUSxJQUFJLEVBQUVWLFVBQVUsQ0FBQyxLQUFLLEVBQUVNLFNBQVM7RUFDbkMsQ0FBQztBQUNIIiwiaWdub3JlTGlzdCI6W119
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVNZXRhIiwiU0VUX1RZUEUiLCJlbnN1cmVQb2pvIiwiY3JlYXRlU2V0Iiwic2NoZW1hIiwiYXJncyIsImZldGNoZWRBdCIsInZhbHVlIiwidHlwZSIsIm1hcCIsIm1ldGEiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udHJvbGxlci9hY3Rpb25zL2NyZWF0ZVNldC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIERlbm9ybWFsaXplLFxuICBRdWVyeWFibGUsXG4gIFNjaGVtYUFyZ3MsXG59IGZyb20gJ0BkYXRhLWNsaWVudC9ub3JtYWxpenInO1xuXG5pbXBvcnQgeyBjcmVhdGVNZXRhIH0gZnJvbSAnLi9jcmVhdGVNZXRhLmpzJztcbmltcG9ydCB7IFNFVF9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBTZXRBY3Rpb24gfSBmcm9tICcuLi8uLi90eXBlcy5qcyc7XG5pbXBvcnQgZW5zdXJlUG9qbyBmcm9tICcuLi9lbnN1cmVQb2pvLmpzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVNldDxTIGV4dGVuZHMgUXVlcnlhYmxlPihcbiAgc2NoZW1hOiBTLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gICAgdmFsdWUsXG4gIH06IHtcbiAgICBhcmdzOiByZWFkb25seSBbLi4uU2NoZW1hQXJnczxTPl07XG4gICAgdmFsdWU6IHt9IHwgKChwcmV2aW91c1ZhbHVlOiBEZW5vcm1hbGl6ZTxTPikgPT4ge30pO1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgfSxcbik6IFNldEFjdGlvbjxTPiB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogU0VUX1RZUEUsXG4gICAgdmFsdWUsXG4gICAgYXJnczogYXJncy5tYXAoZW5zdXJlUG9qbykgYXMgU2NoZW1hQXJnczxTPixcbiAgICBzY2hlbWEsXG4gICAgbWV0YTogY3JlYXRlTWV0YSg2MDAwMCwgZmV0Y2hlZEF0KSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBTUEsU0FBU0EsVUFBVSxRQUFRLGlCQUFpQjtBQUM1QyxTQUFTQyxRQUFRLFFBQVEsc0JBQXNCO0FBRS9DLE9BQU9DLFVBQVUsTUFBTSxrQkFBa0I7QUFFekMsT0FBTyxTQUFTQyxTQUFTQSxDQUN2QkMsTUFBUyxFQUNUO0VBQ0VDLElBQUk7RUFDSkMsU0FBUztFQUNUQztBQUtGLENBQUMsRUFDYTtFQUNkLE9BQU87SUFDTEMsSUFBSSxFQUFFUCxRQUFRO0lBQ2RNLEtBQUs7SUFDTEYsSUFBSSxFQUFFQSxJQUFJLENBQUNJLEdBQUcsQ0FBQ1AsVUFBVSxDQUFrQjtJQUMzQ0UsTUFBTTtJQUNOTSxJQUFJLEVBQUVWLFVBQVUsQ0FBQyxLQUFLLEVBQUVNLFNBQVM7RUFDbkMsQ0FBQztBQUNIIiwiaWdub3JlTGlzdCI6W119

@@ -18,6 +18,6 @@ import { createMeta } from './createMeta.js';

type: SET_RESPONSE_TYPE,
endpoint,
key: endpoint.key(...args),
response,
args: args.map(ensurePojo),
key: endpoint.key(...args),
endpoint,
meta: createMeta(expiryLength, fetchedAt),

@@ -27,2 +27,2 @@ error

}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVNZXRhIiwiU0VUX1JFU1BPTlNFX1RZUEUiLCJlbnN1cmVQb2pvIiwiY3JlYXRlU2V0UmVzcG9uc2UiLCJlbmRwb2ludCIsImFyZ3MiLCJmZXRjaGVkQXQiLCJyZXNwb25zZSIsImVycm9yIiwiX2VuZHBvaW50JGVycm9yRXhwaXJ5IiwiX2VuZHBvaW50JGRhdGFFeHBpcnlMIiwiZXhwaXJ5TGVuZ3RoIiwiZXJyb3JFeHBpcnlMZW5ndGgiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiRXJyb3IiLCJ0eXBlIiwibWFwIiwia2V5IiwibWV0YSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlU2V0UmVzcG9uc2UudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbmRwb2ludEludGVyZmFjZSwgUmVzb2x2ZVR5cGUgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgY3JlYXRlTWV0YSB9IGZyb20gJy4vY3JlYXRlTWV0YS5qcyc7XG5pbXBvcnQgeyBTRVRfUkVTUE9OU0VfVFlQRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgU2V0UmVzcG9uc2VBY3Rpb24gfSBmcm9tICcuLi8uLi90eXBlcy5qcyc7XG5pbXBvcnQgZW5zdXJlUG9qbyBmcm9tICcuLi9lbnN1cmVQb2pvLmpzJztcbmltcG9ydCB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTZXRSZXNwb25zZTxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYge1xuICAgIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG4gIH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgb3B0aW9uczoge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogRXJyb3I7XG4gICAgZmV0Y2hlZEF0PzogbnVtYmVyO1xuICAgIGVycm9yOiB0cnVlO1xuICB9LFxuKTogU2V0UmVzcG9uc2VBY3Rpb248RT47XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTZXRSZXNwb25zZTxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYge1xuICAgIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG4gIH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgb3B0aW9uczoge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogUmVzb2x2ZVR5cGU8RT47XG4gICAgZmV0Y2hlZEF0PzogbnVtYmVyO1xuICAgIGVycm9yPzogZmFsc2U7XG4gIH0sXG4pOiBTZXRSZXNwb25zZUFjdGlvbjxFPjtcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVNldFJlc3BvbnNlPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gICAgcmVzcG9uc2UsXG4gICAgZXJyb3IgPSBmYWxzZSxcbiAgfToge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogYW55O1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgICBlcnJvcj86IGJvb2xlYW47XG4gIH0sXG4pOiBTZXRSZXNwb25zZUFjdGlvbjxFPiB7XG4gIGNvbnN0IGV4cGlyeUxlbmd0aDogbnVtYmVyID1cbiAgICBlcnJvciA/XG4gICAgICAoZW5kcG9pbnQuZXJyb3JFeHBpcnlMZW5ndGggPz8gMTAwMClcbiAgICA6IChlbmRwb2ludC5kYXRhRXhwaXJ5TGVuZ3RoID8/IDYwMDAwKTtcbiAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WID09PSAnZGV2ZWxvcG1lbnQnICYmIGV4cGlyeUxlbmd0aCA8IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ05lZ2F0aXZlIGV4cGlyeSBsZW5ndGggYXJlIG5vdCBhbGxvd2VkLicpO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBTRVRfUkVTUE9OU0VfVFlQRSxcbiAgICBlbmRwb2ludCxcbiAgICByZXNwb25zZSxcbiAgICBhcmdzOiBhcmdzLm1hcChlbnN1cmVQb2pvKSxcbiAgICBrZXk6IGVuZHBvaW50LmtleSguLi5hcmdzKSxcbiAgICBtZXRhOiBjcmVhdGVNZXRhKGV4cGlyeUxlbmd0aCwgZmV0Y2hlZEF0KSxcbiAgICBlcnJvcixcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBRUEsU0FBU0EsVUFBVSxRQUFRLGlCQUFpQjtBQUM1QyxTQUFTQyxpQkFBaUIsUUFBUSxzQkFBc0I7QUFFeEQsT0FBT0MsVUFBVSxNQUFNLGtCQUFrQjtBQStCekMsT0FBTyxTQUFTQyxpQkFBaUJBLENBSy9CQyxRQUFXLEVBQ1g7RUFDRUMsSUFBSTtFQUNKQyxTQUFTO0VBQ1RDLFFBQVE7RUFDUkMsS0FBSyxHQUFHO0FBTVYsQ0FBQyxFQUNxQjtFQUFBLElBQUFDLHFCQUFBLEVBQUFDLHFCQUFBO0VBQ3RCLE1BQU1DLFlBQW9CLEdBQ3hCSCxLQUFLLElBQUFDLHFCQUFBLEdBQ0ZMLFFBQVEsQ0FBQ1EsaUJBQWlCLFlBQUFILHFCQUFBLEdBQUksSUFBSSxJQUFBQyxxQkFBQSxHQUNsQ04sUUFBUSxDQUFDUyxnQkFBZ0IsWUFBQUgscUJBQUEsR0FBSSxLQUFNO0VBQ3hDO0VBQ0EsSUFBSUksT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlMLFlBQVksR0FBRyxDQUFDLEVBQUU7SUFDOUQsTUFBTSxJQUFJTSxLQUFLLENBQUMseUNBQXlDLENBQUM7RUFDNUQ7RUFFQSxPQUFPO0lBQ0xDLElBQUksRUFBRWpCLGlCQUFpQjtJQUN2QkcsUUFBUTtJQUNSRyxRQUFRO0lBQ1JGLElBQUksRUFBRUEsSUFBSSxDQUFDYyxHQUFHLENBQUNqQixVQUFVLENBQUM7SUFDMUJrQixHQUFHLEVBQUVoQixRQUFRLENBQUNnQixHQUFHLENBQUMsR0FBR2YsSUFBSSxDQUFDO0lBQzFCZ0IsSUFBSSxFQUFFckIsVUFBVSxDQUFDVyxZQUFZLEVBQUVMLFNBQVMsQ0FBQztJQUN6Q0U7RUFDRixDQUFDO0FBQ0giLCJpZ25vcmVMaXN0IjpbXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVNZXRhIiwiU0VUX1JFU1BPTlNFX1RZUEUiLCJlbnN1cmVQb2pvIiwiY3JlYXRlU2V0UmVzcG9uc2UiLCJlbmRwb2ludCIsImFyZ3MiLCJmZXRjaGVkQXQiLCJyZXNwb25zZSIsImVycm9yIiwiX2VuZHBvaW50JGVycm9yRXhwaXJ5IiwiX2VuZHBvaW50JGRhdGFFeHBpcnlMIiwiZXhwaXJ5TGVuZ3RoIiwiZXJyb3JFeHBpcnlMZW5ndGgiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiRXJyb3IiLCJ0eXBlIiwia2V5IiwibWFwIiwibWV0YSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sbGVyL2FjdGlvbnMvY3JlYXRlU2V0UmVzcG9uc2UudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbmRwb2ludEludGVyZmFjZSwgUmVzb2x2ZVR5cGUgfSBmcm9tICdAZGF0YS1jbGllbnQvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgY3JlYXRlTWV0YSB9IGZyb20gJy4vY3JlYXRlTWV0YS5qcyc7XG5pbXBvcnQgeyBTRVRfUkVTUE9OU0VfVFlQRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB0eXBlIHsgU2V0UmVzcG9uc2VBY3Rpb24gfSBmcm9tICcuLi8uLi90eXBlcy5qcyc7XG5pbXBvcnQgZW5zdXJlUG9qbyBmcm9tICcuLi9lbnN1cmVQb2pvLmpzJztcbmltcG9ydCB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTZXRSZXNwb25zZTxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYge1xuICAgIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG4gIH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgb3B0aW9uczoge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogRXJyb3I7XG4gICAgZmV0Y2hlZEF0PzogbnVtYmVyO1xuICAgIGVycm9yOiB0cnVlO1xuICB9LFxuKTogU2V0UmVzcG9uc2VBY3Rpb248RT47XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTZXRSZXNwb25zZTxcbiAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYge1xuICAgIHVwZGF0ZT86IEVuZHBvaW50VXBkYXRlRnVuY3Rpb248RT47XG4gIH0sXG4+KFxuICBlbmRwb2ludDogRSxcbiAgb3B0aW9uczoge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogUmVzb2x2ZVR5cGU8RT47XG4gICAgZmV0Y2hlZEF0PzogbnVtYmVyO1xuICAgIGVycm9yPzogZmFsc2U7XG4gIH0sXG4pOiBTZXRSZXNwb25zZUFjdGlvbjxFPjtcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVNldFJlc3BvbnNlPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gICAgcmVzcG9uc2UsXG4gICAgZXJyb3IgPSBmYWxzZSxcbiAgfToge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogYW55O1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgICBlcnJvcj86IGJvb2xlYW47XG4gIH0sXG4pOiBTZXRSZXNwb25zZUFjdGlvbjxFPiB7XG4gIGNvbnN0IGV4cGlyeUxlbmd0aDogbnVtYmVyID1cbiAgICBlcnJvciA/XG4gICAgICAoZW5kcG9pbnQuZXJyb3JFeHBpcnlMZW5ndGggPz8gMTAwMClcbiAgICA6IChlbmRwb2ludC5kYXRhRXhwaXJ5TGVuZ3RoID8/IDYwMDAwKTtcbiAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WID09PSAnZGV2ZWxvcG1lbnQnICYmIGV4cGlyeUxlbmd0aCA8IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ05lZ2F0aXZlIGV4cGlyeSBsZW5ndGggYXJlIG5vdCBhbGxvd2VkLicpO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBTRVRfUkVTUE9OU0VfVFlQRSxcbiAgICBrZXk6IGVuZHBvaW50LmtleSguLi5hcmdzKSxcbiAgICByZXNwb25zZSxcbiAgICBhcmdzOiBhcmdzLm1hcChlbnN1cmVQb2pvKSxcbiAgICBlbmRwb2ludCxcbiAgICBtZXRhOiBjcmVhdGVNZXRhKGV4cGlyeUxlbmd0aCwgZmV0Y2hlZEF0KSxcbiAgICBlcnJvcixcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBRUEsU0FBU0EsVUFBVSxRQUFRLGlCQUFpQjtBQUM1QyxTQUFTQyxpQkFBaUIsUUFBUSxzQkFBc0I7QUFFeEQsT0FBT0MsVUFBVSxNQUFNLGtCQUFrQjtBQStCekMsT0FBTyxTQUFTQyxpQkFBaUJBLENBSy9CQyxRQUFXLEVBQ1g7RUFDRUMsSUFBSTtFQUNKQyxTQUFTO0VBQ1RDLFFBQVE7RUFDUkMsS0FBSyxHQUFHO0FBTVYsQ0FBQyxFQUNxQjtFQUFBLElBQUFDLHFCQUFBLEVBQUFDLHFCQUFBO0VBQ3RCLE1BQU1DLFlBQW9CLEdBQ3hCSCxLQUFLLElBQUFDLHFCQUFBLEdBQ0ZMLFFBQVEsQ0FBQ1EsaUJBQWlCLFlBQUFILHFCQUFBLEdBQUksSUFBSSxJQUFBQyxxQkFBQSxHQUNsQ04sUUFBUSxDQUFDUyxnQkFBZ0IsWUFBQUgscUJBQUEsR0FBSSxLQUFNO0VBQ3hDO0VBQ0EsSUFBSUksT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlMLFlBQVksR0FBRyxDQUFDLEVBQUU7SUFDOUQsTUFBTSxJQUFJTSxLQUFLLENBQUMseUNBQXlDLENBQUM7RUFDNUQ7RUFFQSxPQUFPO0lBQ0xDLElBQUksRUFBRWpCLGlCQUFpQjtJQUN2QmtCLEdBQUcsRUFBRWYsUUFBUSxDQUFDZSxHQUFHLENBQUMsR0FBR2QsSUFBSSxDQUFDO0lBQzFCRSxRQUFRO0lBQ1JGLElBQUksRUFBRUEsSUFBSSxDQUFDZSxHQUFHLENBQUNsQixVQUFVLENBQUM7SUFDMUJFLFFBQVE7SUFDUmlCLElBQUksRUFBRXJCLFVBQVUsQ0FBQ1csWUFBWSxFQUFFTCxTQUFTLENBQUM7SUFDekNFO0VBQ0YsQ0FBQztBQUNIIiwiaWdub3JlTGlzdCI6W119

@@ -17,7 +17,7 @@ import { SUBSCRIBE_TYPE, UNSUBSCRIBE_TYPE } from '../../actionTypes.js';

type: UNSUBSCRIBE_TYPE,
endpoint,
key: endpoint.key(...args),
args,
key: endpoint.key(...args)
endpoint
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVUJTQ1JJQkVfVFlQRSIsIlVOU1VCU0NSSUJFX1RZUEUiLCJjcmVhdGVTdWJzY3JpcHRpb24iLCJlbmRwb2ludCIsImFyZ3MiLCJ0eXBlIiwia2V5IiwiY3JlYXRlVW5zdWJzY3JpcHRpb24iXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udHJvbGxlci9hY3Rpb25zL2NyZWF0ZVN1YnNjcmlwdGlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlIH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB7IFNVQlNDUklCRV9UWVBFLCBVTlNVQlNDUklCRV9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBTdWJzY3JpYmVBY3Rpb24sIFVuc3Vic2NyaWJlQWN0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlU3Vic2NyaXB0aW9uPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4oXG4gIGVuZHBvaW50OiBFLFxuICB7IGFyZ3MgfTogeyBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl0gfSxcbik6IFN1YnNjcmliZUFjdGlvbjxFPiB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogU1VCU0NSSUJFX1RZUEUsXG4gICAgZW5kcG9pbnQsXG4gICAgYXJncyxcbiAgICBrZXk6IGVuZHBvaW50LmtleSguLi5hcmdzKSxcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVVuc3Vic2NyaXB0aW9uPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4oXG4gIGVuZHBvaW50OiBFLFxuICB7IGFyZ3MgfTogeyBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl0gfSxcbik6IFVuc3Vic2NyaWJlQWN0aW9uPEU+IHtcbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBVTlNVQlNDUklCRV9UWVBFLFxuICAgIGVuZHBvaW50LFxuICAgIGFyZ3MsXG4gICAga2V5OiBlbmRwb2ludC5rZXkoLi4uYXJncyksXG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiJBQUVBLFNBQVNBLGNBQWMsRUFBRUMsZ0JBQWdCLFFBQVEsc0JBQXNCO0FBR3ZFLE9BQU8sU0FBU0Msa0JBQWtCQSxDQUNoQ0MsUUFBVyxFQUNYO0VBQUVDO0FBQTRDLENBQUMsRUFDM0I7RUFDcEIsT0FBTztJQUNMQyxJQUFJLEVBQUVMLGNBQWM7SUFDcEJHLFFBQVE7SUFDUkMsSUFBSTtJQUNKRSxHQUFHLEVBQUVILFFBQVEsQ0FBQ0csR0FBRyxDQUFDLEdBQUdGLElBQUk7RUFDM0IsQ0FBQztBQUNIO0FBRUEsT0FBTyxTQUFTRyxvQkFBb0JBLENBQ2xDSixRQUFXLEVBQ1g7RUFBRUM7QUFBNEMsQ0FBQyxFQUN6QjtFQUN0QixPQUFPO0lBQ0xDLElBQUksRUFBRUosZ0JBQWdCO0lBQ3RCRSxRQUFRO0lBQ1JDLElBQUk7SUFDSkUsR0FBRyxFQUFFSCxRQUFRLENBQUNHLEdBQUcsQ0FBQyxHQUFHRixJQUFJO0VBQzNCLENBQUM7QUFDSCIsImlnbm9yZUxpc3QiOltdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVUJTQ1JJQkVfVFlQRSIsIlVOU1VCU0NSSUJFX1RZUEUiLCJjcmVhdGVTdWJzY3JpcHRpb24iLCJlbmRwb2ludCIsImFyZ3MiLCJ0eXBlIiwia2V5IiwiY3JlYXRlVW5zdWJzY3JpcHRpb24iXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udHJvbGxlci9hY3Rpb25zL2NyZWF0ZVN1YnNjcmlwdGlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlIH0gZnJvbSAnQGRhdGEtY2xpZW50L25vcm1hbGl6cic7XG5cbmltcG9ydCB7IFNVQlNDUklCRV9UWVBFLCBVTlNVQlNDUklCRV9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBTdWJzY3JpYmVBY3Rpb24sIFVuc3Vic2NyaWJlQWN0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlU3Vic2NyaXB0aW9uPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4oXG4gIGVuZHBvaW50OiBFLFxuICB7IGFyZ3MgfTogeyBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl0gfSxcbik6IFN1YnNjcmliZUFjdGlvbjxFPiB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogU1VCU0NSSUJFX1RZUEUsXG4gICAgZW5kcG9pbnQsXG4gICAgYXJncyxcbiAgICBrZXk6IGVuZHBvaW50LmtleSguLi5hcmdzKSxcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVVuc3Vic2NyaXB0aW9uPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4oXG4gIGVuZHBvaW50OiBFLFxuICB7IGFyZ3MgfTogeyBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl0gfSxcbik6IFVuc3Vic2NyaWJlQWN0aW9uPEU+IHtcbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBVTlNVQlNDUklCRV9UWVBFLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICAgIGFyZ3MsXG4gICAgZW5kcG9pbnQsXG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiJBQUVBLFNBQVNBLGNBQWMsRUFBRUMsZ0JBQWdCLFFBQVEsc0JBQXNCO0FBR3ZFLE9BQU8sU0FBU0Msa0JBQWtCQSxDQUNoQ0MsUUFBVyxFQUNYO0VBQUVDO0FBQTRDLENBQUMsRUFDM0I7RUFDcEIsT0FBTztJQUNMQyxJQUFJLEVBQUVMLGNBQWM7SUFDcEJHLFFBQVE7SUFDUkMsSUFBSTtJQUNKRSxHQUFHLEVBQUVILFFBQVEsQ0FBQ0csR0FBRyxDQUFDLEdBQUdGLElBQUk7RUFDM0IsQ0FBQztBQUNIO0FBRUEsT0FBTyxTQUFTRyxvQkFBb0JBLENBQ2xDSixRQUFXLEVBQ1g7RUFBRUM7QUFBNEMsQ0FBQyxFQUN6QjtFQUN0QixPQUFPO0lBQ0xDLElBQUksRUFBRUosZ0JBQWdCO0lBQ3RCSyxHQUFHLEVBQUVILFFBQVEsQ0FBQ0csR0FBRyxDQUFDLEdBQUdGLElBQUksQ0FBQztJQUMxQkEsSUFBSTtJQUNKRDtFQUNGLENBQUM7QUFDSCIsImlnbm9yZUxpc3QiOltdfQ==

@@ -0,3 +1,9 @@

import NetworkManager from './NetworkManager.js';
export default function applyManager(managers, controller) {
return managers.map(manager => {
/* istanbul ignore next */
if (process.env.NODE_ENV !== 'production' && !managers.find(mgr => mgr instanceof NetworkManager)) {
console.warn('NetworkManager not found; this is a required manager.');
console.warn('See https://dataclient.io/docs/guides/redux for hooking up redux');
}
return managers.map((manager, i) => {
const middleware = manager.getMiddleware();

@@ -8,4 +14,6 @@ return ({

}) => {
controller.dispatch = dispatch;
controller.getState = getState;
if (i === 0) {
controller.dispatch = dispatch;
controller.getState = getState;
}
// controller is a superset of the middleware API

@@ -18,2 +26,2 @@ return middleware(controller);

/* These should be compatible with redux */
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBseU1hbmFnZXIiLCJtYW5hZ2VycyIsImNvbnRyb2xsZXIiLCJtYXAiLCJtYW5hZ2VyIiwibWlkZGxld2FyZSIsImdldE1pZGRsZXdhcmUiLCJkaXNwYXRjaCIsImdldFN0YXRlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL21hbmFnZXIvYXBwbHlNYW5hZ2VyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIENvbnRyb2xsZXIgZnJvbSAnLi4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmltcG9ydCB0eXBlIHsgUmVkdWNlciwgRGlzcGF0Y2gsIFJlZHVjZXJTdGF0ZSB9IGZyb20gJy4uL21pZGRsZXdhcmVUeXBlcy5qcyc7XG5pbXBvcnQgeyBNYW5hZ2VyIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBhcHBseU1hbmFnZXIoXG4gIG1hbmFnZXJzOiBNYW5hZ2VyW10sXG4gIGNvbnRyb2xsZXI6IENvbnRyb2xsZXIsXG4pOiBNaWRkbGV3YXJlW10ge1xuICByZXR1cm4gbWFuYWdlcnMubWFwKG1hbmFnZXIgPT4ge1xuICAgIGNvbnN0IG1pZGRsZXdhcmUgPSBtYW5hZ2VyLmdldE1pZGRsZXdhcmUoKTtcbiAgICByZXR1cm4gKHsgZGlzcGF0Y2gsIGdldFN0YXRlIH0pID0+IHtcbiAgICAgIChjb250cm9sbGVyIGFzIGFueSkuZGlzcGF0Y2ggPSBkaXNwYXRjaDtcbiAgICAgIChjb250cm9sbGVyIGFzIGFueSkuZ2V0U3RhdGUgPSBnZXRTdGF0ZTtcbiAgICAgIC8vIGNvbnRyb2xsZXIgaXMgYSBzdXBlcnNldCBvZiB0aGUgbWlkZGxld2FyZSBBUElcbiAgICAgIHJldHVybiBtaWRkbGV3YXJlKGNvbnRyb2xsZXIgYXMgQ29udHJvbGxlcjxhbnk+KTtcbiAgICB9O1xuICB9KTtcbn1cblxuLyogVGhlc2Ugc2hvdWxkIGJlIGNvbXBhdGlibGUgd2l0aCByZWR1eCAqL1xuZXhwb3J0IGludGVyZmFjZSBNaWRkbGV3YXJlQVBJPFxuICBSIGV4dGVuZHMgUmVkdWNlcjxhbnksIGFueT4gPSBSZWR1Y2VyPGFueSwgYW55Pixcbj4ge1xuICBnZXRTdGF0ZTogKCkgPT4gUmVkdWNlclN0YXRlPFI+O1xuICBkaXNwYXRjaDogRGlzcGF0Y2g8Uj47XG59XG5leHBvcnQgdHlwZSBNaWRkbGV3YXJlID0gPFIgZXh0ZW5kcyBSZWR1Y2VyPGFueSwgYW55Pj4oe1xuICBkaXNwYXRjaCxcbn06IE1pZGRsZXdhcmVBUEk8Uj4pID0+IChuZXh0OiBEaXNwYXRjaDxSPikgPT4gRGlzcGF0Y2g8Uj47XG4iXSwibWFwcGluZ3MiOiJBQUlBLGVBQWUsU0FBU0EsWUFBWUEsQ0FDbENDLFFBQW1CLEVBQ25CQyxVQUFzQixFQUNSO0VBQ2QsT0FBT0QsUUFBUSxDQUFDRSxHQUFHLENBQUNDLE9BQU8sSUFBSTtJQUM3QixNQUFNQyxVQUFVLEdBQUdELE9BQU8sQ0FBQ0UsYUFBYSxDQUFDLENBQUM7SUFDMUMsT0FBTyxDQUFDO01BQUVDLFFBQVE7TUFBRUM7SUFBUyxDQUFDLEtBQUs7TUFDaENOLFVBQVUsQ0FBU0ssUUFBUSxHQUFHQSxRQUFRO01BQ3RDTCxVQUFVLENBQVNNLFFBQVEsR0FBR0EsUUFBUTtNQUN2QztNQUNBLE9BQU9ILFVBQVUsQ0FBQ0gsVUFBNkIsQ0FBQztJQUNsRCxDQUFDO0VBQ0gsQ0FBQyxDQUFDO0FBQ0o7O0FBRUEiLCJpZ25vcmVMaXN0IjpbXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJOZXR3b3JrTWFuYWdlciIsImFwcGx5TWFuYWdlciIsIm1hbmFnZXJzIiwiY29udHJvbGxlciIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsImZpbmQiLCJtZ3IiLCJjb25zb2xlIiwid2FybiIsIm1hcCIsIm1hbmFnZXIiLCJpIiwibWlkZGxld2FyZSIsImdldE1pZGRsZXdhcmUiLCJkaXNwYXRjaCIsImdldFN0YXRlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL21hbmFnZXIvYXBwbHlNYW5hZ2VyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBOZXR3b3JrTWFuYWdlciBmcm9tICcuL05ldHdvcmtNYW5hZ2VyLmpzJztcbmltcG9ydCB0eXBlIENvbnRyb2xsZXIgZnJvbSAnLi4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmltcG9ydCB0eXBlIHsgUmVkdWNlciwgRGlzcGF0Y2gsIFJlZHVjZXJTdGF0ZSB9IGZyb20gJy4uL21pZGRsZXdhcmVUeXBlcy5qcyc7XG5pbXBvcnQgeyBNYW5hZ2VyIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBhcHBseU1hbmFnZXIoXG4gIG1hbmFnZXJzOiBNYW5hZ2VyW10sXG4gIGNvbnRyb2xsZXI6IENvbnRyb2xsZXIsXG4pOiBNaWRkbGV3YXJlW10ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAoXG4gICAgcHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJyAmJlxuICAgICFtYW5hZ2Vycy5maW5kKG1nciA9PiBtZ3IgaW5zdGFuY2VvZiBOZXR3b3JrTWFuYWdlcilcbiAgKSB7XG4gICAgY29uc29sZS53YXJuKCdOZXR3b3JrTWFuYWdlciBub3QgZm91bmQ7IHRoaXMgaXMgYSByZXF1aXJlZCBtYW5hZ2VyLicpO1xuICAgIGNvbnNvbGUud2FybihcbiAgICAgICdTZWUgaHR0cHM6Ly9kYXRhY2xpZW50LmlvL2RvY3MvZ3VpZGVzL3JlZHV4IGZvciBob29raW5nIHVwIHJlZHV4JyxcbiAgICApO1xuICB9XG4gIHJldHVybiBtYW5hZ2Vycy5tYXAoKG1hbmFnZXIsIGkpID0+IHtcbiAgICBjb25zdCBtaWRkbGV3YXJlID0gbWFuYWdlci5nZXRNaWRkbGV3YXJlKCk7XG4gICAgcmV0dXJuICh7IGRpc3BhdGNoLCBnZXRTdGF0ZSB9KSA9PiB7XG4gICAgICBpZiAoaSA9PT0gMCkge1xuICAgICAgICAoY29udHJvbGxlciBhcyBhbnkpLmRpc3BhdGNoID0gZGlzcGF0Y2g7XG4gICAgICAgIChjb250cm9sbGVyIGFzIGFueSkuZ2V0U3RhdGUgPSBnZXRTdGF0ZTtcbiAgICAgIH1cbiAgICAgIC8vIGNvbnRyb2xsZXIgaXMgYSBzdXBlcnNldCBvZiB0aGUgbWlkZGxld2FyZSBBUElcbiAgICAgIHJldHVybiBtaWRkbGV3YXJlKGNvbnRyb2xsZXIgYXMgQ29udHJvbGxlcjxhbnk+KTtcbiAgICB9O1xuICB9KTtcbn1cblxuLyogVGhlc2Ugc2hvdWxkIGJlIGNvbXBhdGlibGUgd2l0aCByZWR1eCAqL1xuZXhwb3J0IGludGVyZmFjZSBNaWRkbGV3YXJlQVBJPFxuICBSIGV4dGVuZHMgUmVkdWNlcjxhbnksIGFueT4gPSBSZWR1Y2VyPGFueSwgYW55Pixcbj4ge1xuICBnZXRTdGF0ZTogKCkgPT4gUmVkdWNlclN0YXRlPFI+O1xuICBkaXNwYXRjaDogRGlzcGF0Y2g8Uj47XG59XG5leHBvcnQgdHlwZSBNaWRkbGV3YXJlID0gPFIgZXh0ZW5kcyBSZWR1Y2VyPGFueSwgYW55Pj4oe1xuICBkaXNwYXRjaCxcbn06IE1pZGRsZXdhcmVBUEk8Uj4pID0+IChuZXh0OiBEaXNwYXRjaDxSPikgPT4gRGlzcGF0Y2g8Uj47XG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLGNBQWMsTUFBTSxxQkFBcUI7QUFLaEQsZUFBZSxTQUFTQyxZQUFZQSxDQUNsQ0MsUUFBbUIsRUFDbkJDLFVBQXNCLEVBQ1I7RUFDZDtFQUNBLElBQ0VDLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDQyxRQUFRLEtBQUssWUFBWSxJQUNyQyxDQUFDSixRQUFRLENBQUNLLElBQUksQ0FBQ0MsR0FBRyxJQUFJQSxHQUFHLFlBQVlSLGNBQWMsQ0FBQyxFQUNwRDtJQUNBUyxPQUFPLENBQUNDLElBQUksQ0FBQyx1REFBdUQsQ0FBQztJQUNyRUQsT0FBTyxDQUFDQyxJQUFJLENBQ1Ysa0VBQ0YsQ0FBQztFQUNIO0VBQ0EsT0FBT1IsUUFBUSxDQUFDUyxHQUFHLENBQUMsQ0FBQ0MsT0FBTyxFQUFFQyxDQUFDLEtBQUs7SUFDbEMsTUFBTUMsVUFBVSxHQUFHRixPQUFPLENBQUNHLGFBQWEsQ0FBQyxDQUFDO0lBQzFDLE9BQU8sQ0FBQztNQUFFQyxRQUFRO01BQUVDO0lBQVMsQ0FBQyxLQUFLO01BQ2pDLElBQUlKLENBQUMsS0FBSyxDQUFDLEVBQUU7UUFDVlYsVUFBVSxDQUFTYSxRQUFRLEdBQUdBLFFBQVE7UUFDdENiLFVBQVUsQ0FBU2MsUUFBUSxHQUFHQSxRQUFRO01BQ3pDO01BQ0E7TUFDQSxPQUFPSCxVQUFVLENBQUNYLFVBQTZCLENBQUM7SUFDbEQsQ0FBQztFQUNILENBQUMsQ0FBQztBQUNKOztBQUVBIiwiaWdub3JlTGlzdCI6W119

@@ -24,2 +24,23 @@ /* eslint-disable no-inner-declarations */

autoPause: true,
features: {
pause: true,
// start/pause recording of dispatched actions
lock: true,
// lock/unlock dispatching actions and side effects
persist: false,
// persist states on page reloading
export: true,
// export history of actions in a file
import: 'custom',
// import history of actions from a file
jump: true,
// jump back and forth (time travelling)
skip: true,
// skip (cancel) actions
reorder: true,
// drag and drop actions in the history list
dispatch: false,
// dispatch custom actions or action creators
test: false // generate tests for the selected actions
},
actionSanitizer: action => {

@@ -100,2 +121,3 @@ if (!('endpoint' in action)) return action;

return next => action => {
const shouldSkip = skipLogging == null ? void 0 : skipLogging(action);
const ret = next(action);

@@ -109,3 +131,3 @@ if (this.started) {

ret.then(() => {
if (skipLogging != null && skipLogging(action)) return;
if (shouldSkip) return;
this.handleAction(action, state.optimistic.reduce(reducer, state));

@@ -148,2 +170,2 @@ });

}
//# 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","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","subscribe","msg","type","length","state","handleAction","payload","controller","resetEntireStore","middleware","reducer","getState","next","ret","then","optimistic","reduce","send","slice","push","init","cleanup","getMiddleware"],"sources":["../../src/manager/DevtoolsManager.ts"],"sourcesContent":["/* eslint-disable no-inner-declarations */\nimport type { DevToolsConfig } from './devtoolsTypes.js';\nimport type { Middleware } from './LogoutManager.js';\nimport { Controller, EndpointInterface } from '../index.js';\nimport createReducer from '../state/reducer/createReducer.js';\nimport type { Manager, State, ActionTypes } from '../types.js';\n\nexport type { DevToolsConfig };\n\nlet DEFAULT_CONFIG = {};\n\nif (process.env.NODE_ENV !== 'production') {\n  const extraEndpointKeys = [\n    'dataExpiryLength',\n    'errorExpiryLength',\n    'errorPolicy',\n    'invalidIfStale',\n    'pollFrequency',\n    'getOptimisticResponse',\n    'update',\n  ];\n\n  function serializeEndpoint(endpoint: EndpointInterface) {\n    const serial: any = {\n      name: endpoint.name,\n      schema: (endpoint.schema as any)?.toJSON?.() ?? endpoint.schema,\n      sideEffect: endpoint.sideEffect,\n    };\n    extraEndpointKeys.forEach(key => {\n      if (key in endpoint)\n        serial[key] = endpoint[key as keyof EndpointInterface];\n    });\n    return serial;\n  }\n\n  const HASINTL = typeof Intl !== 'undefined';\n  DEFAULT_CONFIG = {\n    name: `Data Client: ${globalThis.document?.title}`,\n    autoPause: true,\n    actionSanitizer: (action: ActionTypes) => {\n      if (!('endpoint' in action)) return action;\n      return {\n        ...action,\n        endpoint: serializeEndpoint(action.endpoint),\n      };\n    },\n    serialize: {\n      options: undefined,\n      /* istanbul ignore next */\n      replacer:\n        HASINTL ?\n          (key: string | number | symbol, value: unknown) => {\n            if (\n              typeof value === 'number' &&\n              typeof key === 'string' &&\n              isFinite(value) &&\n              (key === 'date' || key.endsWith('At'))\n            ) {\n              return Intl.DateTimeFormat('en-US', {\n                hour: 'numeric',\n                minute: 'numeric',\n                second: 'numeric',\n                fractionalSecondDigits: 3,\n              }).format(value);\n            }\n            return value;\n          }\n        : undefined,\n    },\n  };\n}\n\n/** Integrates with https://github.com/reduxjs/redux-devtools\n *\n * Options: https://github.com/reduxjs/redux-devtools/blob/main/extension/docs/API/Arguments.md\n *\n * @see https://dataclient.io/docs/api/DevToolsManager\n */\nexport default class DevToolsManager implements Manager {\n  protected declare middleware: Middleware;\n  protected declare devTools: undefined | any;\n  protected started = false;\n  protected actions: [ActionTypes, State<unknown>][] = [];\n  protected declare controller: Controller;\n  maxBufferLength = 100;\n\n  constructor(\n    config?: DevToolsConfig,\n    skipLogging?: (action: ActionTypes) => boolean,\n  ) {\n    /* istanbul ignore next */\n    this.devTools =\n      typeof window !== 'undefined' &&\n      (window as any).__REDUX_DEVTOOLS_EXTENSION__ &&\n      (window as any).__REDUX_DEVTOOLS_EXTENSION__.connect({\n        ...DEFAULT_CONFIG,\n        ...config,\n      });\n    // we cut it in half so we should double so we don't lose\n    if (config?.maxAge) this.maxBufferLength = config.maxAge * 2;\n    if (process.env.NODE_ENV !== 'production' && this.devTools) {\n      this.devTools.subscribe((msg: any) => {\n        switch (msg.type) {\n          case 'START':\n            this.started = true;\n\n            if (this.actions.length) {\n              this.actions.forEach(([action, state]) => {\n                this.handleAction(action, state);\n              });\n              this.actions = [];\n            }\n            break;\n          case 'STOP':\n            this.started = false;\n            break;\n          case 'DISPATCH':\n            if (msg.payload.type === 'RESET') {\n              this.controller.resetEntireStore();\n            }\n            break;\n        }\n      });\n    }\n\n    /* istanbul ignore if */\n    /* istanbul ignore next */\n    if (this.devTools) {\n      this.middleware = controller => {\n        this.controller = controller;\n        const reducer = createReducer(controller as any);\n        let state = controller.getState();\n        return next => action => {\n          const 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 (skipLogging?.(action)) return;\n            this.handleAction(action, state.optimistic.reduce(reducer, state));\n          });\n          return ret;\n        };\n      };\n    } else {\n      this.middleware = () => next => action => next(action);\n    }\n  }\n\n  handleAction(action: any, state: any) {\n    if (this.started) {\n      this.devTools.send(action, state);\n    } else {\n      // avoid this getting too big in case this is long running\n      // we cut in half so we aren't constantly reallocating\n      if (this.actions.length > this.maxBufferLength)\n        this.actions = this.actions.slice(this.maxBufferLength / 2);\n      // queue actions\n      this.actions.push([action, state]);\n    }\n  }\n\n  /** Called when initial state is ready */\n  init(state: State<any>) {\n    /* istanbul ignore if */\n    if (this.devTools) this.devTools.init(state);\n  }\n\n  /** Ensures all subscriptions are cleaned up. */\n  cleanup() {}\n\n  /** Attaches Manager to store\n   *\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n}\n"],"mappings":"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","ignoreList":[]}
//# 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","subscribe","msg","type","length","state","handleAction","payload","controller","resetEntireStore","middleware","reducer","getState","next","shouldSkip","ret","then","optimistic","reduce","send","slice","push","init","cleanup","getMiddleware"],"sources":["../../src/manager/DevtoolsManager.ts"],"sourcesContent":["/* eslint-disable no-inner-declarations */\nimport type { DevToolsConfig } from './devtoolsTypes.js';\nimport type { Middleware } from './LogoutManager.js';\nimport { Controller, EndpointInterface } from '../index.js';\nimport createReducer from '../state/reducer/createReducer.js';\nimport type { Manager, State, ActionTypes } from '../types.js';\n\nexport type { DevToolsConfig };\n\nlet DEFAULT_CONFIG = {};\n\nif (process.env.NODE_ENV !== 'production') {\n  const extraEndpointKeys = [\n    'dataExpiryLength',\n    'errorExpiryLength',\n    'errorPolicy',\n    'invalidIfStale',\n    'pollFrequency',\n    'getOptimisticResponse',\n    'update',\n  ];\n\n  function serializeEndpoint(endpoint: EndpointInterface) {\n    const serial: any = {\n      name: endpoint.name,\n      schema: (endpoint.schema as any)?.toJSON?.() ?? endpoint.schema,\n      sideEffect: endpoint.sideEffect,\n    };\n    extraEndpointKeys.forEach(key => {\n      if (key in endpoint)\n        serial[key] = endpoint[key as keyof EndpointInterface];\n    });\n    return serial;\n  }\n\n  const HASINTL = typeof Intl !== 'undefined';\n  DEFAULT_CONFIG = {\n    name: `Data Client: ${globalThis.document?.title}`,\n    autoPause: true,\n    features: {\n      pause: true, // start/pause recording of dispatched actions\n      lock: true, // lock/unlock dispatching actions and side effects\n      persist: false, // persist states on page reloading\n      export: true, // export history of actions in a file\n      import: 'custom', // import history of actions from a file\n      jump: true, // jump back and forth (time travelling)\n      skip: true, // skip (cancel) actions\n      reorder: true, // drag and drop actions in the history list\n      dispatch: false, // dispatch custom actions or action creators\n      test: false, // generate tests for the selected actions\n    },\n    actionSanitizer: (action: ActionTypes) => {\n      if (!('endpoint' in action)) return action;\n      return {\n        ...action,\n        endpoint: serializeEndpoint(action.endpoint),\n      };\n    },\n    serialize: {\n      options: undefined,\n      /* istanbul ignore next */\n      replacer:\n        HASINTL ?\n          (key: string | number | symbol, value: unknown) => {\n            if (\n              typeof value === 'number' &&\n              typeof key === 'string' &&\n              isFinite(value) &&\n              (key === 'date' || key.endsWith('At'))\n            ) {\n              return Intl.DateTimeFormat('en-US', {\n                hour: 'numeric',\n                minute: 'numeric',\n                second: 'numeric',\n                fractionalSecondDigits: 3,\n              }).format(value);\n            }\n            return value;\n          }\n        : undefined,\n    },\n  };\n}\n\n/** Integrates with https://github.com/reduxjs/redux-devtools\n *\n * Options: https://github.com/reduxjs/redux-devtools/blob/main/extension/docs/API/Arguments.md\n *\n * @see https://dataclient.io/docs/api/DevToolsManager\n */\nexport default class DevToolsManager implements Manager {\n  protected declare middleware: Middleware;\n  protected declare devTools: undefined | any;\n  protected started = false;\n  protected actions: [ActionTypes, State<unknown>][] = [];\n  protected declare controller: Controller;\n  maxBufferLength = 100;\n\n  constructor(\n    config?: DevToolsConfig,\n    skipLogging?: (action: ActionTypes) => boolean,\n  ) {\n    /* istanbul ignore next */\n    this.devTools =\n      typeof window !== 'undefined' &&\n      (window as any).__REDUX_DEVTOOLS_EXTENSION__ &&\n      (window as any).__REDUX_DEVTOOLS_EXTENSION__.connect({\n        ...DEFAULT_CONFIG,\n        ...config,\n      });\n    // we cut it in half so we should double so we don't lose\n    if (config?.maxAge) this.maxBufferLength = config.maxAge * 2;\n    if (process.env.NODE_ENV !== 'production' && this.devTools) {\n      this.devTools.subscribe((msg: any) => {\n        switch (msg.type) {\n          case 'START':\n            this.started = true;\n\n            if (this.actions.length) {\n              this.actions.forEach(([action, state]) => {\n                this.handleAction(action, state);\n              });\n              this.actions = [];\n            }\n            break;\n          case 'STOP':\n            this.started = false;\n            break;\n          case 'DISPATCH':\n            if (msg.payload.type === 'RESET') {\n              this.controller.resetEntireStore();\n            }\n            break;\n        }\n      });\n    }\n\n    /* istanbul ignore if */\n    /* istanbul ignore next */\n    if (this.devTools) {\n      this.middleware = controller => {\n        this.controller = controller;\n        const reducer = createReducer(controller as any);\n        let state = controller.getState();\n        return next => action => {\n          const shouldSkip = skipLogging?.(action);\n          const ret = next(action);\n          if (this.started) {\n            // we track state changes here since getState() will only update after a batch commit\n            state = reducer(state, action);\n          } else {\n            state = controller.getState();\n          }\n          ret.then(() => {\n            if (shouldSkip) return;\n            this.handleAction(action, state.optimistic.reduce(reducer, state));\n          });\n          return ret;\n        };\n      };\n    } else {\n      this.middleware = () => next => action => next(action);\n    }\n  }\n\n  handleAction(action: any, state: any) {\n    if (this.started) {\n      this.devTools.send(action, state);\n    } else {\n      // avoid this getting too big in case this is long running\n      // we cut in half so we aren't constantly reallocating\n      if (this.actions.length > this.maxBufferLength)\n        this.actions = this.actions.slice(this.maxBufferLength / 2);\n      // queue actions\n      this.actions.push([action, state]);\n    }\n  }\n\n  /** Called when initial state is ready */\n  init(state: State<any>) {\n    /* istanbul ignore if */\n    if (this.devTools) this.devTools.init(state);\n  }\n\n  /** Ensures all subscriptions are cleaned up. */\n  cleanup() {}\n\n  /** Attaches Manager to store\n   *\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n}\n"],"mappings":"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","ignoreList":[]}

@@ -1,2 +0,4 @@

type Action = any;
import { ActionTypes } from '../actions.js';
import { State } from '../types.js';
type Action = ActionTypes;
type ActionCreator<T> = any;

@@ -75,3 +77,3 @@ export interface EnhancerOptions {

*/
stateSanitizer?: <S>(state: S, index: number) => S;
stateSanitizer?: <S extends State<unknown>>(state: S, index: number) => S;
/**

@@ -103,3 +105,3 @@ * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).

*/
predicate?: <S, A extends Action>(state: S, action: A) => boolean;
predicate?: <S extends State<unknown>, A extends Action>(state: S, action: A) => boolean;
/**

@@ -106,0 +108,0 @@ * if specified as `false`, it will not record the changes till clicking on `Start recording` button.

export {};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":[],"sources":["../../src/manager/devtoolsTypes.ts"],"sourcesContent":["type Action = any;\ntype ActionCreator<T> = any;\n\n// taken from https://github.com/reduxjs/redux-devtools/blob/main/packages/redux-devtools-extension/src/index.ts\n\nexport interface EnhancerOptions {\n  /**\n   * the instance name to be showed on the monitor page. Default value is `document.title`.\n   * If not specified and there's no document title, it will consist of `tabId` and `instanceId`.\n   */\n  name?: string;\n  /**\n   * action creators functions to be available in the Dispatcher.\n   */\n  actionCreators?: ActionCreator<any>[] | { [key: string]: ActionCreator<any> };\n  /**\n   * if more than one action is dispatched in the indicated interval, all new actions will be collected and sent at once.\n   * It is the joint between performance and speed. When set to `0`, all actions will be sent instantly.\n   * Set it to a higher value when experiencing perf issues (also `maxAge` to a lower value).\n   *\n   * @default 500 ms.\n   */\n  latency?: number;\n  /**\n   * (> 1) - maximum allowed actions to be stored in the history tree. The oldest actions are removed once maxAge is reached. It's critical for performance.\n   *\n   * @default 50\n   */\n  maxAge?: number;\n  /**\n   * Customizes how actions and state are serialized and deserialized. Can be a boolean or object. If given a boolean, the behavior is the same as if you\n   * were to pass an object and specify `options` as a boolean. Giving an object allows fine-grained customization using the `replacer` and `reviver`\n   * functions.\n   */\n  serialize?:\n    | boolean\n    | {\n        /**\n         * - `undefined` - will use regular `JSON.stringify` to send data (it's the fast mode).\n         * - `false` - will handle also circular references.\n         * - `true` - will handle also date, regex, undefined, error objects, symbols, maps, sets and functions.\n         * - object, which contains `date`, `regex`, `undefined`, `error`, `symbol`, `map`, `set` and `function` keys.\n         *   For each of them you can indicate if to include (by setting as `true`).\n         *   For `function` key you can also specify a custom function which handles serialization.\n         *   See [`jsan`](https://github.com/kolodny/jsan) for more details.\n         */\n        options?:\n          | undefined\n          | boolean\n          | {\n              date?: true;\n              regex?: true;\n              undefined?: true;\n              error?: true;\n              symbol?: true;\n              map?: true;\n              set?: true;\n              function?: true | ((fn: (...args: any[]) => any) => string);\n            };\n        /**\n         * [JSON replacer function](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#The_replacer_parameter) used for both actions and states stringify.\n         * In addition, you can specify a data type by adding a [`__serializedType__`](https://github.com/zalmoxisus/remotedev-serialize/blob/master/helpers/index.js#L4)\n         * key. So you can deserialize it back while importing or persisting data.\n         * Moreover, it will also [show a nice preview showing the provided custom type](https://cloud.githubusercontent.com/assets/7957859/21814330/a17d556a-d761-11e6-85ef-159dd12f36c5.png):\n         */\n        replacer?: (key: string, value: unknown) => any;\n        /**\n         * [JSON `reviver` function](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse#Using_the_reviver_parameter)\n         * used for parsing the imported actions and states. See [`remotedev-serialize`](https://github.com/zalmoxisus/remotedev-serialize/blob/master/immutable/serialize.js#L8-L41)\n         * as an example on how to serialize special data types and get them back.\n         */\n        reviver?: (key: string, value: unknown) => any;\n      };\n  /**\n   * function which takes `action` object and id number as arguments, and should return `action` object back.\n   */\n  actionSanitizer?: <A extends Action>(action: A, id: number) => A;\n  /**\n   * function which takes `state` object and index as arguments, and should return `state` object back.\n   */\n  stateSanitizer?: <S>(state: S, index: number) => S;\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsWhitelist` specified, `actionsBlacklist` is ignored.\n   * @deprecated Use actionsDenylist instead.\n   */\n  actionsBlacklist?: string | string[];\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsWhitelist` specified, `actionsBlacklist` is ignored.\n   * @deprecated Use actionsAllowlist instead.\n   */\n  actionsWhitelist?: string | string[];\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsAllowlist` specified, `actionsDenylist` is ignored.\n   */\n  actionsDenylist?: string | string[];\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsAllowlist` specified, `actionsDenylist` is ignored.\n   */\n  actionsAllowlist?: string | string[];\n  /**\n   * called for every action before sending, takes `state` and `action` object, and returns `true` in case it allows sending the current data to the monitor.\n   * Use it as a more advanced version of `actionsDenylist`/`actionsAllowlist` parameters.\n   */\n  predicate?: <S, A extends Action>(state: S, action: A) => boolean;\n  /**\n   * if specified as `false`, it will not record the changes till clicking on `Start recording` button.\n   * Available only for Redux enhancer, for others use `autoPause`.\n   *\n   * @default true\n   */\n  shouldRecordChanges?: boolean;\n  /**\n   * if specified, whenever clicking on `Pause recording` button and there are actions in the history log, will add this action type.\n   * If not specified, will commit when paused. Available only for Redux enhancer.\n   *\n   * @default \"@@PAUSED\"\"\n   */\n  pauseActionType?: string;\n  /**\n   * auto pauses when the extension’s window is not opened, and so has zero impact on your app when not in use.\n   * Not available for Redux enhancer (as it already does it but storing the data to be sent).\n   *\n   * @default false\n   */\n  autoPause?: boolean;\n  /**\n   * if specified as `true`, it will not allow any non-monitor actions to be dispatched till clicking on `Unlock changes` button.\n   * Available only for Redux enhancer.\n   *\n   * @default false\n   */\n  shouldStartLocked?: boolean;\n  /**\n   * if set to `false`, will not recompute the states on hot reloading (or on replacing the reducers). Available only for Redux enhancer.\n   *\n   * @default true\n   */\n  shouldHotReload?: boolean;\n  /**\n   * if specified as `true`, whenever there's an exception in reducers, the monitors will show the error message, and next actions will not be dispatched.\n   *\n   * @default false\n   */\n  shouldCatchErrors?: boolean;\n  /**\n   * If you want to restrict the extension, specify the features you allow.\n   * If not specified, all of the features are enabled. When set as an object, only those included as `true` will be allowed.\n   * Note that except `true`/`false`, `import` and `export` can be set as `custom` (which is by default for Redux enhancer), meaning that the importing/exporting occurs on the client side.\n   * Otherwise, you'll get/set the data right from the monitor part.\n   */\n  features?: {\n    /**\n     * start/pause recording of dispatched actions\n     */\n    pause?: boolean;\n    /**\n     * lock/unlock dispatching actions and side effects\n     */\n    lock?: boolean;\n    /**\n     * persist states on page reloading\n     */\n    persist?: boolean;\n    /**\n     * export history of actions in a file\n     */\n    export?: boolean | 'custom';\n    /**\n     * import history of actions from a file\n     */\n    import?: boolean | 'custom';\n    /**\n     * jump back and forth (time travelling)\n     */\n    jump?: boolean;\n    /**\n     * skip (cancel) actions\n     */\n    skip?: boolean;\n    /**\n     * drag and drop actions in the history list\n     */\n    reorder?: boolean;\n    /**\n     * dispatch custom actions or action creators\n     */\n    dispatch?: boolean;\n    /**\n     * generate tests for the selected actions\n     */\n    test?: boolean;\n  };\n  /**\n   * Set to true or a stacktrace-returning function to record call stack traces for dispatched actions.\n   * Defaults to false.\n   */\n  trace?: boolean | (<A extends Action>(action: A) => string);\n  /**\n   * The maximum number of stack trace entries to record per action. Defaults to 10.\n   */\n  traceLimit?: number;\n}\n\nexport interface DevToolsConfig extends EnhancerOptions {\n  type?: string;\n}\n"],"mappings":"","ignoreList":[]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":[],"sources":["../../src/manager/devtoolsTypes.ts"],"sourcesContent":["import { ActionTypes } from '../actions.js';\nimport { State } from '../types.js';\n\ntype Action = ActionTypes;\ntype ActionCreator<T> = any;\n\n// taken from https://github.com/reduxjs/redux-devtools/blob/main/packages/redux-devtools-extension/src/index.ts\n\nexport interface EnhancerOptions {\n  /**\n   * the instance name to be showed on the monitor page. Default value is `document.title`.\n   * If not specified and there's no document title, it will consist of `tabId` and `instanceId`.\n   */\n  name?: string;\n  /**\n   * action creators functions to be available in the Dispatcher.\n   */\n  actionCreators?: ActionCreator<any>[] | { [key: string]: ActionCreator<any> };\n  /**\n   * if more than one action is dispatched in the indicated interval, all new actions will be collected and sent at once.\n   * It is the joint between performance and speed. When set to `0`, all actions will be sent instantly.\n   * Set it to a higher value when experiencing perf issues (also `maxAge` to a lower value).\n   *\n   * @default 500 ms.\n   */\n  latency?: number;\n  /**\n   * (> 1) - maximum allowed actions to be stored in the history tree. The oldest actions are removed once maxAge is reached. It's critical for performance.\n   *\n   * @default 50\n   */\n  maxAge?: number;\n  /**\n   * Customizes how actions and state are serialized and deserialized. Can be a boolean or object. If given a boolean, the behavior is the same as if you\n   * were to pass an object and specify `options` as a boolean. Giving an object allows fine-grained customization using the `replacer` and `reviver`\n   * functions.\n   */\n  serialize?:\n    | boolean\n    | {\n        /**\n         * - `undefined` - will use regular `JSON.stringify` to send data (it's the fast mode).\n         * - `false` - will handle also circular references.\n         * - `true` - will handle also date, regex, undefined, error objects, symbols, maps, sets and functions.\n         * - object, which contains `date`, `regex`, `undefined`, `error`, `symbol`, `map`, `set` and `function` keys.\n         *   For each of them you can indicate if to include (by setting as `true`).\n         *   For `function` key you can also specify a custom function which handles serialization.\n         *   See [`jsan`](https://github.com/kolodny/jsan) for more details.\n         */\n        options?:\n          | undefined\n          | boolean\n          | {\n              date?: true;\n              regex?: true;\n              undefined?: true;\n              error?: true;\n              symbol?: true;\n              map?: true;\n              set?: true;\n              function?: true | ((fn: (...args: any[]) => any) => string);\n            };\n        /**\n         * [JSON replacer function](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#The_replacer_parameter) used for both actions and states stringify.\n         * In addition, you can specify a data type by adding a [`__serializedType__`](https://github.com/zalmoxisus/remotedev-serialize/blob/master/helpers/index.js#L4)\n         * key. So you can deserialize it back while importing or persisting data.\n         * Moreover, it will also [show a nice preview showing the provided custom type](https://cloud.githubusercontent.com/assets/7957859/21814330/a17d556a-d761-11e6-85ef-159dd12f36c5.png):\n         */\n        replacer?: (key: string, value: unknown) => any;\n        /**\n         * [JSON `reviver` function](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse#Using_the_reviver_parameter)\n         * used for parsing the imported actions and states. See [`remotedev-serialize`](https://github.com/zalmoxisus/remotedev-serialize/blob/master/immutable/serialize.js#L8-L41)\n         * as an example on how to serialize special data types and get them back.\n         */\n        reviver?: (key: string, value: unknown) => any;\n      };\n  /**\n   * function which takes `action` object and id number as arguments, and should return `action` object back.\n   */\n  actionSanitizer?: <A extends Action>(action: A, id: number) => A;\n  /**\n   * function which takes `state` object and index as arguments, and should return `state` object back.\n   */\n  stateSanitizer?: <S extends State<unknown>>(state: S, index: number) => S;\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsWhitelist` specified, `actionsBlacklist` is ignored.\n   * @deprecated Use actionsDenylist instead.\n   */\n  actionsBlacklist?: string | string[];\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsWhitelist` specified, `actionsBlacklist` is ignored.\n   * @deprecated Use actionsAllowlist instead.\n   */\n  actionsWhitelist?: string | string[];\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsAllowlist` specified, `actionsDenylist` is ignored.\n   */\n  actionsDenylist?: string | string[];\n  /**\n   * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).\n   * If `actionsAllowlist` specified, `actionsDenylist` is ignored.\n   */\n  actionsAllowlist?: string | string[];\n  /**\n   * called for every action before sending, takes `state` and `action` object, and returns `true` in case it allows sending the current data to the monitor.\n   * Use it as a more advanced version of `actionsDenylist`/`actionsAllowlist` parameters.\n   */\n  predicate?: <S extends State<unknown>, A extends Action>(\n    state: S,\n    action: A,\n  ) => boolean;\n  /**\n   * if specified as `false`, it will not record the changes till clicking on `Start recording` button.\n   * Available only for Redux enhancer, for others use `autoPause`.\n   *\n   * @default true\n   */\n  shouldRecordChanges?: boolean;\n  /**\n   * if specified, whenever clicking on `Pause recording` button and there are actions in the history log, will add this action type.\n   * If not specified, will commit when paused. Available only for Redux enhancer.\n   *\n   * @default \"@@PAUSED\"\"\n   */\n  pauseActionType?: string;\n  /**\n   * auto pauses when the extension’s window is not opened, and so has zero impact on your app when not in use.\n   * Not available for Redux enhancer (as it already does it but storing the data to be sent).\n   *\n   * @default false\n   */\n  autoPause?: boolean;\n  /**\n   * if specified as `true`, it will not allow any non-monitor actions to be dispatched till clicking on `Unlock changes` button.\n   * Available only for Redux enhancer.\n   *\n   * @default false\n   */\n  shouldStartLocked?: boolean;\n  /**\n   * if set to `false`, will not recompute the states on hot reloading (or on replacing the reducers). Available only for Redux enhancer.\n   *\n   * @default true\n   */\n  shouldHotReload?: boolean;\n  /**\n   * if specified as `true`, whenever there's an exception in reducers, the monitors will show the error message, and next actions will not be dispatched.\n   *\n   * @default false\n   */\n  shouldCatchErrors?: boolean;\n  /**\n   * If you want to restrict the extension, specify the features you allow.\n   * If not specified, all of the features are enabled. When set as an object, only those included as `true` will be allowed.\n   * Note that except `true`/`false`, `import` and `export` can be set as `custom` (which is by default for Redux enhancer), meaning that the importing/exporting occurs on the client side.\n   * Otherwise, you'll get/set the data right from the monitor part.\n   */\n  features?: {\n    /**\n     * start/pause recording of dispatched actions\n     */\n    pause?: boolean;\n    /**\n     * lock/unlock dispatching actions and side effects\n     */\n    lock?: boolean;\n    /**\n     * persist states on page reloading\n     */\n    persist?: boolean;\n    /**\n     * export history of actions in a file\n     */\n    export?: boolean | 'custom';\n    /**\n     * import history of actions from a file\n     */\n    import?: boolean | 'custom';\n    /**\n     * jump back and forth (time travelling)\n     */\n    jump?: boolean;\n    /**\n     * skip (cancel) actions\n     */\n    skip?: boolean;\n    /**\n     * drag and drop actions in the history list\n     */\n    reorder?: boolean;\n    /**\n     * dispatch custom actions or action creators\n     */\n    dispatch?: boolean;\n    /**\n     * generate tests for the selected actions\n     */\n    test?: boolean;\n  };\n  /**\n   * Set to true or a stacktrace-returning function to record call stack traces for dispatched actions.\n   * Defaults to false.\n   */\n  trace?: boolean | (<A extends Action>(action: A) => string);\n  /**\n   * The maximum number of stack trace entries to record per action. Defaults to 10.\n   */\n  traceLimit?: number;\n}\n\nexport interface DevToolsConfig extends EnhancerOptions {\n  type?: string;\n}\n"],"mappings":"","ignoreList":[]}

@@ -9,12 +9,5 @@ import { createOptimistic } from '../../controller/actions/createOptimistic.js';

};
} else {
// If 'fetch' action reaches the reducer there are no middlewares installed to handle it
/* istanbul ignore next */
if (process.env.NODE_ENV !== 'production') {
console.warn('Fetch appears unhandled - you are likely missing the NetworkManager middleware');
console.warn('See https://dataclient.io/docs/guides/redux for hooking up redux');
}
return state;
}
return state;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVPcHRpbWlzdGljIiwiZmV0Y2hSZWR1Y2VyIiwic3RhdGUiLCJhY3Rpb24iLCJlbmRwb2ludCIsImdldE9wdGltaXN0aWNSZXNwb25zZSIsInNpZGVFZmZlY3QiLCJzZXRBY3Rpb24iLCJhcmdzIiwibWV0YSIsImZldGNoZWRBdCIsIm9wdGltaXN0aWMiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJjb25zb2xlIiwid2FybiJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zdGF0ZS9yZWR1Y2VyL2ZldGNoUmVkdWNlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVPcHRpbWlzdGljIH0gZnJvbSAnLi4vLi4vY29udHJvbGxlci9hY3Rpb25zL2NyZWF0ZU9wdGltaXN0aWMuanMnO1xuaW1wb3J0IHR5cGUgeyBTdGF0ZSwgRmV0Y2hBY3Rpb24gfSBmcm9tICcuLi8uLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBmZXRjaFJlZHVjZXIoc3RhdGU6IFN0YXRlPHVua25vd24+LCBhY3Rpb246IEZldGNoQWN0aW9uKSB7XG4gIGlmIChhY3Rpb24uZW5kcG9pbnQuZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlICYmIGFjdGlvbi5lbmRwb2ludC5zaWRlRWZmZWN0KSB7XG4gICAgY29uc3Qgc2V0QWN0aW9uID0gY3JlYXRlT3B0aW1pc3RpYyhcbiAgICAgIGFjdGlvbi5lbmRwb2ludCxcbiAgICAgIGFjdGlvbi5hcmdzLFxuICAgICAgYWN0aW9uLm1ldGEuZmV0Y2hlZEF0LFxuICAgICk7XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnN0YXRlLFxuICAgICAgb3B0aW1pc3RpYzogWy4uLnN0YXRlLm9wdGltaXN0aWMsIHNldEFjdGlvbl0sXG4gICAgfTtcbiAgfSBlbHNlIHtcbiAgICAvLyBJZiAnZmV0Y2gnIGFjdGlvbiByZWFjaGVzIHRoZSByZWR1Y2VyIHRoZXJlIGFyZSBubyBtaWRkbGV3YXJlcyBpbnN0YWxsZWQgdG8gaGFuZGxlIGl0XG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJykge1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICAnRmV0Y2ggYXBwZWFycyB1bmhhbmRsZWQgLSB5b3UgYXJlIGxpa2VseSBtaXNzaW5nIHRoZSBOZXR3b3JrTWFuYWdlciBtaWRkbGV3YXJlJyxcbiAgICAgICk7XG4gICAgICBjb25zb2xlLndhcm4oXG4gICAgICAgICdTZWUgaHR0cHM6Ly9kYXRhY2xpZW50LmlvL2RvY3MvZ3VpZGVzL3JlZHV4IGZvciBob29raW5nIHVwIHJlZHV4JyxcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHN0YXRlO1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLGdCQUFnQixRQUFRLDhDQUE4QztBQUcvRSxPQUFPLFNBQVNDLFlBQVlBLENBQUNDLEtBQXFCLEVBQUVDLE1BQW1CLEVBQUU7RUFDdkUsSUFBSUEsTUFBTSxDQUFDQyxRQUFRLENBQUNDLHFCQUFxQixJQUFJRixNQUFNLENBQUNDLFFBQVEsQ0FBQ0UsVUFBVSxFQUFFO0lBQ3ZFLE1BQU1DLFNBQVMsR0FBR1AsZ0JBQWdCLENBQ2hDRyxNQUFNLENBQUNDLFFBQVEsRUFDZkQsTUFBTSxDQUFDSyxJQUFJLEVBQ1hMLE1BQU0sQ0FBQ00sSUFBSSxDQUFDQyxTQUNkLENBQUM7SUFDRCxPQUFPO01BQ0wsR0FBR1IsS0FBSztNQUNSUyxVQUFVLEVBQUUsQ0FBQyxHQUFHVCxLQUFLLENBQUNTLFVBQVUsRUFBRUosU0FBUztJQUM3QyxDQUFDO0VBQ0gsQ0FBQyxNQUFNO0lBQ0w7SUFDQTtJQUNBLElBQUlLLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDQyxRQUFRLEtBQUssWUFBWSxFQUFFO01BQ3pDQyxPQUFPLENBQUNDLElBQUksQ0FDVixnRkFDRixDQUFDO01BQ0RELE9BQU8sQ0FBQ0MsSUFBSSxDQUNWLGtFQUNGLENBQUM7SUFDSDtJQUVBLE9BQU9kLEtBQUs7RUFDZDtBQUNGIiwiaWdub3JlTGlzdCI6W119
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVPcHRpbWlzdGljIiwiZmV0Y2hSZWR1Y2VyIiwic3RhdGUiLCJhY3Rpb24iLCJlbmRwb2ludCIsImdldE9wdGltaXN0aWNSZXNwb25zZSIsInNpZGVFZmZlY3QiLCJzZXRBY3Rpb24iLCJhcmdzIiwibWV0YSIsImZldGNoZWRBdCIsIm9wdGltaXN0aWMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc3RhdGUvcmVkdWNlci9mZXRjaFJlZHVjZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlT3B0aW1pc3RpYyB9IGZyb20gJy4uLy4uL2NvbnRyb2xsZXIvYWN0aW9ucy9jcmVhdGVPcHRpbWlzdGljLmpzJztcbmltcG9ydCB0eXBlIHsgU3RhdGUsIEZldGNoQWN0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZmV0Y2hSZWR1Y2VyKHN0YXRlOiBTdGF0ZTx1bmtub3duPiwgYWN0aW9uOiBGZXRjaEFjdGlvbikge1xuICBpZiAoYWN0aW9uLmVuZHBvaW50LmdldE9wdGltaXN0aWNSZXNwb25zZSAmJiBhY3Rpb24uZW5kcG9pbnQuc2lkZUVmZmVjdCkge1xuICAgIGNvbnN0IHNldEFjdGlvbiA9IGNyZWF0ZU9wdGltaXN0aWMoXG4gICAgICBhY3Rpb24uZW5kcG9pbnQsXG4gICAgICBhY3Rpb24uYXJncyxcbiAgICAgIGFjdGlvbi5tZXRhLmZldGNoZWRBdCxcbiAgICApO1xuICAgIHJldHVybiB7XG4gICAgICAuLi5zdGF0ZSxcbiAgICAgIG9wdGltaXN0aWM6IFsuLi5zdGF0ZS5vcHRpbWlzdGljLCBzZXRBY3Rpb25dLFxuICAgIH07XG4gIH1cbiAgcmV0dXJuIHN0YXRlO1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxnQkFBZ0IsUUFBUSw4Q0FBOEM7QUFHL0UsT0FBTyxTQUFTQyxZQUFZQSxDQUFDQyxLQUFxQixFQUFFQyxNQUFtQixFQUFFO0VBQ3ZFLElBQUlBLE1BQU0sQ0FBQ0MsUUFBUSxDQUFDQyxxQkFBcUIsSUFBSUYsTUFBTSxDQUFDQyxRQUFRLENBQUNFLFVBQVUsRUFBRTtJQUN2RSxNQUFNQyxTQUFTLEdBQUdQLGdCQUFnQixDQUNoQ0csTUFBTSxDQUFDQyxRQUFRLEVBQ2ZELE1BQU0sQ0FBQ0ssSUFBSSxFQUNYTCxNQUFNLENBQUNNLElBQUksQ0FBQ0MsU0FDZCxDQUFDO0lBQ0QsT0FBTztNQUNMLEdBQUdSLEtBQUs7TUFDUlMsVUFBVSxFQUFFLENBQUMsR0FBR1QsS0FBSyxDQUFDUyxVQUFVLEVBQUVKLFNBQVM7SUFDN0MsQ0FBQztFQUNIO0VBQ0EsT0FBT0wsS0FBSztBQUNkIiwiaWdub3JlTGlzdCI6W119
{
"name": "@data-client/core",
"version": "0.14.1",
"version": "0.14.2",
"description": "High performance mutable data framework.",

@@ -5,0 +5,0 @@ "sideEffects": false,

@@ -30,7 +30,7 @@ import type { EndpointInterface, NI } from '@data-client/normalizr';

type: FETCH_TYPE,
key: endpoint.key(...args),
args,
endpoint,
args,
key: endpoint.key(...args),
meta,
};
}

@@ -27,7 +27,7 @@ import type { EndpointInterface } from '@data-client/normalizr';

type: OPTIMISTIC_TYPE,
key: endpoint.key(...args),
args,
endpoint,
args,
key: endpoint.key(...args),
meta: createMeta(endpoint.dataExpiryLength ?? 60000, fetchedAt),
};
}

@@ -26,7 +26,7 @@ import type {

type: SET_TYPE,
schema,
value,
args: args.map(ensurePojo) as SchemaArgs<S>,
schema,
meta: createMeta(60000, fetchedAt),
};
}

@@ -66,6 +66,6 @@ import type { EndpointInterface, ResolveType } from '@data-client/normalizr';

type: SET_RESPONSE_TYPE,
endpoint,
key: endpoint.key(...args),
response,
args: args.map(ensurePojo),
key: endpoint.key(...args),
endpoint,
meta: createMeta(expiryLength, fetchedAt),

@@ -72,0 +72,0 @@ error,

@@ -24,6 +24,6 @@ import type { EndpointInterface } from '@data-client/normalizr';

type: UNSUBSCRIBE_TYPE,
key: endpoint.key(...args),
args,
endpoint,
args,
key: endpoint.key(...args),
};
}

@@ -0,1 +1,2 @@

import NetworkManager from './NetworkManager.js';
import type Controller from '../controller/Controller.js';

@@ -9,7 +10,19 @@ import type { Reducer, Dispatch, ReducerState } from '../middlewareTypes.js';

): Middleware[] {
return managers.map(manager => {
/* istanbul ignore next */
if (
process.env.NODE_ENV !== 'production' &&
!managers.find(mgr => mgr instanceof NetworkManager)
) {
console.warn('NetworkManager not found; this is a required manager.');
console.warn(
'See https://dataclient.io/docs/guides/redux for hooking up redux',
);
}
return managers.map((manager, i) => {
const middleware = manager.getMiddleware();
return ({ dispatch, getState }) => {
(controller as any).dispatch = dispatch;
(controller as any).getState = getState;
if (i === 0) {
(controller as any).dispatch = dispatch;
(controller as any).getState = getState;
}
// controller is a superset of the middleware API

@@ -16,0 +29,0 @@ return middleware(controller as Controller<any>);

@@ -40,2 +40,14 @@ /* eslint-disable no-inner-declarations */

autoPause: true,
features: {
pause: true, // start/pause recording of dispatched actions
lock: true, // lock/unlock dispatching actions and side effects
persist: false, // persist states on page reloading
export: true, // export history of actions in a file
import: 'custom', // import history of actions from a file
jump: true, // jump back and forth (time travelling)
skip: true, // skip (cancel) actions
reorder: true, // drag and drop actions in the history list
dispatch: false, // dispatch custom actions or action creators
test: false, // generate tests for the selected actions
},
actionSanitizer: (action: ActionTypes) => {

@@ -135,2 +147,3 @@ if (!('endpoint' in action)) return action;

return next => action => {
const shouldSkip = skipLogging?.(action);
const ret = next(action);

@@ -144,3 +157,3 @@ if (this.started) {

ret.then(() => {
if (skipLogging?.(action)) return;
if (shouldSkip) return;
this.handleAction(action, state.optimistic.reduce(reducer, state));

@@ -147,0 +160,0 @@ });

@@ -1,2 +0,5 @@

type Action = any;
import { ActionTypes } from '../actions.js';
import { State } from '../types.js';
type Action = ActionTypes;
type ActionCreator<T> = any;

@@ -81,3 +84,3 @@

*/
stateSanitizer?: <S>(state: S, index: number) => S;
stateSanitizer?: <S extends State<unknown>>(state: S, index: number) => S;
/**

@@ -109,3 +112,6 @@ * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).

*/
predicate?: <S, A extends Action>(state: S, action: A) => boolean;
predicate?: <S extends State<unknown>, A extends Action>(
state: S,
action: A,
) => boolean;
/**

@@ -112,0 +118,0 @@ * if specified as `false`, it will not record the changes till clicking on `Start recording` button.

@@ -598,3 +598,3 @@ import { INVALID, Entity } from '@data-client/endpoint';

});
it('rdc/fetch should console.warn()', () => {
it('rdc/fetch should not console.warn()', () => {
const warnspy = jest

@@ -622,3 +622,4 @@ .spyOn(global.console, 'warn')

expect(newState).toBe(iniState);
expect(warnspy.mock.calls.length).toBe(2);
// moved warns to applyManager() vv
expect(warnspy.mock.calls.length).toBe(0);
} finally {

@@ -625,0 +626,0 @@ warnspy.mockRestore();

@@ -15,16 +15,4 @@ import { createOptimistic } from '../../controller/actions/createOptimistic.js';

};
} else {
// If 'fetch' action reaches the reducer there are no middlewares installed to handle it
/* istanbul ignore next */
if (process.env.NODE_ENV !== 'production') {
console.warn(
'Fetch appears unhandled - you are likely missing the NetworkManager middleware',
);
console.warn(
'See https://dataclient.io/docs/guides/redux for hooking up redux',
);
}
return state;
}
return state;
}

@@ -1,2 +0,4 @@

type Action = any;
import { ActionTypes } from '../actions.js';
import { State } from '../types.js';
type Action = ActionTypes;
type ActionCreator<T> = any;

@@ -75,3 +77,3 @@ export interface EnhancerOptions {

*/
stateSanitizer?: <S>(state: S, index: number) => S;
stateSanitizer?: <S extends State<unknown>>(state: S, index: number) => S;
/**

@@ -103,3 +105,3 @@ * *string or array of strings as regex* - actions types to be hidden / shown in the monitors (while passed to the reducers).

*/
predicate?: <S, A extends Action>(state: S, action: A) => boolean;
predicate?: <S extends State<unknown>, A extends Action>(state: S, action: A) => boolean;
/**

@@ -106,0 +108,0 @@ * if specified as `false`, it will not record the changes till clicking on `Start recording` button.

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc