@tanstack/query-async-storage-persister 5.94.4 → 5.94.5

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 (41) hide show
  1. package/build/legacy/_tsup-dts-rollup.d.cts +78 -0
  2. package/build/legacy/_tsup-dts-rollup.d.ts +78 -0
  3. package/build/legacy/asyncThrottle.cjs +64 -0
  4. package/build/legacy/asyncThrottle.cjs.map +1 -0
  5. package/build/legacy/asyncThrottle.d.cts +1 -0
  6. package/build/legacy/asyncThrottle.d.ts +1 -0
  7. package/build/legacy/asyncThrottle.js +39 -0
  8. package/build/legacy/asyncThrottle.js.map +1 -0
  9. package/build/legacy/index.cjs +86 -0
  10. package/build/legacy/index.cjs.map +1 -0
  11. package/build/legacy/index.d.cts +2 -0
  12. package/build/legacy/index.d.ts +2 -0
  13. package/build/legacy/index.js +61 -0
  14. package/build/legacy/index.js.map +1 -0
  15. package/build/legacy/utils.cjs +32 -0
  16. package/build/legacy/utils.cjs.map +1 -0
  17. package/build/legacy/utils.d.cts +1 -0
  18. package/build/legacy/utils.d.ts +1 -0
  19. package/build/legacy/utils.js +7 -0
  20. package/build/legacy/utils.js.map +1 -0
  21. package/build/modern/_tsup-dts-rollup.d.cts +78 -0
  22. package/build/modern/_tsup-dts-rollup.d.ts +78 -0
  23. package/build/modern/asyncThrottle.cjs +64 -0
  24. package/build/modern/asyncThrottle.cjs.map +1 -0
  25. package/build/modern/asyncThrottle.d.cts +1 -0
  26. package/build/modern/asyncThrottle.d.ts +1 -0
  27. package/build/modern/asyncThrottle.js +39 -0
  28. package/build/modern/asyncThrottle.js.map +1 -0
  29. package/build/modern/index.cjs +86 -0
  30. package/build/modern/index.cjs.map +1 -0
  31. package/build/modern/index.d.cts +2 -0
  32. package/build/modern/index.d.ts +2 -0
  33. package/build/modern/index.js +61 -0
  34. package/build/modern/index.js.map +1 -0
  35. package/build/modern/utils.cjs +32 -0
  36. package/build/modern/utils.cjs.map +1 -0
  37. package/build/modern/utils.d.cts +1 -0
  38. package/build/modern/utils.d.ts +1 -0
  39. package/build/modern/utils.js +7 -0
  40. package/build/modern/utils.js.map +1 -0
  41. package/package.json +3 -3
