diff --git a/dist/lib/hooks/usePoll.d.ts b/dist/lib/hooks/usePoll.d.ts deleted file mode 100644 index c29767e..0000000 --- a/dist/lib/hooks/usePoll.d.ts +++ /dev/null @@ -1,20 +0,0 @@ -import type { PollWorkerProps } from "../types"; -export declare function usePoll(props: PollWorkerProps): { - data: any; - loading: boolean; - preload: boolean; - error: undefined; - update: boolean; -} | { - error: any; - loading: boolean; - preload: boolean; - data: import("../utils").UnknownDataResponseType; - update: boolean; -} | { - loading: any; - data: import("../utils").UnknownDataResponseType; - error?: Error | undefined; - preload: boolean; - update: boolean; -}; diff --git a/dist/lib/index.d.ts b/dist/lib/index.d.ts index 9d1c0df..4008f9a 100644 --- a/dist/lib/index.d.ts +++ b/dist/lib/index.d.ts @@ -1,3 +1,2 @@ export { useFetch } from './hooks/useFetch'; -export { usePoll } from './hooks/usePoll'; export { usePreFetch } from './hooks/usePreFetch'; diff --git a/dist/lib/utils/index.d.ts b/dist/lib/utils/index.d.ts index 90b50c4..01ce239 100644 --- a/dist/lib/utils/index.d.ts +++ b/dist/lib/utils/index.d.ts @@ -1,7 +1,6 @@ import type { createArrayOfUpdatesType } from "../types"; export * from "./state_tools"; export * from "./store_tools"; -export * from "./poll"; export declare const DAY: number; export declare function cleanupWorker(worker: Worker | undefined): void; export declare const dataExpired: (maxAge: number, timestamp?: number | undefined) => boolean; diff --git a/dist/lib/utils/poll.d.ts b/dist/lib/utils/poll.d.ts deleted file mode 100644 index 09da044..0000000 --- a/dist/lib/utils/poll.d.ts +++ /dev/null @@ -1,8 +0,0 @@ -export interface PollProps { - fn: () => Promise; - validate: (res: unknown) => boolean; - interval: number; - maxAttempts?: number; - attempts?: number; -} -export declare const poll: ({ fn, validate, interval, maxAttempts }: PollProps) => Promise; diff --git a/dist/queryPlus.es.js b/dist/queryPlus.es.js index 772e9f0..d523df6 100644 --- a/dist/queryPlus.es.js +++ b/dist/queryPlus.es.js @@ -19,7 +19,7 @@ var __spreadValues = (a, b) => { var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b)); import { useReducer, useRef, useEffect } from "react"; import "idb-keyval"; -const encodedJs = "var k=Object.defineProperty,j=Object.defineProperties;var A=Object.getOwnPropertyDescriptors;var W=Object.getOwnPropertySymbols;var Q=Object.prototype.hasOwnProperty,v=Object.prototype.propertyIsEnumerable;var B=(h,d,l)=>d in h?k(h,d,{enumerable:!0,configurable:!0,writable:!0,value:l}):h[d]=l,Z=(h,d)=>{for(var l in d||(d={}))Q.call(d,l)&&B(h,l,d[l]);if(W)for(var l of W(d))v.call(d,l)&&B(h,l,d[l]);return h},T=(h,d)=>j(h,A(d));(function(){"use strict";function h(t){return new Promise((e,n)=>{t.oncomplete=t.onsuccess=()=>e(t.result),t.onabort=t.onerror=()=>n(t.error)})}function d(t,e){const n=indexedDB.open(t);n.onupgradeneeded=()=>n.result.createObjectStore(e);const c=h(n);return(a,r)=>c.then(i=>r(i.transaction(e,a).objectStore(e)))}let l;function w(){return l||(l=d("keyval-store","keyval")),l}function D(t,e=w()){return e("readonly",n=>h(n.get(t)))}function C(t,e,n=w()){return n("readwrite",c=>(c.put(e,t),h(c.transaction)))}function N(t,e,n=w()){return n("readwrite",c=>new Promise((a,r)=>{c.get(t).onsuccess=function(){try{c.put(e(this.result),t),a(h(c.transaction))}catch(i){r(i)}}}))}function F(t,e=w()){return e("readwrite",n=>(n.delete(t),h(n.transaction)))}function x(){const n=d("usestore-db","usestore-db");return{remove:o=>F(o,n),getData:o=>D(o,n),setData:(o,f)=>C(o,f,n),updateData:(o,f)=>N(o,f,n)}}const U=(t,e)=>e?t+e<Date.now():!0,g=t=>typeof t=="object"&&!Array.isArray(t)&&t!==null,Y=(t,e,n={})=>(Object.keys(t).forEach(c=>{let a=e?e+"."+c:c;g(t[c])?Y(t[c],a,n):n[a]=Array.isArray(t[c])?t[c].sort():t[c]}),Object.entries(n).sort()),J=t=>t.flatMap(e=>g(e)?Y(e):[e]).sort(),M=t=>{var e,n;return(n=(e=t==null?void 0:t.method)==null?void 0:e.toUpperCase())!=null?n:"GET"},G=(t,e,n)=>{let c=Array.isArray(t)?"array":typeof t,a=Array.isArray(e)?"array":typeof e;return c!==a?!1:c!=="object"&&c!=="array"?c===a:n&&c==="object"?n.map(r=>t[r]===e[r]).every(r=>r):(c==="array"&&(t=J(t),e=J(e)),!n&&c==="object"&&(t=Y(t),e=Y(e)),JSON.stringify(t)===JSON.stringify(e))},L=t=>t?new Function(`return ${decodeURI(t)}`)():e=>e,P="dmFyIG09T2JqZWN0LmRlZmluZVByb3BlcnR5LFQ9T2JqZWN0LmRlZmluZVByb3BlcnRpZXM7dmFyIEQ9T2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnM7dmFyIGc9T2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9sczt2YXIgTT1PYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LE89T2JqZWN0LnByb3RvdHlwZS5wcm9wZXJ0eUlzRW51bWVyYWJsZTt2YXIgZD0oaSxzLG4pPT5zIGluIGk/bShpLHMse2VudW1lcmFibGU6ITAsY29uZmlndXJhYmxlOiEwLHdyaXRhYmxlOiEwLHZhbHVlOm59KTppW3NdPW4saD0oaSxzKT0+e2Zvcih2YXIgbiBpbiBzfHwocz17fSkpTS5jYWxsKHMsbikmJmQoaSxuLHNbbl0pO2lmKGcpZm9yKHZhciBuIG9mIGcocykpTy5jYWxsKHMsbikmJmQoaSxuLHNbbl0pO3JldHVybiBpfSxwPShpLHMpPT5UKGksRChzKSk7KGZ1bmN0aW9uKCl7InVzZSBzdHJpY3QiO2NvbnN0IGk9YXN5bmMoe2ZuOnQsdmFsaWRhdGU6ZSxpbnRlcnZhbDphLG1heEF0dGVtcHRzOnIsYXR0ZW1wdHM6Yz0wfSk9Pnthc3luYyBmdW5jdGlvbiBmKHUseSl7dHJ5e2NvbnN0IGw9YXdhaXQgdCgpO2lmKGMrKyxlKGwpKXtpZihyJiZjPT09cilyZXR1cm4geShuZXcgRXJyb3IoIkV4Y2VlZGVkIG1heCBhdHRlbXB0cyIpKTthd2FpdCBzZXRUaW1lb3V0KGYsYSx1LHkpfWVsc2UgcmV0dXJuIHUobCl9Y2F0Y2gobCl7Y29uc29sZS5lcnJvcihgcG9sbGluZyBFcnJvcjogJHsobD09bnVsbD92b2lkIDA6bC5tZXNzYWdlKXx8ImNvbm5lY3Rpb24gZmFpbGVkIn1gKX19cmV0dXJuIG5ldyBQcm9taXNlKGYpfSxzPXQ9PnR5cGVvZiB0PT0ib2JqZWN0IiYmIUFycmF5LmlzQXJyYXkodCkmJnQhPT1udWxsLG49KHQsZSxhPXt9KT0+KE9iamVjdC5rZXlzKHQpLmZvckVhY2gocj0+e2xldCBjPWU/ZSsiLiIrcjpyO3ModFtyXSk/bih0W3JdLGMsYSk6YVtjXT1BcnJheS5pc0FycmF5KHRbcl0pP3Rbcl0uc29ydCgpOnRbcl19KSxPYmplY3QuZW50cmllcyhhKS5zb3J0KCkpLEE9dD0+dC5mbGF0TWFwKGU9PnMoZSk/bihlKTpbZV0pLnNvcnQoKSx3PSh0LGUsYSk9PntsZXQgcj1BcnJheS5pc0FycmF5KHQpPyJhcnJheSI6dHlwZW9mIHQsYz1BcnJheS5pc0FycmF5KGUpPyJhcnJheSI6dHlwZW9mIGU7cmV0dXJuIHIhPT1jPyExOnIhPT0ib2JqZWN0IiYmciE9PSJhcnJheSI/cj09PWM6YSYmcj09PSJvYmplY3QiP2EubWFwKGY9PnRbZl09PT1lW2ZdKS5ldmVyeShmPT5mKToocj09PSJhcnJheSImJih0PUEodCksZT1BKGUpKSwhYSYmcj09PSJvYmplY3QiJiYodD1uKHQpLGU9bihlKSksSlNPTi5zdHJpbmdpZnkodCk9PT1KU09OLnN0cmluZ2lmeShlKSl9O3NlbGYuYWRkRXZlbnRMaXN0ZW5lcigibWVzc2FnZSIsdD0+e2NvbnN0e3R5cGU6ZX09dC5kYXRhO2xldCBhPW5ldyBBYm9ydENvbnRyb2xsZXIscj1hPT1udWxsP3ZvaWQgMDphLnNpZ25hbDtpZihlPT09ImNhbmNlbCImJihhPT1udWxsfHxhLmFib3J0KCkpLGU9PT0icG9sbCIpe2NvbnN0e3VybDpjLG9wdGlvbnM6ZixpbnRlcnZhbDp1LG1heEF0dGVtcHRzOnksZXhpc3RpbmdEYXRhOmwsY29tcGFyZUtleXM6RX09dC5kYXRhO2koe2ZuOigpPT5mZXRjaChjLGY/cChoKHt9LGYpLHtzaWduYWw6cn0pOntzaWduYWw6cn0pLnRoZW4obz0+e2lmKCFvLm9rfHxvLnN0YXR1cz09PTQwNCl0aHJvdyBuZXcgRXJyb3IoYEhUVFAgZXJyb3IhIFN0YXR1czogJHtvLnN0YXR1c31gKTtpZihvLnN0YXR1cz09PTQwMyl0aHJvdyBuZXcgRXJyb3IoIlVuYXV0aG9yaXplZCEiKTtyZXR1cm4gby5qc29uKCl9KSxpbnRlcnZhbDp1LG1heEF0dGVtcHRzOnksdmFsaWRhdGU6bz0+IXcobCxvLEUpfSkudGhlbihvPT57c2VsZi5wb3N0TWVzc2FnZSh7dHlwZToiREFUQSIsZGF0YTpvfSl9KS5jYXRjaChvPT57c2VsZi5wb3N0TWVzc2FnZSh7dHlwZTpvLm1lc3NhZ2V8fCJVbmtub3duIGVycm9yIn0pfSl9fSl9KSgpOwo=",I=typeof window!="undefined"&&window.Blob&&new Blob([atob(P)],{type:"text/javascript;charset=utf-8"});function O(){const t=I&&(window.URL||window.webkitURL).createObjectURL(I);try{return t?new Worker(t,{}):new Worker("data:application/javascript;base64,"+P,{type:"module"})}finally{t&&(window.URL||window.webkitURL).revokeObjectURL(t)}}const{remove:E,getData:z,setData:X,updateData:V}=x(),S=t=>{if(!t.ok||t.status===404)throw new Error(`HTTP error! Status: ${t.status}`);if(t.status===403)throw new Error("Unauthorized!");return t.json()},R=t=>{self.postMessage({type:t.message||"Unknown error"})};self.addEventListener("message",t=>{const{type:e}=t.data;let n=new AbortController,c=n==null?void 0:n.signal,a=new O;if(e==="cancel"&&(n==null||n.abort(),a==null||a.postMessage({type:"cancel"}),a.terminate()),e==="poll"){let{existingData:r,url:i,options:o,interval:f,maxAttempts:u,compareKeys:m}=t.data;fetch(i,o?T(Z({},o),{signal:c}):{signal:c}).then(S).then(p=>{G(r,p,m)?self.postMessage({type:"CACHED",data:p}):(X(i,{timestamp:Date.now(),data:p}),self.postMessage({type:"DATA",data:p}))}).catch(R).finally(()=>{a==null||a.postMessage({type:e,url:i,options:o,interval:f,maxAttempts:u,existingData:r,compareKeys:m})}),a==null||a.addEventListener("message",({data:p})=>{self.postMessage(p)})}if(e==="pre-fetch"){let{prefetch:r}=t.data;r.forEach(({middleware:i,url:o,options:f,maxAge:u})=>{let m=L(i);fetch(o.toString(),Z({signal:c},f)).then(S).then(p=>{X(o.toString(),{timestamp:Date.now(),data:m(p),maxAge:u}).then(()=>{console.log(`saved prefetch ${o}`)}).catch(b=>{console.log(`error saving prefetch ${o}`,b)})}).catch(()=>{console.info("no data found")})})}if(e==="fetch"){let{existingData:r,url:i,options:o,maxAge:f,middleware:u,update:m}=t.data;const p=s=>{s=L(u)(s),(!r||!G(r,s))&&(self.postMessage({type:"DATA",data:s}),X(i.toString(),{data:s,timestamp:Date.now(),maxAge:f}).then(()=>{console.info("saved data")}).catch(()=>{console.info("couldn't access indexedDB to save data")})),self.postMessage({type:"COMPLETE"})};let b=M(o);b==="DELETE"&&(E(i.toString()),fetch(i,o).then(()=>{m?fetch(m.url,m.options).then(S).then(p).catch(s=>{throw s}):self.postMessage({type:"COMPLETE"})}).catch(R)),b==="GET"&&(z(i.toString()).then(s=>{if(!s)throw new Error("no value found in db");if(U(s==null?void 0:s.maxAge,s==null?void 0:s.timestamp))throw E(i.toString()),new Error("data expired");self.postMessage(G(r,s==null?void 0:s.data)?{type:"CACHED"}:{type:"PRE_LOAD",data:s==null?void 0:s.data})}).catch(s=>{console.info(s==null?void 0:s.message)}),fetch(i,o?T(Z({},o),{signal:c}):{signal:c}).then(S).then(p).catch(R)),(b==="PUT"||b==="POST")&&fetch(i,o?T(Z({},o),{signal:c}):{signal:c}).then(S).then(s=>{m?fetch(m.url,m.options).then(S).then(p).catch(y=>{throw y}):V(i.toString(),y=>{let K=Date.now(),H=g(s)&&g(y==null?void 0:y.data)?Z(Z({},y.data),s):s;return self.postMessage({type:b,data:H}),{timestamp:K,maxAge:f,data:H}}).catch(()=>{console.info("update store failed")}).finally(()=>{self.postMessage({type:"COMPLETE"})})}).catch(R)}})})();
"; +const encodedJs = "dmFyIGI9T2JqZWN0LmRlZmluZVByb3BlcnR5LEk9T2JqZWN0LmRlZmluZVByb3BlcnRpZXM7dmFyIFE9T2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnM7dmFyIFI9T2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9sczt2YXIgVz1PYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LFg9T2JqZWN0LnByb3RvdHlwZS5wcm9wZXJ0eUlzRW51bWVyYWJsZTt2YXIgVT0oaSxmLGgpPT5mIGluIGk/YihpLGYse2VudW1lcmFibGU6ITAsY29uZmlndXJhYmxlOiEwLHdyaXRhYmxlOiEwLHZhbHVlOmh9KTppW2ZdPWgsbD0oaSxmKT0+e2Zvcih2YXIgaCBpbiBmfHwoZj17fSkpVy5jYWxsKGYsaCkmJlUoaSxoLGZbaF0pO2lmKFIpZm9yKHZhciBoIG9mIFIoZikpWC5jYWxsKGYsaCkmJlUoaSxoLGZbaF0pO3JldHVybiBpfSxUPShpLGYpPT5JKGksUShmKSk7KGZ1bmN0aW9uKCl7InVzZSBzdHJpY3QiO2Z1bmN0aW9uIGkodCl7cmV0dXJuIG5ldyBQcm9taXNlKChlLG4pPT57dC5vbmNvbXBsZXRlPXQub25zdWNjZXNzPSgpPT5lKHQucmVzdWx0KSx0Lm9uYWJvcnQ9dC5vbmVycm9yPSgpPT5uKHQuZXJyb3IpfSl9ZnVuY3Rpb24gZih0LGUpe2NvbnN0IG49aW5kZXhlZERCLm9wZW4odCk7bi5vbnVwZ3JhZGVuZWVkZWQ9KCk9Pm4ucmVzdWx0LmNyZWF0ZU9iamVjdFN0b3JlKGUpO2NvbnN0IHI9aShuKTtyZXR1cm4oYSxzKT0+ci50aGVuKGM9PnMoYy50cmFuc2FjdGlvbihlLGEpLm9iamVjdFN0b3JlKGUpKSl9bGV0IGg7ZnVuY3Rpb24gdygpe3JldHVybiBofHwoaD1mKCJrZXl2YWwtc3RvcmUiLCJrZXl2YWwiKSksaH1mdW5jdGlvbiBfKHQsZT13KCkpe3JldHVybiBlKCJyZWFkb25seSIsbj0+aShuLmdldCh0KSkpfWZ1bmN0aW9uIEcodCxlLG49dygpKXtyZXR1cm4gbigicmVhZHdyaXRlIixyPT4oci5wdXQoZSx0KSxpKHIudHJhbnNhY3Rpb24pKSl9ZnVuY3Rpb24gJCh0LGUsbj13KCkpe3JldHVybiBuKCJyZWFkd3JpdGUiLHI9Pm5ldyBQcm9taXNlKChhLHMpPT57ci5nZXQodCkub25zdWNjZXNzPWZ1bmN0aW9uKCl7dHJ5e3IucHV0KGUodGhpcy5yZXN1bHQpLHQpLGEoaShyLnRyYW5zYWN0aW9uKSl9Y2F0Y2goYyl7cyhjKX19fSkpfWZ1bmN0aW9uIEYodCxlPXcoKSl7cmV0dXJuIGUoInJlYWR3cml0ZSIsbj0+KG4uZGVsZXRlKHQpLGkobi50cmFuc2FjdGlvbikpKX1mdW5jdGlvbiBqKCl7Y29uc3Qgbj1mKCJ1c2VzdG9yZS1kYiIsInVzZXN0b3JlLWRiIik7cmV0dXJue3JlbW92ZTpkPT5GKGQsbiksZ2V0RGF0YTpkPT5fKGQsbiksc2V0RGF0YTooZCxnKT0+RyhkLGcsbiksdXBkYXRlRGF0YTooZCxnKT0+JChkLGcsbil9fWNvbnN0IHo9KHQsZSk9PmU/dCtlPERhdGUubm93KCk6ITAsQT10PT50eXBlb2YgdD09Im9iamVjdCImJiFBcnJheS5pc0FycmF5KHQpJiZ0IT09bnVsbCxtPSh0LGUsbj17fSk9PihPYmplY3Qua2V5cyh0KS5mb3JFYWNoKHI9PntsZXQgYT1lP2UrIi4iK3I6cjtBKHRbcl0pP20odFtyXSxhLG4pOm5bYV09QXJyYXkuaXNBcnJheSh0W3JdKT90W3JdLnNvcnQoKTp0W3JdfSksT2JqZWN0LmVudHJpZXMobikuc29ydCgpKSxNPXQ9PnQuZmxhdE1hcChlPT5BKGUpP20oZSk6W2VdKS5zb3J0KCksSD10PT57dmFyIGUsbjtyZXR1cm4obj0oZT10PT1udWxsP3ZvaWQgMDp0Lm1ldGhvZCk9PW51bGw/dm9pZCAwOmUudG9VcHBlckNhc2UoKSkhPW51bGw/bjoiR0VUIn0sTz0odCxlLG4pPT57bGV0IHI9QXJyYXkuaXNBcnJheSh0KT8iYXJyYXkiOnR5cGVvZiB0LGE9QXJyYXkuaXNBcnJheShlKT8iYXJyYXkiOnR5cGVvZiBlO3JldHVybiByIT09YT8hMTpyIT09Im9iamVjdCImJnIhPT0iYXJyYXkiP3I9PT1hOm4mJnI9PT0ib2JqZWN0Ij9uLm1hcChzPT50W3NdPT09ZVtzXSkuZXZlcnkocz0+cyk6KHI9PT0iYXJyYXkiJiYodD1NKHQpLGU9TShlKSksIW4mJnI9PT0ib2JqZWN0IiYmKHQ9bSh0KSxlPW0oZSkpLEpTT04uc3RyaW5naWZ5KHQpPT09SlNPTi5zdHJpbmdpZnkoZSkpfSxDPXQ9PnQ/bmV3IEZ1bmN0aW9uKGByZXR1cm4gJHtkZWNvZGVVUkkodCl9YCkoKTplPT5lLHtyZW1vdmU6UCxnZXREYXRhOkosc2V0RGF0YTpCLHVwZGF0ZURhdGE6Tn09aigpLEQ9dD0+e2lmKCF0Lm9rfHx0LnN0YXR1cz09PTQwNCl0aHJvdyBuZXcgRXJyb3IoYEhUVFAgZXJyb3IhIFN0YXR1czogJHt0LnN0YXR1c31gKTtpZih0LnN0YXR1cz09PTQwMyl0aHJvdyBuZXcgRXJyb3IoIlVuYXV0aG9yaXplZCEiKTtyZXR1cm4gdC5qc29uKCl9LFM9dD0+e3NlbGYucG9zdE1lc3NhZ2Uoe3R5cGU6dC5tZXNzYWdlfHwiVW5rbm93biBlcnJvciJ9KX07c2VsZi5hZGRFdmVudExpc3RlbmVyKCJtZXNzYWdlIix0PT57Y29uc3R7dHlwZTplfT10LmRhdGE7bGV0IG49bmV3IEFib3J0Q29udHJvbGxlcixyPW49PW51bGw/dm9pZCAwOm4uc2lnbmFsO2lmKGU9PT0iY2FuY2VsIiYmKG49PW51bGx8fG4uYWJvcnQoKSksZT09PSJwcmUtZmV0Y2giKXtsZXR7cHJlZmV0Y2g6YX09dC5kYXRhO2EuZm9yRWFjaCgoe21pZGRsZXdhcmU6cyx1cmw6YyxvcHRpb25zOmQsbWF4QWdlOmd9KT0+e2xldCBwPUMocyk7ZmV0Y2goYy50b1N0cmluZygpLGwoe3NpZ25hbDpyfSxkKSkudGhlbihEKS50aGVuKEU9PntCKGMudG9TdHJpbmcoKSx7dGltZXN0YW1wOkRhdGUubm93KCksZGF0YTpwKEUpLG1heEFnZTpnfSkudGhlbigoKT0+e2NvbnNvbGUubG9nKGBzYXZlZCBwcmVmZXRjaCAke2N9YCl9KS5jYXRjaCh1PT57Y29uc29sZS5sb2coYGVycm9yIHNhdmluZyBwcmVmZXRjaCAke2N9YCx1KX0pfSkuY2F0Y2goKCk9Pntjb25zb2xlLmluZm8oIm5vIGRhdGEgZm91bmQiKX0pfSl9aWYoZT09PSJmZXRjaCIpe2xldHtleGlzdGluZ0RhdGE6YSx1cmw6cyxvcHRpb25zOmMsbWF4QWdlOmQsbWlkZGxld2FyZTpnLHVwZGF0ZTpwfT10LmRhdGE7Y29uc3QgRT1vPT57bz1DKGcpKG8pLCghYXx8IU8oYSxvKSkmJihzZWxmLnBvc3RNZXNzYWdlKHt0eXBlOiJEQVRBIixkYXRhOm99KSxCKHMudG9TdHJpbmcoKSx7ZGF0YTpvLHRpbWVzdGFtcDpEYXRlLm5vdygpLG1heEFnZTpkfSkudGhlbigoKT0+e2NvbnNvbGUuaW5mbygic2F2ZWQgZGF0YSIpfSkuY2F0Y2goKCk9Pntjb25zb2xlLmluZm8oImNvdWxkbid0IGFjY2VzcyBpbmRleGVkREIgdG8gc2F2ZSBkYXRhIil9KSksc2VsZi5wb3N0TWVzc2FnZSh7dHlwZToiQ09NUExFVEUifSl9O2xldCB1PUgoYyk7dT09PSJERUxFVEUiJiYoUChzLnRvU3RyaW5nKCkpLGZldGNoKHMsYykudGhlbigoKT0+e3A/ZmV0Y2gocC51cmwscC5vcHRpb25zKS50aGVuKEQpLnRoZW4oRSkuY2F0Y2gobz0+e3Rocm93IG99KTpzZWxmLnBvc3RNZXNzYWdlKHt0eXBlOiJDT01QTEVURSJ9KX0pLmNhdGNoKFMpKSx1PT09IkdFVCImJihKKHMudG9TdHJpbmcoKSkudGhlbihvPT57aWYoIW8pdGhyb3cgbmV3IEVycm9yKCJubyB2YWx1ZSBmb3VuZCBpbiBkYiIpO2lmKHoobz09bnVsbD92b2lkIDA6by5tYXhBZ2Usbz09bnVsbD92b2lkIDA6by50aW1lc3RhbXApKXRocm93IFAocy50b1N0cmluZygpKSxuZXcgRXJyb3IoImRhdGEgZXhwaXJlZCIpO3NlbGYucG9zdE1lc3NhZ2UoTyhhLG89PW51bGw/dm9pZCAwOm8uZGF0YSk/e3R5cGU6IkNBQ0hFRCJ9Ont0eXBlOiJQUkVfTE9BRCIsZGF0YTpvPT1udWxsP3ZvaWQgMDpvLmRhdGF9KX0pLmNhdGNoKG89Pntjb25zb2xlLmluZm8obz09bnVsbD92b2lkIDA6by5tZXNzYWdlKX0pLGZldGNoKHMsYz9UKGwoe30sYykse3NpZ25hbDpyfSk6e3NpZ25hbDpyfSkudGhlbihEKS50aGVuKEUpLmNhdGNoKFMpKSwodT09PSJQVVQifHx1PT09IlBPU1QiKSYmZmV0Y2gocyxjP1QobCh7fSxjKSx7c2lnbmFsOnJ9KTp7c2lnbmFsOnJ9KS50aGVuKEQpLnRoZW4obz0+e3A/ZmV0Y2gocC51cmwscC5vcHRpb25zKS50aGVuKEQpLnRoZW4oRSkuY2F0Y2goeT0+e3Rocm93IHl9KTpOKHMudG9TdHJpbmcoKSx5PT57bGV0IHg9RGF0ZS5ub3coKSxMPUEobykmJkEoeT09bnVsbD92b2lkIDA6eS5kYXRhKT9sKGwoe30seS5kYXRhKSxvKTpvO3JldHVybiBzZWxmLnBvc3RNZXNzYWdlKHt0eXBlOnUsZGF0YTpMfSkse3RpbWVzdGFtcDp4LG1heEFnZTpkLGRhdGE6TH19KS5jYXRjaCgoKT0+e2NvbnNvbGUuaW5mbygidXBkYXRlIHN0b3JlIGZhaWxlZCIpfSkuZmluYWxseSgoKT0+e3NlbGYucG9zdE1lc3NhZ2Uoe3R5cGU6IkNPTVBMRVRFIn0pfSl9KS5jYXRjaChTKX19KX0pKCk7Cg=="; const blob = typeof window !== "undefined" && window.Blob && new Blob([atob(encodedJs)], { type: "text/javascript;charset=utf-8" }); function WorkerWrapper() { const objURL = blob && (window.URL || window.webkitURL).createObjectURL(blob); @@ -124,52 +124,6 @@ function useFetch() { fetchWorker }, state); } -function usePoll(props) { - const [state, dispatch] = useReducer(reducer, initialState); - const worker = useRef(new WorkerWrapper()); - useEffect(() => { - var _a, _b; - if (props && worker.current) { - dispatch({ - type: "loading", - loading: true - }); - (_a = worker.current) == null ? void 0 : _a.addEventListener("message", ({ - data: { - type, - data - } - }) => { - if (type === "COMPLETE") - dispatch({ - type: "loading", - loading: false - }); - else if (type === "DATA") - dispatch({ - type: "data", - data - }); - else - dispatch({ - type: "error", - error: new Error(type) - }); - }); - (_b = worker.current) == null ? void 0 : _b.postMessage(__spreadProps(__spreadValues({ - type: "poll" - }, props), { - existingData: state.data - })); - } - }, [props, worker.current]); - useEffect(() => { - return () => { - cleanupWorker(worker.current); - }; - }, []); - return __spreadValues({}, state); -} function usePreFetch(prefetch) { const worker = useRef(new WorkerWrapper()); useEffect(() => { @@ -190,4 +144,4 @@ function usePreFetch(prefetch) { }; }, []); } -export { useFetch, usePoll, usePreFetch }; +export { useFetch, usePreFetch }; diff --git a/dist/queryPlus.umd.js b/dist/queryPlus.umd.js index 8c75df8..7f8d72e 100644 --- a/dist/queryPlus.umd.js +++ b/dist/queryPlus.umd.js @@ -1 +1 @@ -(function(W,d){typeof exports=="object"&&typeof module!="undefined"?d(exports,require("react"),require("idb-keyval")):typeof define=="function"&&define.amd?define(["exports","react","idb-keyval"],d):(W=typeof globalThis!="undefined"?globalThis:W||self,d(W.queryPlus={},W.React))})(this,function(W,d){"use strict";var K=Object.defineProperty,H=Object.defineProperties;var F=Object.getOwnPropertyDescriptors;var S=Object.getOwnPropertySymbols;var w=Object.prototype.hasOwnProperty,y=Object.prototype.propertyIsEnumerable;var u=(W,d,b)=>d in W?K(W,d,{enumerable:!0,configurable:!0,writable:!0,value:b}):W[d]=b,c=(W,d)=>{for(var b in d||(d={}))w.call(d,b)&&u(W,b,d[b]);if(S)for(var b of S(d))y.call(d,b)&&u(W,b,d[b]);return W},a=(W,d)=>H(W,F(d));const b="var k=Object.defineProperty,j=Object.defineProperties;var A=Object.getOwnPropertyDescriptors;var W=Object.getOwnPropertySymbols;var Q=Object.prototype.hasOwnProperty,v=Object.prototype.propertyIsEnumerable;var B=(h,d,l)=>d in h?k(h,d,{enumerable:!0,configurable:!0,writable:!0,value:l}):h[d]=l,Z=(h,d)=>{for(var l in d||(d={}))Q.call(d,l)&&B(h,l,d[l]);if(W)for(var l of W(d))v.call(d,l)&&B(h,l,d[l]);return h},T=(h,d)=>j(h,A(d));(function(){"use strict";function h(t){return new Promise((e,n)=>{t.oncomplete=t.onsuccess=()=>e(t.result),t.onabort=t.onerror=()=>n(t.error)})}function d(t,e){const n=indexedDB.open(t);n.onupgradeneeded=()=>n.result.createObjectStore(e);const c=h(n);return(a,r)=>c.then(i=>r(i.transaction(e,a).objectStore(e)))}let l;function w(){return l||(l=d("keyval-store","keyval")),l}function D(t,e=w()){return e("readonly",n=>h(n.get(t)))}function C(t,e,n=w()){return n("readwrite",c=>(c.put(e,t),h(c.transaction)))}function N(t,e,n=w()){return n("readwrite",c=>new Promise((a,r)=>{c.get(t).onsuccess=function(){try{c.put(e(this.result),t),a(h(c.transaction))}catch(i){r(i)}}}))}function F(t,e=w()){return e("readwrite",n=>(n.delete(t),h(n.transaction)))}function x(){const n=d("usestore-db","usestore-db");return{remove:o=>F(o,n),getData:o=>D(o,n),setData:(o,f)=>C(o,f,n),updateData:(o,f)=>N(o,f,n)}}const U=(t,e)=>e?t+e<Date.now():!0,g=t=>typeof t=="object"&&!Array.isArray(t)&&t!==null,Y=(t,e,n={})=>(Object.keys(t).forEach(c=>{let a=e?e+"."+c:c;g(t[c])?Y(t[c],a,n):n[a]=Array.isArray(t[c])?t[c].sort():t[c]}),Object.entries(n).sort()),J=t=>t.flatMap(e=>g(e)?Y(e):[e]).sort(),M=t=>{var e,n;return(n=(e=t==null?void 0:t.method)==null?void 0:e.toUpperCase())!=null?n:"GET"},G=(t,e,n)=>{let c=Array.isArray(t)?"array":typeof t,a=Array.isArray(e)?"array":typeof e;return c!==a?!1:c!=="object"&&c!=="array"?c===a:n&&c==="object"?n.map(r=>t[r]===e[r]).every(r=>r):(c==="array"&&(t=J(t),e=J(e)),!n&&c==="object"&&(t=Y(t),e=Y(e)),JSON.stringify(t)===JSON.stringify(e))},L=t=>t?new Function(`return ${decodeURI(t)}`)():e=>e,P="dmFyIG09T2JqZWN0LmRlZmluZVByb3BlcnR5LFQ9T2JqZWN0LmRlZmluZVByb3BlcnRpZXM7dmFyIEQ9T2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnM7dmFyIGc9T2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9sczt2YXIgTT1PYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LE89T2JqZWN0LnByb3RvdHlwZS5wcm9wZXJ0eUlzRW51bWVyYWJsZTt2YXIgZD0oaSxzLG4pPT5zIGluIGk/bShpLHMse2VudW1lcmFibGU6ITAsY29uZmlndXJhYmxlOiEwLHdyaXRhYmxlOiEwLHZhbHVlOm59KTppW3NdPW4saD0oaSxzKT0+e2Zvcih2YXIgbiBpbiBzfHwocz17fSkpTS5jYWxsKHMsbikmJmQoaSxuLHNbbl0pO2lmKGcpZm9yKHZhciBuIG9mIGcocykpTy5jYWxsKHMsbikmJmQoaSxuLHNbbl0pO3JldHVybiBpfSxwPShpLHMpPT5UKGksRChzKSk7KGZ1bmN0aW9uKCl7InVzZSBzdHJpY3QiO2NvbnN0IGk9YXN5bmMoe2ZuOnQsdmFsaWRhdGU6ZSxpbnRlcnZhbDphLG1heEF0dGVtcHRzOnIsYXR0ZW1wdHM6Yz0wfSk9Pnthc3luYyBmdW5jdGlvbiBmKHUseSl7dHJ5e2NvbnN0IGw9YXdhaXQgdCgpO2lmKGMrKyxlKGwpKXtpZihyJiZjPT09cilyZXR1cm4geShuZXcgRXJyb3IoIkV4Y2VlZGVkIG1heCBhdHRlbXB0cyIpKTthd2FpdCBzZXRUaW1lb3V0KGYsYSx1LHkpfWVsc2UgcmV0dXJuIHUobCl9Y2F0Y2gobCl7Y29uc29sZS5lcnJvcihgcG9sbGluZyBFcnJvcjogJHsobD09bnVsbD92b2lkIDA6bC5tZXNzYWdlKXx8ImNvbm5lY3Rpb24gZmFpbGVkIn1gKX19cmV0dXJuIG5ldyBQcm9taXNlKGYpfSxzPXQ9PnR5cGVvZiB0PT0ib2JqZWN0IiYmIUFycmF5LmlzQXJyYXkodCkmJnQhPT1udWxsLG49KHQsZSxhPXt9KT0+KE9iamVjdC5rZXlzKHQpLmZvckVhY2gocj0+e2xldCBjPWU/ZSsiLiIrcjpyO3ModFtyXSk/bih0W3JdLGMsYSk6YVtjXT1BcnJheS5pc0FycmF5KHRbcl0pP3Rbcl0uc29ydCgpOnRbcl19KSxPYmplY3QuZW50cmllcyhhKS5zb3J0KCkpLEE9dD0+dC5mbGF0TWFwKGU9PnMoZSk/bihlKTpbZV0pLnNvcnQoKSx3PSh0LGUsYSk9PntsZXQgcj1BcnJheS5pc0FycmF5KHQpPyJhcnJheSI6dHlwZW9mIHQsYz1BcnJheS5pc0FycmF5KGUpPyJhcnJheSI6dHlwZW9mIGU7cmV0dXJuIHIhPT1jPyExOnIhPT0ib2JqZWN0IiYmciE9PSJhcnJheSI/cj09PWM6YSYmcj09PSJvYmplY3QiP2EubWFwKGY9PnRbZl09PT1lW2ZdKS5ldmVyeShmPT5mKToocj09PSJhcnJheSImJih0PUEodCksZT1BKGUpKSwhYSYmcj09PSJvYmplY3QiJiYodD1uKHQpLGU9bihlKSksSlNPTi5zdHJpbmdpZnkodCk9PT1KU09OLnN0cmluZ2lmeShlKSl9O3NlbGYuYWRkRXZlbnRMaXN0ZW5lcigibWVzc2FnZSIsdD0+e2NvbnN0e3R5cGU6ZX09dC5kYXRhO2xldCBhPW5ldyBBYm9ydENvbnRyb2xsZXIscj1hPT1udWxsP3ZvaWQgMDphLnNpZ25hbDtpZihlPT09ImNhbmNlbCImJihhPT1udWxsfHxhLmFib3J0KCkpLGU9PT0icG9sbCIpe2NvbnN0e3VybDpjLG9wdGlvbnM6ZixpbnRlcnZhbDp1LG1heEF0dGVtcHRzOnksZXhpc3RpbmdEYXRhOmwsY29tcGFyZUtleXM6RX09dC5kYXRhO2koe2ZuOigpPT5mZXRjaChjLGY/cChoKHt9LGYpLHtzaWduYWw6cn0pOntzaWduYWw6cn0pLnRoZW4obz0+e2lmKCFvLm9rfHxvLnN0YXR1cz09PTQwNCl0aHJvdyBuZXcgRXJyb3IoYEhUVFAgZXJyb3IhIFN0YXR1czogJHtvLnN0YXR1c31gKTtpZihvLnN0YXR1cz09PTQwMyl0aHJvdyBuZXcgRXJyb3IoIlVuYXV0aG9yaXplZCEiKTtyZXR1cm4gby5qc29uKCl9KSxpbnRlcnZhbDp1LG1heEF0dGVtcHRzOnksdmFsaWRhdGU6bz0+IXcobCxvLEUpfSkudGhlbihvPT57c2VsZi5wb3N0TWVzc2FnZSh7dHlwZToiREFUQSIsZGF0YTpvfSl9KS5jYXRjaChvPT57c2VsZi5wb3N0TWVzc2FnZSh7dHlwZTpvLm1lc3NhZ2V8fCJVbmtub3duIGVycm9yIn0pfSl9fSl9KSgpOwo=",I=typeof window!="undefined"&&window.Blob&&new Blob([atob(P)],{type:"text/javascript;charset=utf-8"});function O(){const t=I&&(window.URL||window.webkitURL).createObjectURL(I);try{return t?new Worker(t,{}):new Worker("data:application/javascript;base64,"+P,{type:"module"})}finally{t&&(window.URL||window.webkitURL).revokeObjectURL(t)}}const{remove:E,getData:z,setData:X,updateData:V}=x(),S=t=>{if(!t.ok||t.status===404)throw new Error(`HTTP error! Status: ${t.status}`);if(t.status===403)throw new Error("Unauthorized!");return t.json()},R=t=>{self.postMessage({type:t.message||"Unknown error"})};self.addEventListener("message",t=>{const{type:e}=t.data;let n=new AbortController,c=n==null?void 0:n.signal,a=new O;if(e==="cancel"&&(n==null||n.abort(),a==null||a.postMessage({type:"cancel"}),a.terminate()),e==="poll"){let{existingData:r,url:i,options:o,interval:f,maxAttempts:u,compareKeys:m}=t.data;fetch(i,o?T(Z({},o),{signal:c}):{signal:c}).then(S).then(p=>{G(r,p,m)?self.postMessage({type:"CACHED",data:p}):(X(i,{timestamp:Date.now(),data:p}),self.postMessage({type:"DATA",data:p}))}).catch(R).finally(()=>{a==null||a.postMessage({type:e,url:i,options:o,interval:f,maxAttempts:u,existingData:r,compareKeys:m})}),a==null||a.addEventListener("message",({data:p})=>{self.postMessage(p)})}if(e==="pre-fetch"){let{prefetch:r}=t.data;r.forEach(({middleware:i,url:o,options:f,maxAge:u})=>{let m=L(i);fetch(o.toString(),Z({signal:c},f)).then(S).then(p=>{X(o.toString(),{timestamp:Date.now(),data:m(p),maxAge:u}).then(()=>{console.log(`saved prefetch ${o}`)}).catch(b=>{console.log(`error saving prefetch ${o}`,b)})}).catch(()=>{console.info("no data found")})})}if(e==="fetch"){let{existingData:r,url:i,options:o,maxAge:f,middleware:u,update:m}=t.data;const p=s=>{s=L(u)(s),(!r||!G(r,s))&&(self.postMessage({type:"DATA",data:s}),X(i.toString(),{data:s,timestamp:Date.now(),maxAge:f}).then(()=>{console.info("saved data")}).catch(()=>{console.info("couldn't access indexedDB to save data")})),self.postMessage({type:"COMPLETE"})};let b=M(o);b==="DELETE"&&(E(i.toString()),fetch(i,o).then(()=>{m?fetch(m.url,m.options).then(S).then(p).catch(s=>{throw s}):self.postMessage({type:"COMPLETE"})}).catch(R)),b==="GET"&&(z(i.toString()).then(s=>{if(!s)throw new Error("no value found in db");if(U(s==null?void 0:s.maxAge,s==null?void 0:s.timestamp))throw E(i.toString()),new Error("data expired");self.postMessage(G(r,s==null?void 0:s.data)?{type:"CACHED"}:{type:"PRE_LOAD",data:s==null?void 0:s.data})}).catch(s=>{console.info(s==null?void 0:s.message)}),fetch(i,o?T(Z({},o),{signal:c}):{signal:c}).then(S).then(p).catch(R)),(b==="PUT"||b==="POST")&&fetch(i,o?T(Z({},o),{signal:c}):{signal:c}).then(S).then(s=>{m?fetch(m.url,m.options).then(S).then(p).catch(y=>{throw y}):V(i.toString(),y=>{let K=Date.now(),H=g(s)&&g(y==null?void 0:y.data)?Z(Z({},y.data),s):s;return self.postMessage({type:b,data:H}),{timestamp:K,maxAge:f,data:H}}).catch(()=>{console.info("update store failed")}).finally(()=>{self.postMessage({type:"COMPLETE"})})}).catch(R)}})})();
",R=typeof window!="undefined"&&window.Blob&&new Blob([atob(b)],{type:"text/javascript;charset=utf-8"});function m(){const l=R&&(window.URL||window.webkitURL).createObjectURL(R);try{return l?new Worker(l,{}):new Worker("data:application/javascript;base64,"+b,{type:"module"})}finally{l&&(window.URL||window.webkitURL).revokeObjectURL(l)}}const t={data:void 0,error:void 0,loading:!1,preload:!1,update:!0};function s(l,Z){switch(Z.type){case"pre-load":return a(c({},l),{data:Z.data,loading:!1,preload:!0,error:void 0});case"data":return a(c({},l),{data:Z.data,loading:!1,preload:!1,error:void 0});case"error":return a(c({},l),{error:Z.error,loading:!1,preload:!1});case"loading":return a(c({},l),{loading:Z.loading});default:return l}}const T=24*60*60*1e3;function i(l){l==null||l.postMessage({type:"cancel"}),l==null||l.terminate(),l=void 0}const N=l=>l?encodeURI(l.toString()):void 0;function k(){const[l,Z]=d.useReducer(s,t),V=d.useRef(),e=async({url:G,options:Y,maxAge:p=T,middleware:h})=>{let n=V.current;Z({type:"loading",loading:!0}),n==null||n.addEventListener("message",({data:{type:o,data:U}})=>{switch(o){case"CACHED":case"COMPLETE":Z({type:"loading",loading:!1});break;case"DATA":Z({type:"data",data:U});break;case"PRE_LOAD":Z({type:"pre-load",data:U});break;default:Z({type:"error",error:new Error(o)});break}}),n==null||n.postMessage({type:"fetch",url:G,options:Y,existingData:l.data,middleware:N(h),maxAge:p})};return d.useEffect(()=>(V.current=new m,()=>{i(V.current)}),[]),c({fetchWorker:e},l)}function J(l){const[Z,V]=d.useReducer(s,t),e=d.useRef(new m);return d.useEffect(()=>{var G,Y;l&&e.current&&(V({type:"loading",loading:!0}),(G=e.current)==null||G.addEventListener("message",({data:{type:p,data:h}})=>{V(p==="COMPLETE"?{type:"loading",loading:!1}:p==="DATA"?{type:"data",data:h}:{type:"error",error:new Error(p)})}),(Y=e.current)==null||Y.postMessage(a(c({type:"poll"},l),{existingData:Z.data})))},[l,e.current]),d.useEffect(()=>()=>{i(e.current)},[]),c({},Z)}function X(l){const Z=d.useRef(new m);d.useEffect(()=>{var V;l&&Z.current&&((V=Z.current)==null||V.postMessage({type:"pre-fetch",prefetch:l.map(e=>a(c({},e),{middleware:N(e.middleware)}))}))},[l,Z.current]),d.useEffect(()=>(Z.current=new m,()=>{i(Z.current)}),[])}W.useFetch=k,W.usePoll=J,W.usePreFetch=X,Object.defineProperties(W,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})}); +(function(l,d){typeof exports=="object"&&typeof module!="undefined"?d(exports,require("react"),require("idb-keyval")):typeof define=="function"&&define.amd?define(["exports","react","idb-keyval"],d):(l=typeof globalThis!="undefined"?globalThis:l||self,d(l.queryPlus={},l.React))})(this,function(l,d){"use strict";var J=Object.defineProperty,V=Object.defineProperties;var N=Object.getOwnPropertyDescriptors;var Y=Object.getOwnPropertySymbols;var r=Object.prototype.hasOwnProperty,C=Object.prototype.propertyIsEnumerable;var s=(l,d,b)=>d in l?J(l,d,{enumerable:!0,configurable:!0,writable:!0,value:b}):l[d]=b,m=(l,d)=>{for(var b in d||(d={}))r.call(d,b)&&s(l,b,d[b]);if(Y)for(var b of Y(d))C.call(d,b)&&s(l,b,d[b]);return l},n=(l,d)=>V(l,N(d));const b="dmFyIGI9T2JqZWN0LmRlZmluZVByb3BlcnR5LEk9T2JqZWN0LmRlZmluZVByb3BlcnRpZXM7dmFyIFE9T2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnM7dmFyIFI9T2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9sczt2YXIgVz1PYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LFg9T2JqZWN0LnByb3RvdHlwZS5wcm9wZXJ0eUlzRW51bWVyYWJsZTt2YXIgVT0oaSxmLGgpPT5mIGluIGk/YihpLGYse2VudW1lcmFibGU6ITAsY29uZmlndXJhYmxlOiEwLHdyaXRhYmxlOiEwLHZhbHVlOmh9KTppW2ZdPWgsbD0oaSxmKT0+e2Zvcih2YXIgaCBpbiBmfHwoZj17fSkpVy5jYWxsKGYsaCkmJlUoaSxoLGZbaF0pO2lmKFIpZm9yKHZhciBoIG9mIFIoZikpWC5jYWxsKGYsaCkmJlUoaSxoLGZbaF0pO3JldHVybiBpfSxUPShpLGYpPT5JKGksUShmKSk7KGZ1bmN0aW9uKCl7InVzZSBzdHJpY3QiO2Z1bmN0aW9uIGkodCl7cmV0dXJuIG5ldyBQcm9taXNlKChlLG4pPT57dC5vbmNvbXBsZXRlPXQub25zdWNjZXNzPSgpPT5lKHQucmVzdWx0KSx0Lm9uYWJvcnQ9dC5vbmVycm9yPSgpPT5uKHQuZXJyb3IpfSl9ZnVuY3Rpb24gZih0LGUpe2NvbnN0IG49aW5kZXhlZERCLm9wZW4odCk7bi5vbnVwZ3JhZGVuZWVkZWQ9KCk9Pm4ucmVzdWx0LmNyZWF0ZU9iamVjdFN0b3JlKGUpO2NvbnN0IHI9aShuKTtyZXR1cm4oYSxzKT0+ci50aGVuKGM9PnMoYy50cmFuc2FjdGlvbihlLGEpLm9iamVjdFN0b3JlKGUpKSl9bGV0IGg7ZnVuY3Rpb24gdygpe3JldHVybiBofHwoaD1mKCJrZXl2YWwtc3RvcmUiLCJrZXl2YWwiKSksaH1mdW5jdGlvbiBfKHQsZT13KCkpe3JldHVybiBlKCJyZWFkb25seSIsbj0+aShuLmdldCh0KSkpfWZ1bmN0aW9uIEcodCxlLG49dygpKXtyZXR1cm4gbigicmVhZHdyaXRlIixyPT4oci5wdXQoZSx0KSxpKHIudHJhbnNhY3Rpb24pKSl9ZnVuY3Rpb24gJCh0LGUsbj13KCkpe3JldHVybiBuKCJyZWFkd3JpdGUiLHI9Pm5ldyBQcm9taXNlKChhLHMpPT57ci5nZXQodCkub25zdWNjZXNzPWZ1bmN0aW9uKCl7dHJ5e3IucHV0KGUodGhpcy5yZXN1bHQpLHQpLGEoaShyLnRyYW5zYWN0aW9uKSl9Y2F0Y2goYyl7cyhjKX19fSkpfWZ1bmN0aW9uIEYodCxlPXcoKSl7cmV0dXJuIGUoInJlYWR3cml0ZSIsbj0+KG4uZGVsZXRlKHQpLGkobi50cmFuc2FjdGlvbikpKX1mdW5jdGlvbiBqKCl7Y29uc3Qgbj1mKCJ1c2VzdG9yZS1kYiIsInVzZXN0b3JlLWRiIik7cmV0dXJue3JlbW92ZTpkPT5GKGQsbiksZ2V0RGF0YTpkPT5fKGQsbiksc2V0RGF0YTooZCxnKT0+RyhkLGcsbiksdXBkYXRlRGF0YTooZCxnKT0+JChkLGcsbil9fWNvbnN0IHo9KHQsZSk9PmU/dCtlPERhdGUubm93KCk6ITAsQT10PT50eXBlb2YgdD09Im9iamVjdCImJiFBcnJheS5pc0FycmF5KHQpJiZ0IT09bnVsbCxtPSh0LGUsbj17fSk9PihPYmplY3Qua2V5cyh0KS5mb3JFYWNoKHI9PntsZXQgYT1lP2UrIi4iK3I6cjtBKHRbcl0pP20odFtyXSxhLG4pOm5bYV09QXJyYXkuaXNBcnJheSh0W3JdKT90W3JdLnNvcnQoKTp0W3JdfSksT2JqZWN0LmVudHJpZXMobikuc29ydCgpKSxNPXQ9PnQuZmxhdE1hcChlPT5BKGUpP20oZSk6W2VdKS5zb3J0KCksSD10PT57dmFyIGUsbjtyZXR1cm4obj0oZT10PT1udWxsP3ZvaWQgMDp0Lm1ldGhvZCk9PW51bGw/dm9pZCAwOmUudG9VcHBlckNhc2UoKSkhPW51bGw/bjoiR0VUIn0sTz0odCxlLG4pPT57bGV0IHI9QXJyYXkuaXNBcnJheSh0KT8iYXJyYXkiOnR5cGVvZiB0LGE9QXJyYXkuaXNBcnJheShlKT8iYXJyYXkiOnR5cGVvZiBlO3JldHVybiByIT09YT8hMTpyIT09Im9iamVjdCImJnIhPT0iYXJyYXkiP3I9PT1hOm4mJnI9PT0ib2JqZWN0Ij9uLm1hcChzPT50W3NdPT09ZVtzXSkuZXZlcnkocz0+cyk6KHI9PT0iYXJyYXkiJiYodD1NKHQpLGU9TShlKSksIW4mJnI9PT0ib2JqZWN0IiYmKHQ9bSh0KSxlPW0oZSkpLEpTT04uc3RyaW5naWZ5KHQpPT09SlNPTi5zdHJpbmdpZnkoZSkpfSxDPXQ9PnQ/bmV3IEZ1bmN0aW9uKGByZXR1cm4gJHtkZWNvZGVVUkkodCl9YCkoKTplPT5lLHtyZW1vdmU6UCxnZXREYXRhOkosc2V0RGF0YTpCLHVwZGF0ZURhdGE6Tn09aigpLEQ9dD0+e2lmKCF0Lm9rfHx0LnN0YXR1cz09PTQwNCl0aHJvdyBuZXcgRXJyb3IoYEhUVFAgZXJyb3IhIFN0YXR1czogJHt0LnN0YXR1c31gKTtpZih0LnN0YXR1cz09PTQwMyl0aHJvdyBuZXcgRXJyb3IoIlVuYXV0aG9yaXplZCEiKTtyZXR1cm4gdC5qc29uKCl9LFM9dD0+e3NlbGYucG9zdE1lc3NhZ2Uoe3R5cGU6dC5tZXNzYWdlfHwiVW5rbm93biBlcnJvciJ9KX07c2VsZi5hZGRFdmVudExpc3RlbmVyKCJtZXNzYWdlIix0PT57Y29uc3R7dHlwZTplfT10LmRhdGE7bGV0IG49bmV3IEFib3J0Q29udHJvbGxlcixyPW49PW51bGw/dm9pZCAwOm4uc2lnbmFsO2lmKGU9PT0iY2FuY2VsIiYmKG49PW51bGx8fG4uYWJvcnQoKSksZT09PSJwcmUtZmV0Y2giKXtsZXR7cHJlZmV0Y2g6YX09dC5kYXRhO2EuZm9yRWFjaCgoe21pZGRsZXdhcmU6cyx1cmw6YyxvcHRpb25zOmQsbWF4QWdlOmd9KT0+e2xldCBwPUMocyk7ZmV0Y2goYy50b1N0cmluZygpLGwoe3NpZ25hbDpyfSxkKSkudGhlbihEKS50aGVuKEU9PntCKGMudG9TdHJpbmcoKSx7dGltZXN0YW1wOkRhdGUubm93KCksZGF0YTpwKEUpLG1heEFnZTpnfSkudGhlbigoKT0+e2NvbnNvbGUubG9nKGBzYXZlZCBwcmVmZXRjaCAke2N9YCl9KS5jYXRjaCh1PT57Y29uc29sZS5sb2coYGVycm9yIHNhdmluZyBwcmVmZXRjaCAke2N9YCx1KX0pfSkuY2F0Y2goKCk9Pntjb25zb2xlLmluZm8oIm5vIGRhdGEgZm91bmQiKX0pfSl9aWYoZT09PSJmZXRjaCIpe2xldHtleGlzdGluZ0RhdGE6YSx1cmw6cyxvcHRpb25zOmMsbWF4QWdlOmQsbWlkZGxld2FyZTpnLHVwZGF0ZTpwfT10LmRhdGE7Y29uc3QgRT1vPT57bz1DKGcpKG8pLCghYXx8IU8oYSxvKSkmJihzZWxmLnBvc3RNZXNzYWdlKHt0eXBlOiJEQVRBIixkYXRhOm99KSxCKHMudG9TdHJpbmcoKSx7ZGF0YTpvLHRpbWVzdGFtcDpEYXRlLm5vdygpLG1heEFnZTpkfSkudGhlbigoKT0+e2NvbnNvbGUuaW5mbygic2F2ZWQgZGF0YSIpfSkuY2F0Y2goKCk9Pntjb25zb2xlLmluZm8oImNvdWxkbid0IGFjY2VzcyBpbmRleGVkREIgdG8gc2F2ZSBkYXRhIil9KSksc2VsZi5wb3N0TWVzc2FnZSh7dHlwZToiQ09NUExFVEUifSl9O2xldCB1PUgoYyk7dT09PSJERUxFVEUiJiYoUChzLnRvU3RyaW5nKCkpLGZldGNoKHMsYykudGhlbigoKT0+e3A/ZmV0Y2gocC51cmwscC5vcHRpb25zKS50aGVuKEQpLnRoZW4oRSkuY2F0Y2gobz0+e3Rocm93IG99KTpzZWxmLnBvc3RNZXNzYWdlKHt0eXBlOiJDT01QTEVURSJ9KX0pLmNhdGNoKFMpKSx1PT09IkdFVCImJihKKHMudG9TdHJpbmcoKSkudGhlbihvPT57aWYoIW8pdGhyb3cgbmV3IEVycm9yKCJubyB2YWx1ZSBmb3VuZCBpbiBkYiIpO2lmKHoobz09bnVsbD92b2lkIDA6by5tYXhBZ2Usbz09bnVsbD92b2lkIDA6by50aW1lc3RhbXApKXRocm93IFAocy50b1N0cmluZygpKSxuZXcgRXJyb3IoImRhdGEgZXhwaXJlZCIpO3NlbGYucG9zdE1lc3NhZ2UoTyhhLG89PW51bGw/dm9pZCAwOm8uZGF0YSk/e3R5cGU6IkNBQ0hFRCJ9Ont0eXBlOiJQUkVfTE9BRCIsZGF0YTpvPT1udWxsP3ZvaWQgMDpvLmRhdGF9KX0pLmNhdGNoKG89Pntjb25zb2xlLmluZm8obz09bnVsbD92b2lkIDA6by5tZXNzYWdlKX0pLGZldGNoKHMsYz9UKGwoe30sYykse3NpZ25hbDpyfSk6e3NpZ25hbDpyfSkudGhlbihEKS50aGVuKEUpLmNhdGNoKFMpKSwodT09PSJQVVQifHx1PT09IlBPU1QiKSYmZmV0Y2gocyxjP1QobCh7fSxjKSx7c2lnbmFsOnJ9KTp7c2lnbmFsOnJ9KS50aGVuKEQpLnRoZW4obz0+e3A/ZmV0Y2gocC51cmwscC5vcHRpb25zKS50aGVuKEQpLnRoZW4oRSkuY2F0Y2goeT0+e3Rocm93IHl9KTpOKHMudG9TdHJpbmcoKSx5PT57bGV0IHg9RGF0ZS5ub3coKSxMPUEobykmJkEoeT09bnVsbD92b2lkIDA6eS5kYXRhKT9sKGwoe30seS5kYXRhKSxvKTpvO3JldHVybiBzZWxmLnBvc3RNZXNzYWdlKHt0eXBlOnUsZGF0YTpMfSkse3RpbWVzdGFtcDp4LG1heEFnZTpkLGRhdGE6TH19KS5jYXRjaCgoKT0+e2NvbnNvbGUuaW5mbygidXBkYXRlIHN0b3JlIGZhaWxlZCIpfSkuZmluYWxseSgoKT0+e3NlbGYucG9zdE1lc3NhZ2Uoe3R5cGU6IkNPTVBMRVRFIn0pfSl9KS5jYXRjaChTKX19KX0pKCk7Cg==",u=typeof window!="undefined"&&window.Blob&&new Blob([atob(b)],{type:"text/javascript;charset=utf-8"});function p(){const e=u&&(window.URL||window.webkitURL).createObjectURL(u);try{return e?new Worker(e,{}):new Worker("data:application/javascript;base64,"+b,{type:"module"})}finally{e&&(window.URL||window.webkitURL).revokeObjectURL(e)}}const h={data:void 0,error:void 0,loading:!1,preload:!1,update:!0};function y(e,c){switch(c.type){case"pre-load":return n(m({},e),{data:c.data,loading:!1,preload:!0,error:void 0});case"data":return n(m({},e),{data:c.data,loading:!1,preload:!1,error:void 0});case"error":return n(m({},e),{error:c.error,loading:!1,preload:!1});case"loading":return n(m({},e),{loading:c.loading});default:return e}}const R=24*60*60*1e3;function G(e){e==null||e.postMessage({type:"cancel"}),e==null||e.terminate(),e=void 0}const K=e=>e?encodeURI(e.toString()):void 0;function T(){const[e,c]=d.useReducer(y,h),Z=d.useRef(),i=async({url:k,options:S,maxAge:W=R,middleware:I})=>{let o=Z.current;c({type:"loading",loading:!0}),o==null||o.addEventListener("message",({data:{type:a,data:t}})=>{switch(a){case"CACHED":case"COMPLETE":c({type:"loading",loading:!1});break;case"DATA":c({type:"data",data:t});break;case"PRE_LOAD":c({type:"pre-load",data:t});break;default:c({type:"error",error:new Error(a)});break}}),o==null||o.postMessage({type:"fetch",url:k,options:S,existingData:e.data,middleware:K(I),maxAge:W})};return d.useEffect(()=>(Z.current=new p,()=>{G(Z.current)}),[]),m({fetchWorker:i},e)}function X(e){const c=d.useRef(new p);d.useEffect(()=>{var Z;e&&c.current&&((Z=c.current)==null||Z.postMessage({type:"pre-fetch",prefetch:e.map(i=>n(m({},i),{middleware:K(i.middleware)}))}))},[e,c.current]),d.useEffect(()=>(c.current=new p,()=>{G(c.current)}),[])}l.useFetch=T,l.usePreFetch=X,Object.defineProperties(l,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})}); diff --git a/src/lib/hooks/usePoll.tsx b/src/lib/hooks/usePoll.tsx deleted file mode 100644 index dce4f8e..0000000 --- a/src/lib/hooks/usePoll.tsx +++ /dev/null @@ -1,29 +0,0 @@ -import { useRef, useEffect, useReducer } from "react"; - -import FetchWorker from '../workers/fetch_worker.js?worker&inline' -import { cleanupWorker, initialState, reducer } from "../utils"; - -import type { WorkerResponseType, PollWorkerProps } from "../types"; - -export function usePoll(props: PollWorkerProps) { - const [state, dispatch] = useReducer(reducer, initialState); - const worker = useRef(new FetchWorker()); - - useEffect(() => { - if(props && worker.current) { - dispatch({ type: 'loading', loading: true }) - worker.current?.addEventListener('message', ({ data: { type, data } }: WorkerResponseType) => { - if(type === 'COMPLETE') dispatch({ type: 'loading', loading: false }); - else if(type === 'DATA') dispatch({ type: 'data', data }); - else dispatch({ type: 'error', error: new Error(type) }); - }) - worker.current?.postMessage({ type: 'poll', ...props, existingData: state.data }); - } - }, [props, worker.current]); - useEffect(() => { - return () => { - cleanupWorker(worker.current); - } - }, []); - return { ...state! }; -}; diff --git a/src/lib/hooks/useStore.tsx b/src/lib/hooks/useStore.tsx deleted file mode 100644 index c2743ce..0000000 --- a/src/lib/hooks/useStore.tsx +++ /dev/null @@ -1,19 +0,0 @@ -import { useRef, useEffect, useState } from "react"; - -import StoreWorker from '../workers/store_worker.js?worker&inline' -import { cleanupWorker } from "../utils"; - -import type { WorkerResponseType } from "../types"; - -export function useData(key: string) { - const [data, setData] = useState() - const worker = useRef(new StoreWorker()); - // build the postMessage functions - - useEffect(() => { - return () => { - cleanupWorker(worker.current); - } - }, []); - return [data]; -}; diff --git a/src/lib/index.ts b/src/lib/index.ts index 3128e79..2c8a84d 100644 --- a/src/lib/index.ts +++ b/src/lib/index.ts @@ -1,3 +1,2 @@ export {useFetch} from './hooks/useFetch'; -export {usePoll} from './hooks/usePoll'; export {usePreFetch} from './hooks/usePreFetch'; \ No newline at end of file diff --git a/src/lib/utils/index.ts b/src/lib/utils/index.ts index 0ac111b..83b0afc 100644 --- a/src/lib/utils/index.ts +++ b/src/lib/utils/index.ts @@ -2,7 +2,6 @@ import type { createArrayOfUpdatesType, ArrayOfStringAnyTuple, StringAnyTuple } export * from "./state_tools"; export * from "./store_tools"; -export * from "./poll"; export const DAY = 24 * 60 * 60 * 1000; diff --git a/src/lib/utils/poll.ts b/src/lib/utils/poll.ts deleted file mode 100644 index c7e9266..0000000 --- a/src/lib/utils/poll.ts +++ /dev/null @@ -1,35 +0,0 @@ -export interface PollProps { - fn: () => Promise; - validate: (res: unknown) => boolean; - interval: number; - maxAttempts?: number; - attempts?: number -} - -export const poll: ( - { fn, validate, interval, maxAttempts }: PollProps, -) => Promise = async ({ fn, validate, interval, maxAttempts, attempts=0 }) => { - async function executePoll( - resolve: (value: unknown) => void, - reject: (reason?: any) => void, - ) { - try { - const result = await fn(); - attempts++; - if (!validate(result)) { - return resolve(result); - } else if (maxAttempts && (attempts === maxAttempts)) { - return reject(new Error("Exceeded max attempts")); - } else { - await setTimeout(executePoll, interval, resolve, reject); - } - } catch (error) { - console.error( - `polling Error: ${ - (error as Error)?.message || "connection failed" - }`, - ); - } - } - return new Promise(executePoll); -}; diff --git a/src/lib/workers/fetch_worker.ts b/src/lib/workers/fetch_worker.ts index 7ded2fe..145b749 100644 --- a/src/lib/workers/fetch_worker.ts +++ b/src/lib/workers/fetch_worker.ts @@ -7,9 +7,7 @@ import { store, } from "../utils"; -import PollWorker from "./polling_worker.js?worker&inline"; - -import type { WorkerResponseType, ValueType, FetchWorkerRequestType } from "../types"; +import type { ValueType, FetchWorkerRequestType } from "../types"; const { remove, getData, setData, updateData } = store(); @@ -33,53 +31,10 @@ self.addEventListener( const { type } = event.data; let controller: AbortController | undefined = new AbortController(); let signal = controller?.signal; - let pollWorker = new PollWorker(); + if (type === "cancel") { controller?.abort(); - pollWorker?.postMessage({ type: "cancel" }); - pollWorker.terminate(); - } - if (type === "poll") { - let { - existingData, - url, - options, - interval, - maxAttempts, - compareKeys, - } = event.data; - fetch(url, options ? { ...options, signal } : { signal }) - .then(handleResponse) - .then( - (data: unknown) => { - if (isMatch(existingData, data, compareKeys)) { - self.postMessage({ type: "CACHED", data }); - } else { - setData(url, { timestamp: Date.now(), data }); - self.postMessage({ type: "DATA", data }); - } - }, - ) - .catch(handleError) - .finally(() => { - pollWorker?.postMessage({ - type, - url, - options, - interval, - maxAttempts, - existingData, - compareKeys, - }); - }); - pollWorker?.addEventListener( - "message", - ({ data }: WorkerResponseType) => { - self.postMessage(data); - }, - ); } - if (type === "pre-fetch") { let { prefetch } = event.data; prefetch.forEach(({middleware, url, options, maxAge}:FetchWorkerRequestType) => { diff --git a/src/lib/workers/polling_worker.ts b/src/lib/workers/polling_worker.ts deleted file mode 100644 index 8f1cd92..0000000 --- a/src/lib/workers/polling_worker.ts +++ /dev/null @@ -1,35 +0,0 @@ -import {isMatch, poll} from "../utils" -self.addEventListener('message', (event) => { - const { type } = event.data; - let controller: AbortController | undefined = new AbortController(); - let signal = controller?.signal; - if (type === 'cancel') { - controller?.abort(); - } - if (type === 'poll') { - const { url, options, interval, maxAttempts, existingData, compareKeys } = event.data; - const validate = (newJson: unknown) => !isMatch(existingData, newJson, compareKeys); - const getData = () => fetch(url, options ? {...options, signal} : {signal}).then( - (response) => { - if (!response.ok || response.status === 404) { - throw new Error(`HTTP error! Status: ${ response.status }`); - } - if (response.status === 403) { - throw new Error(`Unauthorized!`); - } - return response.json(); - } - ) - poll({ - fn: getData, - interval, - maxAttempts, - validate - }) - .then(data => { - self.postMessage({type: 'DATA', data}); - }).catch(error => { - self.postMessage({type: error.message || 'Unknown error'}); - }) - } -}); \ No newline at end of file diff --git a/src/lib/workers/store_worker.ts b/src/lib/workers/store_worker.ts deleted file mode 100644 index 9f4e1ed..0000000 --- a/src/lib/workers/store_worker.ts +++ /dev/null @@ -1,79 +0,0 @@ -import { dataExpired, store } from "../utils"; - -const { remove, getData, setData, updateData } = store(); - -self.addEventListener( - "message", - (event) => { - let { - type, - url, - maxAge, - newData - } = event.data; - if(type === "get") { - getData(url).then(data => { - if(dataExpired(data, maxAge)) { - self.postMessage({ - type: "expired", - url, - }); - } else { - self.postMessage({ - type: "get-success", - url, - data, - }); - } - }).catch((error) => { - self.postMessage({ - type: "error", - error, - url, - }); - }) - } - if(type === "delete") { - remove(url).then(() => { - self.postMessage({ - type: "delete-success", - url, - }); - }).catch((error) => { - self.postMessage({ - type: "error", - error, - url, - }); - }) - } - if(type === "set") { - setData(url, newData).then(() => { - self.postMessage({ - type: "set-success", - url, - }); - }).catch((error) => { - self.postMessage({ - type: "error", - error, - url, - }); - }) - } - if(type === "update") { - updateData(url, newData).then(() => { - self.postMessage({ - type: "update-success", - url, - }); - }).catch((error) => { - self.postMessage({ - type: "error", - error, - url, - }); - }) - } - }, -);