@tanstack/query-sync-storage-persister 5.0.0-alpha.85 → 5.0.0-alpha.87
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/legacy/index.cjs +95 -0
- package/build/legacy/index.cjs.map +1 -0
- package/build/legacy/index.d.cts +33 -0
- package/build/{lib → legacy}/index.d.ts +5 -4
- package/build/{lib/index.legacy.js → legacy/index.js} +11 -11
- package/build/legacy/index.js.map +1 -0
- package/build/modern/index.cjs +95 -0
- package/build/modern/index.cjs.map +1 -0
- package/build/modern/index.d.cts +33 -0
- package/build/modern/index.d.ts +33 -0
- package/build/{lib → modern}/index.js +11 -11
- package/build/modern/index.js.map +1 -0
- package/package.json +17 -15
- package/build/lib/__tests__/storageIsFull.test.d.ts +0 -2
- package/build/lib/__tests__/storageIsFull.test.d.ts.map +0 -1
- package/build/lib/__tests__/utils.d.ts +0 -2
- package/build/lib/__tests__/utils.d.ts.map +0 -1
- package/build/lib/index.cjs +0 -73
- package/build/lib/index.cjs.map +0 -1
- package/build/lib/index.d.ts.map +0 -1
- package/build/lib/index.js.map +0 -1
- package/build/lib/index.legacy.cjs +0 -73
- package/build/lib/index.legacy.cjs.map +0 -1
- package/build/lib/index.legacy.js.map +0 -1
|
@@ -0,0 +1,95 @@
|
|
|
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
|
+
var src_exports = {};
|
|
20
|
+
__export(src_exports, {
|
|
21
|
+
createSyncStoragePersister: () => createSyncStoragePersister
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(src_exports);
|
|
24
|
+
function createSyncStoragePersister({
|
|
25
|
+
storage,
|
|
26
|
+
key = `REACT_QUERY_OFFLINE_CACHE`,
|
|
27
|
+
throttleTime = 1e3,
|
|
28
|
+
serialize = JSON.stringify,
|
|
29
|
+
deserialize = JSON.parse,
|
|
30
|
+
retry
|
|
31
|
+
}) {
|
|
32
|
+
if (storage) {
|
|
33
|
+
const trySave = (persistedClient) => {
|
|
34
|
+
try {
|
|
35
|
+
storage.setItem(key, serialize(persistedClient));
|
|
36
|
+
return;
|
|
37
|
+
} catch (error) {
|
|
38
|
+
return error;
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
return {
|
|
42
|
+
persistClient: throttle((persistedClient) => {
|
|
43
|
+
let client = persistedClient;
|
|
44
|
+
let error = trySave(client);
|
|
45
|
+
let errorCount = 0;
|
|
46
|
+
while (error && client) {
|
|
47
|
+
errorCount++;
|
|
48
|
+
client = retry == null ? void 0 : retry({
|
|
49
|
+
persistedClient: client,
|
|
50
|
+
error,
|
|
51
|
+
errorCount
|
|
52
|
+
});
|
|
53
|
+
if (client) {
|
|
54
|
+
error = trySave(client);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}, throttleTime),
|
|
58
|
+
restoreClient: () => {
|
|
59
|
+
const cacheString = storage.getItem(key);
|
|
60
|
+
if (!cacheString) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
return deserialize(cacheString);
|
|
64
|
+
},
|
|
65
|
+
removeClient: () => {
|
|
66
|
+
storage.removeItem(key);
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
return {
|
|
71
|
+
persistClient: noop,
|
|
72
|
+
restoreClient: () => void 0,
|
|
73
|
+
removeClient: noop
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
function throttle(func, wait = 100) {
|
|
77
|
+
let timer = null;
|
|
78
|
+
let params;
|
|
79
|
+
return function(...args) {
|
|
80
|
+
params = args;
|
|
81
|
+
if (timer === null) {
|
|
82
|
+
timer = setTimeout(() => {
|
|
83
|
+
func(...params);
|
|
84
|
+
timer = null;
|
|
85
|
+
}, wait);
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
function noop() {
|
|
90
|
+
}
|
|
91
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
92
|
+
0 && (module.exports = {
|
|
93
|
+
createSyncStoragePersister
|
|
94
|
+
});
|
|
95
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistRetryer,\n PersistedClient,\n Persister,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\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: Storage | 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?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAqCO,SAAS,2BAA2B;AAAA,EACzC;AAAA,EACA,MAAM;AAAA,EACN,eAAe;AAAA,EACf,YAAY,KAAK;AAAA,EACjB,cAAc,KAAK;AAAA,EACnB;AACF,GAAiD;AAC/C,MAAI,SAAS;AACX,UAAM,UAAU,CAAC,oBAAwD;AACvE,UAAI;AACF,gBAAQ,QAAQ,KAAK,UAAU,eAAe,CAAC;AAC/C;AAAA,MACF,SAAS,OAAO;AACd,eAAO;AAAA,MACT;AAAA,IACF;AACA,WAAO;AAAA,MACL,eAAe,SAAS,CAAC,oBAAoB;AAC3C,YAAI,SAAsC;AAC1C,YAAI,QAAQ,QAAQ,MAAM;AAC1B,YAAI,aAAa;AACjB,eAAO,SAAS,QAAQ;AACtB;AACA,mBAAS,+BAAQ;AAAA,YACf,iBAAiB;AAAA,YACjB;AAAA,YACA;AAAA,UACF;AAEA,cAAI,QAAQ;AACV,oBAAQ,QAAQ,MAAM;AAAA,UACxB;AAAA,QACF;AAAA,MACF,GAAG,YAAY;AAAA,MACf,eAAe,MAAM;AACnB,cAAM,cAAc,QAAQ,QAAQ,GAAG;AAEvC,YAAI,CAAC,aAAa;AAChB;AAAA,QACF;AAEA,eAAO,YAAY,WAAW;AAAA,MAChC;AAAA,MACA,cAAc,MAAM;AAClB,gBAAQ,WAAW,GAAG;AAAA,MACxB;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AAAA,IACL,eAAe;AAAA,IACf,eAAe,MAAM;AAAA,IACrB,cAAc;AAAA,EAChB;AACF;AAEA,SAAS,SACP,MACA,OAAO,KACP;AACA,MAAI,QAA8C;AAClD,MAAI;AACJ,SAAO,YAAa,MAAa;AAC/B,aAAS;AACT,QAAI,UAAU,MAAM;AAClB,cAAQ,WAAW,MAAM;AACvB,aAAK,GAAG,MAAM;AACd,gBAAQ;AAAA,MACV,GAAG,IAAI;AAAA,IACT;AAAA,EACF;AACF;AAGA,SAAS,OAAO;AAAC;","names":[]}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { Persister, PersistedClient, PersistRetryer } from '@tanstack/query-persist-client-core';
|
|
2
|
+
|
|
3
|
+
interface Storage {
|
|
4
|
+
getItem: (key: string) => string | null;
|
|
5
|
+
setItem: (key: string, value: string) => void;
|
|
6
|
+
removeItem: (key: string) => void;
|
|
7
|
+
}
|
|
8
|
+
interface CreateSyncStoragePersisterOptions {
|
|
9
|
+
/** The storage client used for setting and retrieving items from cache.
|
|
10
|
+
* For SSR pass in `undefined`. Note that window.localStorage can be
|
|
11
|
+
* `null` in Android WebViews depending on how they are configured.
|
|
12
|
+
*/
|
|
13
|
+
storage: Storage | undefined | null;
|
|
14
|
+
/** The key to use when storing the cache */
|
|
15
|
+
key?: string;
|
|
16
|
+
/** To avoid spamming,
|
|
17
|
+
* pass a time in ms to throttle saving the cache to disk */
|
|
18
|
+
throttleTime?: number;
|
|
19
|
+
/**
|
|
20
|
+
* How to serialize the data to storage.
|
|
21
|
+
* @default `JSON.stringify`
|
|
22
|
+
*/
|
|
23
|
+
serialize?: (client: PersistedClient) => string;
|
|
24
|
+
/**
|
|
25
|
+
* How to deserialize the data from storage.
|
|
26
|
+
* @default `JSON.parse`
|
|
27
|
+
*/
|
|
28
|
+
deserialize?: (cachedString: string) => PersistedClient;
|
|
29
|
+
retry?: PersistRetryer;
|
|
30
|
+
}
|
|
31
|
+
declare function createSyncStoragePersister({ storage, key, throttleTime, serialize, deserialize, retry, }: CreateSyncStoragePersisterOptions): Persister;
|
|
32
|
+
|
|
33
|
+
export { createSyncStoragePersister };
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { Persister, PersistedClient, PersistRetryer } from '@tanstack/query-persist-client-core';
|
|
2
|
+
|
|
2
3
|
interface Storage {
|
|
3
4
|
getItem: (key: string) => string | null;
|
|
4
5
|
setItem: (key: string, value: string) => void;
|
|
@@ -27,6 +28,6 @@ interface CreateSyncStoragePersisterOptions {
|
|
|
27
28
|
deserialize?: (cachedString: string) => PersistedClient;
|
|
28
29
|
retry?: PersistRetryer;
|
|
29
30
|
}
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
31
|
+
declare function createSyncStoragePersister({ storage, key, throttleTime, serialize, deserialize, retry, }: CreateSyncStoragePersisterOptions): Persister;
|
|
32
|
+
|
|
33
|
+
export { createSyncStoragePersister };
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
function createSyncStoragePersister({
|
|
2
2
|
storage,
|
|
3
3
|
key = `REACT_QUERY_OFFLINE_CACHE`,
|
|
4
|
-
throttleTime =
|
|
4
|
+
throttleTime = 1e3,
|
|
5
5
|
serialize = JSON.stringify,
|
|
6
6
|
deserialize = JSON.parse,
|
|
7
7
|
retry
|
|
8
8
|
}) {
|
|
9
9
|
if (storage) {
|
|
10
|
-
const trySave = persistedClient => {
|
|
10
|
+
const trySave = (persistedClient) => {
|
|
11
11
|
try {
|
|
12
12
|
storage.setItem(key, serialize(persistedClient));
|
|
13
13
|
return;
|
|
@@ -16,7 +16,7 @@ function createSyncStoragePersister({
|
|
|
16
16
|
}
|
|
17
17
|
};
|
|
18
18
|
return {
|
|
19
|
-
persistClient: throttle(persistedClient => {
|
|
19
|
+
persistClient: throttle((persistedClient) => {
|
|
20
20
|
let client = persistedClient;
|
|
21
21
|
let error = trySave(client);
|
|
22
22
|
let errorCount = 0;
|
|
@@ -46,14 +46,14 @@ function createSyncStoragePersister({
|
|
|
46
46
|
}
|
|
47
47
|
return {
|
|
48
48
|
persistClient: noop,
|
|
49
|
-
restoreClient: () =>
|
|
49
|
+
restoreClient: () => void 0,
|
|
50
50
|
removeClient: noop
|
|
51
51
|
};
|
|
52
52
|
}
|
|
53
53
|
function throttle(func, wait = 100) {
|
|
54
54
|
let timer = null;
|
|
55
55
|
let params;
|
|
56
|
-
return function
|
|
56
|
+
return function(...args) {
|
|
57
57
|
params = args;
|
|
58
58
|
if (timer === null) {
|
|
59
59
|
timer = setTimeout(() => {
|
|
@@ -63,9 +63,9 @@ function throttle(func, wait = 100) {
|
|
|
63
63
|
}
|
|
64
64
|
};
|
|
65
65
|
}
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
//# sourceMappingURL=index.
|
|
66
|
+
function noop() {
|
|
67
|
+
}
|
|
68
|
+
export {
|
|
69
|
+
createSyncStoragePersister
|
|
70
|
+
};
|
|
71
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistRetryer,\n PersistedClient,\n Persister,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\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: Storage | 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?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"mappings":"AAqCO,SAAS,2BAA2B;AAAA,EACzC;AAAA,EACA,MAAM;AAAA,EACN,eAAe;AAAA,EACf,YAAY,KAAK;AAAA,EACjB,cAAc,KAAK;AAAA,EACnB;AACF,GAAiD;AAC/C,MAAI,SAAS;AACX,UAAM,UAAU,CAAC,oBAAwD;AACvE,UAAI;AACF,gBAAQ,QAAQ,KAAK,UAAU,eAAe,CAAC;AAC/C;AAAA,MACF,SAAS,OAAO;AACd,eAAO;AAAA,MACT;AAAA,IACF;AACA,WAAO;AAAA,MACL,eAAe,SAAS,CAAC,oBAAoB;AAC3C,YAAI,SAAsC;AAC1C,YAAI,QAAQ,QAAQ,MAAM;AAC1B,YAAI,aAAa;AACjB,eAAO,SAAS,QAAQ;AACtB;AACA,mBAAS,+BAAQ;AAAA,YACf,iBAAiB;AAAA,YACjB;AAAA,YACA;AAAA,UACF;AAEA,cAAI,QAAQ;AACV,oBAAQ,QAAQ,MAAM;AAAA,UACxB;AAAA,QACF;AAAA,MACF,GAAG,YAAY;AAAA,MACf,eAAe,MAAM;AACnB,cAAM,cAAc,QAAQ,QAAQ,GAAG;AAEvC,YAAI,CAAC,aAAa;AAChB;AAAA,QACF;AAEA,eAAO,YAAY,WAAW;AAAA,MAChC;AAAA,MACA,cAAc,MAAM;AAClB,gBAAQ,WAAW,GAAG;AAAA,MACxB;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AAAA,IACL,eAAe;AAAA,IACf,eAAe,MAAM;AAAA,IACrB,cAAc;AAAA,EAChB;AACF;AAEA,SAAS,SACP,MACA,OAAO,KACP;AACA,MAAI,QAA8C;AAClD,MAAI;AACJ,SAAO,YAAa,MAAa;AAC/B,aAAS;AACT,QAAI,UAAU,MAAM;AAClB,cAAQ,WAAW,MAAM;AACvB,aAAK,GAAG,MAAM;AACd,gBAAQ;AAAA,MACV,GAAG,IAAI;AAAA,IACT;AAAA,EACF;AACF;AAGA,SAAS,OAAO;AAAC;","names":[]}
|
|
@@ -0,0 +1,95 @@
|
|
|
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
|
+
var src_exports = {};
|
|
20
|
+
__export(src_exports, {
|
|
21
|
+
createSyncStoragePersister: () => createSyncStoragePersister
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(src_exports);
|
|
24
|
+
function createSyncStoragePersister({
|
|
25
|
+
storage,
|
|
26
|
+
key = `REACT_QUERY_OFFLINE_CACHE`,
|
|
27
|
+
throttleTime = 1e3,
|
|
28
|
+
serialize = JSON.stringify,
|
|
29
|
+
deserialize = JSON.parse,
|
|
30
|
+
retry
|
|
31
|
+
}) {
|
|
32
|
+
if (storage) {
|
|
33
|
+
const trySave = (persistedClient) => {
|
|
34
|
+
try {
|
|
35
|
+
storage.setItem(key, serialize(persistedClient));
|
|
36
|
+
return;
|
|
37
|
+
} catch (error) {
|
|
38
|
+
return error;
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
return {
|
|
42
|
+
persistClient: throttle((persistedClient) => {
|
|
43
|
+
let client = persistedClient;
|
|
44
|
+
let error = trySave(client);
|
|
45
|
+
let errorCount = 0;
|
|
46
|
+
while (error && client) {
|
|
47
|
+
errorCount++;
|
|
48
|
+
client = retry?.({
|
|
49
|
+
persistedClient: client,
|
|
50
|
+
error,
|
|
51
|
+
errorCount
|
|
52
|
+
});
|
|
53
|
+
if (client) {
|
|
54
|
+
error = trySave(client);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}, throttleTime),
|
|
58
|
+
restoreClient: () => {
|
|
59
|
+
const cacheString = storage.getItem(key);
|
|
60
|
+
if (!cacheString) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
return deserialize(cacheString);
|
|
64
|
+
},
|
|
65
|
+
removeClient: () => {
|
|
66
|
+
storage.removeItem(key);
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
return {
|
|
71
|
+
persistClient: noop,
|
|
72
|
+
restoreClient: () => void 0,
|
|
73
|
+
removeClient: noop
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
function throttle(func, wait = 100) {
|
|
77
|
+
let timer = null;
|
|
78
|
+
let params;
|
|
79
|
+
return function(...args) {
|
|
80
|
+
params = args;
|
|
81
|
+
if (timer === null) {
|
|
82
|
+
timer = setTimeout(() => {
|
|
83
|
+
func(...params);
|
|
84
|
+
timer = null;
|
|
85
|
+
}, wait);
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
function noop() {
|
|
90
|
+
}
|
|
91
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
92
|
+
0 && (module.exports = {
|
|
93
|
+
createSyncStoragePersister
|
|
94
|
+
});
|
|
95
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistRetryer,\n PersistedClient,\n Persister,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\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: Storage | 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?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAqCO,SAAS,2BAA2B;AAAA,EACzC;AAAA,EACA,MAAM;AAAA,EACN,eAAe;AAAA,EACf,YAAY,KAAK;AAAA,EACjB,cAAc,KAAK;AAAA,EACnB;AACF,GAAiD;AAC/C,MAAI,SAAS;AACX,UAAM,UAAU,CAAC,oBAAwD;AACvE,UAAI;AACF,gBAAQ,QAAQ,KAAK,UAAU,eAAe,CAAC;AAC/C;AAAA,MACF,SAAS,OAAO;AACd,eAAO;AAAA,MACT;AAAA,IACF;AACA,WAAO;AAAA,MACL,eAAe,SAAS,CAAC,oBAAoB;AAC3C,YAAI,SAAsC;AAC1C,YAAI,QAAQ,QAAQ,MAAM;AAC1B,YAAI,aAAa;AACjB,eAAO,SAAS,QAAQ;AACtB;AACA,mBAAS,QAAQ;AAAA,YACf,iBAAiB;AAAA,YACjB;AAAA,YACA;AAAA,UACF,CAAC;AAED,cAAI,QAAQ;AACV,oBAAQ,QAAQ,MAAM;AAAA,UACxB;AAAA,QACF;AAAA,MACF,GAAG,YAAY;AAAA,MACf,eAAe,MAAM;AACnB,cAAM,cAAc,QAAQ,QAAQ,GAAG;AAEvC,YAAI,CAAC,aAAa;AAChB;AAAA,QACF;AAEA,eAAO,YAAY,WAAW;AAAA,MAChC;AAAA,MACA,cAAc,MAAM;AAClB,gBAAQ,WAAW,GAAG;AAAA,MACxB;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AAAA,IACL,eAAe;AAAA,IACf,eAAe,MAAM;AAAA,IACrB,cAAc;AAAA,EAChB;AACF;AAEA,SAAS,SACP,MACA,OAAO,KACP;AACA,MAAI,QAA8C;AAClD,MAAI;AACJ,SAAO,YAAa,MAAa;AAC/B,aAAS;AACT,QAAI,UAAU,MAAM;AAClB,cAAQ,WAAW,MAAM;AACvB,aAAK,GAAG,MAAM;AACd,gBAAQ;AAAA,MACV,GAAG,IAAI;AAAA,IACT;AAAA,EACF;AACF;AAGA,SAAS,OAAO;AAAC;","names":[]}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { Persister, PersistedClient, PersistRetryer } from '@tanstack/query-persist-client-core';
|
|
2
|
+
|
|
3
|
+
interface Storage {
|
|
4
|
+
getItem: (key: string) => string | null;
|
|
5
|
+
setItem: (key: string, value: string) => void;
|
|
6
|
+
removeItem: (key: string) => void;
|
|
7
|
+
}
|
|
8
|
+
interface CreateSyncStoragePersisterOptions {
|
|
9
|
+
/** The storage client used for setting and retrieving items from cache.
|
|
10
|
+
* For SSR pass in `undefined`. Note that window.localStorage can be
|
|
11
|
+
* `null` in Android WebViews depending on how they are configured.
|
|
12
|
+
*/
|
|
13
|
+
storage: Storage | undefined | null;
|
|
14
|
+
/** The key to use when storing the cache */
|
|
15
|
+
key?: string;
|
|
16
|
+
/** To avoid spamming,
|
|
17
|
+
* pass a time in ms to throttle saving the cache to disk */
|
|
18
|
+
throttleTime?: number;
|
|
19
|
+
/**
|
|
20
|
+
* How to serialize the data to storage.
|
|
21
|
+
* @default `JSON.stringify`
|
|
22
|
+
*/
|
|
23
|
+
serialize?: (client: PersistedClient) => string;
|
|
24
|
+
/**
|
|
25
|
+
* How to deserialize the data from storage.
|
|
26
|
+
* @default `JSON.parse`
|
|
27
|
+
*/
|
|
28
|
+
deserialize?: (cachedString: string) => PersistedClient;
|
|
29
|
+
retry?: PersistRetryer;
|
|
30
|
+
}
|
|
31
|
+
declare function createSyncStoragePersister({ storage, key, throttleTime, serialize, deserialize, retry, }: CreateSyncStoragePersisterOptions): Persister;
|
|
32
|
+
|
|
33
|
+
export { createSyncStoragePersister };
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { Persister, PersistedClient, PersistRetryer } from '@tanstack/query-persist-client-core';
|
|
2
|
+
|
|
3
|
+
interface Storage {
|
|
4
|
+
getItem: (key: string) => string | null;
|
|
5
|
+
setItem: (key: string, value: string) => void;
|
|
6
|
+
removeItem: (key: string) => void;
|
|
7
|
+
}
|
|
8
|
+
interface CreateSyncStoragePersisterOptions {
|
|
9
|
+
/** The storage client used for setting and retrieving items from cache.
|
|
10
|
+
* For SSR pass in `undefined`. Note that window.localStorage can be
|
|
11
|
+
* `null` in Android WebViews depending on how they are configured.
|
|
12
|
+
*/
|
|
13
|
+
storage: Storage | undefined | null;
|
|
14
|
+
/** The key to use when storing the cache */
|
|
15
|
+
key?: string;
|
|
16
|
+
/** To avoid spamming,
|
|
17
|
+
* pass a time in ms to throttle saving the cache to disk */
|
|
18
|
+
throttleTime?: number;
|
|
19
|
+
/**
|
|
20
|
+
* How to serialize the data to storage.
|
|
21
|
+
* @default `JSON.stringify`
|
|
22
|
+
*/
|
|
23
|
+
serialize?: (client: PersistedClient) => string;
|
|
24
|
+
/**
|
|
25
|
+
* How to deserialize the data from storage.
|
|
26
|
+
* @default `JSON.parse`
|
|
27
|
+
*/
|
|
28
|
+
deserialize?: (cachedString: string) => PersistedClient;
|
|
29
|
+
retry?: PersistRetryer;
|
|
30
|
+
}
|
|
31
|
+
declare function createSyncStoragePersister({ storage, key, throttleTime, serialize, deserialize, retry, }: CreateSyncStoragePersisterOptions): Persister;
|
|
32
|
+
|
|
33
|
+
export { createSyncStoragePersister };
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
function createSyncStoragePersister({
|
|
2
2
|
storage,
|
|
3
3
|
key = `REACT_QUERY_OFFLINE_CACHE`,
|
|
4
|
-
throttleTime =
|
|
4
|
+
throttleTime = 1e3,
|
|
5
5
|
serialize = JSON.stringify,
|
|
6
6
|
deserialize = JSON.parse,
|
|
7
7
|
retry
|
|
8
8
|
}) {
|
|
9
9
|
if (storage) {
|
|
10
|
-
const trySave = persistedClient => {
|
|
10
|
+
const trySave = (persistedClient) => {
|
|
11
11
|
try {
|
|
12
12
|
storage.setItem(key, serialize(persistedClient));
|
|
13
13
|
return;
|
|
@@ -16,7 +16,7 @@ function createSyncStoragePersister({
|
|
|
16
16
|
}
|
|
17
17
|
};
|
|
18
18
|
return {
|
|
19
|
-
persistClient: throttle(persistedClient => {
|
|
19
|
+
persistClient: throttle((persistedClient) => {
|
|
20
20
|
let client = persistedClient;
|
|
21
21
|
let error = trySave(client);
|
|
22
22
|
let errorCount = 0;
|
|
@@ -46,14 +46,14 @@ function createSyncStoragePersister({
|
|
|
46
46
|
}
|
|
47
47
|
return {
|
|
48
48
|
persistClient: noop,
|
|
49
|
-
restoreClient: () =>
|
|
49
|
+
restoreClient: () => void 0,
|
|
50
50
|
removeClient: noop
|
|
51
51
|
};
|
|
52
52
|
}
|
|
53
53
|
function throttle(func, wait = 100) {
|
|
54
54
|
let timer = null;
|
|
55
55
|
let params;
|
|
56
|
-
return function
|
|
56
|
+
return function(...args) {
|
|
57
57
|
params = args;
|
|
58
58
|
if (timer === null) {
|
|
59
59
|
timer = setTimeout(() => {
|
|
@@ -63,9 +63,9 @@ function throttle(func, wait = 100) {
|
|
|
63
63
|
}
|
|
64
64
|
};
|
|
65
65
|
}
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
//# sourceMappingURL=index.js.map
|
|
66
|
+
function noop() {
|
|
67
|
+
}
|
|
68
|
+
export {
|
|
69
|
+
createSyncStoragePersister
|
|
70
|
+
};
|
|
71
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistRetryer,\n PersistedClient,\n Persister,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\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: Storage | 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?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"mappings":"AAqCO,SAAS,2BAA2B;AAAA,EACzC;AAAA,EACA,MAAM;AAAA,EACN,eAAe;AAAA,EACf,YAAY,KAAK;AAAA,EACjB,cAAc,KAAK;AAAA,EACnB;AACF,GAAiD;AAC/C,MAAI,SAAS;AACX,UAAM,UAAU,CAAC,oBAAwD;AACvE,UAAI;AACF,gBAAQ,QAAQ,KAAK,UAAU,eAAe,CAAC;AAC/C;AAAA,MACF,SAAS,OAAO;AACd,eAAO;AAAA,MACT;AAAA,IACF;AACA,WAAO;AAAA,MACL,eAAe,SAAS,CAAC,oBAAoB;AAC3C,YAAI,SAAsC;AAC1C,YAAI,QAAQ,QAAQ,MAAM;AAC1B,YAAI,aAAa;AACjB,eAAO,SAAS,QAAQ;AACtB;AACA,mBAAS,QAAQ;AAAA,YACf,iBAAiB;AAAA,YACjB;AAAA,YACA;AAAA,UACF,CAAC;AAED,cAAI,QAAQ;AACV,oBAAQ,QAAQ,MAAM;AAAA,UACxB;AAAA,QACF;AAAA,MACF,GAAG,YAAY;AAAA,MACf,eAAe,MAAM;AACnB,cAAM,cAAc,QAAQ,QAAQ,GAAG;AAEvC,YAAI,CAAC,aAAa;AAChB;AAAA,QACF;AAEA,eAAO,YAAY,WAAW;AAAA,MAChC;AAAA,MACA,cAAc,MAAM;AAClB,gBAAQ,WAAW,GAAG;AAAA,MACxB;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AAAA,IACL,eAAe;AAAA,IACf,eAAe,MAAM;AAAA,IACrB,cAAc;AAAA,EAChB;AACF;AAEA,SAAS,SACP,MACA,OAAO,KACP;AACA,MAAI,QAA8C;AAClD,MAAI;AACJ,SAAO,YAAa,MAAa;AAC/B,aAAS;AACT,QAAI,UAAU,MAAM;AAClB,cAAQ,WAAW,MAAM;AACvB,aAAK,GAAG,MAAM;AACd,gBAAQ;AAAA,MACV,GAAG,IAAI;AAAA,IACT;AAAA,EACF;AACF;AAGA,SAAS,OAAO;AAAC;","names":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tanstack/query-sync-storage-persister",
|
|
3
|
-
"version": "5.0.0-alpha.
|
|
3
|
+
"version": "5.0.0-alpha.87",
|
|
4
4
|
"description": "A persister for synchronous storages, to be used with TanStack/Query",
|
|
5
5
|
"author": "tannerlinsley",
|
|
6
6
|
"license": "MIT",
|
|
@@ -11,26 +11,30 @@
|
|
|
11
11
|
"url": "https://github.com/sponsors/tannerlinsley"
|
|
12
12
|
},
|
|
13
13
|
"type": "module",
|
|
14
|
-
"types": "build/
|
|
15
|
-
"main": "build/
|
|
16
|
-
"module": "build/
|
|
14
|
+
"types": "build/legacy/index.d.ts",
|
|
15
|
+
"main": "build/legacy/index.cjs",
|
|
16
|
+
"module": "build/legacy/index.js",
|
|
17
17
|
"exports": {
|
|
18
18
|
".": {
|
|
19
|
-
"
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
19
|
+
"import": {
|
|
20
|
+
"types": "./build/modern/index.d.ts",
|
|
21
|
+
"default": "./build/modern/index.js"
|
|
22
|
+
},
|
|
23
|
+
"require": {
|
|
24
|
+
"types": "./build/modern/index.d.cts",
|
|
25
|
+
"default": "./build/modern/index.cjs"
|
|
26
|
+
}
|
|
23
27
|
},
|
|
24
28
|
"./package.json": "./package.json"
|
|
25
29
|
},
|
|
26
30
|
"sideEffects": false,
|
|
27
31
|
"files": [
|
|
28
|
-
"build
|
|
32
|
+
"build",
|
|
29
33
|
"src"
|
|
30
34
|
],
|
|
31
35
|
"dependencies": {
|
|
32
|
-
"@tanstack/query-core": "5.0.0-alpha.
|
|
33
|
-
"@tanstack/query-persist-client-core": "5.0.0-alpha.
|
|
36
|
+
"@tanstack/query-core": "5.0.0-alpha.87",
|
|
37
|
+
"@tanstack/query-persist-client-core": "5.0.0-alpha.87"
|
|
34
38
|
},
|
|
35
39
|
"scripts": {
|
|
36
40
|
"clean": "rimraf ./build && rimraf ./coverage",
|
|
@@ -38,9 +42,7 @@
|
|
|
38
42
|
"test:types": "tsc --noEmit",
|
|
39
43
|
"test:lib": "vitest run --coverage",
|
|
40
44
|
"test:lib:dev": "pnpm run test:lib --watch",
|
|
41
|
-
"test:build": "publint --strict",
|
|
42
|
-
"build": "
|
|
43
|
-
"build:rollup": "rollup --config rollup.config.js",
|
|
44
|
-
"build:types": "tsc --emitDeclarationOnly"
|
|
45
|
+
"test:build": "publint --strict && attw --pack",
|
|
46
|
+
"build": "tsup"
|
|
45
47
|
}
|
|
46
48
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"storageIsFull.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/storageIsFull.test.ts"],"names":[],"mappings":""}
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
package/build/lib/index.cjs
DELETED
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
function createSyncStoragePersister({
|
|
4
|
-
storage,
|
|
5
|
-
key = `REACT_QUERY_OFFLINE_CACHE`,
|
|
6
|
-
throttleTime = 1000,
|
|
7
|
-
serialize = JSON.stringify,
|
|
8
|
-
deserialize = JSON.parse,
|
|
9
|
-
retry
|
|
10
|
-
}) {
|
|
11
|
-
if (storage) {
|
|
12
|
-
const trySave = persistedClient => {
|
|
13
|
-
try {
|
|
14
|
-
storage.setItem(key, serialize(persistedClient));
|
|
15
|
-
return;
|
|
16
|
-
} catch (error) {
|
|
17
|
-
return error;
|
|
18
|
-
}
|
|
19
|
-
};
|
|
20
|
-
return {
|
|
21
|
-
persistClient: throttle(persistedClient => {
|
|
22
|
-
let client = persistedClient;
|
|
23
|
-
let error = trySave(client);
|
|
24
|
-
let errorCount = 0;
|
|
25
|
-
while (error && client) {
|
|
26
|
-
errorCount++;
|
|
27
|
-
client = retry?.({
|
|
28
|
-
persistedClient: client,
|
|
29
|
-
error,
|
|
30
|
-
errorCount
|
|
31
|
-
});
|
|
32
|
-
if (client) {
|
|
33
|
-
error = trySave(client);
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
}, throttleTime),
|
|
37
|
-
restoreClient: () => {
|
|
38
|
-
const cacheString = storage.getItem(key);
|
|
39
|
-
if (!cacheString) {
|
|
40
|
-
return;
|
|
41
|
-
}
|
|
42
|
-
return deserialize(cacheString);
|
|
43
|
-
},
|
|
44
|
-
removeClient: () => {
|
|
45
|
-
storage.removeItem(key);
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
}
|
|
49
|
-
return {
|
|
50
|
-
persistClient: noop,
|
|
51
|
-
restoreClient: () => undefined,
|
|
52
|
-
removeClient: noop
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
function throttle(func, wait = 100) {
|
|
56
|
-
let timer = null;
|
|
57
|
-
let params;
|
|
58
|
-
return function (...args) {
|
|
59
|
-
params = args;
|
|
60
|
-
if (timer === null) {
|
|
61
|
-
timer = setTimeout(() => {
|
|
62
|
-
func(...params);
|
|
63
|
-
timer = null;
|
|
64
|
-
}, wait);
|
|
65
|
-
}
|
|
66
|
-
};
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
70
|
-
function noop() {}
|
|
71
|
-
|
|
72
|
-
exports.createSyncStoragePersister = createSyncStoragePersister;
|
|
73
|
-
//# sourceMappingURL=index.cjs.map
|
package/build/lib/index.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistRetryer,\n PersistedClient,\n Persister,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\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: Storage | 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?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createSyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","throttle","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","noop","undefined","func","wait","timer","params","args","setTimeout"],"mappings":";;AAqCO,SAASA,0BAA0BA,CAAC;EACzCC,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;AACiC,CAAC,EAAa;AAC/C,EAAA,IAAIR,OAAO,EAAE;IACX,MAAMS,OAAO,GAAIC,eAAgC,IAAwB;MACvE,IAAI;QACFV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AAChD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IACD,OAAO;AACLC,MAAAA,aAAa,EAAEC,QAAQ,CAAEJ,eAAe,IAAK;QAC3C,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;QAC3B,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;UACZD,MAAM,GAAGP,KAAK,GAAG;AACfE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;AACzB,WAAA;AACF,SAAA;OACD,EAAEb,YAAY,CAAC;MAChBe,aAAa,EAAEA,MAAM;AACnB,QAAA,MAAMC,WAAW,GAAGlB,OAAO,CAACmB,OAAO,CAAClB,GAAG,CAAC,CAAA;QAExC,IAAI,CAACiB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOZ,WAAW,CAACY,WAAW,CAAC,CAAA;OAChC;MACDE,YAAY,EAAEA,MAAM;AAClBpB,QAAAA,OAAO,CAACqB,UAAU,CAACpB,GAAG,CAAC,CAAA;AACzB,OAAA;KACD,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAES,IAAI;IACnBL,aAAa,EAAEA,MAAMM,SAAS;AAC9BH,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,CAAA;AAEA,SAASR,QAAQA,CACfU,IAA6B,EAC7BC,IAAI,GAAG,GAAG,EACV;EACA,IAAIC,KAA2C,GAAG,IAAI,CAAA;AACtD,EAAA,IAAIC,MAAa,CAAA;EACjB,OAAO,UAAU,GAAGC,IAAW,EAAE;AAC/BD,IAAAA,MAAM,GAAGC,IAAI,CAAA;IACb,IAAIF,KAAK,KAAK,IAAI,EAAE;MAClBA,KAAK,GAAGG,UAAU,CAAC,MAAM;QACvBL,IAAI,CAAC,GAAGG,MAAM,CAAC,CAAA;AACfD,QAAAA,KAAK,GAAG,IAAI,CAAA;OACb,EAAED,IAAI,CAAC,CAAA;AACV,KAAA;GACD,CAAA;AACH,CAAA;;AAEA;AACA,SAASH,IAAIA,GAAG;;;;"}
|
package/build/lib/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,cAAc,EACd,eAAe,EACf,SAAS,EACV,MAAM,qCAAqC,CAAA;AAE5C,UAAU,OAAO;IACf,OAAO,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,MAAM,GAAG,IAAI,CAAA;IACvC,OAAO,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IAC7C,UAAU,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAA;CAClC;AAED,UAAU,iCAAiC;IACzC;;;OAGG;IACH,OAAO,EAAE,OAAO,GAAG,SAAS,GAAG,IAAI,CAAA;IACnC,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,cAAc,CAAA;CACvB;AAED,wBAAgB,0BAA0B,CAAC,EACzC,OAAO,EACP,GAAiC,EACjC,YAAmB,EACnB,SAA0B,EAC1B,WAAwB,EACxB,KAAK,GACN,EAAE,iCAAiC,GAAG,SAAS,CAgD/C"}
|
package/build/lib/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistRetryer,\n PersistedClient,\n Persister,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\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: Storage | 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?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createSyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","throttle","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","noop","undefined","func","wait","timer","params","args","setTimeout"],"mappings":"AAqCO,SAASA,0BAA0BA,CAAC;EACzCC,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;AACiC,CAAC,EAAa;AAC/C,EAAA,IAAIR,OAAO,EAAE;IACX,MAAMS,OAAO,GAAIC,eAAgC,IAAwB;MACvE,IAAI;QACFV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AAChD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IACD,OAAO;AACLC,MAAAA,aAAa,EAAEC,QAAQ,CAAEJ,eAAe,IAAK;QAC3C,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;QAC3B,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;UACZD,MAAM,GAAGP,KAAK,GAAG;AACfE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;AACzB,WAAA;AACF,SAAA;OACD,EAAEb,YAAY,CAAC;MAChBe,aAAa,EAAEA,MAAM;AACnB,QAAA,MAAMC,WAAW,GAAGlB,OAAO,CAACmB,OAAO,CAAClB,GAAG,CAAC,CAAA;QAExC,IAAI,CAACiB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOZ,WAAW,CAACY,WAAW,CAAC,CAAA;OAChC;MACDE,YAAY,EAAEA,MAAM;AAClBpB,QAAAA,OAAO,CAACqB,UAAU,CAACpB,GAAG,CAAC,CAAA;AACzB,OAAA;KACD,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAES,IAAI;IACnBL,aAAa,EAAEA,MAAMM,SAAS;AAC9BH,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,CAAA;AAEA,SAASR,QAAQA,CACfU,IAA6B,EAC7BC,IAAI,GAAG,GAAG,EACV;EACA,IAAIC,KAA2C,GAAG,IAAI,CAAA;AACtD,EAAA,IAAIC,MAAa,CAAA;EACjB,OAAO,UAAU,GAAGC,IAAW,EAAE;AAC/BD,IAAAA,MAAM,GAAGC,IAAI,CAAA;IACb,IAAIF,KAAK,KAAK,IAAI,EAAE;MAClBA,KAAK,GAAGG,UAAU,CAAC,MAAM;QACvBL,IAAI,CAAC,GAAGG,MAAM,CAAC,CAAA;AACfD,QAAAA,KAAK,GAAG,IAAI,CAAA;OACb,EAAED,IAAI,CAAC,CAAA;AACV,KAAA;GACD,CAAA;AACH,CAAA;;AAEA;AACA,SAASH,IAAIA,GAAG;;;;"}
|
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
function createSyncStoragePersister({
|
|
4
|
-
storage,
|
|
5
|
-
key = `REACT_QUERY_OFFLINE_CACHE`,
|
|
6
|
-
throttleTime = 1000,
|
|
7
|
-
serialize = JSON.stringify,
|
|
8
|
-
deserialize = JSON.parse,
|
|
9
|
-
retry
|
|
10
|
-
}) {
|
|
11
|
-
if (storage) {
|
|
12
|
-
const trySave = persistedClient => {
|
|
13
|
-
try {
|
|
14
|
-
storage.setItem(key, serialize(persistedClient));
|
|
15
|
-
return;
|
|
16
|
-
} catch (error) {
|
|
17
|
-
return error;
|
|
18
|
-
}
|
|
19
|
-
};
|
|
20
|
-
return {
|
|
21
|
-
persistClient: throttle(persistedClient => {
|
|
22
|
-
let client = persistedClient;
|
|
23
|
-
let error = trySave(client);
|
|
24
|
-
let errorCount = 0;
|
|
25
|
-
while (error && client) {
|
|
26
|
-
errorCount++;
|
|
27
|
-
client = retry == null ? void 0 : retry({
|
|
28
|
-
persistedClient: client,
|
|
29
|
-
error,
|
|
30
|
-
errorCount
|
|
31
|
-
});
|
|
32
|
-
if (client) {
|
|
33
|
-
error = trySave(client);
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
}, throttleTime),
|
|
37
|
-
restoreClient: () => {
|
|
38
|
-
const cacheString = storage.getItem(key);
|
|
39
|
-
if (!cacheString) {
|
|
40
|
-
return;
|
|
41
|
-
}
|
|
42
|
-
return deserialize(cacheString);
|
|
43
|
-
},
|
|
44
|
-
removeClient: () => {
|
|
45
|
-
storage.removeItem(key);
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
}
|
|
49
|
-
return {
|
|
50
|
-
persistClient: noop,
|
|
51
|
-
restoreClient: () => undefined,
|
|
52
|
-
removeClient: noop
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
function throttle(func, wait = 100) {
|
|
56
|
-
let timer = null;
|
|
57
|
-
let params;
|
|
58
|
-
return function (...args) {
|
|
59
|
-
params = args;
|
|
60
|
-
if (timer === null) {
|
|
61
|
-
timer = setTimeout(() => {
|
|
62
|
-
func(...params);
|
|
63
|
-
timer = null;
|
|
64
|
-
}, wait);
|
|
65
|
-
}
|
|
66
|
-
};
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
70
|
-
function noop() {}
|
|
71
|
-
|
|
72
|
-
exports.createSyncStoragePersister = createSyncStoragePersister;
|
|
73
|
-
//# sourceMappingURL=index.legacy.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.legacy.cjs","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistRetryer,\n PersistedClient,\n Persister,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\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: Storage | 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?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createSyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","throttle","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","noop","undefined","func","wait","timer","params","args","setTimeout"],"mappings":";;AAqCO,SAASA,0BAA0BA,CAAC;EACzCC,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;AACiC,CAAC,EAAa;AAC/C,EAAA,IAAIR,OAAO,EAAE;IACX,MAAMS,OAAO,GAAIC,eAAgC,IAAwB;MACvE,IAAI;QACFV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AAChD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IACD,OAAO;AACLC,MAAAA,aAAa,EAAEC,QAAQ,CAAEJ,eAAe,IAAK;QAC3C,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;QAC3B,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;AACZD,UAAAA,MAAM,GAAGP,KAAK,IAALA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,KAAK,CAAG;AACfE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;AACzB,WAAA;AACF,SAAA;OACD,EAAEb,YAAY,CAAC;MAChBe,aAAa,EAAEA,MAAM;AACnB,QAAA,MAAMC,WAAW,GAAGlB,OAAO,CAACmB,OAAO,CAAClB,GAAG,CAAC,CAAA;QAExC,IAAI,CAACiB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOZ,WAAW,CAACY,WAAW,CAAC,CAAA;OAChC;MACDE,YAAY,EAAEA,MAAM;AAClBpB,QAAAA,OAAO,CAACqB,UAAU,CAACpB,GAAG,CAAC,CAAA;AACzB,OAAA;KACD,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAES,IAAI;IACnBL,aAAa,EAAEA,MAAMM,SAAS;AAC9BH,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,CAAA;AAEA,SAASR,QAAQA,CACfU,IAA6B,EAC7BC,IAAI,GAAG,GAAG,EACV;EACA,IAAIC,KAA2C,GAAG,IAAI,CAAA;AACtD,EAAA,IAAIC,MAAa,CAAA;EACjB,OAAO,UAAU,GAAGC,IAAW,EAAE;AAC/BD,IAAAA,MAAM,GAAGC,IAAI,CAAA;IACb,IAAIF,KAAK,KAAK,IAAI,EAAE;MAClBA,KAAK,GAAGG,UAAU,CAAC,MAAM;QACvBL,IAAI,CAAC,GAAGG,MAAM,CAAC,CAAA;AACfD,QAAAA,KAAK,GAAG,IAAI,CAAA;OACb,EAAED,IAAI,CAAC,CAAA;AACV,KAAA;GACD,CAAA;AACH,CAAA;;AAEA;AACA,SAASH,IAAIA,GAAG;;;;"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.legacy.js","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistRetryer,\n PersistedClient,\n Persister,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\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: Storage | 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?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createSyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","throttle","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","noop","undefined","func","wait","timer","params","args","setTimeout"],"mappings":"AAqCO,SAASA,0BAA0BA,CAAC;EACzCC,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;AACiC,CAAC,EAAa;AAC/C,EAAA,IAAIR,OAAO,EAAE;IACX,MAAMS,OAAO,GAAIC,eAAgC,IAAwB;MACvE,IAAI;QACFV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AAChD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IACD,OAAO;AACLC,MAAAA,aAAa,EAAEC,QAAQ,CAAEJ,eAAe,IAAK;QAC3C,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;QAC3B,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;AACZD,UAAAA,MAAM,GAAGP,KAAK,IAALA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,KAAK,CAAG;AACfE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;AACzB,WAAA;AACF,SAAA;OACD,EAAEb,YAAY,CAAC;MAChBe,aAAa,EAAEA,MAAM;AACnB,QAAA,MAAMC,WAAW,GAAGlB,OAAO,CAACmB,OAAO,CAAClB,GAAG,CAAC,CAAA;QAExC,IAAI,CAACiB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOZ,WAAW,CAACY,WAAW,CAAC,CAAA;OAChC;MACDE,YAAY,EAAEA,MAAM;AAClBpB,QAAAA,OAAO,CAACqB,UAAU,CAACpB,GAAG,CAAC,CAAA;AACzB,OAAA;KACD,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAES,IAAI;IACnBL,aAAa,EAAEA,MAAMM,SAAS;AAC9BH,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,CAAA;AAEA,SAASR,QAAQA,CACfU,IAA6B,EAC7BC,IAAI,GAAG,GAAG,EACV;EACA,IAAIC,KAA2C,GAAG,IAAI,CAAA;AACtD,EAAA,IAAIC,MAAa,CAAA;EACjB,OAAO,UAAU,GAAGC,IAAW,EAAE;AAC/BD,IAAAA,MAAM,GAAGC,IAAI,CAAA;IACb,IAAIF,KAAK,KAAK,IAAI,EAAE;MAClBA,KAAK,GAAGG,UAAU,CAAC,MAAM;QACvBL,IAAI,CAAC,GAAGG,MAAM,CAAC,CAAA;AACfD,QAAAA,KAAK,GAAG,IAAI,CAAA;OACb,EAAED,IAAI,CAAC,CAAA;AACV,KAAA;GACD,CAAA;AACH,CAAA;;AAEA;AACA,SAASH,IAAIA,GAAG;;;;"}
|