@@ -0,0 +1,78 @@
1
+ import type { AsyncStorage } from '@tanstack/query-persist-client-core';
2
+ import type { MaybePromise } from '@tanstack/query-persist-client-core';
3
+ import { Options } from 'tsup';
4
+ import type { PersistedClient } from '@tanstack/query-persist-client-core';
5
+ import type { Persister } from '@tanstack/query-persist-client-core';
6
+ import type { Promisable } from '@tanstack/query-persist-client-core';
7
+ import { UserConfig } from 'vite';
8
+
9
+ export declare type AsyncPersistRetryer = (props: {
10
+ persistedClient: PersistedClient;
11
+ error: Error;
12
+ errorCount: number;
13
+ }) => Promisable<PersistedClient | undefined>;
14
+
15
+ export declare function asyncThrottle<TArgs extends ReadonlyArray<unknown>>(func: (...args: TArgs) => Promise<void>, { interval, onError }?: AsyncThrottleOptions): (...args: TArgs) => Promise<void>;
16
+
17
+ declare interface AsyncThrottleOptions {
18
+ interval?: number;
19
+ onError?: (error: unknown) => void;
20
+ }
21
+
22
+ export declare const createAsyncStoragePersister: ({ storage, key, throttleTime, serialize, deserialize, retry, }: CreateAsyncStoragePersisterOptions) => Persister;
23
+
24
+ declare interface CreateAsyncStoragePersisterOptions {
25
+ /** The storage client used for setting and retrieving items from cache.
26
+ * For SSR pass in `undefined`. Note that window.localStorage can be
27
+ * `null` in Android WebViews depending on how they are configured.
28
+ */
29
+ storage: AsyncStorage<string> | undefined | null;
30
+ /** The key to use when storing the cache */
31
+ key?: string;
32
+ /** To avoid spamming,
33
+ * pass a time in ms to throttle saving the cache to disk */
34
+ throttleTime?: number;
35
+ /**
36
+ * How to serialize the data to storage.
37
+ * @default `JSON.stringify`
38
+ */
39
+ serialize?: (client: PersistedClient) => MaybePromise<string>;
40
+ /**
41
+ * How to deserialize the data from storage.
42
+ * @default `JSON.parse`
43
+ */
44
+ deserialize?: (cachedString: string) => MaybePromise<PersistedClient>;
45
+ retry?: AsyncPersistRetryer;
46
+ }
47
+
48
+ export declare const default_alias: any[];
49
+
50
+ export declare const default_alias_1: any[];
51
+
52
+ export declare const default_alias_2: Options | Options[] | ((overrideOptions: Options) => Options | Options[] | Promise<Options | Options[]>);
53
+
54
+ export declare const default_alias_3: UserConfig;
55
+
56
+ /**
57
+ * @param {Object} opts - Options for building configurations.
58
+ * @param {string[]} opts.entry - The entry array.
59
+ * @returns {import('tsup').Options}
60
+ */
61
+ export declare function legacyConfig(opts: {
62
+ entry: string[];
63
+ }): Options;
64
+
65
+ /**
66
+ * @param {Object} opts - Options for building configurations.
67
+ * @param {string[]} opts.entry - The entry array.
68
+ * @returns {import('tsup').Options}
69
+ */
70
+ export declare function modernConfig(opts: {
71
+ entry: string[];
72
+ }): Options;
73
+
74
+ export declare function noop(): void;
75
+
76
+ export declare function noop(): undefined;
77
+
78
+ export { }
@@ -0,0 +1,78 @@
1
+ import type { AsyncStorage } from '@tanstack/query-persist-client-core';
2
+ import type { MaybePromise } from '@tanstack/query-persist-client-core';
3
+ import { Options } from 'tsup';
4
+ import type { PersistedClient } from '@tanstack/query-persist-client-core';
5
+ import type { Persister } from '@tanstack/query-persist-client-core';
6
+ import type { Promisable } from '@tanstack/query-persist-client-core';
7
+ import { UserConfig } from 'vite';
8
+
9
+ export declare type AsyncPersistRetryer = (props: {
10
+ persistedClient: PersistedClient;
11
+ error: Error;
12
+ errorCount: number;
13
+ }) => Promisable<PersistedClient | undefined>;
14
+
15
+ export declare function asyncThrottle<TArgs extends ReadonlyArray<unknown>>(func: (...args: TArgs) => Promise<void>, { interval, onError }?: AsyncThrottleOptions): (...args: TArgs) => Promise<void>;
16
+
17
+ declare interface AsyncThrottleOptions {
18
+ interval?: number;
19
+ onError?: (error: unknown) => void;
20
+ }
21
+
22
+ export declare const createAsyncStoragePersister: ({ storage, key, throttleTime, serialize, deserialize, retry, }: CreateAsyncStoragePersisterOptions) => Persister;
23
+
24
+ declare interface CreateAsyncStoragePersisterOptions {
25
+ /** The storage client used for setting and retrieving items from cache.
26
+ * For SSR pass in `undefined`. Note that window.localStorage can be
27
+ * `null` in Android WebViews depending on how they are configured.
28
+ */
29
+ storage: AsyncStorage<string> | undefined | null;
30
+ /** The key to use when storing the cache */
31
+ key?: string;
32
+ /** To avoid spamming,
33
+ * pass a time in ms to throttle saving the cache to disk */
34
+ throttleTime?: number;
35
+ /**
36
+ * How to serialize the data to storage.
37
+ * @default `JSON.stringify`
38
+ */
39
+ serialize?: (client: PersistedClient) => MaybePromise<string>;
40
+ /**
41
+ * How to deserialize the data from storage.
42
+ * @default `JSON.parse`
43
+ */
44
+ deserialize?: (cachedString: string) => MaybePromise<PersistedClient>;
45
+ retry?: AsyncPersistRetryer;
46
+ }
47
+
48
+ export declare const default_alias: any[];
49
+
50
+ export declare const default_alias_1: any[];
51
+
52
+ export declare const default_alias_2: Options | Options[] | ((overrideOptions: Options) => Options | Options[] | Promise<Options | Options[]>);
53
+
54
+ export declare const default_alias_3: UserConfig;
55
+
56
+ /**
57
+ * @param {Object} opts - Options for building configurations.
58
+ * @param {string[]} opts.entry - The entry array.
59
+ * @returns {import('tsup').Options}
60
+ */
61
+ export declare function legacyConfig(opts: {
62
+ entry: string[];
63
+ }): Options;
64
+
65
+ /**
66
+ * @param {Object} opts - Options for building configurations.
67
+ * @param {string[]} opts.entry - The entry array.
68
+ * @returns {import('tsup').Options}
69
+ */
70
+ export declare function modernConfig(opts: {
71
+ entry: string[];
72
+ }): Options;
73
+
74
+ export declare function noop(): void;
75
+
76
+ export declare function noop(): undefined;
77
+
78
+ export { }
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/asyncThrottle.ts
21
+ var asyncThrottle_exports = {};
22
+ __export(asyncThrottle_exports, {
23
+ asyncThrottle: () => asyncThrottle
24
+ });
25
+ module.exports = __toCommonJS(asyncThrottle_exports);
26
+ var import_query_core = require("@tanstack/query-core");
27
+ var import_utils = require("./utils.cjs");
28
+ function asyncThrottle(func, { interval = 1e3, onError = import_utils.noop } = {}) {
29
+ if (typeof func !== "function") throw new Error("argument is not function.");
30
+ let nextExecutionTime = 0;
31
+ let lastArgs = null;
32
+ let isExecuting = false;
33
+ let isScheduled = false;
34
+ return async (...args) => {
35
+ lastArgs = args;
36
+ if (isScheduled) return;
37
+ isScheduled = true;
38
+ while (isExecuting) {
39
+ await new Promise((done) => import_query_core.timeoutManager.setTimeout(done, interval));
40
+ }
41
+ while (Date.now() < nextExecutionTime) {
42
+ await new Promise(
43
+ (done) => import_query_core.timeoutManager.setTimeout(done, nextExecutionTime - Date.now())
44
+ );
45
+ }
46
+ isScheduled = false;
47
+ isExecuting = true;
48
+ try {
49
+ await func(...lastArgs);
50
+ } catch (error) {
51
+ try {
52
+ onError(error);
53
+ } catch {
54
+ }
55
+ }
56
+ nextExecutionTime = Date.now() + interval;
57
+ isExecuting = false;
58
+ };
59
+ }
60
+ // Annotate the CommonJS export names for ESM import in node:
61
+ 0 && (module.exports = {
62
+ asyncThrottle
63
+ });
64
+ //# sourceMappingURL=asyncThrottle.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/asyncThrottle.ts"],"sourcesContent":["import { timeoutManager } from '@tanstack/query-core'\nimport { noop } from './utils'\n\ninterface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nexport function asyncThrottle<TArgs extends ReadonlyArray<unknown>>(\n func: (...args: TArgs) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let nextExecutionTime = 0\n let lastArgs = null\n let isExecuting = false\n let isScheduled = false\n\n return async (...args: TArgs) => {\n lastArgs = args\n if (isScheduled) return\n isScheduled = true\n while (isExecuting) {\n await new Promise((done) => timeoutManager.setTimeout(done, interval))\n }\n while (Date.now() < nextExecutionTime) {\n await new Promise((done) =>\n timeoutManager.setTimeout(done, nextExecutionTime - Date.now()),\n )\n }\n isScheduled = false\n isExecuting = true\n try {\n await func(...lastArgs)\n } catch (error) {\n try {\n onError(error)\n } catch {}\n }\n nextExecutionTime = Date.now() + interval\n isExecuting = false\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wBAA+B;AAC/B,mBAAqB;AAOd,SAAS,cACd,MACA,EAAE,WAAW,KAAM,UAAU,kBAAK,IAA0B,CAAC,GAC7D;AACA,MAAI,OAAO,SAAS,WAAY,OAAM,IAAI,MAAM,2BAA2B;AAE3E,MAAI,oBAAoB;AACxB,MAAI,WAAW;AACf,MAAI,cAAc;AAClB,MAAI,cAAc;AAElB,SAAO,UAAU,SAAgB;AAC/B,eAAW;AACX,QAAI,YAAa;AACjB,kBAAc;AACd,WAAO,aAAa;AAClB,YAAM,IAAI,QAAQ,CAAC,SAAS,iCAAe,WAAW,MAAM,QAAQ,CAAC;AAAA,IACvE;AACA,WAAO,KAAK,IAAI,IAAI,mBAAmB;AACrC,YAAM,IAAI;AAAA,QAAQ,CAAC,SACjB,iCAAe,WAAW,MAAM,oBAAoB,KAAK,IAAI,CAAC;AAAA,MAChE;AAAA,IACF;AACA,kBAAc;AACd,kBAAc;AACd,QAAI;AACF,YAAM,KAAK,GAAG,QAAQ;AAAA,IACxB,SAAS,OAAO;AACd,UAAI;AACF,gBAAQ,KAAK;AAAA,MACf,QAAQ;AAAA,MAAC;AAAA,IACX;AACA,wBAAoB,KAAK,IAAI,IAAI;AACjC,kBAAc;AAAA,EAChB;AACF;","names":[]}
@@ -0,0 +1 @@
1
+ export { asyncThrottle } from './_tsup-dts-rollup.cjs';
@@ -0,0 +1 @@
1
+ export { asyncThrottle } from './_tsup-dts-rollup.js';
@@ -0,0 +1,39 @@
1
+ // src/asyncThrottle.ts
2
+ import { timeoutManager } from "@tanstack/query-core";
3
+ import { noop } from "./utils.js";
4
+ function asyncThrottle(func, { interval = 1e3, onError = noop } = {}) {
5
+ if (typeof func !== "function") throw new Error("argument is not function.");
6
+ let nextExecutionTime = 0;
7
+ let lastArgs = null;
8
+ let isExecuting = false;
9
+ let isScheduled = false;
10
+ return async (...args) => {
11
+ lastArgs = args;
12
+ if (isScheduled) return;
13
+ isScheduled = true;
14
+ while (isExecuting) {
15
+ await new Promise((done) => timeoutManager.setTimeout(done, interval));
16
+ }
17
+ while (Date.now() < nextExecutionTime) {
18
+ await new Promise(
19
+ (done) => timeoutManager.setTimeout(done, nextExecutionTime - Date.now())
20
+ );
21
+ }
22
+ isScheduled = false;
23
+ isExecuting = true;
24
+ try {
25
+ await func(...lastArgs);
26
+ } catch (error) {
27
+ try {
28
+ onError(error);
29
+ } catch {
30
+ }
31
+ }
32
+ nextExecutionTime = Date.now() + interval;
33
+ isExecuting = false;
34
+ };
35
+ }
36
+ export {
37
+ asyncThrottle
38
+ };
39
+ //# sourceMappingURL=asyncThrottle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/asyncThrottle.ts"],"sourcesContent":["import { timeoutManager } from '@tanstack/query-core'\nimport { noop } from './utils'\n\ninterface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nexport function asyncThrottle<TArgs extends ReadonlyArray<unknown>>(\n func: (...args: TArgs) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let nextExecutionTime = 0\n let lastArgs = null\n let isExecuting = false\n let isScheduled = false\n\n return async (...args: TArgs) => {\n lastArgs = args\n if (isScheduled) return\n isScheduled = true\n while (isExecuting) {\n await new Promise((done) => timeoutManager.setTimeout(done, interval))\n }\n while (Date.now() < nextExecutionTime) {\n await new Promise((done) =>\n timeoutManager.setTimeout(done, nextExecutionTime - Date.now()),\n )\n }\n isScheduled = false\n isExecuting = true\n try {\n await func(...lastArgs)\n } catch (error) {\n try {\n onError(error)\n } catch {}\n }\n nextExecutionTime = Date.now() + interval\n isExecuting = false\n }\n}\n"],"mappings":";AAAA,SAAS,sBAAsB;AAC/B,SAAS,YAAY;AAOd,SAAS,cACd,MACA,EAAE,WAAW,KAAM,UAAU,KAAK,IAA0B,CAAC,GAC7D;AACA,MAAI,OAAO,SAAS,WAAY,OAAM,IAAI,MAAM,2BAA2B;AAE3E,MAAI,oBAAoB;AACxB,MAAI,WAAW;AACf,MAAI,cAAc;AAClB,MAAI,cAAc;AAElB,SAAO,UAAU,SAAgB;AAC/B,eAAW;AACX,QAAI,YAAa;AACjB,kBAAc;AACd,WAAO,aAAa;AAClB,YAAM,IAAI,QAAQ,CAAC,SAAS,eAAe,WAAW,MAAM,QAAQ,CAAC;AAAA,IACvE;AACA,WAAO,KAAK,IAAI,IAAI,mBAAmB;AACrC,YAAM,IAAI;AAAA,QAAQ,CAAC,SACjB,eAAe,WAAW,MAAM,oBAAoB,KAAK,IAAI,CAAC;AAAA,MAChE;AAAA,IACF;AACA,kBAAc;AACd,kBAAc;AACd,QAAI;AACF,YAAM,KAAK,GAAG,QAAQ;AAAA,IACxB,SAAS,OAAO;AACd,UAAI;AACF,gBAAQ,KAAK;AAAA,MACf,QAAQ;AAAA,MAAC;AAAA,IACX;AACA,wBAAoB,KAAK,IAAI,IAAI;AACjC,kBAAc;AAAA,EAChB;AACF;","names":[]}
@@ -0,0 +1,86 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/index.ts
21
+ var index_exports = {};
22
+ __export(index_exports, {
23
+ createAsyncStoragePersister: () => createAsyncStoragePersister
24
+ });
25
+ module.exports = __toCommonJS(index_exports);
26
+ var import_asyncThrottle = require("./asyncThrottle.cjs");
27
+ var import_utils = require("./utils.cjs");
28
+ var createAsyncStoragePersister = ({
29
+ storage,
30
+ key = `REACT_QUERY_OFFLINE_CACHE`,
31
+ throttleTime = 1e3,
32
+ serialize = JSON.stringify,
33
+ deserialize = JSON.parse,
34
+ retry
35
+ }) => {
36
+ if (storage) {
37
+ const trySave = async (persistedClient) => {
38
+ try {
39
+ const serialized = await serialize(persistedClient);
40
+ await storage.setItem(key, serialized);
41
+ return;
42
+ } catch (error) {
43
+ return error;
44
+ }
45
+ };
46
+ return {
47
+ persistClient: (0, import_asyncThrottle.asyncThrottle)(
48
+ async (persistedClient) => {
49
+ let client = persistedClient;
50
+ let error = await trySave(client);
51
+ let errorCount = 0;
52
+ while (error && client) {
53
+ errorCount++;
54
+ client = await (retry == null ? void 0 : retry({
55
+ persistedClient: client,
56
+ error,
57
+ errorCount
58
+ }));
59
+ if (client) {
60
+ error = await trySave(client);
61
+ }
62
+ }
63
+ },
64
+ { interval: throttleTime }
65
+ ),
66
+ restoreClient: async () => {
67
+ const cacheString = await storage.getItem(key);
68
+ if (!cacheString) {
69
+ return;
70
+ }
71
+ return await deserialize(cacheString);
72
+ },
73
+ removeClient: () => storage.removeItem(key)
74
+ };
75
+ }
76
+ return {
77
+ persistClient: import_utils.noop,
78
+ restoreClient: () => Promise.resolve(void 0),
79
+ removeClient: import_utils.noop
80
+ };
81
+ };
82
+ // Annotate the CommonJS export names for ESM import in node:
83
+ 0 && (module.exports = {
84
+ createAsyncStoragePersister
85
+ });
86
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import { asyncThrottle } from './asyncThrottle'\nimport { noop } from './utils'\nimport type {\n AsyncStorage,\n MaybePromise,\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\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<string> | 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) => MaybePromise<string>\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => MaybePromise<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 const serialized = await serialize(persistedClient)\n await storage.setItem(key, serialized)\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 await 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"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,2BAA8B;AAC9B,mBAAqB;AAwCd,IAAM,8BAA8B,CAAC;AAAA,EAC1C;AAAA,EACA,MAAM;AAAA,EACN,eAAe;AAAA,EACf,YAAY,KAAK;AAAA,EACjB,cAAc,KAAK;AAAA,EACnB;AACF,MAAqD;AACnD,MAAI,SAAS;AACX,UAAM,UAAU,OACd,oBAC+B;AAC/B,UAAI;AACF,cAAM,aAAa,MAAM,UAAU,eAAe;AAClD,cAAM,QAAQ,QAAQ,KAAK,UAAU;AACrC;AAAA,MACF,SAAS,OAAO;AACd,eAAO;AAAA,MACT;AAAA,IACF;AAEA,WAAO;AAAA,MACL,mBAAe;AAAA,QACb,OAAO,oBAAoB;AACzB,cAAI,SAAsC;AAC1C,cAAI,QAAQ,MAAM,QAAQ,MAAM;AAChC,cAAI,aAAa;AACjB,iBAAO,SAAS,QAAQ;AACtB;AACA,qBAAS,OAAM,+BAAQ;AAAA,cACrB,iBAAiB;AAAA,cACjB;AAAA,cACA;AAAA,YACF;AAEA,gBAAI,QAAQ;AACV,sBAAQ,MAAM,QAAQ,MAAM;AAAA,YAC9B;AAAA,UACF;AAAA,QACF;AAAA,QACA,EAAE,UAAU,aAAa;AAAA,MAC3B;AAAA,MACA,eAAe,YAAY;AACzB,cAAM,cAAc,MAAM,QAAQ,QAAQ,GAAG;AAE7C,YAAI,CAAC,aAAa;AAChB;AAAA,QACF;AAEA,eAAO,MAAM,YAAY,WAAW;AAAA,MACtC;AAAA,MACA,cAAc,MAAM,QAAQ,WAAW,GAAG;AAAA,IAC5C;AAAA,EACF;AAEA,SAAO;AAAA,IACL,eAAe;AAAA,IACf,eAAe,MAAM,QAAQ,QAAQ,MAAS;AAAA,IAC9C,cAAc;AAAA,EAChB;AACF;","names":[]}
@@ -0,0 +1,2 @@
1
+ export { AsyncPersistRetryer } from './_tsup-dts-rollup.cjs';
2
+ export { createAsyncStoragePersister } from './_tsup-dts-rollup.cjs';
@@ -0,0 +1,2 @@
1
+ export { AsyncPersistRetryer } from './_tsup-dts-rollup.js';
2
+ export { createAsyncStoragePersister } from './_tsup-dts-rollup.js';
@@ -0,0 +1,61 @@
1
+ // src/index.ts
2
+ import { asyncThrottle } from "./asyncThrottle.js";
3
+ import { noop } from "./utils.js";
4
+ var createAsyncStoragePersister = ({
5
+ storage,
6
+ key = `REACT_QUERY_OFFLINE_CACHE`,
7
+ throttleTime = 1e3,
8
+ serialize = JSON.stringify,
9
+ deserialize = JSON.parse,
10
+ retry
11
+ }) => {
12
+ if (storage) {
13
+ const trySave = async (persistedClient) => {
14
+ try {
15
+ const serialized = await serialize(persistedClient);
16
+ await storage.setItem(key, serialized);
17
+ return;
18
+ } catch (error) {
19
+ return error;
20
+ }
21
+ };
22
+ return {
23
+ persistClient: asyncThrottle(
24
+ async (persistedClient) => {
25
+ let client = persistedClient;
26
+ let error = await trySave(client);
27
+ let errorCount = 0;
28
+ while (error && client) {
29
+ errorCount++;
30
+ client = await (retry == null ? void 0 : retry({
31
+ persistedClient: client,
32
+ error,
33
+ errorCount
34
+ }));
35
+ if (client) {
36
+ error = await trySave(client);
37
+ }
38
+ }
39
+ },
40
+ { interval: throttleTime }
41
+ ),
42
+ restoreClient: async () => {
43
+ const cacheString = await storage.getItem(key);
44
+ if (!cacheString) {
45
+ return;
46
+ }
47
+ return await deserialize(cacheString);
48
+ },
49
+ removeClient: () => storage.removeItem(key)
50
+ };
51
+ }
52
+ return {
53
+ persistClient: noop,
54
+ restoreClient: () => Promise.resolve(void 0),
55
+ removeClient: noop
56
+ };
57
+ };
58
+ export {
59
+ createAsyncStoragePersister
60
+ };
61
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import { asyncThrottle } from './asyncThrottle'\nimport { noop } from './utils'\nimport type {\n AsyncStorage,\n MaybePromise,\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\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<string> | 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) => MaybePromise<string>\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => MaybePromise<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 const serialized = await serialize(persistedClient)\n await storage.setItem(key, serialized)\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 await 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"],"mappings":";AAAA,SAAS,qBAAqB;AAC9B,SAAS,YAAY;AAwCd,IAAM,8BAA8B,CAAC;AAAA,EAC1C;AAAA,EACA,MAAM;AAAA,EACN,eAAe;AAAA,EACf,YAAY,KAAK;AAAA,EACjB,cAAc,KAAK;AAAA,EACnB;AACF,MAAqD;AACnD,MAAI,SAAS;AACX,UAAM,UAAU,OACd,oBAC+B;AAC/B,UAAI;AACF,cAAM,aAAa,MAAM,UAAU,eAAe;AAClD,cAAM,QAAQ,QAAQ,KAAK,UAAU;AACrC;AAAA,MACF,SAAS,OAAO;AACd,eAAO;AAAA,MACT;AAAA,IACF;AAEA,WAAO;AAAA,MACL,eAAe;AAAA,QACb,OAAO,oBAAoB;AACzB,cAAI,SAAsC;AAC1C,cAAI,QAAQ,MAAM,QAAQ,MAAM;AAChC,cAAI,aAAa;AACjB,iBAAO,SAAS,QAAQ;AACtB;AACA,qBAAS,OAAM,+BAAQ;AAAA,cACrB,iBAAiB;AAAA,cACjB;AAAA,cACA;AAAA,YACF;AAEA,gBAAI,QAAQ;AACV,sBAAQ,MAAM,QAAQ,MAAM;AAAA,YAC9B;AAAA,UACF;AAAA,QACF;AAAA,QACA,EAAE,UAAU,aAAa;AAAA,MAC3B;AAAA,MACA,eAAe,YAAY;AACzB,cAAM,cAAc,MAAM,QAAQ,QAAQ,GAAG;AAE7C,YAAI,CAAC,aAAa;AAChB;AAAA,QACF;AAEA,eAAO,MAAM,YAAY,WAAW;AAAA,MACtC;AAAA,MACA,cAAc,MAAM,QAAQ,WAAW,GAAG;AAAA,IAC5C;AAAA,EACF;AAEA,SAAO;AAAA,IACL,eAAe;AAAA,IACf,eAAe,MAAM,QAAQ,QAAQ,MAAS;AAAA,IAC9C,cAAc;AAAA,EAChB;AACF;","names":[]}
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/utils.ts
21
+ var utils_exports = {};
22
+ __export(utils_exports, {
23
+ noop: () => noop
24
+ });
25
+ module.exports = __toCommonJS(utils_exports);
26
+ function noop() {
27
+ }
28
+ // Annotate the CommonJS export names for ESM import in node:
29
+ 0 && (module.exports = {
30
+ noop
31
+ });
32
+ //# sourceMappingURL=utils.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/utils.ts"],"sourcesContent":["export function noop(): void\nexport function noop(): undefined\nexport function noop() {}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAEO,SAAS,OAAO;AAAC;","names":[]}
@@ -0,0 +1 @@
1
+ export { noop } from './_tsup-dts-rollup.cjs';
@@ -0,0 +1 @@
1
+ export { noop } from './_tsup-dts-rollup.js';
@@ -0,0 +1,7 @@
1
+ // src/utils.ts
2
+ function noop() {
3
+ }
4
+ export {
5
+ noop
6
+ };
7
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/utils.ts"],"sourcesContent":["export function noop(): void\nexport function noop(): undefined\nexport function noop() {}\n"],"mappings":";AAEO,SAAS,OAAO;AAAC;","names":[]}
@@ -0,0 +1,78 @@
1
+ import type { AsyncStorage } from '@tanstack/query-persist-client-core';
2
+ import type { MaybePromise } from '@tanstack/query-persist-client-core';
3
+ import { Options } from 'tsup';
4
+ import type { PersistedClient } from '@tanstack/query-persist-client-core';
5
+ import type { Persister } from '@tanstack/query-persist-client-core';
6
+ import type { Promisable } from '@tanstack/query-persist-client-core';
7
+ import { UserConfig } from 'vite';
8
+
9
+ export declare type AsyncPersistRetryer = (props: {
10
+ persistedClient: PersistedClient;
11
+ error: Error;
12
+ errorCount: number;
13
+ }) => Promisable<PersistedClient | undefined>;
14
+
15
+ export declare function asyncThrottle<TArgs extends ReadonlyArray<unknown>>(func: (...args: TArgs) => Promise<void>, { interval, onError }?: AsyncThrottleOptions): (...args: TArgs) => Promise<void>;
16
+
17
+ declare interface AsyncThrottleOptions {
18
+ interval?: number;
19
+ onError?: (error: unknown) => void;
20
+ }
21
+
22
+ export declare const createAsyncStoragePersister: ({ storage, key, throttleTime, serialize, deserialize, retry, }: CreateAsyncStoragePersisterOptions) => Persister;
23
+
24
+ declare interface CreateAsyncStoragePersisterOptions {
25
+ /** The storage client used for setting and retrieving items from cache.
26
+ * For SSR pass in `undefined`. Note that window.localStorage can be
27
+ * `null` in Android WebViews depending on how they are configured.
28
+ */
29
+ storage: AsyncStorage<string> | undefined | null;
30
+ /** The key to use when storing the cache */
31
+ key?: string;
32
+ /** To avoid spamming,
33
+ * pass a time in ms to throttle saving the cache to disk */
34
+ throttleTime?: number;
35
+ /**
36
+ * How to serialize the data to storage.
37
+ * @default `JSON.stringify`
38
+ */
39
+ serialize?: (client: PersistedClient) => MaybePromise<string>;
40
+ /**
41
+ * How to deserialize the data from storage.
42
+ * @default `JSON.parse`
43
+ */
44
+ deserialize?: (cachedString: string) => MaybePromise<PersistedClient>;
45
+ retry?: AsyncPersistRetryer;
46
+ }
47
+
48
+ export declare const default_alias: any[];
49
+
50
+ export declare const default_alias_1: any[];
51
+
52
+ export declare const default_alias_2: Options | Options[] | ((overrideOptions: Options) => Options | Options[] | Promise<Options | Options[]>);
53
+
54
+ export declare const default_alias_3: UserConfig;
55
+
56
+ /**
57
+ * @param {Object} opts - Options for building configurations.
58
+ * @param {string[]} opts.entry - The entry array.
59
+ * @returns {import('tsup').Options}
60
+ */
61
+ export declare function legacyConfig(opts: {
62
+ entry: string[];
63
+ }): Options;
64
+
65
+ /**
66
+ * @param {Object} opts - Options for building configurations.
67
+ * @param {string[]} opts.entry - The entry array.
68
+ * @returns {import('tsup').Options}
69
+ */
70
+ export declare function modernConfig(opts: {
71
+ entry: string[];
72
+ }): Options;
73
+
74
+ export declare function noop(): void;
75
+
76
+ export declare function noop(): undefined;
77
+
78
+ export { }
@@ -0,0 +1,78 @@
1
+ import type { AsyncStorage } from '@tanstack/query-persist-client-core';
2
+ import type { MaybePromise } from '@tanstack/query-persist-client-core';
3
+ import { Options } from 'tsup';
4
+ import type { PersistedClient } from '@tanstack/query-persist-client-core';
5
+ import type { Persister } from '@tanstack/query-persist-client-core';
6
+ import type { Promisable } from '@tanstack/query-persist-client-core';
7
+ import { UserConfig } from 'vite';
8
+
9
+ export declare type AsyncPersistRetryer = (props: {
10
+ persistedClient: PersistedClient;
11
+ error: Error;
12
+ errorCount: number;
13
+ }) => Promisable<PersistedClient | undefined>;
14
+
15
+ export declare function asyncThrottle<TArgs extends ReadonlyArray<unknown>>(func: (...args: TArgs) => Promise<void>, { interval, onError }?: AsyncThrottleOptions): (...args: TArgs) => Promise<void>;
16
+
17
+ declare interface AsyncThrottleOptions {
18
+ interval?: number;
19
+ onError?: (error: unknown) => void;
20
+ }
21
+
22
+ export declare const createAsyncStoragePersister: ({ storage, key, throttleTime, serialize, deserialize, retry, }: CreateAsyncStoragePersisterOptions) => Persister;
23
+
24
+ declare interface CreateAsyncStoragePersisterOptions {
25
+ /** The storage client used for setting and retrieving items from cache.
26
+ * For SSR pass in `undefined`. Note that window.localStorage can be
27
+ * `null` in Android WebViews depending on how they are configured.
28
+ */
29
+ storage: AsyncStorage<string> | undefined | null;
30
+ /** The key to use when storing the cache */
31
+ key?: string;
32
+ /** To avoid spamming,
33
+ * pass a time in ms to throttle saving the cache to disk */
34
+ throttleTime?: number;
35
+ /**
36
+ * How to serialize the data to storage.
37
+ * @default `JSON.stringify`
38
+ */
39
+ serialize?: (client: PersistedClient) => MaybePromise<string>;
40
+ /**
41
+ * How to deserialize the data from storage.
42
+ * @default `JSON.parse`
43
+ */
44
+ deserialize?: (cachedString: string) => MaybePromise<PersistedClient>;
45
+ retry?: AsyncPersistRetryer;
46
+ }
47
+
48
+ export declare const default_alias: any[];
49
+
50
+ export declare const default_alias_1: any[];
51
+
52
+ export declare const default_alias_2: Options | Options[] | ((overrideOptions: Options) => Options | Options[] | Promise<Options | Options[]>);
53
+
54
+ export declare const default_alias_3: UserConfig;
55
+
56
+ /**
57
+ * @param {Object} opts - Options for building configurations.
58
+ * @param {string[]} opts.entry - The entry array.
59
+ * @returns {import('tsup').Options}
60
+ */
61
+ export declare function legacyConfig(opts: {
62
+ entry: string[];
63
+ }): Options;
64
+
65
+ /**
66
+ * @param {Object} opts - Options for building configurations.
67
+ * @param {string[]} opts.entry - The entry array.
68
+ * @returns {import('tsup').Options}
69
+ */
70
+ export declare function modernConfig(opts: {
71
+ entry: string[];
72
+ }): Options;
73
+
74
+ export declare function noop(): void;
75
+
76
+ export declare function noop(): undefined;
77
+
78
+ export { }
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/asyncThrottle.ts
21
+ var asyncThrottle_exports = {};
22
+ __export(asyncThrottle_exports, {
23
+ asyncThrottle: () => asyncThrottle
24
+ });
25
+ module.exports = __toCommonJS(asyncThrottle_exports);
26
+ var import_query_core = require("@tanstack/query-core");
27
+ var import_utils = require("./utils.cjs");
28
+ function asyncThrottle(func, { interval = 1e3, onError = import_utils.noop } = {}) {
29
+ if (typeof func !== "function") throw new Error("argument is not function.");
30
+ let nextExecutionTime = 0;
31
+ let lastArgs = null;
32
+ let isExecuting = false;
33
+ let isScheduled = false;
34
+ return async (...args) => {
35
+ lastArgs = args;
36
+ if (isScheduled) return;
37
+ isScheduled = true;
38
+ while (isExecuting) {
39
+ await new Promise((done) => import_query_core.timeoutManager.setTimeout(done, interval));
40
+ }
41
+ while (Date.now() < nextExecutionTime) {
42
+ await new Promise(
43
+ (done) => import_query_core.timeoutManager.setTimeout(done, nextExecutionTime - Date.now())
44
+ );
45
+ }
46
+ isScheduled = false;
47
+ isExecuting = true;
48
+ try {
49
+ await func(...lastArgs);
50
+ } catch (error) {
51
+ try {
52
+ onError(error);
53
+ } catch {
54
+ }
55
+ }
56
+ nextExecutionTime = Date.now() + interval;
57
+ isExecuting = false;
58
+ };
59
+ }
60
+ // Annotate the CommonJS export names for ESM import in node:
61
+ 0 && (module.exports = {
62
+ asyncThrottle
63
+ });
64
+ //# sourceMappingURL=asyncThrottle.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/asyncThrottle.ts"],"sourcesContent":["import { timeoutManager } from '@tanstack/query-core'\nimport { noop } from './utils'\n\ninterface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nexport function asyncThrottle<TArgs extends ReadonlyArray<unknown>>(\n func: (...args: TArgs) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let nextExecutionTime = 0\n let lastArgs = null\n let isExecuting = false\n let isScheduled = false\n\n return async (...args: TArgs) => {\n lastArgs = args\n if (isScheduled) return\n isScheduled = true\n while (isExecuting) {\n await new Promise((done) => timeoutManager.setTimeout(done, interval))\n }\n while (Date.now() < nextExecutionTime) {\n await new Promise((done) =>\n timeoutManager.setTimeout(done, nextExecutionTime - Date.now()),\n )\n }\n isScheduled = false\n isExecuting = true\n try {\n await func(...lastArgs)\n } catch (error) {\n try {\n onError(error)\n } catch {}\n }\n nextExecutionTime = Date.now() + interval\n isExecuting = false\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wBAA+B;AAC/B,mBAAqB;AAOd,SAAS,cACd,MACA,EAAE,WAAW,KAAM,UAAU,kBAAK,IAA0B,CAAC,GAC7D;AACA,MAAI,OAAO,SAAS,WAAY,OAAM,IAAI,MAAM,2BAA2B;AAE3E,MAAI,oBAAoB;AACxB,MAAI,WAAW;AACf,MAAI,cAAc;AAClB,MAAI,cAAc;AAElB,SAAO,UAAU,SAAgB;AAC/B,eAAW;AACX,QAAI,YAAa;AACjB,kBAAc;AACd,WAAO,aAAa;AAClB,YAAM,IAAI,QAAQ,CAAC,SAAS,iCAAe,WAAW,MAAM,QAAQ,CAAC;AAAA,IACvE;AACA,WAAO,KAAK,IAAI,IAAI,mBAAmB;AACrC,YAAM,IAAI;AAAA,QAAQ,CAAC,SACjB,iCAAe,WAAW,MAAM,oBAAoB,KAAK,IAAI,CAAC;AAAA,MAChE;AAAA,IACF;AACA,kBAAc;AACd,kBAAc;AACd,QAAI;AACF,YAAM,KAAK,GAAG,QAAQ;AAAA,IACxB,SAAS,OAAO;AACd,UAAI;AACF,gBAAQ,KAAK;AAAA,MACf,QAAQ;AAAA,MAAC;AAAA,IACX;AACA,wBAAoB,KAAK,IAAI,IAAI;AACjC,kBAAc;AAAA,EAChB;AACF;","names":[]}
@@ -0,0 +1 @@
1
+ export { asyncThrottle } from './_tsup-dts-rollup.cjs';
@@ -0,0 +1 @@
1
+ export { asyncThrottle } from './_tsup-dts-rollup.js';
@@ -0,0 +1,39 @@
1
+ // src/asyncThrottle.ts
2
+ import { timeoutManager } from "@tanstack/query-core";
3
+ import { noop } from "./utils.js";
4
+ function asyncThrottle(func, { interval = 1e3, onError = noop } = {}) {
5
+ if (typeof func !== "function") throw new Error("argument is not function.");
6
+ let nextExecutionTime = 0;
7
+ let lastArgs = null;
8
+ let isExecuting = false;
9
+ let isScheduled = false;
10
+ return async (...args) => {
11
+ lastArgs = args;
12
+ if (isScheduled) return;
13
+ isScheduled = true;
14
+ while (isExecuting) {
15
+ await new Promise((done) => timeoutManager.setTimeout(done, interval));
16
+ }
17
+ while (Date.now() < nextExecutionTime) {
18
+ await new Promise(
19
+ (done) => timeoutManager.setTimeout(done, nextExecutionTime - Date.now())
20
+ );
21
+ }
22
+ isScheduled = false;
23
+ isExecuting = true;
24
+ try {
25
+ await func(...lastArgs);
26
+ } catch (error) {
27
+ try {
28
+ onError(error);
29
+ } catch {
30
+ }
31
+ }
32
+ nextExecutionTime = Date.now() + interval;
33
+ isExecuting = false;
34
+ };
35
+ }
36
+ export {
37
+ asyncThrottle
38
+ };
39
+ //# sourceMappingURL=asyncThrottle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/asyncThrottle.ts"],"sourcesContent":["import { timeoutManager } from '@tanstack/query-core'\nimport { noop } from './utils'\n\ninterface AsyncThrottleOptions {\n interval?: number\n onError?: (error: unknown) => void\n}\n\nexport function asyncThrottle<TArgs extends ReadonlyArray<unknown>>(\n func: (...args: TArgs) => Promise<void>,\n { interval = 1000, onError = noop }: AsyncThrottleOptions = {},\n) {\n if (typeof func !== 'function') throw new Error('argument is not function.')\n\n let nextExecutionTime = 0\n let lastArgs = null\n let isExecuting = false\n let isScheduled = false\n\n return async (...args: TArgs) => {\n lastArgs = args\n if (isScheduled) return\n isScheduled = true\n while (isExecuting) {\n await new Promise((done) => timeoutManager.setTimeout(done, interval))\n }\n while (Date.now() < nextExecutionTime) {\n await new Promise((done) =>\n timeoutManager.setTimeout(done, nextExecutionTime - Date.now()),\n )\n }\n isScheduled = false\n isExecuting = true\n try {\n await func(...lastArgs)\n } catch (error) {\n try {\n onError(error)\n } catch {}\n }\n nextExecutionTime = Date.now() + interval\n isExecuting = false\n }\n}\n"],"mappings":";AAAA,SAAS,sBAAsB;AAC/B,SAAS,YAAY;AAOd,SAAS,cACd,MACA,EAAE,WAAW,KAAM,UAAU,KAAK,IAA0B,CAAC,GAC7D;AACA,MAAI,OAAO,SAAS,WAAY,OAAM,IAAI,MAAM,2BAA2B;AAE3E,MAAI,oBAAoB;AACxB,MAAI,WAAW;AACf,MAAI,cAAc;AAClB,MAAI,cAAc;AAElB,SAAO,UAAU,SAAgB;AAC/B,eAAW;AACX,QAAI,YAAa;AACjB,kBAAc;AACd,WAAO,aAAa;AAClB,YAAM,IAAI,QAAQ,CAAC,SAAS,eAAe,WAAW,MAAM,QAAQ,CAAC;AAAA,IACvE;AACA,WAAO,KAAK,IAAI,IAAI,mBAAmB;AACrC,YAAM,IAAI;AAAA,QAAQ,CAAC,SACjB,eAAe,WAAW,MAAM,oBAAoB,KAAK,IAAI,CAAC;AAAA,MAChE;AAAA,IACF;AACA,kBAAc;AACd,kBAAc;AACd,QAAI;AACF,YAAM,KAAK,GAAG,QAAQ;AAAA,IACxB,SAAS,OAAO;AACd,UAAI;AACF,gBAAQ,KAAK;AAAA,MACf,QAAQ;AAAA,MAAC;AAAA,IACX;AACA,wBAAoB,KAAK,IAAI,IAAI;AACjC,kBAAc;AAAA,EAChB;AACF;","names":[]}
@@ -0,0 +1,86 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/index.ts
21
+ var index_exports = {};
22
+ __export(index_exports, {
23
+ createAsyncStoragePersister: () => createAsyncStoragePersister
24
+ });
25
+ module.exports = __toCommonJS(index_exports);
26
+ var import_asyncThrottle = require("./asyncThrottle.cjs");
27
+ var import_utils = require("./utils.cjs");
28
+ var createAsyncStoragePersister = ({
29
+ storage,
30
+ key = `REACT_QUERY_OFFLINE_CACHE`,
31
+ throttleTime = 1e3,
32
+ serialize = JSON.stringify,
33
+ deserialize = JSON.parse,
34
+ retry
35
+ }) => {
36
+ if (storage) {
37
+ const trySave = async (persistedClient) => {
38
+ try {
39
+ const serialized = await serialize(persistedClient);
40
+ await storage.setItem(key, serialized);
41
+ return;
42
+ } catch (error) {
43
+ return error;
44
+ }
45
+ };
46
+ return {
47
+ persistClient: (0, import_asyncThrottle.asyncThrottle)(
48
+ async (persistedClient) => {
49
+ let client = persistedClient;
50
+ let error = await trySave(client);
51
+ let errorCount = 0;
52
+ while (error && client) {
53
+ errorCount++;
54
+ client = await retry?.({
55
+ persistedClient: client,
56
+ error,
57
+ errorCount
58
+ });
59
+ if (client) {
60
+ error = await trySave(client);
61
+ }
62
+ }
63
+ },
64
+ { interval: throttleTime }
65
+ ),
66
+ restoreClient: async () => {
67
+ const cacheString = await storage.getItem(key);
68
+ if (!cacheString) {
69
+ return;
70
+ }
71
+ return await deserialize(cacheString);
72
+ },
73
+ removeClient: () => storage.removeItem(key)
74
+ };
75
+ }
76
+ return {
77
+ persistClient: import_utils.noop,
78
+ restoreClient: () => Promise.resolve(void 0),
79
+ removeClient: import_utils.noop
80
+ };
81
+ };
82
+ // Annotate the CommonJS export names for ESM import in node:
83
+ 0 && (module.exports = {
84
+ createAsyncStoragePersister
85
+ });
86
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import { asyncThrottle } from './asyncThrottle'\nimport { noop } from './utils'\nimport type {\n AsyncStorage,\n MaybePromise,\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\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<string> | 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) => MaybePromise<string>\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => MaybePromise<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 const serialized = await serialize(persistedClient)\n await storage.setItem(key, serialized)\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 await 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"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,2BAA8B;AAC9B,mBAAqB;AAwCd,IAAM,8BAA8B,CAAC;AAAA,EAC1C;AAAA,EACA,MAAM;AAAA,EACN,eAAe;AAAA,EACf,YAAY,KAAK;AAAA,EACjB,cAAc,KAAK;AAAA,EACnB;AACF,MAAqD;AACnD,MAAI,SAAS;AACX,UAAM,UAAU,OACd,oBAC+B;AAC/B,UAAI;AACF,cAAM,aAAa,MAAM,UAAU,eAAe;AAClD,cAAM,QAAQ,QAAQ,KAAK,UAAU;AACrC;AAAA,MACF,SAAS,OAAO;AACd,eAAO;AAAA,MACT;AAAA,IACF;AAEA,WAAO;AAAA,MACL,mBAAe;AAAA,QACb,OAAO,oBAAoB;AACzB,cAAI,SAAsC;AAC1C,cAAI,QAAQ,MAAM,QAAQ,MAAM;AAChC,cAAI,aAAa;AACjB,iBAAO,SAAS,QAAQ;AACtB;AACA,qBAAS,MAAM,QAAQ;AAAA,cACrB,iBAAiB;AAAA,cACjB;AAAA,cACA;AAAA,YACF,CAAC;AAED,gBAAI,QAAQ;AACV,sBAAQ,MAAM,QAAQ,MAAM;AAAA,YAC9B;AAAA,UACF;AAAA,QACF;AAAA,QACA,EAAE,UAAU,aAAa;AAAA,MAC3B;AAAA,MACA,eAAe,YAAY;AACzB,cAAM,cAAc,MAAM,QAAQ,QAAQ,GAAG;AAE7C,YAAI,CAAC,aAAa;AAChB;AAAA,QACF;AAEA,eAAO,MAAM,YAAY,WAAW;AAAA,MACtC;AAAA,MACA,cAAc,MAAM,QAAQ,WAAW,GAAG;AAAA,IAC5C;AAAA,EACF;AAEA,SAAO;AAAA,IACL,eAAe;AAAA,IACf,eAAe,MAAM,QAAQ,QAAQ,MAAS;AAAA,IAC9C,cAAc;AAAA,EAChB;AACF;","names":[]}
@@ -0,0 +1,2 @@
1
+ export { AsyncPersistRetryer } from './_tsup-dts-rollup.cjs';
2
+ export { createAsyncStoragePersister } from './_tsup-dts-rollup.cjs';
@@ -0,0 +1,2 @@
1
+ export { AsyncPersistRetryer } from './_tsup-dts-rollup.js';
2
+ export { createAsyncStoragePersister } from './_tsup-dts-rollup.js';
@@ -0,0 +1,61 @@
1
+ // src/index.ts
2
+ import { asyncThrottle } from "./asyncThrottle.js";
3
+ import { noop } from "./utils.js";
4
+ var createAsyncStoragePersister = ({
5
+ storage,
6
+ key = `REACT_QUERY_OFFLINE_CACHE`,
7
+ throttleTime = 1e3,
8
+ serialize = JSON.stringify,
9
+ deserialize = JSON.parse,
10
+ retry
11
+ }) => {
12
+ if (storage) {
13
+ const trySave = async (persistedClient) => {
14
+ try {
15
+ const serialized = await serialize(persistedClient);
16
+ await storage.setItem(key, serialized);
17
+ return;
18
+ } catch (error) {
19
+ return error;
20
+ }
21
+ };
22
+ return {
23
+ persistClient: asyncThrottle(
24
+ async (persistedClient) => {
25
+ let client = persistedClient;
26
+ let error = await trySave(client);
27
+ let errorCount = 0;
28
+ while (error && client) {
29
+ errorCount++;
30
+ client = await retry?.({
31
+ persistedClient: client,
32
+ error,
33
+ errorCount
34
+ });
35
+ if (client) {
36
+ error = await trySave(client);
37
+ }
38
+ }
39
+ },
40
+ { interval: throttleTime }
41
+ ),
42
+ restoreClient: async () => {
43
+ const cacheString = await storage.getItem(key);
44
+ if (!cacheString) {
45
+ return;
46
+ }
47
+ return await deserialize(cacheString);
48
+ },
49
+ removeClient: () => storage.removeItem(key)
50
+ };
51
+ }
52
+ return {
53
+ persistClient: noop,
54
+ restoreClient: () => Promise.resolve(void 0),
55
+ removeClient: noop
56
+ };
57
+ };
58
+ export {
59
+ createAsyncStoragePersister
60
+ };
61
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import { asyncThrottle } from './asyncThrottle'\nimport { noop } from './utils'\nimport type {\n AsyncStorage,\n MaybePromise,\n PersistedClient,\n Persister,\n Promisable,\n} from '@tanstack/query-persist-client-core'\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<string> | 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) => MaybePromise<string>\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => MaybePromise<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 const serialized = await serialize(persistedClient)\n await storage.setItem(key, serialized)\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 await 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"],"mappings":";AAAA,SAAS,qBAAqB;AAC9B,SAAS,YAAY;AAwCd,IAAM,8BAA8B,CAAC;AAAA,EAC1C;AAAA,EACA,MAAM;AAAA,EACN,eAAe;AAAA,EACf,YAAY,KAAK;AAAA,EACjB,cAAc,KAAK;AAAA,EACnB;AACF,MAAqD;AACnD,MAAI,SAAS;AACX,UAAM,UAAU,OACd,oBAC+B;AAC/B,UAAI;AACF,cAAM,aAAa,MAAM,UAAU,eAAe;AAClD,cAAM,QAAQ,QAAQ,KAAK,UAAU;AACrC;AAAA,MACF,SAAS,OAAO;AACd,eAAO;AAAA,MACT;AAAA,IACF;AAEA,WAAO;AAAA,MACL,eAAe;AAAA,QACb,OAAO,oBAAoB;AACzB,cAAI,SAAsC;AAC1C,cAAI,QAAQ,MAAM,QAAQ,MAAM;AAChC,cAAI,aAAa;AACjB,iBAAO,SAAS,QAAQ;AACtB;AACA,qBAAS,MAAM,QAAQ;AAAA,cACrB,iBAAiB;AAAA,cACjB;AAAA,cACA;AAAA,YACF,CAAC;AAED,gBAAI,QAAQ;AACV,sBAAQ,MAAM,QAAQ,MAAM;AAAA,YAC9B;AAAA,UACF;AAAA,QACF;AAAA,QACA,EAAE,UAAU,aAAa;AAAA,MAC3B;AAAA,MACA,eAAe,YAAY;AACzB,cAAM,cAAc,MAAM,QAAQ,QAAQ,GAAG;AAE7C,YAAI,CAAC,aAAa;AAChB;AAAA,QACF;AAEA,eAAO,MAAM,YAAY,WAAW;AAAA,MACtC;AAAA,MACA,cAAc,MAAM,QAAQ,WAAW,GAAG;AAAA,IAC5C;AAAA,EACF;AAEA,SAAO;AAAA,IACL,eAAe;AAAA,IACf,eAAe,MAAM,QAAQ,QAAQ,MAAS;AAAA,IAC9C,cAAc;AAAA,EAChB;AACF;","names":[]}
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/utils.ts
21
+ var utils_exports = {};
22
+ __export(utils_exports, {
23
+ noop: () => noop
24
+ });
25
+ module.exports = __toCommonJS(utils_exports);
26
+ function noop() {
27
+ }
28
+ // Annotate the CommonJS export names for ESM import in node:
29
+ 0 && (module.exports = {
30
+ noop
31
+ });
32
+ //# sourceMappingURL=utils.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/utils.ts"],"sourcesContent":["export function noop(): void\nexport function noop(): undefined\nexport function noop() {}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAEO,SAAS,OAAO;AAAC;","names":[]}
@@ -0,0 +1 @@
1
+ export { noop } from './_tsup-dts-rollup.cjs';
@@ -0,0 +1 @@
1
+ export { noop } from './_tsup-dts-rollup.js';
@@ -0,0 +1,7 @@
1
+ // src/utils.ts
2
+ function noop() {
3
+ }
4
+ export {
5
+ noop
6
+ };
7
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/utils.ts"],"sourcesContent":["export function noop(): void\nexport function noop(): undefined\nexport function noop() {}\n"],"mappings":";AAEO,SAAS,OAAO;AAAC;","names":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tanstack/query-async-storage-persister",
3
- "version": "5.94.4",
3
+ "version": "5.94.5",
4
4
  "description": "A persister for asynchronous storages, to be used with TanStack/Query",
5
5
  "author": "tannerlinsley",
6
6
  "license": "MIT",
@@ -40,8 +40,8 @@
40
40
  "!src/__tests__"
41
41
  ],
42
42
  "dependencies": {
43
- "@tanstack/query-core": "5.94.4",
44
- "@tanstack/query-persist-client-core": "5.94.4"
43
+ "@tanstack/query-core": "5.94.5",
44
+ "@tanstack/query-persist-client-core": "5.94.5"
45
45
  },
46
46
  "devDependencies": {
47
47
  "npm-run-all2": "^5.0.0",