@tanstack/query-async-storage-persister 5.0.0-alpha.7 → 5.0.0-alpha.70

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/build/lib/__tests__/asyncThrottle.test.d.ts +1 -0
  2. package/build/lib/__tests__/asyncThrottle.test.d.ts.map +1 -0
  3. package/build/lib/__tests__/utils.d.ts +1 -0
  4. package/build/lib/__tests__/utils.d.ts.map +1 -0
  5. package/build/lib/{asyncThrottle.mjs → asyncThrottle.cjs} +4 -2
  6. package/build/lib/{asyncThrottle.mjs.map → asyncThrottle.cjs.map} +1 -1
  7. package/build/lib/asyncThrottle.d.ts +1 -0
  8. package/build/lib/asyncThrottle.d.ts.map +1 -0
  9. package/build/lib/asyncThrottle.js +1 -3
  10. package/build/lib/asyncThrottle.js.map +1 -1
  11. package/build/lib/asyncThrottle.legacy.cjs +52 -0
  12. package/build/lib/asyncThrottle.legacy.cjs.map +1 -0
  13. package/build/lib/{asyncThrottle.esm.js → asyncThrottle.legacy.js} +1 -1
  14. package/build/lib/asyncThrottle.legacy.js.map +1 -0
  15. package/build/lib/{index.mjs → index.cjs} +6 -4
  16. package/build/lib/{index.mjs.map → index.cjs.map} +1 -1
  17. package/build/lib/index.d.ts +2 -1
  18. package/build/lib/index.d.ts.map +1 -0
  19. package/build/lib/index.js +5 -7
  20. package/build/lib/index.js.map +1 -1
  21. package/build/lib/index.legacy.cjs +62 -0
  22. package/build/lib/index.legacy.cjs.map +1 -0
  23. package/build/lib/{index.esm.js → index.legacy.js} +2 -2
  24. package/build/lib/index.legacy.js.map +1 -0
  25. package/package.json +14 -10
  26. package/build/lib/asyncThrottle.esm.js.map +0 -1
  27. package/build/lib/index.esm.js.map +0 -1
  28. package/build/umd/index.development.js +0 -114
  29. package/build/umd/index.development.js.map +0 -1
  30. package/build/umd/index.production.js +0 -2
  31. package/build/umd/index.production.js.map +0 -1
@@ -1 +1,2 @@
1
1
  export {};
2
+ //# sourceMappingURL=asyncThrottle.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"asyncThrottle.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/asyncThrottle.test.ts"],"names":[],"mappings":""}
@@ -1 +1,2 @@
1
1
  export declare function sleep(timeout: number): Promise<void>;
2
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/__tests__/utils.ts"],"names":[],"mappings":"AAAA,wBAAgB,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAIpD"}
@@ -1,3 +1,5 @@
1
+ 'use strict';
2
+
1
3
  const noop = () => {
2
4
  /* do nothing */
3
5
  };
@@ -46,5 +48,5 @@ function asyncThrottle(func, {
46
48
  };
47
49
  }
48
50
 
49
- export { asyncThrottle };
50
- //# sourceMappingURL=asyncThrottle.mjs.map
51
+ exports.asyncThrottle = asyncThrottle;
52
+ //# sourceMappingURL=asyncThrottle.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"asyncThrottle.mjs","sources":["../../src/asyncThrottle.ts"],"sourcesContent":["export interface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nconst noop = () => {\n /* do nothing */\n}\n\nexport function asyncThrottle<Args extends readonly unknown[]>(\n func: (...args: Args) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let running = false\n let lastTime = 0\n let timeout: ReturnType<typeof setTimeout>\n let currentArgs: Args | null = null\n\n const execFunc = async () => {\n if (currentArgs) {\n const args = currentArgs\n currentArgs = null\n try {\n running = true\n await func(...args)\n } catch (error) {\n onError(error)\n } finally {\n lastTime = Date.now() // this line must after 'func' executed to avoid two 'func' running in concurrent.\n running = false\n }\n }\n }\n\n const delayFunc = async () => {\n clearTimeout(timeout)\n timeout = setTimeout(() => {\n if (running) {\n delayFunc() // Will come here when 'func' execution time is greater than the interval.\n } else {\n execFunc()\n }\n }, interval)\n }\n\n return (...args: Args) => {\n currentArgs = args\n\n const tooSoon = Date.now() - lastTime < interval\n if (running || tooSoon) {\n delayFunc()\n } else {\n execFunc()\n }\n }\n}\n"],"names":["noop","asyncThrottle","func","interval","onError","Error","running","lastTime","timeout","currentArgs","execFunc","args","error","Date","now","delayFunc","clearTimeout","setTimeout","tooSoon"],"mappings":"AAKA,MAAMA,IAAI,GAAG,MAAM;AACjB;AAAA,CACD,CAAA;AAEM,SAASC,aAAa,CAC3BC,IAAsC,EACtC;AAAEC,EAAAA,QAAQ,GAAG,IAAI;AAAEC,EAAAA,OAAO,GAAGJ,IAAAA;AAA2B,CAAC,GAAG,EAAE,EAC9D;EACA,IAAI,OAAOE,IAAI,KAAK,UAAU,EAAE,MAAM,IAAIG,KAAK,CAAC,2BAA2B,CAAC,CAAA;EAE5E,IAAIC,OAAO,GAAG,KAAK,CAAA;EACnB,IAAIC,QAAQ,GAAG,CAAC,CAAA;AAChB,EAAA,IAAIC,OAAsC,CAAA;EAC1C,IAAIC,WAAwB,GAAG,IAAI,CAAA;EAEnC,MAAMC,QAAQ,GAAG,YAAY;AAC3B,IAAA,IAAID,WAAW,EAAE;MACf,MAAME,IAAI,GAAGF,WAAW,CAAA;AACxBA,MAAAA,WAAW,GAAG,IAAI,CAAA;MAClB,IAAI;AACFH,QAAAA,OAAO,GAAG,IAAI,CAAA;AACd,QAAA,MAAMJ,IAAI,CAAC,GAAGS,IAAI,CAAC,CAAA;OACpB,CAAC,OAAOC,KAAK,EAAE;QACdR,OAAO,CAACQ,KAAK,CAAC,CAAA;AAChB,OAAC,SAAS;AACRL,QAAAA,QAAQ,GAAGM,IAAI,CAACC,GAAG,EAAE,CAAC;AACtBR,QAAAA,OAAO,GAAG,KAAK,CAAA;AACjB,OAAA;AACF,KAAA;GACD,CAAA;EAED,MAAMS,SAAS,GAAG,YAAY;IAC5BC,YAAY,CAACR,OAAO,CAAC,CAAA;IACrBA,OAAO,GAAGS,UAAU,CAAC,MAAM;AACzB,MAAA,IAAIX,OAAO,EAAE;AACXS,QAAAA,SAAS,EAAE,CAAC;AACd,OAAC,MAAM;AACLL,QAAAA,QAAQ,EAAE,CAAA;AACZ,OAAA;KACD,EAAEP,QAAQ,CAAC,CAAA;GACb,CAAA;EAED,OAAO,CAAC,GAAGQ,IAAU,KAAK;AACxBF,IAAAA,WAAW,GAAGE,IAAI,CAAA;IAElB,MAAMO,OAAO,GAAGL,IAAI,CAACC,GAAG,EAAE,GAAGP,QAAQ,GAAGJ,QAAQ,CAAA;IAChD,IAAIG,OAAO,IAAIY,OAAO,EAAE;AACtBH,MAAAA,SAAS,EAAE,CAAA;AACb,KAAC,MAAM;AACLL,MAAAA,QAAQ,EAAE,CAAA;AACZ,KAAA;GACD,CAAA;AACH;;;;"}
1
+ {"version":3,"file":"asyncThrottle.cjs","sources":["../../src/asyncThrottle.ts"],"sourcesContent":["export interface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nconst noop = () => {\n /* do nothing */\n}\n\nexport function asyncThrottle<Args extends readonly unknown[]>(\n func: (...args: Args) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let running = false\n let lastTime = 0\n let timeout: ReturnType<typeof setTimeout>\n let currentArgs: Args | null = null\n\n const execFunc = async () => {\n if (currentArgs) {\n const args = currentArgs\n currentArgs = null\n try {\n running = true\n await func(...args)\n } catch (error) {\n onError(error)\n } finally {\n lastTime = Date.now() // this line must after 'func' executed to avoid two 'func' running in concurrent.\n running = false\n }\n }\n }\n\n const delayFunc = async () => {\n clearTimeout(timeout)\n timeout = setTimeout(() => {\n if (running) {\n delayFunc() // Will come here when 'func' execution time is greater than the interval.\n } else {\n execFunc()\n }\n }, interval)\n }\n\n return (...args: Args) => {\n currentArgs = args\n\n const tooSoon = Date.now() - lastTime < interval\n if (running || tooSoon) {\n delayFunc()\n } else {\n execFunc()\n }\n }\n}\n"],"names":["noop","asyncThrottle","func","interval","onError","Error","running","lastTime","timeout","currentArgs","execFunc","args","error","Date","now","delayFunc","clearTimeout","setTimeout","tooSoon"],"mappings":";;AAKA,MAAMA,IAAI,GAAGA,MAAM;AACjB;AAAA,CACD,CAAA;AAEM,SAASC,aAAaA,CAC3BC,IAAsC,EACtC;AAAEC,EAAAA,QAAQ,GAAG,IAAI;AAAEC,EAAAA,OAAO,GAAGJ,IAAAA;AAA2B,CAAC,GAAG,EAAE,EAC9D;EACA,IAAI,OAAOE,IAAI,KAAK,UAAU,EAAE,MAAM,IAAIG,KAAK,CAAC,2BAA2B,CAAC,CAAA;EAE5E,IAAIC,OAAO,GAAG,KAAK,CAAA;EACnB,IAAIC,QAAQ,GAAG,CAAC,CAAA;AAChB,EAAA,IAAIC,OAAsC,CAAA;EAC1C,IAAIC,WAAwB,GAAG,IAAI,CAAA;AAEnC,EAAA,MAAMC,QAAQ,GAAG,YAAY;AAC3B,IAAA,IAAID,WAAW,EAAE;MACf,MAAME,IAAI,GAAGF,WAAW,CAAA;AACxBA,MAAAA,WAAW,GAAG,IAAI,CAAA;MAClB,IAAI;AACFH,QAAAA,OAAO,GAAG,IAAI,CAAA;AACd,QAAA,MAAMJ,IAAI,CAAC,GAAGS,IAAI,CAAC,CAAA;OACpB,CAAC,OAAOC,KAAK,EAAE;QACdR,OAAO,CAACQ,KAAK,CAAC,CAAA;AAChB,OAAC,SAAS;AACRL,QAAAA,QAAQ,GAAGM,IAAI,CAACC,GAAG,EAAE,CAAC;AACtBR,QAAAA,OAAO,GAAG,KAAK,CAAA;AACjB,OAAA;AACF,KAAA;GACD,CAAA;AAED,EAAA,MAAMS,SAAS,GAAG,YAAY;IAC5BC,YAAY,CAACR,OAAO,CAAC,CAAA;IACrBA,OAAO,GAAGS,UAAU,CAAC,MAAM;AACzB,MAAA,IAAIX,OAAO,EAAE;QACXS,SAAS,EAAE,CAAC;AACd,OAAC,MAAM;AACLL,QAAAA,QAAQ,EAAE,CAAA;AACZ,OAAA;KACD,EAAEP,QAAQ,CAAC,CAAA;GACb,CAAA;EAED,OAAO,CAAC,GAAGQ,IAAU,KAAK;AACxBF,IAAAA,WAAW,GAAGE,IAAI,CAAA;IAElB,MAAMO,OAAO,GAAGL,IAAI,CAACC,GAAG,EAAE,GAAGP,QAAQ,GAAGJ,QAAQ,CAAA;IAChD,IAAIG,OAAO,IAAIY,OAAO,EAAE;AACtBH,MAAAA,SAAS,EAAE,CAAA;AACb,KAAC,MAAM;AACLL,MAAAA,QAAQ,EAAE,CAAA;AACZ,KAAA;GACD,CAAA;AACH;;;;"}
@@ -3,3 +3,4 @@ export interface AsyncThrottleOptions {
3
3
  onError?: (error: unknown) => void;
4
4
  }
