@tanstack/react-query-persist-client 5.0.0-alpha.47 → 5.0.0-alpha.49
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/package.json +2 -2
- package/build/lib/PersistQueryClientProvider.esm.js +0 -54
- package/build/lib/PersistQueryClientProvider.esm.js.map +0 -1
- package/build/lib/_virtual/_rollupPluginBabelHelpers.esm.js +0 -17
- package/build/lib/_virtual/_rollupPluginBabelHelpers.esm.js.map +0 -1
- package/build/lib/index.esm.js +0 -3
- package/build/lib/index.esm.js.map +0 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tanstack/react-query-persist-client",
|
|
3
|
-
"version": "5.0.0-alpha.
|
|
3
|
+
"version": "5.0.0-alpha.49",
|
|
4
4
|
"description": "React bindings to work with persisters in TanStack/react-query",
|
|
5
5
|
"author": "tannerlinsley",
|
|
6
6
|
"license": "MIT",
|
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
"type": "commonjs",
|
|
14
14
|
"types": "build/lib/index.d.ts",
|
|
15
15
|
"main": "build/lib/index.js",
|
|
16
|
-
"module": "build/lib/index.
|
|
16
|
+
"module": "build/lib/index.mjs",
|
|
17
17
|
"exports": {
|
|
18
18
|
".": {
|
|
19
19
|
"types": "./build/lib/index.d.ts",
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
import { extends as _extends } from './_virtual/_rollupPluginBabelHelpers.esm.js';
|
|
3
|
-
import * as React from 'react';
|
|
4
|
-
import { persistQueryClient } from '@tanstack/query-persist-client-core';
|
|
5
|
-
import { QueryClientProvider, IsRestoringProvider } from '@tanstack/react-query';
|
|
6
|
-
|
|
7
|
-
const PersistQueryClientProvider = ({
|
|
8
|
-
client,
|
|
9
|
-
children,
|
|
10
|
-
persistOptions,
|
|
11
|
-
onSuccess,
|
|
12
|
-
...props
|
|
13
|
-
}) => {
|
|
14
|
-
const [isRestoring, setIsRestoring] = React.useState(true);
|
|
15
|
-
const refs = React.useRef({
|
|
16
|
-
persistOptions,
|
|
17
|
-
onSuccess
|
|
18
|
-
});
|
|
19
|
-
React.useEffect(() => {
|
|
20
|
-
refs.current = {
|
|
21
|
-
persistOptions,
|
|
22
|
-
onSuccess
|
|
23
|
-
};
|
|
24
|
-
});
|
|
25
|
-
React.useEffect(() => {
|
|
26
|
-
let isStale = false;
|
|
27
|
-
setIsRestoring(true);
|
|
28
|
-
const [unsubscribe, promise] = persistQueryClient({
|
|
29
|
-
...refs.current.persistOptions,
|
|
30
|
-
queryClient: client
|
|
31
|
-
});
|
|
32
|
-
promise.then(async () => {
|
|
33
|
-
if (!isStale) {
|
|
34
|
-
try {
|
|
35
|
-
await (refs.current.onSuccess == null ? void 0 : refs.current.onSuccess());
|
|
36
|
-
} finally {
|
|
37
|
-
setIsRestoring(false);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
});
|
|
41
|
-
return () => {
|
|
42
|
-
isStale = true;
|
|
43
|
-
unsubscribe();
|
|
44
|
-
};
|
|
45
|
-
}, [client]);
|
|
46
|
-
return /*#__PURE__*/React.createElement(QueryClientProvider, _extends({
|
|
47
|
-
client: client
|
|
48
|
-
}, props), /*#__PURE__*/React.createElement(IsRestoringProvider, {
|
|
49
|
-
value: isRestoring
|
|
50
|
-
}, children));
|
|
51
|
-
};
|
|
52
|
-
|
|
53
|
-
export { PersistQueryClientProvider };
|
|
54
|
-
//# sourceMappingURL=PersistQueryClientProvider.esm.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PersistQueryClientProvider.esm.js","sources":["../../src/PersistQueryClientProvider.tsx"],"sourcesContent":["'use client'\nimport * as React from 'react'\n\nimport type { PersistQueryClientOptions } from '@tanstack/query-persist-client-core'\nimport { persistQueryClient } from '@tanstack/query-persist-client-core'\nimport type { QueryClientProviderProps } from '@tanstack/react-query'\nimport { QueryClientProvider, IsRestoringProvider } from '@tanstack/react-query'\n\nexport type PersistQueryClientProviderProps = QueryClientProviderProps & {\n persistOptions: Omit<PersistQueryClientOptions, 'queryClient'>\n onSuccess?: () => Promise<unknown> | unknown\n}\n\nexport const PersistQueryClientProvider = ({\n client,\n children,\n persistOptions,\n onSuccess,\n ...props\n}: PersistQueryClientProviderProps): JSX.Element => {\n const [isRestoring, setIsRestoring] = React.useState(true)\n const refs = React.useRef({ persistOptions, onSuccess })\n\n React.useEffect(() => {\n refs.current = { persistOptions, onSuccess }\n })\n\n React.useEffect(() => {\n let isStale = false\n setIsRestoring(true)\n const [unsubscribe, promise] = persistQueryClient({\n ...refs.current.persistOptions,\n queryClient: client,\n })\n\n promise.then(async () => {\n if (!isStale) {\n try {\n await refs.current.onSuccess?.()\n } finally {\n setIsRestoring(false)\n }\n }\n })\n\n return () => {\n isStale = true\n unsubscribe()\n }\n }, [client])\n\n return (\n <QueryClientProvider client={client} {...props}>\n <IsRestoringProvider value={isRestoring}>{children}</IsRestoringProvider>\n </QueryClientProvider>\n )\n}\n"],"names":["onSuccess","queryClient","isStale","unsubscribe","client","value"],"mappings":";;;;;;AAaO;;;;;;AAM0B;;AAE/B;;AAA4CA;AAAU;;;;AAGnBA;;AACnC;;;;AAKE;AACE;AACAC;AACF;;;;AAKM;AACF;;AAEA;AACF;AACF;AAEA;AACEC;AACAC;;AAEJ;AAEA;AACuBC;AAAe;AACbC;;AAG3B;;"}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
function _extends() {
|
|
2
|
-
_extends = Object.assign ? Object.assign.bind() : function (target) {
|
|
3
|
-
for (var i = 1; i < arguments.length; i++) {
|
|
4
|
-
var source = arguments[i];
|
|
5
|
-
for (var key in source) {
|
|
6
|
-
if (Object.prototype.hasOwnProperty.call(source, key)) {
|
|
7
|
-
target[key] = source[key];
|
|
8
|
-
}
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
return target;
|
|
12
|
-
};
|
|
13
|
-
return _extends.apply(this, arguments);
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export { _extends as extends };
|
|
17
|
-
//# sourceMappingURL=_rollupPluginBabelHelpers.esm.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"_rollupPluginBabelHelpers.esm.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;"}
|
package/build/lib/index.esm.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.esm.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|