5
5
  export declare function asyncThrottle<Args extends readonly unknown[]>(func: (...args: Args) => Promise<void>, { interval, onError }?: AsyncThrottleOptions): (...args: Args) => void;
6
+ //# sourceMappingURL=asyncThrottle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"asyncThrottle.d.ts","sourceRoot":"","sources":["../../src/asyncThrottle.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,oBAAoB;IACnC,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,IAAI,CAAA;CACnC;AAMD,wBAAgB,aAAa,CAAC,IAAI,SAAS,SAAS,OAAO,EAAE,EAC3D,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,IAAI,KAAK,OAAO,CAAC,IAAI,CAAC,EACtC,EAAE,QAAe,EAAE,OAAc,EAAE,GAAE,oBAAyB,aAoC7C,IAAI,UAUtB"}
@@ -1,5 +1,3 @@
1
- 'use strict';
2
-
3
1
  const noop = () => {
4
2
  /* do nothing */
5
3
  };
@@ -48,5 +46,5 @@ function asyncThrottle(func, {
48
46
  };
49
47
  }
50
48
 
51
- exports.asyncThrottle = asyncThrottle;
49
+ export { asyncThrottle };
52
50
  //# sourceMappingURL=asyncThrottle.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"asyncThrottle.js","sources":["../../src/asyncThrottle.ts"],"sourcesContent":["export interface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nconst noop = () => {\n /* do nothing */\n}\n\nexport function asyncThrottle<Args extends readonly unknown[]>(\n func: (...args: Args) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let running = false\n let lastTime = 0\n let timeout: ReturnType<typeof setTimeout>\n let currentArgs: Args | null = null\n\n const execFunc = async () => {\n if (currentArgs) {\n const args = currentArgs\n currentArgs = null\n try {\n running = true\n await func(...args)\n } catch (error) {\n onError(error)\n } finally {\n lastTime = Date.now() // this line must after 'func' executed to avoid two 'func' running in concurrent.\n running = false\n }\n }\n }\n\n const delayFunc = async () => {\n clearTimeout(timeout)\n timeout = setTimeout(() => {\n if (running) {\n delayFunc() // Will come here when 'func' execution time is greater than the interval.\n } else {\n execFunc()\n }\n }, interval)\n }\n\n return (...args: Args) => {\n currentArgs = args\n\n const tooSoon = Date.now() - lastTime < interval\n if (running || tooSoon) {\n delayFunc()\n } else {\n execFunc()\n }\n }\n}\n"],"names":["noop","asyncThrottle","func","interval","onError","Error","running","lastTime","timeout","currentArgs","execFunc","args","error","Date","now","delayFunc","clearTimeout","setTimeout","tooSoon"],"mappings":";;AAKA,MAAMA,IAAI,GAAG,MAAM;AACjB;AAAA,CACD,CAAA;AAEM,SAASC,aAAa,CAC3BC,IAAsC,EACtC;AAAEC,EAAAA,QAAQ,GAAG,IAAI;AAAEC,EAAAA,OAAO,GAAGJ,IAAAA;AAA2B,CAAC,GAAG,EAAE,EAC9D;EACA,IAAI,OAAOE,IAAI,KAAK,UAAU,EAAE,MAAM,IAAIG,KAAK,CAAC,2BAA2B,CAAC,CAAA;EAE5E,IAAIC,OAAO,GAAG,KAAK,CAAA;EACnB,IAAIC,QAAQ,GAAG,CAAC,CAAA;AAChB,EAAA,IAAIC,OAAsC,CAAA;EAC1C,IAAIC,WAAwB,GAAG,IAAI,CAAA;EAEnC,MAAMC,QAAQ,GAAG,YAAY;AAC3B,IAAA,IAAID,WAAW,EAAE;MACf,MAAME,IAAI,GAAGF,WAAW,CAAA;AACxBA,MAAAA,WAAW,GAAG,IAAI,CAAA;MAClB,IAAI;AACFH,QAAAA,OAAO,GAAG,IAAI,CAAA;AACd,QAAA,MAAMJ,IAAI,CAAC,GAAGS,IAAI,CAAC,CAAA;OACpB,CAAC,OAAOC,KAAK,EAAE;QACdR,OAAO,CAACQ,KAAK,CAAC,CAAA;AAChB,OAAC,SAAS;AACRL,QAAAA,QAAQ,GAAGM,IAAI,CAACC,GAAG,EAAE,CAAC;AACtBR,QAAAA,OAAO,GAAG,KAAK,CAAA;AACjB,OAAA;AACF,KAAA;GACD,CAAA;EAED,MAAMS,SAAS,GAAG,YAAY;IAC5BC,YAAY,CAACR,OAAO,CAAC,CAAA;IACrBA,OAAO,GAAGS,UAAU,CAAC,MAAM;AACzB,MAAA,IAAIX,OAAO,EAAE;AACXS,QAAAA,SAAS,EAAE,CAAC;AACd,OAAC,MAAM;AACLL,QAAAA,QAAQ,EAAE,CAAA;AACZ,OAAA;KACD,EAAEP,QAAQ,CAAC,CAAA;GACb,CAAA;EAED,OAAO,CAAC,GAAGQ,IAAU,KAAK;AACxBF,IAAAA,WAAW,GAAGE,IAAI,CAAA;IAElB,MAAMO,OAAO,GAAGL,IAAI,CAACC,GAAG,EAAE,GAAGP,QAAQ,GAAGJ,QAAQ,CAAA;IAChD,IAAIG,OAAO,IAAIY,OAAO,EAAE;AACtBH,MAAAA,SAAS,EAAE,CAAA;AACb,KAAC,MAAM;AACLL,MAAAA,QAAQ,EAAE,CAAA;AACZ,KAAA;GACD,CAAA;AACH;;;;"}
1
+ {"version":3,"file":"asyncThrottle.js","sources":["../../src/asyncThrottle.ts"],"sourcesContent":["export interface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nconst noop = () => {\n /* do nothing */\n}\n\nexport function asyncThrottle<Args extends readonly unknown[]>(\n func: (...args: Args) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let running = false\n let lastTime = 0\n let timeout: ReturnType<typeof setTimeout>\n let currentArgs: Args | null = null\n\n const execFunc = async () => {\n if (currentArgs) {\n const args = currentArgs\n currentArgs = null\n try {\n running = true\n await func(...args)\n } catch (error) {\n onError(error)\n } finally {\n lastTime = Date.now() // this line must after 'func' executed to avoid two 'func' running in concurrent.\n running = false\n }\n }\n }\n\n const delayFunc = async () => {\n clearTimeout(timeout)\n timeout = setTimeout(() => {\n if (running) {\n delayFunc() // Will come here when 'func' execution time is greater than the interval.\n } else {\n execFunc()\n }\n }, interval)\n }\n\n return (...args: Args) => {\n currentArgs = args\n\n const tooSoon = Date.now() - lastTime < interval\n if (running || tooSoon) {\n delayFunc()\n } else {\n execFunc()\n }\n }\n}\n"],"names":["noop","asyncThrottle","func","interval","onError","Error","running","lastTime","timeout","currentArgs","execFunc","args","error","Date","now","delayFunc","clearTimeout","setTimeout","tooSoon"],"mappings":"AAKA,MAAMA,IAAI,GAAGA,MAAM;AACjB;AAAA,CACD,CAAA;AAEM,SAASC,aAAaA,CAC3BC,IAAsC,EACtC;AAAEC,EAAAA,QAAQ,GAAG,IAAI;AAAEC,EAAAA,OAAO,GAAGJ,IAAAA;AAA2B,CAAC,GAAG,EAAE,EAC9D;EACA,IAAI,OAAOE,IAAI,KAAK,UAAU,EAAE,MAAM,IAAIG,KAAK,CAAC,2BAA2B,CAAC,CAAA;EAE5E,IAAIC,OAAO,GAAG,KAAK,CAAA;EACnB,IAAIC,QAAQ,GAAG,CAAC,CAAA;AAChB,EAAA,IAAIC,OAAsC,CAAA;EAC1C,IAAIC,WAAwB,GAAG,IAAI,CAAA;AAEnC,EAAA,MAAMC,QAAQ,GAAG,YAAY;AAC3B,IAAA,IAAID,WAAW,EAAE;MACf,MAAME,IAAI,GAAGF,WAAW,CAAA;AACxBA,MAAAA,WAAW,GAAG,IAAI,CAAA;MAClB,IAAI;AACFH,QAAAA,OAAO,GAAG,IAAI,CAAA;AACd,QAAA,MAAMJ,IAAI,CAAC,GAAGS,IAAI,CAAC,CAAA;OACpB,CAAC,OAAOC,KAAK,EAAE;QACdR,OAAO,CAACQ,KAAK,CAAC,CAAA;AAChB,OAAC,SAAS;AACRL,QAAAA,QAAQ,GAAGM,IAAI,CAACC,GAAG,EAAE,CAAC;AACtBR,QAAAA,OAAO,GAAG,KAAK,CAAA;AACjB,OAAA;AACF,KAAA;GACD,CAAA;AAED,EAAA,MAAMS,SAAS,GAAG,YAAY;IAC5BC,YAAY,CAACR,OAAO,CAAC,CAAA;IACrBA,OAAO,GAAGS,UAAU,CAAC,MAAM;AACzB,MAAA,IAAIX,OAAO,EAAE;QACXS,SAAS,EAAE,CAAC;AACd,OAAC,MAAM;AACLL,QAAAA,QAAQ,EAAE,CAAA;AACZ,OAAA;KACD,EAAEP,QAAQ,CAAC,CAAA;GACb,CAAA;EAED,OAAO,CAAC,GAAGQ,IAAU,KAAK;AACxBF,IAAAA,WAAW,GAAGE,IAAI,CAAA;IAElB,MAAMO,OAAO,GAAGL,IAAI,CAACC,GAAG,EAAE,GAAGP,QAAQ,GAAGJ,QAAQ,CAAA;IAChD,IAAIG,OAAO,IAAIY,OAAO,EAAE;AACtBH,MAAAA,SAAS,EAAE,CAAA;AACb,KAAC,MAAM;AACLL,MAAAA,QAAQ,EAAE,CAAA;AACZ,KAAA;GACD,CAAA;AACH;;;;"}
@@ -0,0 +1,52 @@
1
+ 'use strict';
2
+
3
+ const noop = () => {
4
+ /* do nothing */
5
+ };
6
+ function asyncThrottle(func, {
7
+ interval = 1000,
8
+ onError = noop
9
+ } = {}) {
10
+ if (typeof func !== 'function') throw new Error('argument is not function.');
11
+ let running = false;
12
+ let lastTime = 0;
13
+ let timeout;
14
+ let currentArgs = null;
15
+ const execFunc = async () => {
16
+ if (currentArgs) {
17
+ const args = currentArgs;
18
+ currentArgs = null;
19
+ try {
20
+ running = true;
21
+ await func(...args);
22
+ } catch (error) {
23
+ onError(error);
24
+ } finally {
25
+ lastTime = Date.now(); // this line must after 'func' executed to avoid two 'func' running in concurrent.
26
+ running = false;
27
+ }
28
+ }
29
+ };
30
+ const delayFunc = async () => {
31
+ clearTimeout(timeout);
32
+ timeout = setTimeout(() => {
33
+ if (running) {
34
+ delayFunc(); // Will come here when 'func' execution time is greater than the interval.
35
+ } else {
36
+ execFunc();
37
+ }
38
+ }, interval);
39
+ };
40
+ return (...args) => {
41
+ currentArgs = args;
42
+ const tooSoon = Date.now() - lastTime < interval;
43
+ if (running || tooSoon) {
44
+ delayFunc();
45
+ } else {
46
+ execFunc();
47
+ }
48
+ };
49
+ }
50
+
51
+ exports.asyncThrottle = asyncThrottle;
52
+ //# sourceMappingURL=asyncThrottle.legacy.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"asyncThrottle.legacy.cjs","sources":["../../src/asyncThrottle.ts"],"sourcesContent":["export interface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nconst noop = () => {\n /* do nothing */\n}\n\nexport function asyncThrottle<Args extends readonly unknown[]>(\n func: (...args: Args) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let running = false\n let lastTime = 0\n let timeout: ReturnType<typeof setTimeout>\n let currentArgs: Args | null = null\n\n const execFunc = async () => {\n if (currentArgs) {\n const args = currentArgs\n currentArgs = null\n try {\n running = true\n await func(...args)\n } catch (error) {\n onError(error)\n } finally {\n lastTime = Date.now() // this line must after 'func' executed to avoid two 'func' running in concurrent.\n running = false\n }\n }\n }\n\n const delayFunc = async () => {\n clearTimeout(timeout)\n timeout = setTimeout(() => {\n if (running) {\n delayFunc() // Will come here when 'func' execution time is greater than the interval.\n } else {\n execFunc()\n }\n }, interval)\n }\n\n return (...args: Args) => {\n currentArgs = args\n\n const tooSoon = Date.now() - lastTime < interval\n if (running || tooSoon) {\n delayFunc()\n } else {\n execFunc()\n }\n }\n}\n"],"names":["noop","asyncThrottle","func","interval","onError","Error","running","lastTime","timeout","currentArgs","execFunc","args","error","Date","now","delayFunc","clearTimeout","setTimeout","tooSoon"],"mappings":";;AAKA,MAAMA,IAAI,GAAGA,MAAM;AACjB;AAAA,CACD,CAAA;AAEM,SAASC,aAAaA,CAC3BC,IAAsC,EACtC;AAAEC,EAAAA,QAAQ,GAAG,IAAI;AAAEC,EAAAA,OAAO,GAAGJ,IAAAA;AAA2B,CAAC,GAAG,EAAE,EAC9D;EACA,IAAI,OAAOE,IAAI,KAAK,UAAU,EAAE,MAAM,IAAIG,KAAK,CAAC,2BAA2B,CAAC,CAAA;EAE5E,IAAIC,OAAO,GAAG,KAAK,CAAA;EACnB,IAAIC,QAAQ,GAAG,CAAC,CAAA;AAChB,EAAA,IAAIC,OAAsC,CAAA;EAC1C,IAAIC,WAAwB,GAAG,IAAI,CAAA;AAEnC,EAAA,MAAMC,QAAQ,GAAG,YAAY;AAC3B,IAAA,IAAID,WAAW,EAAE;MACf,MAAME,IAAI,GAAGF,WAAW,CAAA;AACxBA,MAAAA,WAAW,GAAG,IAAI,CAAA;MAClB,IAAI;AACFH,QAAAA,OAAO,GAAG,IAAI,CAAA;AACd,QAAA,MAAMJ,IAAI,CAAC,GAAGS,IAAI,CAAC,CAAA;OACpB,CAAC,OAAOC,KAAK,EAAE;QACdR,OAAO,CAACQ,KAAK,CAAC,CAAA;AAChB,OAAC,SAAS;AACRL,QAAAA,QAAQ,GAAGM,IAAI,CAACC,GAAG,EAAE,CAAC;AACtBR,QAAAA,OAAO,GAAG,KAAK,CAAA;AACjB,OAAA;AACF,KAAA;GACD,CAAA;AAED,EAAA,MAAMS,SAAS,GAAG,YAAY;IAC5BC,YAAY,CAACR,OAAO,CAAC,CAAA;IACrBA,OAAO,GAAGS,UAAU,CAAC,MAAM;AACzB,MAAA,IAAIX,OAAO,EAAE;QACXS,SAAS,EAAE,CAAC;AACd,OAAC,MAAM;AACLL,QAAAA,QAAQ,EAAE,CAAA;AACZ,OAAA;KACD,EAAEP,QAAQ,CAAC,CAAA;GACb,CAAA;EAED,OAAO,CAAC,GAAGQ,IAAU,KAAK;AACxBF,IAAAA,WAAW,GAAGE,IAAI,CAAA;IAElB,MAAMO,OAAO,GAAGL,IAAI,CAACC,GAAG,EAAE,GAAGP,QAAQ,GAAGJ,QAAQ,CAAA;IAChD,IAAIG,OAAO,IAAIY,OAAO,EAAE;AACtBH,MAAAA,SAAS,EAAE,CAAA;AACb,KAAC,MAAM;AACLL,MAAAA,QAAQ,EAAE,CAAA;AACZ,KAAA;GACD,CAAA;AACH;;;;"}
@@ -47,4 +47,4 @@ function asyncThrottle(func, {
47
47
  }
48
48
 
49
49
  export { asyncThrottle };
50
- //# sourceMappingURL=asyncThrottle.esm.js.map
50
+ //# sourceMappingURL=asyncThrottle.legacy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"asyncThrottle.legacy.js","sources":["../../src/asyncThrottle.ts"],"sourcesContent":["export interface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nconst noop = () => {\n /* do nothing */\n}\n\nexport function asyncThrottle<Args extends readonly unknown[]>(\n func: (...args: Args) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let running = false\n let lastTime = 0\n let timeout: ReturnType<typeof setTimeout>\n let currentArgs: Args | null = null\n\n const execFunc = async () => {\n if (currentArgs) {\n const args = currentArgs\n currentArgs = null\n try {\n running = true\n await func(...args)\n } catch (error) {\n onError(error)\n } finally {\n lastTime = Date.now() // this line must after 'func' executed to avoid two 'func' running in concurrent.\n running = false\n }\n }\n }\n\n const delayFunc = async () => {\n clearTimeout(timeout)\n timeout = setTimeout(() => {\n if (running) {\n delayFunc() // Will come here when 'func' execution time is greater than the interval.\n } else {\n execFunc()\n }\n }, interval)\n }\n\n return (...args: Args) => {\n currentArgs = args\n\n const tooSoon = Date.now() - lastTime < interval\n if (running || tooSoon) {\n delayFunc()\n } else {\n execFunc()\n }\n }\n}\n"],"names":["noop","asyncThrottle","func","interval","onError","Error","running","lastTime","timeout","currentArgs","execFunc","args","error","Date","now","delayFunc","clearTimeout","setTimeout","tooSoon"],"mappings":"AAKA,MAAMA,IAAI,GAAGA,MAAM;AACjB;AAAA,CACD,CAAA;AAEM,SAASC,aAAaA,CAC3BC,IAAsC,EACtC;AAAEC,EAAAA,QAAQ,GAAG,IAAI;AAAEC,EAAAA,OAAO,GAAGJ,IAAAA;AAA2B,CAAC,GAAG,EAAE,EAC9D;EACA,IAAI,OAAOE,IAAI,KAAK,UAAU,EAAE,MAAM,IAAIG,KAAK,CAAC,2BAA2B,CAAC,CAAA;EAE5E,IAAIC,OAAO,GAAG,KAAK,CAAA;EACnB,IAAIC,QAAQ,GAAG,CAAC,CAAA;AAChB,EAAA,IAAIC,OAAsC,CAAA;EAC1C,IAAIC,WAAwB,GAAG,IAAI,CAAA;AAEnC,EAAA,MAAMC,QAAQ,GAAG,YAAY;AAC3B,IAAA,IAAID,WAAW,EAAE;MACf,MAAME,IAAI,GAAGF,WAAW,CAAA;AACxBA,MAAAA,WAAW,GAAG,IAAI,CAAA;MAClB,IAAI;AACFH,QAAAA,OAAO,GAAG,IAAI,CAAA;AACd,QAAA,MAAMJ,IAAI,CAAC,GAAGS,IAAI,CAAC,CAAA;OACpB,CAAC,OAAOC,KAAK,EAAE;QACdR,OAAO,CAACQ,KAAK,CAAC,CAAA;AAChB,OAAC,SAAS;AACRL,QAAAA,QAAQ,GAAGM,IAAI,CAACC,GAAG,EAAE,CAAC;AACtBR,QAAAA,OAAO,GAAG,KAAK,CAAA;AACjB,OAAA;AACF,KAAA;GACD,CAAA;AAED,EAAA,MAAMS,SAAS,GAAG,YAAY;IAC5BC,YAAY,CAACR,OAAO,CAAC,CAAA;IACrBA,OAAO,GAAGS,UAAU,CAAC,MAAM;AACzB,MAAA,IAAIX,OAAO,EAAE;QACXS,SAAS,EAAE,CAAC;AACd,OAAC,MAAM;AACLL,QAAAA,QAAQ,EAAE,CAAA;AACZ,OAAA;KACD,EAAEP,QAAQ,CAAC,CAAA;GACb,CAAA;EAED,OAAO,CAAC,GAAGQ,IAAU,KAAK;AACxBF,IAAAA,WAAW,GAAGE,IAAI,CAAA;IAElB,MAAMO,OAAO,GAAGL,IAAI,CAACC,GAAG,EAAE,GAAGP,QAAQ,GAAGJ,QAAQ,CAAA;IAChD,IAAIG,OAAO,IAAIY,OAAO,EAAE;AACtBH,MAAAA,SAAS,EAAE,CAAA;AACb,KAAC,MAAM;AACLL,MAAAA,QAAQ,EAAE,CAAA;AACZ,KAAA;GACD,CAAA;AACH;;;;"}
@@ -1,4 +1,6 @@
1
- import { asyncThrottle } from './asyncThrottle.mjs';
1
+ 'use strict';
2
+
3
+ var asyncThrottle = require('./asyncThrottle.cjs');
2
4
 
3
5
  const createAsyncStoragePersister = ({
4
6
  storage,
@@ -18,7 +20,7 @@ const createAsyncStoragePersister = ({
18
20
  }
19
21
  };
20
22
  return {
21
- persistClient: asyncThrottle(async persistedClient => {
23
+ persistClient: asyncThrottle.asyncThrottle(async persistedClient => {
22
24
  let client = persistedClient;
23
25
  let error = await trySave(client);
24
26
  let errorCount = 0;
@@ -56,5 +58,5 @@ const createAsyncStoragePersister = ({
56
58
  // eslint-disable-next-line @typescript-eslint/no-empty-function
57
59
  function noop() {}
58
60
 
59
- export { createAsyncStoragePersister };
60
- //# sourceMappingURL=index.mjs.map
61
+ exports.createAsyncStoragePersister = createAsyncStoragePersister;
62
+ //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\nimport { asyncThrottle } from './asyncThrottle'\n\ninterface AsyncStorage {\n getItem: (key: string) => Promise<string | null>\n setItem: (key: string, value: string) => Promise<unknown>\n removeItem: (key: string) => Promise<void>\n}\n\nexport type AsyncPersistRetryer = (props: {\n persistedClient: PersistedClient\n error: Error\n errorCount: number\n}) => Promisable<PersistedClient | undefined>\n\ninterface CreateAsyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: AsyncStorage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: AsyncPersistRetryer\n}\n\nexport const createAsyncStoragePersister = ({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateAsyncStoragePersisterOptions): Persister => {\n if (storage) {\n const trySave = async (\n persistedClient: PersistedClient,\n ): Promise<Error | undefined> => {\n try {\n await storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n\n return {\n persistClient: asyncThrottle(\n async (persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = await trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = await retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = await trySave(client)\n }\n }\n },\n { interval: throttleTime },\n ),\n restoreClient: async () => {\n const cacheString = await storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => storage.removeItem(key),\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => Promise.resolve(undefined),\n removeClient: noop,\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createAsyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","asyncThrottle","client","errorCount","interval","restoreClient","cacheString","getItem","removeClient","removeItem","noop","Promise","resolve","undefined"],"mappings":";;AA4CO,MAAMA,2BAA2B,GAAG,CAAC;EAC1CC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACkC,CAAC,KAAgB;AACnD,EAAA,IAAIR,OAAO,EAAE;AACX,IAAA,MAAMS,OAAO,GAAG,MACdC,eAAgC,IACD;MAC/B,IAAI;QACF,MAAMV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AACtD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IAED,OAAO;AACLC,MAAAA,aAAa,EAAEC,aAAa,CAC1B,MAAOJ,eAAe,IAAK;QACzB,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;QACjC,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;UACZD,MAAM,GAAG,MAAMP,KAAK,GAAG;AACrBE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;AAC/B,WAAA;AACF,SAAA;AACF,OAAC,EACD;AAAEE,QAAAA,QAAQ,EAAEf,YAAAA;AAAa,OAAC,CAC3B;AACDgB,MAAAA,aAAa,EAAE,YAAY;QACzB,MAAMC,WAAW,GAAG,MAAMnB,OAAO,CAACoB,OAAO,CAACnB,GAAG,CAAC,CAAA;QAE9C,IAAI,CAACkB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOb,WAAW,CAACa,WAAW,CAAC,CAAA;OAChC;AACDE,MAAAA,YAAY,EAAE,MAAMrB,OAAO,CAACsB,UAAU,CAACrB,GAAG,CAAA;KAC3C,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAEU,IAAI;AACnBL,IAAAA,aAAa,EAAE,MAAMM,OAAO,CAACC,OAAO,CAACC,SAAS,CAAC;AAC/CL,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,EAAC;;AAED;AACA,SAASA,IAAI,GAAG;;;;"}
1
+ {"version":3,"file":"index.cjs","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\nimport { asyncThrottle } from './asyncThrottle'\n\ninterface AsyncStorage {\n getItem: (key: string) => Promise<string | null>\n setItem: (key: string, value: string) => Promise<unknown>\n removeItem: (key: string) => Promise<void>\n}\n\nexport type AsyncPersistRetryer = (props: {\n persistedClient: PersistedClient\n error: Error\n errorCount: number\n}) => Promisable<PersistedClient | undefined>\n\ninterface CreateAsyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: AsyncStorage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: AsyncPersistRetryer\n}\n\nexport const createAsyncStoragePersister = ({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateAsyncStoragePersisterOptions): Persister => {\n if (storage) {\n const trySave = async (\n persistedClient: PersistedClient,\n ): Promise<Error | undefined> => {\n try {\n await storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n\n return {\n persistClient: asyncThrottle(\n async (persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = await trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = await retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = await trySave(client)\n }\n }\n },\n { interval: throttleTime },\n ),\n restoreClient: async () => {\n const cacheString = await storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => storage.removeItem(key),\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => Promise.resolve(undefined),\n removeClient: noop,\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createAsyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","asyncThrottle","client","errorCount","interval","restoreClient","cacheString","getItem","removeClient","removeItem","noop","Promise","resolve","undefined"],"mappings":";;;;AA4CO,MAAMA,2BAA2B,GAAGA,CAAC;EAC1CC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACkC,CAAC,KAAgB;AACnD,EAAA,IAAIR,OAAO,EAAE;AACX,IAAA,MAAMS,OAAO,GAAG,MACdC,eAAgC,IACD;MAC/B,IAAI;QACF,MAAMV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AACtD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IAED,OAAO;AACLC,MAAAA,aAAa,EAAEC,2BAAa,CAC1B,MAAOJ,eAAe,IAAK;QACzB,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;QACjC,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;UACZD,MAAM,GAAG,MAAMP,KAAK,GAAG;AACrBE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;AAC/B,WAAA;AACF,SAAA;AACF,OAAC,EACD;AAAEE,QAAAA,QAAQ,EAAEf,YAAAA;AAAa,OAC3B,CAAC;MACDgB,aAAa,EAAE,YAAY;QACzB,MAAMC,WAAW,GAAG,MAAMnB,OAAO,CAACoB,OAAO,CAACnB,GAAG,CAAC,CAAA;QAE9C,IAAI,CAACkB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOb,WAAW,CAACa,WAAW,CAAC,CAAA;OAChC;AACDE,MAAAA,YAAY,EAAEA,MAAMrB,OAAO,CAACsB,UAAU,CAACrB,GAAG,CAAA;KAC3C,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAEU,IAAI;IACnBL,aAAa,EAAEA,MAAMM,OAAO,CAACC,OAAO,CAACC,SAAS,CAAC;AAC/CL,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,EAAC;;AAED;AACA,SAASA,IAAIA,GAAG;;;;"}
@@ -4,7 +4,7 @@ interface AsyncStorage {
4
4
  setItem: (key: string, value: string) => Promise<unknown>;
5
5
  removeItem: (key: string) => Promise<void>;
6
6
  }
7
- export declare type AsyncPersistRetryer = (props: {
7
+ export type AsyncPersistRetryer = (props: {
8
8
  persistedClient: PersistedClient;
9
9
  error: Error;
10
10
  errorCount: number;
@@ -34,3 +34,4 @@ interface CreateAsyncStoragePersisterOptions {
34
34
  }
35
35
  export declare const createAsyncStoragePersister: ({ storage, key, throttleTime, serialize, deserialize, retry, }: CreateAsyncStoragePersisterOptions) => Persister;
36
36
  export {};
37
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,eAAe,EACf,SAAS,EACT,UAAU,EACX,MAAM,qCAAqC,CAAA;AAG5C,UAAU,YAAY;IACpB,OAAO,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA;IAChD,OAAO,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,CAAA;IACzD,UAAU,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;CAC3C;AAED,MAAM,MAAM,mBAAmB,GAAG,CAAC,KAAK,EAAE;IACxC,eAAe,EAAE,eAAe,CAAA;IAChC,KAAK,EAAE,KAAK,CAAA;IACZ,UAAU,EAAE,MAAM,CAAA;CACnB,KAAK,UAAU,CAAC,eAAe,GAAG,SAAS,CAAC,CAAA;AAE7C,UAAU,kCAAkC;IAC1C;;;OAGG;IACH,OAAO,EAAE,YAAY,GAAG,SAAS,GAAG,IAAI,CAAA;IACxC,4CAA4C;IAC5C,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ;gEAC4D;IAC5D,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB;;;OAGG;IACH,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,eAAe,KAAK,MAAM,CAAA;IAC/C;;;OAGG;IACH,WAAW,CAAC,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,eAAe,CAAA;IAEvD,KAAK,CAAC,EAAE,mBAAmB,CAAA;CAC5B;AAED,eAAO,MAAM,2BAA2B,mEAOrC,kCAAkC,KAAG,SAoDvC,CAAA"}
@@ -1,6 +1,4 @@
1
- 'use strict';
2
-
3
- var asyncThrottle = require('./asyncThrottle.js');
1
+ import { asyncThrottle } from './asyncThrottle.js';
4
2
 
5
3
  const createAsyncStoragePersister = ({
6
4
  storage,
@@ -20,17 +18,17 @@ const createAsyncStoragePersister = ({
20
18
  }
21
19
  };
22
20
  return {
23
- persistClient: asyncThrottle.asyncThrottle(async persistedClient => {
21
+ persistClient: asyncThrottle(async persistedClient => {
24
22
  let client = persistedClient;
25
23
  let error = await trySave(client);
26
24
  let errorCount = 0;
27
25
  while (error && client) {
28
26
  errorCount++;
29
- client = await (retry == null ? void 0 : retry({
27
+ client = await retry?.({
30
28
  persistedClient: client,
31
29
  error,
32
30
  errorCount
33
- }));
31
+ });
34
32
  if (client) {
35
33
  error = await trySave(client);
36
34
  }
@@ -58,5 +56,5 @@ const createAsyncStoragePersister = ({
58
56
  // eslint-disable-next-line @typescript-eslint/no-empty-function
59
57
  function noop() {}
60
58
 
61
- exports.createAsyncStoragePersister = createAsyncStoragePersister;
59
+ export { createAsyncStoragePersister };
62
60
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\nimport { asyncThrottle } from './asyncThrottle'\n\ninterface AsyncStorage {\n getItem: (key: string) => Promise<string | null>\n setItem: (key: string, value: string) => Promise<unknown>\n removeItem: (key: string) => Promise<void>\n}\n\nexport type AsyncPersistRetryer = (props: {\n persistedClient: PersistedClient\n error: Error\n errorCount: number\n}) => Promisable<PersistedClient | undefined>\n\ninterface CreateAsyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: AsyncStorage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: AsyncPersistRetryer\n}\n\nexport const createAsyncStoragePersister = ({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateAsyncStoragePersisterOptions): Persister => {\n if (storage) {\n const trySave = async (\n persistedClient: PersistedClient,\n ): Promise<Error | undefined> => {\n try {\n await storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n\n return {\n persistClient: asyncThrottle(\n async (persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = await trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = await retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = await trySave(client)\n }\n }\n },\n { interval: throttleTime },\n ),\n restoreClient: async () => {\n const cacheString = await storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => storage.removeItem(key),\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => Promise.resolve(undefined),\n removeClient: noop,\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createAsyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","asyncThrottle","client","errorCount","interval","restoreClient","cacheString","getItem","removeClient","removeItem","noop","Promise","resolve","undefined"],"mappings":";;;;AA4CO,MAAMA,2BAA2B,GAAG,CAAC;EAC1CC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACkC,CAAC,KAAgB;AACnD,EAAA,IAAIR,OAAO,EAAE;AACX,IAAA,MAAMS,OAAO,GAAG,MACdC,eAAgC,IACD;MAC/B,IAAI;QACF,MAAMV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AACtD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IAED,OAAO;AACLC,MAAAA,aAAa,EAAEC,2BAAa,CAC1B,MAAOJ,eAAe,IAAK;QACzB,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;QACjC,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;AACZD,UAAAA,MAAM,GAAG,OAAMP,KAAK,IAAA,IAAA,GAAA,KAAA,CAAA,GAALA,KAAK,CAAG;AACrBE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;AAC/B,WAAA;AACF,SAAA;AACF,OAAC,EACD;AAAEE,QAAAA,QAAQ,EAAEf,YAAAA;AAAa,OAAC,CAC3B;AACDgB,MAAAA,aAAa,EAAE,YAAY;QACzB,MAAMC,WAAW,GAAG,MAAMnB,OAAO,CAACoB,OAAO,CAACnB,GAAG,CAAC,CAAA;QAE9C,IAAI,CAACkB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOb,WAAW,CAACa,WAAW,CAAC,CAAA;OAChC;AACDE,MAAAA,YAAY,EAAE,MAAMrB,OAAO,CAACsB,UAAU,CAACrB,GAAG,CAAA;KAC3C,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAEU,IAAI;AACnBL,IAAAA,aAAa,EAAE,MAAMM,OAAO,CAACC,OAAO,CAACC,SAAS,CAAC;AAC/CL,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,EAAC;;AAED;AACA,SAASA,IAAI,GAAG;;;;"}
1
+ {"version":3,"file":"index.js","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\nimport { asyncThrottle } from './asyncThrottle'\n\ninterface AsyncStorage {\n getItem: (key: string) => Promise<string | null>\n setItem: (key: string, value: string) => Promise<unknown>\n removeItem: (key: string) => Promise<void>\n}\n\nexport type AsyncPersistRetryer = (props: {\n persistedClient: PersistedClient\n error: Error\n errorCount: number\n}) => Promisable<PersistedClient | undefined>\n\ninterface CreateAsyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: AsyncStorage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: AsyncPersistRetryer\n}\n\nexport const createAsyncStoragePersister = ({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateAsyncStoragePersisterOptions): Persister => {\n if (storage) {\n const trySave = async (\n persistedClient: PersistedClient,\n ): Promise<Error | undefined> => {\n try {\n await storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n\n return {\n persistClient: asyncThrottle(\n async (persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = await trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = await retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = await trySave(client)\n }\n }\n },\n { interval: throttleTime },\n ),\n restoreClient: async () => {\n const cacheString = await storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => storage.removeItem(key),\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => Promise.resolve(undefined),\n removeClient: noop,\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createAsyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","asyncThrottle","client","errorCount","interval","restoreClient","cacheString","getItem","removeClient","removeItem","noop","Promise","resolve","undefined"],"mappings":";;AA4CO,MAAMA,2BAA2B,GAAGA,CAAC;EAC1CC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACkC,CAAC,KAAgB;AACnD,EAAA,IAAIR,OAAO,EAAE;AACX,IAAA,MAAMS,OAAO,GAAG,MACdC,eAAgC,IACD;MAC/B,IAAI;QACF,MAAMV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AACtD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IAED,OAAO;AACLC,MAAAA,aAAa,EAAEC,aAAa,CAC1B,MAAOJ,eAAe,IAAK;QACzB,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;QACjC,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;UACZD,MAAM,GAAG,MAAMP,KAAK,GAAG;AACrBE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;AAC/B,WAAA;AACF,SAAA;AACF,OAAC,EACD;AAAEE,QAAAA,QAAQ,EAAEf,YAAAA;AAAa,OAC3B,CAAC;MACDgB,aAAa,EAAE,YAAY;QACzB,MAAMC,WAAW,GAAG,MAAMnB,OAAO,CAACoB,OAAO,CAACnB,GAAG,CAAC,CAAA;QAE9C,IAAI,CAACkB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOb,WAAW,CAACa,WAAW,CAAC,CAAA;OAChC;AACDE,MAAAA,YAAY,EAAEA,MAAMrB,OAAO,CAACsB,UAAU,CAACrB,GAAG,CAAA;KAC3C,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAEU,IAAI;IACnBL,aAAa,EAAEA,MAAMM,OAAO,CAACC,OAAO,CAACC,SAAS,CAAC;AAC/CL,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,EAAC;;AAED;AACA,SAASA,IAAIA,GAAG;;;;"}
@@ -0,0 +1,62 @@
1
+ 'use strict';
2
+
3
+ var asyncThrottle = require('./asyncThrottle.legacy.cjs');
4
+
5
+ const createAsyncStoragePersister = ({
6
+ storage,
7
+ key = `REACT_QUERY_OFFLINE_CACHE`,
8
+ throttleTime = 1000,
9
+ serialize = JSON.stringify,
10
+ deserialize = JSON.parse,
11
+ retry
12
+ }) => {
13
+ if (storage) {
14
+ const trySave = async persistedClient => {
15
+ try {
16
+ await storage.setItem(key, serialize(persistedClient));
17
+ return;
18
+ } catch (error) {
19
+ return error;
20
+ }
21
+ };
22
+ return {
23
+ persistClient: asyncThrottle.asyncThrottle(async persistedClient => {
24
+ let client = persistedClient;
25
+ let error = await trySave(client);
26
+ let errorCount = 0;
27
+ while (error && client) {
28
+ errorCount++;
29
+ client = await (retry == null ? void 0 : retry({
30
+ persistedClient: client,
31
+ error,
32
+ errorCount
33
+ }));
34
+ if (client) {
35
+ error = await trySave(client);
36
+ }
37
+ }
38
+ }, {
39
+ interval: throttleTime
40
+ }),
41
+ restoreClient: async () => {
42
+ const cacheString = await storage.getItem(key);
43
+ if (!cacheString) {
44
+ return;
45
+ }
46
+ return deserialize(cacheString);
47
+ },
48
+ removeClient: () => storage.removeItem(key)
49
+ };
50
+ }
51
+ return {
52
+ persistClient: noop,
53
+ restoreClient: () => Promise.resolve(undefined),
54
+ removeClient: noop
55
+ };
56
+ };
57
+
58
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
59
+ function noop() {}
60
+
61
+ exports.createAsyncStoragePersister = createAsyncStoragePersister;
62
+ //# sourceMappingURL=index.legacy.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.legacy.cjs","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\nimport { asyncThrottle } from './asyncThrottle'\n\ninterface AsyncStorage {\n getItem: (key: string) => Promise<string | null>\n setItem: (key: string, value: string) => Promise<unknown>\n removeItem: (key: string) => Promise<void>\n}\n\nexport type AsyncPersistRetryer = (props: {\n persistedClient: PersistedClient\n error: Error\n errorCount: number\n}) => Promisable<PersistedClient | undefined>\n\ninterface CreateAsyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: AsyncStorage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: AsyncPersistRetryer\n}\n\nexport const createAsyncStoragePersister = ({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateAsyncStoragePersisterOptions): Persister => {\n if (storage) {\n const trySave = async (\n persistedClient: PersistedClient,\n ): Promise<Error | undefined> => {\n try {\n await storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n\n return {\n persistClient: asyncThrottle(\n async (persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = await trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = await retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = await trySave(client)\n }\n }\n },\n { interval: throttleTime },\n ),\n restoreClient: async () => {\n const cacheString = await storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => storage.removeItem(key),\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => Promise.resolve(undefined),\n removeClient: noop,\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createAsyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","asyncThrottle","client","errorCount","interval","restoreClient","cacheString","getItem","removeClient","removeItem","noop","Promise","resolve","undefined"],"mappings":";;;;AA4CO,MAAMA,2BAA2B,GAAGA,CAAC;EAC1CC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACkC,CAAC,KAAgB;AACnD,EAAA,IAAIR,OAAO,EAAE;AACX,IAAA,MAAMS,OAAO,GAAG,MACdC,eAAgC,IACD;MAC/B,IAAI;QACF,MAAMV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AACtD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IAED,OAAO;AACLC,MAAAA,aAAa,EAAEC,2BAAa,CAC1B,MAAOJ,eAAe,IAAK;QACzB,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;QACjC,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;AACZD,UAAAA,MAAM,GAAG,OAAMP,KAAK,IAAA,IAAA,GAAA,KAAA,CAAA,GAALA,KAAK,CAAG;AACrBE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;AAC/B,WAAA;AACF,SAAA;AACF,OAAC,EACD;AAAEE,QAAAA,QAAQ,EAAEf,YAAAA;AAAa,OAC3B,CAAC;MACDgB,aAAa,EAAE,YAAY;QACzB,MAAMC,WAAW,GAAG,MAAMnB,OAAO,CAACoB,OAAO,CAACnB,GAAG,CAAC,CAAA;QAE9C,IAAI,CAACkB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOb,WAAW,CAACa,WAAW,CAAC,CAAA;OAChC;AACDE,MAAAA,YAAY,EAAEA,MAAMrB,OAAO,CAACsB,UAAU,CAACrB,GAAG,CAAA;KAC3C,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAEU,IAAI;IACnBL,aAAa,EAAEA,MAAMM,OAAO,CAACC,OAAO,CAACC,SAAS,CAAC;AAC/CL,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,EAAC;;AAED;AACA,SAASA,IAAIA,GAAG;;;;"}
@@ -1,4 +1,4 @@
1
- import { asyncThrottle } from './asyncThrottle.esm.js';
1
+ import { asyncThrottle } from './asyncThrottle.legacy.js';
2
2
 
3
3
  const createAsyncStoragePersister = ({
4
4
  storage,
@@ -57,4 +57,4 @@ const createAsyncStoragePersister = ({
57
57
  function noop() {}
58
58
 
59
59
  export { createAsyncStoragePersister };
60
- //# sourceMappingURL=index.esm.js.map
60
+ //# sourceMappingURL=index.legacy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.legacy.js","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\nimport { asyncThrottle } from './asyncThrottle'\n\ninterface AsyncStorage {\n getItem: (key: string) => Promise<string | null>\n setItem: (key: string, value: string) => Promise<unknown>\n removeItem: (key: string) => Promise<void>\n}\n\nexport type AsyncPersistRetryer = (props: {\n persistedClient: PersistedClient\n error: Error\n errorCount: number\n}) => Promisable<PersistedClient | undefined>\n\ninterface CreateAsyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: AsyncStorage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: AsyncPersistRetryer\n}\n\nexport const createAsyncStoragePersister = ({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateAsyncStoragePersisterOptions): Persister => {\n if (storage) {\n const trySave = async (\n persistedClient: PersistedClient,\n ): Promise<Error | undefined> => {\n try {\n await storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n\n return {\n persistClient: asyncThrottle(\n async (persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = await trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = await retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = await trySave(client)\n }\n }\n },\n { interval: throttleTime },\n ),\n restoreClient: async () => {\n const cacheString = await storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => storage.removeItem(key),\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => Promise.resolve(undefined),\n removeClient: noop,\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createAsyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","asyncThrottle","client","errorCount","interval","restoreClient","cacheString","getItem","removeClient","removeItem","noop","Promise","resolve","undefined"],"mappings":";;AA4CO,MAAMA,2BAA2B,GAAGA,CAAC;EAC1CC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACkC,CAAC,KAAgB;AACnD,EAAA,IAAIR,OAAO,EAAE;AACX,IAAA,MAAMS,OAAO,GAAG,MACdC,eAAgC,IACD;MAC/B,IAAI;QACF,MAAMV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AACtD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IAED,OAAO;AACLC,MAAAA,aAAa,EAAEC,aAAa,CAC1B,MAAOJ,eAAe,IAAK;QACzB,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;QACjC,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;AACZD,UAAAA,MAAM,GAAG,OAAMP,KAAK,IAAA,IAAA,GAAA,KAAA,CAAA,GAALA,KAAK,CAAG;AACrBE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;AAC/B,WAAA;AACF,SAAA;AACF,OAAC,EACD;AAAEE,QAAAA,QAAQ,EAAEf,YAAAA;AAAa,OAC3B,CAAC;MACDgB,aAAa,EAAE,YAAY;QACzB,MAAMC,WAAW,GAAG,MAAMnB,OAAO,CAACoB,OAAO,CAACnB,GAAG,CAAC,CAAA;QAE9C,IAAI,CAACkB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOb,WAAW,CAACa,WAAW,CAAC,CAAA;OAChC;AACDE,MAAAA,YAAY,EAAEA,MAAMrB,OAAO,CAACsB,UAAU,CAACrB,GAAG,CAAA;KAC3C,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAEU,IAAI;IACnBL,aAAa,EAAEA,MAAMM,OAAO,CAACC,OAAO,CAACC,SAAS,CAAC;AAC/CL,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,EAAC;;AAED;AACA,SAASA,IAAIA,GAAG;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tanstack/query-async-storage-persister",
3
- "version": "5.0.0-alpha.7",
3
+ "version": "5.0.0-alpha.70",
4
4
  "description": "A persister for asynchronous storages, to be used with TanStack/Query",
5
5
  "author": "tannerlinsley",
6
6
  "license": "MIT",
@@ -10,32 +10,36 @@
10
10
  "type": "github",
11
11
  "url": "https://github.com/sponsors/tannerlinsley"
12
12
  },
13
+ "type": "module",
13
14
  "types": "build/lib/index.d.ts",
14
- "main": "build/lib/index.js",
15
- "module": "build/lib/index.esm.js",
15
+ "main": "build/lib/index.legacy.cjs",
16
+ "module": "build/lib/index.legacy.js",
16
17
  "exports": {
17
18
  ".": {
18
19
  "types": "./build/lib/index.d.ts",
19
- "import": "./build/lib/index.mjs",
20
- "default": "./build/lib/index.js"
20
+ "import": "./build/lib/index.js",
21
+ "require": "./build/lib/index.cjs",
22
+ "default": "./build/lib/index.cjs"
21
23
  },
22
24
  "./package.json": "./package.json"
23
25
  },
24
26
  "sideEffects": false,
25
27
  "files": [
26
28
  "build/lib/*",
27
- "build/umd/*",
28
29
  "src"
29
30
  ],
30
31
  "dependencies": {
31
- "@tanstack/query-persist-client-core": "5.0.0-alpha.7"
32
+ "@tanstack/query-persist-client-core": "5.0.0-alpha.70"
32
33
  },
33
34
  "scripts": {
34
- "clean": "rimraf ./build",
35
+ "clean": "rimraf ./build && rimraf ./coverage",
35
36
  "test:eslint": "eslint --ext .ts,.tsx ./src",
36
- "test:types": "tsc",
37
+ "test:types": "tsc --noEmit",
37
38
  "test:lib": "vitest run --coverage",
38
39
  "test:lib:dev": "pnpm run test:lib --watch",
39
- "build:types": "tsc --build"
40
+ "test:build": "publint --strict",
41
+ "build": "pnpm build:rollup && pnpm build:types",
42
+ "build:rollup": "rollup --config rollup.config.js",
43
+ "build:types": "tsc --emitDeclarationOnly"
40
44
  }
41
45
  }
@@ -1 +0,0 @@
1
- {"version":3,"file":"asyncThrottle.esm.js","sources":["../../src/asyncThrottle.ts"],"sourcesContent":["export interface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nconst noop = () => {\n /* do nothing */\n}\n\nexport function asyncThrottle<Args extends readonly unknown[]>(\n func: (...args: Args) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let running = false\n let lastTime = 0\n let timeout: ReturnType<typeof setTimeout>\n let currentArgs: Args | null = null\n\n const execFunc = async () => {\n if (currentArgs) {\n const args = currentArgs\n currentArgs = null\n try {\n running = true\n await func(...args)\n } catch (error) {\n onError(error)\n } finally {\n lastTime = Date.now() // this line must after 'func' executed to avoid two 'func' running in concurrent.\n running = false\n }\n }\n }\n\n const delayFunc = async () => {\n clearTimeout(timeout)\n timeout = setTimeout(() => {\n if (running) {\n delayFunc() // Will come here when 'func' execution time is greater than the interval.\n } else {\n execFunc()\n }\n }, interval)\n }\n\n return (...args: Args) => {\n currentArgs = args\n\n const tooSoon = Date.now() - lastTime < interval\n if (running || tooSoon) {\n delayFunc()\n } else {\n execFunc()\n }\n }\n}\n"],"names":["noop","asyncThrottle","func","interval","onError","Error","running","lastTime","timeout","currentArgs","execFunc","args","error","Date","now","delayFunc","clearTimeout","setTimeout","tooSoon"],"mappings":"AAKA,MAAMA,IAAI,GAAG,MAAM;AACjB;AAAA,CACD,CAAA;AAEM,SAASC,aAAa,CAC3BC,IAAsC,EACtC;AAAEC,EAAAA,QAAQ,GAAG,IAAI;AAAEC,EAAAA,OAAO,GAAGJ,IAAAA;AAA2B,CAAC,GAAG,EAAE,EAC9D;EACA,IAAI,OAAOE,IAAI,KAAK,UAAU,EAAE,MAAM,IAAIG,KAAK,CAAC,2BAA2B,CAAC,CAAA;EAE5E,IAAIC,OAAO,GAAG,KAAK,CAAA;EACnB,IAAIC,QAAQ,GAAG,CAAC,CAAA;AAChB,EAAA,IAAIC,OAAsC,CAAA;EAC1C,IAAIC,WAAwB,GAAG,IAAI,CAAA;EAEnC,MAAMC,QAAQ,GAAG,YAAY;AAC3B,IAAA,IAAID,WAAW,EAAE;MACf,MAAME,IAAI,GAAGF,WAAW,CAAA;AACxBA,MAAAA,WAAW,GAAG,IAAI,CAAA;MAClB,IAAI;AACFH,QAAAA,OAAO,GAAG,IAAI,CAAA;AACd,QAAA,MAAMJ,IAAI,CAAC,GAAGS,IAAI,CAAC,CAAA;OACpB,CAAC,OAAOC,KAAK,EAAE;QACdR,OAAO,CAACQ,KAAK,CAAC,CAAA;AAChB,OAAC,SAAS;AACRL,QAAAA,QAAQ,GAAGM,IAAI,CAACC,GAAG,EAAE,CAAC;AACtBR,QAAAA,OAAO,GAAG,KAAK,CAAA;AACjB,OAAA;AACF,KAAA;GACD,CAAA;EAED,MAAMS,SAAS,GAAG,YAAY;IAC5BC,YAAY,CAACR,OAAO,CAAC,CAAA;IACrBA,OAAO,GAAGS,UAAU,CAAC,MAAM;AACzB,MAAA,IAAIX,OAAO,EAAE;AACXS,QAAAA,SAAS,EAAE,CAAC;AACd,OAAC,MAAM;AACLL,QAAAA,QAAQ,EAAE,CAAA;AACZ,OAAA;KACD,EAAEP,QAAQ,CAAC,CAAA;GACb,CAAA;EAED,OAAO,CAAC,GAAGQ,IAAU,KAAK;AACxBF,IAAAA,WAAW,GAAGE,IAAI,CAAA;IAElB,MAAMO,OAAO,GAAGL,IAAI,CAACC,GAAG,EAAE,GAAGP,QAAQ,GAAGJ,QAAQ,CAAA;IAChD,IAAIG,OAAO,IAAIY,OAAO,EAAE;AACtBH,MAAAA,SAAS,EAAE,CAAA;AACb,KAAC,MAAM;AACLL,MAAAA,QAAQ,EAAE,CAAA;AACZ,KAAA;GACD,CAAA;AACH;;;;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.esm.js","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\nimport { asyncThrottle } from './asyncThrottle'\n\ninterface AsyncStorage {\n getItem: (key: string) => Promise<string | null>\n setItem: (key: string, value: string) => Promise<unknown>\n removeItem: (key: string) => Promise<void>\n}\n\nexport type AsyncPersistRetryer = (props: {\n persistedClient: PersistedClient\n error: Error\n errorCount: number\n}) => Promisable<PersistedClient | undefined>\n\ninterface CreateAsyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: AsyncStorage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: AsyncPersistRetryer\n}\n\nexport const createAsyncStoragePersister = ({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateAsyncStoragePersisterOptions): Persister => {\n if (storage) {\n const trySave = async (\n persistedClient: PersistedClient,\n ): Promise<Error | undefined> => {\n try {\n await storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n\n return {\n persistClient: asyncThrottle(\n async (persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = await trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = await retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = await trySave(client)\n }\n }\n },\n { interval: throttleTime },\n ),\n restoreClient: async () => {\n const cacheString = await storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => storage.removeItem(key),\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => Promise.resolve(undefined),\n removeClient: noop,\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createAsyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","asyncThrottle","client","errorCount","interval","restoreClient","cacheString","getItem","removeClient","removeItem","noop","Promise","resolve","undefined"],"mappings":";;AA4CO,MAAMA,2BAA2B,GAAG,CAAC;EAC1CC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACkC,CAAC,KAAgB;AACnD,EAAA,IAAIR,OAAO,EAAE;AACX,IAAA,MAAMS,OAAO,GAAG,MACdC,eAAgC,IACD;MAC/B,IAAI;QACF,MAAMV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AACtD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IAED,OAAO;AACLC,MAAAA,aAAa,EAAEC,aAAa,CAC1B,MAAOJ,eAAe,IAAK;QACzB,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;QACjC,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;AACZD,UAAAA,MAAM,GAAG,OAAMP,KAAK,IAAA,IAAA,GAAA,KAAA,CAAA,GAALA,KAAK,CAAG;AACrBE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAG,MAAMH,OAAO,CAACM,MAAM,CAAC,CAAA;AAC/B,WAAA;AACF,SAAA;AACF,OAAC,EACD;AAAEE,QAAAA,QAAQ,EAAEf,YAAAA;AAAa,OAAC,CAC3B;AACDgB,MAAAA,aAAa,EAAE,YAAY;QACzB,MAAMC,WAAW,GAAG,MAAMnB,OAAO,CAACoB,OAAO,CAACnB,GAAG,CAAC,CAAA;QAE9C,IAAI,CAACkB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOb,WAAW,CAACa,WAAW,CAAC,CAAA;OAChC;AACDE,MAAAA,YAAY,EAAE,MAAMrB,OAAO,CAACsB,UAAU,CAACrB,GAAG,CAAA;KAC3C,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAEU,IAAI;AACnBL,IAAAA,aAAa,EAAE,MAAMM,OAAO,CAACC,OAAO,CAACC,SAAS,CAAC;AAC/CL,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,EAAC;;AAED;AACA,SAASA,IAAI,GAAG;;;;"}
@@ -1,114 +0,0 @@
1
- (function (global, factory) {
2
- typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :
3
- typeof define === 'function' && define.amd ? define(['exports'], factory) :
4
- (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.QueryAsyncStoragePersister = {}));
5
- })(this, (function (exports) { 'use strict';
6
-
7
- const noop$1 = () => {
8
- /* do nothing */
9
- };
10
- function asyncThrottle(func, {
11
- interval = 1000,
12
- onError = noop$1
13
- } = {}) {
14
- if (typeof func !== 'function') throw new Error('argument is not function.');
15
- let running = false;
16
- let lastTime = 0;
17
- let timeout;
18
- let currentArgs = null;
19
- const execFunc = async () => {
20
- if (currentArgs) {
21
- const args = currentArgs;
22
- currentArgs = null;
23
- try {
24
- running = true;
25
- await func(...args);
26
- } catch (error) {
27
- onError(error);
28
- } finally {
29
- lastTime = Date.now(); // this line must after 'func' executed to avoid two 'func' running in concurrent.
30
- running = false;
31
- }
32
- }
33
- };
34
- const delayFunc = async () => {
35
- clearTimeout(timeout);
36
- timeout = setTimeout(() => {
37
- if (running) {
38
- delayFunc(); // Will come here when 'func' execution time is greater than the interval.
39
- } else {
40
- execFunc();
41
- }
42
- }, interval);
43
- };
44
- return (...args) => {
45
- currentArgs = args;
46
- const tooSoon = Date.now() - lastTime < interval;
47
- if (running || tooSoon) {
48
- delayFunc();
49
- } else {
50
- execFunc();
51
- }
52
- };
53
- }
54
-
55
- const createAsyncStoragePersister = ({
56
- storage,
57
- key = `REACT_QUERY_OFFLINE_CACHE`,
58
- throttleTime = 1000,
59
- serialize = JSON.stringify,
60
- deserialize = JSON.parse,
61
- retry
62
- }) => {
63
- if (storage) {
64
- const trySave = async persistedClient => {
65
- try {
66
- await storage.setItem(key, serialize(persistedClient));
67
- return;
68
- } catch (error) {
69
- return error;
70
- }
71
- };
72
- return {
73
- persistClient: asyncThrottle(async persistedClient => {
74
- let client = persistedClient;
75
- let error = await trySave(client);
76
- let errorCount = 0;
77
- while (error && client) {
78
- errorCount++;
79
- client = await retry?.({
80
- persistedClient: client,
81
- error,
82
- errorCount
83
- });
84
- if (client) {
85
- error = await trySave(client);
86
- }
87
- }
88
- }, {
89
- interval: throttleTime
90
- }),
91
- restoreClient: async () => {
92
- const cacheString = await storage.getItem(key);
93
- if (!cacheString) {
94
- return;
95
- }
96
- return deserialize(cacheString);
97
- },
98
- removeClient: () => storage.removeItem(key)
99
- };
100
- }
101
- return {
102
- persistClient: noop,
103
- restoreClient: () => Promise.resolve(undefined),
104
- removeClient: noop
105
- };
106
- };
107
-
108
- // eslint-disable-next-line @typescript-eslint/no-empty-function
109
- function noop() {}
110
-
111
- exports.createAsyncStoragePersister = createAsyncStoragePersister;
112
-
113
- }));
114
- //# sourceMappingURL=index.development.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.development.js","sources":["../../src/asyncThrottle.ts","../../src/index.ts"],"sourcesContent":["export interface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nconst noop = () => {\n /* do nothing */\n}\n\nexport function asyncThrottle<Args extends readonly unknown[]>(\n func: (...args: Args) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let running = false\n let lastTime = 0\n let timeout: ReturnType<typeof setTimeout>\n let currentArgs: Args | null = null\n\n const execFunc = async () => {\n if (currentArgs) {\n const args = currentArgs\n currentArgs = null\n try {\n running = true\n await func(...args)\n } catch (error) {\n onError(error)\n } finally {\n lastTime = Date.now() // this line must after 'func' executed to avoid two 'func' running in concurrent.\n running = false\n }\n }\n }\n\n const delayFunc = async () => {\n clearTimeout(timeout)\n timeout = setTimeout(() => {\n if (running) {\n delayFunc() // Will come here when 'func' execution time is greater than the interval.\n } else {\n execFunc()\n }\n }, interval)\n }\n\n return (...args: Args) => {\n currentArgs = args\n\n const tooSoon = Date.now() - lastTime < interval\n if (running || tooSoon) {\n delayFunc()\n } else {\n execFunc()\n }\n }\n}\n","import type {\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\nimport { asyncThrottle } from './asyncThrottle'\n\ninterface AsyncStorage {\n getItem: (key: string) => Promise<string | null>\n setItem: (key: string, value: string) => Promise<unknown>\n removeItem: (key: string) => Promise<void>\n}\n\nexport type AsyncPersistRetryer = (props: {\n persistedClient: PersistedClient\n error: Error\n errorCount: number\n}) => Promisable<PersistedClient | undefined>\n\ninterface CreateAsyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: AsyncStorage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: AsyncPersistRetryer\n}\n\nexport const createAsyncStoragePersister = ({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateAsyncStoragePersisterOptions): Persister => {\n if (storage) {\n const trySave = async (\n persistedClient: PersistedClient,\n ): Promise<Error | undefined> => {\n try {\n await storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n\n return {\n persistClient: asyncThrottle(\n async (persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = await trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = await retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = await trySave(client)\n }\n }\n },\n { interval: throttleTime },\n ),\n restoreClient: async () => {\n const cacheString = await storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => storage.removeItem(key),\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => Promise.resolve(undefined),\n removeClient: noop,\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["noop","asyncThrottle","func","interval","onError","Error","running","lastTime","timeout","currentArgs","execFunc","args","error","Date","now","delayFunc","clearTimeout","setTimeout","tooSoon","createAsyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","persistClient","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","Promise","resolve","undefined"],"mappings":";;;;;;EAKA,MAAMA,MAAI,GAAG,MAAM;EACjB;EAAA,CACD,CAAA;EAEM,SAASC,aAAa,CAC3BC,IAAsC,EACtC;EAAEC,EAAAA,QAAQ,GAAG,IAAI;EAAEC,EAAAA,OAAO,GAAGJ,MAAAA;EAA2B,CAAC,GAAG,EAAE,EAC9D;IACA,IAAI,OAAOE,IAAI,KAAK,UAAU,EAAE,MAAM,IAAIG,KAAK,CAAC,2BAA2B,CAAC,CAAA;IAE5E,IAAIC,OAAO,GAAG,KAAK,CAAA;IACnB,IAAIC,QAAQ,GAAG,CAAC,CAAA;EAChB,EAAA,IAAIC,OAAsC,CAAA;IAC1C,IAAIC,WAAwB,GAAG,IAAI,CAAA;IAEnC,MAAMC,QAAQ,GAAG,YAAY;EAC3B,IAAA,IAAID,WAAW,EAAE;QACf,MAAME,IAAI,GAAGF,WAAW,CAAA;EACxBA,MAAAA,WAAW,GAAG,IAAI,CAAA;QAClB,IAAI;EACFH,QAAAA,OAAO,GAAG,IAAI,CAAA;EACd,QAAA,MAAMJ,IAAI,CAAC,GAAGS,IAAI,CAAC,CAAA;SACpB,CAAC,OAAOC,KAAK,EAAE;UACdR,OAAO,CAACQ,KAAK,CAAC,CAAA;EAChB,OAAC,SAAS;EACRL,QAAAA,QAAQ,GAAGM,IAAI,CAACC,GAAG,EAAE,CAAC;EACtBR,QAAAA,OAAO,GAAG,KAAK,CAAA;EACjB,OAAA;EACF,KAAA;KACD,CAAA;IAED,MAAMS,SAAS,GAAG,YAAY;MAC5BC,YAAY,CAACR,OAAO,CAAC,CAAA;MACrBA,OAAO,GAAGS,UAAU,CAAC,MAAM;EACzB,MAAA,IAAIX,OAAO,EAAE;EACXS,QAAAA,SAAS,EAAE,CAAC;EACd,OAAC,MAAM;EACLL,QAAAA,QAAQ,EAAE,CAAA;EACZ,OAAA;OACD,EAAEP,QAAQ,CAAC,CAAA;KACb,CAAA;IAED,OAAO,CAAC,GAAGQ,IAAU,KAAK;EACxBF,IAAAA,WAAW,GAAGE,IAAI,CAAA;MAElB,MAAMO,OAAO,GAAGL,IAAI,CAACC,GAAG,EAAE,GAAGP,QAAQ,GAAGJ,QAAQ,CAAA;MAChD,IAAIG,OAAO,IAAIY,OAAO,EAAE;EACtBH,MAAAA,SAAS,EAAE,CAAA;EACb,KAAC,MAAM;EACLL,MAAAA,QAAQ,EAAE,CAAA;EACZ,KAAA;KACD,CAAA;EACH;;ACbO,QAAMS,2BAA2B,GAAG,CAAC;IAC1CC,OAAO;EACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;EACjCC,EAAAA,YAAY,GAAG,IAAI;IACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;IAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;EACxBC,EAAAA,KAAAA;EACkC,CAAC,KAAgB;EACnD,EAAA,IAAIR,OAAO,EAAE;EACX,IAAA,MAAMS,OAAO,GAAG,MACdC,eAAgC,IACD;QAC/B,IAAI;UACF,MAAMV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;EACtD,QAAA,OAAA;SACD,CAAC,OAAOlB,KAAK,EAAE;EACd,QAAA,OAAOA,KAAK,CAAA;EACd,OAAA;OACD,CAAA;MAED,OAAO;EACLoB,MAAAA,aAAa,EAAE/B,aAAa,CAC1B,MAAO6B,eAAe,IAAK;UACzB,IAAIG,MAAmC,GAAGH,eAAe,CAAA;EACzD,QAAA,IAAIlB,KAAK,GAAG,MAAMiB,OAAO,CAACI,MAAM,CAAC,CAAA;UACjC,IAAIC,UAAU,GAAG,CAAC,CAAA;UAClB,OAAOtB,KAAK,IAAIqB,MAAM,EAAE;EACtBC,UAAAA,UAAU,EAAE,CAAA;YACZD,MAAM,GAAG,MAAML,KAAK,GAAG;EACrBE,YAAAA,eAAe,EAAEG,MAAM;cACvBrB,KAAK;EACLsB,YAAAA,UAAAA;EACF,WAAC,CAAC,CAAA;EAEF,UAAA,IAAID,MAAM,EAAE;EACVrB,YAAAA,KAAK,GAAG,MAAMiB,OAAO,CAACI,MAAM,CAAC,CAAA;EAC/B,WAAA;EACF,SAAA;EACF,OAAC,EACD;EAAE9B,QAAAA,QAAQ,EAAEmB,YAAAA;EAAa,OAAC,CAC3B;EACDa,MAAAA,aAAa,EAAE,YAAY;UACzB,MAAMC,WAAW,GAAG,MAAMhB,OAAO,CAACiB,OAAO,CAAChB,GAAG,CAAC,CAAA;UAE9C,IAAI,CAACe,WAAW,EAAE;EAChB,UAAA,OAAA;EACF,SAAA;UAEA,OAAOV,WAAW,CAACU,WAAW,CAAC,CAAA;SAChC;EACDE,MAAAA,YAAY,EAAE,MAAMlB,OAAO,CAACmB,UAAU,CAAClB,GAAG,CAAA;OAC3C,CAAA;EACH,GAAA;IAEA,OAAO;EACLW,IAAAA,aAAa,EAAEhC,IAAI;EACnBmC,IAAAA,aAAa,EAAE,MAAMK,OAAO,CAACC,OAAO,CAACC,SAAS,CAAC;EAC/CJ,IAAAA,YAAY,EAAEtC,IAAAA;KACf,CAAA;EACH,EAAC;;EAED;EACA,SAASA,IAAI,GAAG;;;;;;;;"}
@@ -1,2 +0,0 @@
1
- !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).QueryAsyncStoragePersister={})}(this,(function(e){"use strict";const t=()=>{};function r(e,{interval:r=1e3,onError:n=t}={}){if("function"!=typeof e)throw new Error("argument is not function.");let i,o=!1,s=0,a=null;const c=async()=>{if(a){const t=a;a=null;try{o=!0,await e(...t)}catch(e){n(e)}finally{s=Date.now(),o=!1}}},l=async()=>{clearTimeout(i),i=setTimeout((()=>{o?l():c()}),r)};return(...e)=>{a=e;const t=Date.now()-s<r;o||t?l():c()}}function n(){}e.createAsyncStoragePersister=({storage:e,key:t="REACT_QUERY_OFFLINE_CACHE",throttleTime:i=1e3,serialize:o=JSON.stringify,deserialize:s=JSON.parse,retry:a})=>{if(e){const n=async r=>{try{return void await e.setItem(t,o(r))}catch(e){return e}};return{persistClient:r((async e=>{let t=e,r=await n(t),i=0;for(;r&&t;)i++,t=await(a?.({persistedClient:t,error:r,errorCount:i})),t&&(r=await n(t))}),{interval:i}),restoreClient:async()=>{const r=await e.getItem(t);if(r)return s(r)},removeClient:()=>e.removeItem(t)}}return{persistClient:n,restoreClient:()=>Promise.resolve(void 0),removeClient:n}}}));
2
- //# sourceMappingURL=index.production.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.production.js","sources":["../../src/asyncThrottle.ts","../../src/index.ts"],"sourcesContent":["export interface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nconst noop = () => {\n /* do nothing */\n}\n\nexport function asyncThrottle<Args extends readonly unknown[]>(\n func: (...args: Args) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let running = false\n let lastTime = 0\n let timeout: ReturnType<typeof setTimeout>\n let currentArgs: Args | null = null\n\n const execFunc = async () => {\n if (currentArgs) {\n const args = currentArgs\n currentArgs = null\n try {\n running = true\n await func(...args)\n } catch (error) {\n onError(error)\n } finally {\n lastTime = Date.now() // this line must after 'func' executed to avoid two 'func' running in concurrent.\n running = false\n }\n }\n }\n\n const delayFunc = async () => {\n clearTimeout(timeout)\n timeout = setTimeout(() => {\n if (running) {\n delayFunc() // Will come here when 'func' execution time is greater than the interval.\n } else {\n execFunc()\n }\n }, interval)\n }\n\n return (...args: Args) => {\n currentArgs = args\n\n const tooSoon = Date.now() - lastTime < interval\n if (running || tooSoon) {\n delayFunc()\n } else {\n execFunc()\n }\n }\n}\n","import type {\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\nimport { asyncThrottle } from './asyncThrottle'\n\ninterface AsyncStorage {\n getItem: (key: string) => Promise<string | null>\n setItem: (key: string, value: string) => Promise<unknown>\n removeItem: (key: string) => Promise<void>\n}\n\nexport type AsyncPersistRetryer = (props: {\n persistedClient: PersistedClient\n error: Error\n errorCount: number\n}) => Promisable<PersistedClient | undefined>\n\ninterface CreateAsyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: AsyncStorage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: AsyncPersistRetryer\n}\n\nexport const createAsyncStoragePersister = ({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateAsyncStoragePersisterOptions): Persister => {\n if (storage) {\n const trySave = async (\n persistedClient: PersistedClient,\n ): Promise<Error | undefined> => {\n try {\n await storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n\n return {\n persistClient: asyncThrottle(\n async (persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = await trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = await retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = await trySave(client)\n }\n }\n },\n { interval: throttleTime },\n ),\n restoreClient: async () => {\n const cacheString = await storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => storage.removeItem(key),\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => Promise.resolve(undefined),\n removeClient: noop,\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["noop","asyncThrottle","func","interval","onError","Error","timeout","running","lastTime","currentArgs","execFunc","async","args","error","Date","now","delayFunc","clearTimeout","setTimeout","tooSoon","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","setItem","persistedClient","persistClient","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","Promise","resolve","undefined"],"mappings":"kQAKA,MAAMA,EAAO,OAIN,SAASC,EACdC,GACAC,SAAEA,EAAW,IAAIC,QAAEA,EAAUJ,GAA+B,IAE5D,GAAoB,mBAATE,EAAqB,MAAM,IAAIG,MAAM,6BAEhD,IAEIC,EAFAC,GAAU,EACVC,EAAW,EAEXC,EAA2B,KAE/B,MAAMC,EAAWC,UACf,GAAIF,EAAa,CACf,MAAMG,EAAOH,EACbA,EAAc,KACd,IACEF,GAAU,QACJL,KAAQU,EAMhB,CALE,MAAOC,GACPT,EAAQS,EACV,CAAU,QACRL,EAAWM,KAAKC,MAChBR,GAAU,CACZ,CACF,GAGIS,EAAYL,UAChBM,aAAaX,GACbA,EAAUY,YAAW,KACfX,EACFS,IAEAN,GACF,GACCP,EAAS,EAGd,MAAO,IAAIS,KACTH,EAAcG,EAEd,MAAMO,EAAUL,KAAKC,MAAQP,EAAWL,EACpCI,GAAWY,EACbH,IAEAN,GACF,CAEJ,CCiDA,SAASV,IAAO,+BA9D2B,EACzCoB,UACAC,MAAO,4BACPC,eAAe,IACfC,YAAYC,KAAKC,UACjBC,cAAcF,KAAKG,MACnBC,YAEA,GAAIR,EAAS,CACX,MAAMS,EAAUlB,UAGd,IAEE,kBADMS,EAAQU,QAAQT,EAAKE,EAAUQ,GAIvC,CAFE,MAAOlB,GACP,OAAOA,CACT,GAGF,MAAO,CACLmB,cAAe/B,GACbU,UACE,IAAIsB,EAAsCF,EACtClB,QAAcgB,EAAQI,GACtBC,EAAa,EACjB,KAAOrB,GAASoB,GACdC,IACAD,QAAeL,IAAQ,CACrBG,gBAAiBE,EACjBpB,QACAqB,gBAGED,IACFpB,QAAcgB,EAAQI,GAE1B,GAEF,CAAE9B,SAAUmB,IAEda,cAAexB,UACb,MAAMyB,QAAoBhB,EAAQiB,QAAQhB,GAE1C,GAAKe,EAIL,OAAOV,EAAYU,EAAY,EAEjCE,aAAc,IAAMlB,EAAQmB,WAAWlB,GAE3C,CAEA,MAAO,CACLW,cAAehC,EACfmC,cAAe,IAAMK,QAAQC,aAAQC,GACrCJ,aAActC,EACf"}