tanstack-query-callbacks 0.1.0-beta.0 → 0.2.0
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/README.md +80 -1
- package/dist/react/index.cjs +6 -3
- package/dist/react/index.d.cts +6 -1
- package/dist/react/index.d.mts +6 -1
- package/dist/react/index.d.ts +6 -1
- package/dist/react/index.mjs +5 -2
- package/dist/vue/index.cjs +2 -2
- package/dist/vue/index.d.cts +1 -1
- package/dist/vue/index.d.mts +1 -1
- package/dist/vue/index.d.ts +1 -1
- package/dist/vue/index.mjs +1 -1
- package/package.json +51 -37
- /package/dist/{index.cjs → core/index.cjs} +0 -0
- /package/dist/{index.d.cts → core/index.d.cts} +0 -0
- /package/dist/{index.d.mts → core/index.d.mts} +0 -0
- /package/dist/{index.d.ts → core/index.d.ts} +0 -0
- /package/dist/{index.mjs → core/index.mjs} +0 -0
package/README.md
CHANGED
|
@@ -1,3 +1,82 @@
|
|
|
1
1
|
# tanstack-query-callbacks
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
[![npm version][npm-version-src]][npm-version-href]
|
|
4
|
+
[![npm downloads][npm-downloads-src]][npm-downloads-href]
|
|
5
|
+
[![bundle][bundle-src]][bundle-href]
|
|
6
|
+
[![coverage][coverage-src]][coverage-href]
|
|
7
|
+
|
|
8
|
+
Use callbacks of query in the usual way, as before.
|
|
9
|
+
|
|
10
|
+
The tanstack/query has removed `onSuccess`, `onError` and `onSettled` from useQuery in v5. You can find more information in the [RFC](https://github.com/TanStack/query/discussions/5279).
|
|
11
|
+
|
|
12
|
+
# Features
|
|
13
|
+
|
|
14
|
+
- Support Tanstack/Query v4, v5
|
|
15
|
+
- Support Vue, React
|
|
16
|
+
|
|
17
|
+
## Instanll
|
|
18
|
+
|
|
19
|
+
```shell
|
|
20
|
+
// use npm
|
|
21
|
+
npm install tanstack-query-callbacks
|
|
22
|
+
|
|
23
|
+
// use pnpm
|
|
24
|
+
pnpm add tanstack-query-callbacks
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
## Usage (Vue)
|
|
28
|
+
|
|
29
|
+
```vue
|
|
30
|
+
<script setup lang="ts">
|
|
31
|
+
import { useQuery } from '@tanstack/vue-query'
|
|
32
|
+
import { useQueryCallbacks } from 'tanstack-query-callbacks/vue'
|
|
33
|
+
const queryKey = ['foo']
|
|
34
|
+
const query = useQuery(queryKey, () => Promise.resolve('bar'))
|
|
35
|
+
useQueryCallbacks({
|
|
36
|
+
queryKey,
|
|
37
|
+
onSuccess: (data) => {
|
|
38
|
+
console.log('success', data)
|
|
39
|
+
},
|
|
40
|
+
onError: (err) => {
|
|
41
|
+
console.error('error', err)
|
|
42
|
+
},
|
|
43
|
+
onSettled: (data, err) => {
|
|
44
|
+
console.log('settled', { data, err })
|
|
45
|
+
}
|
|
46
|
+
})
|
|
47
|
+
</script>
|
|
48
|
+
```
|
|
49
|
+
|
|
50
|
+
## Usage (React)
|
|
51
|
+
|
|
52
|
+
```ts
|
|
53
|
+
import { useQuery } from '@tanstack/react-query'
|
|
54
|
+
import { useQueryCallbacks } from 'tanstack-query-callbacks/react'
|
|
55
|
+
|
|
56
|
+
const queryKey = ['foo']
|
|
57
|
+
const query = useQuery(queryKey, () => Promise.resolve('bar'))
|
|
58
|
+
|
|
59
|
+
useQueryCallbacks({
|
|
60
|
+
queryKey,
|
|
61
|
+
onSuccess: (data) => {
|
|
62
|
+
console.log('success', data)
|
|
63
|
+
},
|
|
64
|
+
onError: (err) => {
|
|
65
|
+
console.error('error', err)
|
|
66
|
+
},
|
|
67
|
+
onSettled: (data, err) => {
|
|
68
|
+
console.log('settled', { data, err })
|
|
69
|
+
}
|
|
70
|
+
})
|
|
71
|
+
```
|
|
72
|
+
|
|
73
|
+
<!-- Link Resources -->
|
|
74
|
+
|
|
75
|
+
[npm-version-src]: https://img.shields.io/npm/v/tanstack-query-callbacks?style=flat&colorA=18181B&colorB=F0DB4F
|
|
76
|
+
[npm-version-href]: https://npmjs.com/package/tanstack-query-callbacks
|
|
77
|
+
[npm-downloads-src]: https://img.shields.io/npm/dm/tanstack-query-callbacks?style=flat&colorA=18181B&colorB=F0DB4F
|
|
78
|
+
[npm-downloads-href]: https://npmjs.com/package/tanstack-query-callbacks
|
|
79
|
+
[bundle-src]: https://img.shields.io/bundlephobia/minzip/tanstack-query-callbacks?style=flat&colorA=18181B&colorB=F0DB4F
|
|
80
|
+
[bundle-href]: https://bundlephobia.com/result?p=tanstack-query-callbacks
|
|
81
|
+
[coverage-src]: https://img.shields.io/codecov/c/gh/aa900031/tanstack-query-callbacks?token=AG56Z6EP8U&logo=codecov&color=F0DB4F
|
|
82
|
+
[coverage-href]: https://codecov.io/gh/aa900031/tanstack-query-callbacks
|
package/dist/react/index.cjs
CHANGED
|
@@ -2,13 +2,16 @@
|
|
|
2
2
|
|
|
3
3
|
const react = require('react');
|
|
4
4
|
const reactQuery = require('@tanstack/react-query');
|
|
5
|
-
const
|
|
5
|
+
const core_index = require('../core/index.cjs');
|
|
6
6
|
require('@tanstack/query-core');
|
|
7
7
|
|
|
8
8
|
function useQueryCallbacks(props) {
|
|
9
|
-
const queryClient = reactQuery.useQueryClient(
|
|
9
|
+
const queryClient = reactQuery.useQueryClient(
|
|
10
|
+
props.context ? { context: props.context } : props.queryClient
|
|
11
|
+
// for v5
|
|
12
|
+
);
|
|
10
13
|
react.useEffect(() => {
|
|
11
|
-
return
|
|
14
|
+
return core_index.subscribeQueryCallbacks({
|
|
12
15
|
queryClient,
|
|
13
16
|
queryKey: props.queryKey,
|
|
14
17
|
onSuccess: props.onSuccess,
|
package/dist/react/index.d.cts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import { Context } from 'react';
|
|
1
2
|
import { QueryKey, QueryClient } from '@tanstack/react-query';
|
|
2
|
-
import { QueryCallbacks } from '../index.cjs';
|
|
3
|
+
import { QueryCallbacks } from '../core/index.cjs';
|
|
3
4
|
import '@tanstack/query-core';
|
|
4
5
|
|
|
5
6
|
interface UseQueryCallbacksProps<TQueryFnData, TError> extends QueryCallbacks<TQueryFnData, TError> {
|
|
@@ -8,6 +9,10 @@ interface UseQueryCallbacksProps<TQueryFnData, TError> extends QueryCallbacks<TQ
|
|
|
8
9
|
* QueryClient instance
|
|
9
10
|
*/
|
|
10
11
|
queryClient?: QueryClient;
|
|
12
|
+
/**
|
|
13
|
+
* QueryClient context for v4
|
|
14
|
+
*/
|
|
15
|
+
context?: Context<QueryClient | undefined>;
|
|
11
16
|
}
|
|
12
17
|
declare function useQueryCallbacks<TQueryFnData = unknown, TError = unknown>(props: UseQueryCallbacksProps<TQueryFnData, TError>): void;
|
|
13
18
|
|
package/dist/react/index.d.mts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import { Context } from 'react';
|
|
1
2
|
import { QueryKey, QueryClient } from '@tanstack/react-query';
|
|
2
|
-
import { QueryCallbacks } from '../index.mjs';
|
|
3
|
+
import { QueryCallbacks } from '../core/index.mjs';
|
|
3
4
|
import '@tanstack/query-core';
|
|
4
5
|
|
|
5
6
|
interface UseQueryCallbacksProps<TQueryFnData, TError> extends QueryCallbacks<TQueryFnData, TError> {
|
|
@@ -8,6 +9,10 @@ interface UseQueryCallbacksProps<TQueryFnData, TError> extends QueryCallbacks<TQ
|
|
|
8
9
|
* QueryClient instance
|
|
9
10
|
*/
|
|
10
11
|
queryClient?: QueryClient;
|
|
12
|
+
/**
|
|
13
|
+
* QueryClient context for v4
|
|
14
|
+
*/
|
|
15
|
+
context?: Context<QueryClient | undefined>;
|
|
11
16
|
}
|
|
12
17
|
declare function useQueryCallbacks<TQueryFnData = unknown, TError = unknown>(props: UseQueryCallbacksProps<TQueryFnData, TError>): void;
|
|
13
18
|
|
package/dist/react/index.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import { Context } from 'react';
|
|
1
2
|
import { QueryKey, QueryClient } from '@tanstack/react-query';
|
|
2
|
-
import { QueryCallbacks } from '../index.js';
|
|
3
|
+
import { QueryCallbacks } from '../core/index.js';
|
|
3
4
|
import '@tanstack/query-core';
|
|
4
5
|
|
|
5
6
|
interface UseQueryCallbacksProps<TQueryFnData, TError> extends QueryCallbacks<TQueryFnData, TError> {
|
|
@@ -8,6 +9,10 @@ interface UseQueryCallbacksProps<TQueryFnData, TError> extends QueryCallbacks<TQ
|
|
|
8
9
|
* QueryClient instance
|
|
9
10
|
*/
|
|
10
11
|
queryClient?: QueryClient;
|
|
12
|
+
/**
|
|
13
|
+
* QueryClient context for v4
|
|
14
|
+
*/
|
|
15
|
+
context?: Context<QueryClient | undefined>;
|
|
11
16
|
}
|
|
12
17
|
declare function useQueryCallbacks<TQueryFnData = unknown, TError = unknown>(props: UseQueryCallbacksProps<TQueryFnData, TError>): void;
|
|
13
18
|
|
package/dist/react/index.mjs
CHANGED
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
import { useEffect } from 'react';
|
|
2
2
|
import { useQueryClient } from '@tanstack/react-query';
|
|
3
|
-
import { subscribeQueryCallbacks } from '../index.mjs';
|
|
3
|
+
import { subscribeQueryCallbacks } from '../core/index.mjs';
|
|
4
4
|
import '@tanstack/query-core';
|
|
5
5
|
|
|
6
6
|
function useQueryCallbacks(props) {
|
|
7
|
-
const queryClient = useQueryClient(
|
|
7
|
+
const queryClient = useQueryClient(
|
|
8
|
+
props.context ? { context: props.context } : props.queryClient
|
|
9
|
+
// for v5
|
|
10
|
+
);
|
|
8
11
|
useEffect(() => {
|
|
9
12
|
return subscribeQueryCallbacks({
|
|
10
13
|
queryClient,
|
package/dist/vue/index.cjs
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
const vueDemi = require('vue-demi');
|
|
4
4
|
const vueQuery = require('@tanstack/vue-query');
|
|
5
|
-
const
|
|
5
|
+
const core_index = require('../core/index.cjs');
|
|
6
6
|
require('@tanstack/query-core');
|
|
7
7
|
|
|
8
8
|
function useQueryCallbacks(props) {
|
|
@@ -10,7 +10,7 @@ function useQueryCallbacks(props) {
|
|
|
10
10
|
vueDemi.watch(
|
|
11
11
|
() => vueDemi.unref(props.queryKey),
|
|
12
12
|
(queryKey, _oldVal, onCleanup) => {
|
|
13
|
-
const unsubscribe =
|
|
13
|
+
const unsubscribe = core_index.subscribeQueryCallbacks({
|
|
14
14
|
queryClient,
|
|
15
15
|
queryKey,
|
|
16
16
|
onSuccess: props.onSuccess,
|
package/dist/vue/index.d.cts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { MaybeRef } from 'vue-demi';
|
|
2
2
|
import { QueryKey, QueryClient } from '@tanstack/vue-query';
|
|
3
|
-
import { QueryCallbacks } from '../index.cjs';
|
|
3
|
+
import { QueryCallbacks } from '../core/index.cjs';
|
|
4
4
|
import '@tanstack/query-core';
|
|
5
5
|
|
|
6
6
|
interface UseQueryCallbacksProps<TQueryFnData, TError> extends QueryCallbacks<TQueryFnData, TError> {
|
package/dist/vue/index.d.mts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { MaybeRef } from 'vue-demi';
|
|
2
2
|
import { QueryKey, QueryClient } from '@tanstack/vue-query';
|
|
3
|
-
import { QueryCallbacks } from '../index.mjs';
|
|
3
|
+
import { QueryCallbacks } from '../core/index.mjs';
|
|
4
4
|
import '@tanstack/query-core';
|
|
5
5
|
|
|
6
6
|
interface UseQueryCallbacksProps<TQueryFnData, TError> extends QueryCallbacks<TQueryFnData, TError> {
|
package/dist/vue/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { MaybeRef } from 'vue-demi';
|
|
2
2
|
import { QueryKey, QueryClient } from '@tanstack/vue-query';
|
|
3
|
-
import { QueryCallbacks } from '../index.js';
|
|
3
|
+
import { QueryCallbacks } from '../core/index.js';
|
|
4
4
|
import '@tanstack/query-core';
|
|
5
5
|
|
|
6
6
|
interface UseQueryCallbacksProps<TQueryFnData, TError> extends QueryCallbacks<TQueryFnData, TError> {
|
package/dist/vue/index.mjs
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { inject, watch, unref } from 'vue-demi';
|
|
2
2
|
import { useQueryClient } from '@tanstack/vue-query';
|
|
3
|
-
import { subscribeQueryCallbacks } from '../index.mjs';
|
|
3
|
+
import { subscribeQueryCallbacks } from '../core/index.mjs';
|
|
4
4
|
import '@tanstack/query-core';
|
|
5
5
|
|
|
6
6
|
function useQueryCallbacks(props) {
|
package/package.json
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "tanstack-query-callbacks",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "0.
|
|
5
|
-
"packageManager": "pnpm@8.
|
|
4
|
+
"version": "0.2.0",
|
|
5
|
+
"packageManager": "pnpm@8.15.1",
|
|
6
6
|
"author": "zhong666 <hi@zhong666.me>",
|
|
7
7
|
"license": "MIT",
|
|
8
8
|
"keywords": [
|
|
@@ -15,12 +15,12 @@
|
|
|
15
15
|
"exports": {
|
|
16
16
|
".": {
|
|
17
17
|
"import": {
|
|
18
|
-
"types": "./dist/index.d.mts",
|
|
19
|
-
"default": "./dist/index.mjs"
|
|
18
|
+
"types": "./dist/core/index.d.mts",
|
|
19
|
+
"default": "./dist/core/index.mjs"
|
|
20
20
|
},
|
|
21
21
|
"require": {
|
|
22
|
-
"types": "./dist/index.d.cts",
|
|
23
|
-
"default": "./dist/index.cjs"
|
|
22
|
+
"types": "./dist/core/index.d.cts",
|
|
23
|
+
"default": "./dist/core/index.cjs"
|
|
24
24
|
}
|
|
25
25
|
},
|
|
26
26
|
"./vue": {
|
|
@@ -32,70 +32,84 @@
|
|
|
32
32
|
"require": "./dist/react/index.cjs"
|
|
33
33
|
}
|
|
34
34
|
},
|
|
35
|
-
"main": "dist/index.cjs",
|
|
36
|
-
"module": "dist/index.mjs",
|
|
37
|
-
"types": "dist/index.d.ts",
|
|
35
|
+
"main": "dist/core/index.cjs",
|
|
36
|
+
"module": "dist/core/index.mjs",
|
|
37
|
+
"types": "dist/core/index.d.ts",
|
|
38
38
|
"files": [
|
|
39
39
|
"dist",
|
|
40
|
-
"
|
|
41
|
-
"
|
|
40
|
+
"react.d.ts",
|
|
41
|
+
"vue.d.ts"
|
|
42
42
|
],
|
|
43
43
|
"publishConfig": {
|
|
44
44
|
"access": "public"
|
|
45
45
|
},
|
|
46
46
|
"peerDependencies": {
|
|
47
|
-
"@tanstack/query-core": "^5.*",
|
|
48
|
-
"@tanstack/
|
|
49
|
-
"@tanstack/
|
|
47
|
+
"@tanstack/query-core": "^4.* || ^5.*",
|
|
48
|
+
"@tanstack/react-query": "^4.* || ^5.*",
|
|
49
|
+
"@tanstack/vue-query": "^4.* || ^5.*",
|
|
50
50
|
"@vue/composition-api": "^1.1.0",
|
|
51
|
-
"
|
|
52
|
-
"
|
|
51
|
+
"react": "^18.0.0",
|
|
52
|
+
"vue": "^2.6.12 || ^3.2.0"
|
|
53
53
|
},
|
|
54
54
|
"peerDependenciesMeta": {
|
|
55
|
-
"@tanstack/
|
|
55
|
+
"@tanstack/react-query": {
|
|
56
56
|
"optional": true
|
|
57
57
|
},
|
|
58
|
-
"@tanstack/
|
|
58
|
+
"@tanstack/vue-query": {
|
|
59
59
|
"optional": true
|
|
60
60
|
},
|
|
61
61
|
"@vue/composition-api": {
|
|
62
62
|
"optional": true
|
|
63
63
|
},
|
|
64
|
-
"
|
|
64
|
+
"react": {
|
|
65
65
|
"optional": true
|
|
66
66
|
},
|
|
67
|
-
"
|
|
67
|
+
"vue": {
|
|
68
68
|
"optional": true
|
|
69
69
|
}
|
|
70
70
|
},
|
|
71
71
|
"devDependencies": {
|
|
72
|
-
"@aa900031/eslint-config": "^1.0
|
|
72
|
+
"@aa900031/eslint-config": "^1.3.0",
|
|
73
73
|
"@release-it/conventional-changelog": "^7.0.2",
|
|
74
|
-
"@tanstack/query-core": "^5.
|
|
75
|
-
"@tanstack/
|
|
76
|
-
"@tanstack/react-query": "^5.
|
|
74
|
+
"@tanstack/query-core": "^5.18.1",
|
|
75
|
+
"@tanstack/query-core-v4": "npm:@tanstack/query-core@^4.36.1",
|
|
76
|
+
"@tanstack/react-query": "^5.18.1",
|
|
77
|
+
"@tanstack/react-query-v4": "npm:@tanstack/react-query@^4.36.1",
|
|
78
|
+
"@tanstack/vue-query": "^5.18.1",
|
|
79
|
+
"@tanstack/vue-query-v4": "npm:@tanstack/vue-query@^4.37.1",
|
|
80
|
+
"@testing-library/react": "14.2.1",
|
|
77
81
|
"@testing-library/vue": "^8.0.1",
|
|
78
|
-
"@testing-library/react": "14.1.2",
|
|
79
82
|
"@tsconfig/node18": "^18.2.2",
|
|
80
|
-
"@types/node": "^18.
|
|
81
|
-
"@types/react": "^18.2.
|
|
83
|
+
"@types/node": "^18.19.14",
|
|
84
|
+
"@types/react": "^18.2.51",
|
|
82
85
|
"@types/react-dom": "^18.2.18",
|
|
83
|
-
"
|
|
84
|
-
"
|
|
86
|
+
"@vitest/coverage-istanbul": "^1.2.2",
|
|
87
|
+
"@vitest/ui": "^1.2.2",
|
|
88
|
+
"@vue/composition-api": "^1.7.2",
|
|
89
|
+
"conventional-changelog-unjs": "^0.1.1",
|
|
90
|
+
"eslint": "^8.56.0",
|
|
85
91
|
"happy-dom": "^12.10.3",
|
|
86
|
-
"
|
|
87
|
-
"typescript": "^5.2.2",
|
|
88
|
-
"unbuild": "^2.0.0",
|
|
89
|
-
"vitest": "^1.1.0",
|
|
90
|
-
"vue": "^3.3.13",
|
|
92
|
+
"npm-run-all2": "^6.1.2",
|
|
91
93
|
"react": "^18.2.0",
|
|
92
|
-
"react-dom": "^18.2.0"
|
|
94
|
+
"react-dom": "^18.2.0",
|
|
95
|
+
"release-it": "^16.3.0",
|
|
96
|
+
"typescript": "^5.3.3",
|
|
97
|
+
"unbuild": "^2.0.0",
|
|
98
|
+
"vitest": "^1.2.2",
|
|
99
|
+
"vue": "^3.4.15",
|
|
100
|
+
"vue-2": "npm:vue@2.7",
|
|
101
|
+
"vue-2.7": "npm:vue@2.7"
|
|
93
102
|
},
|
|
94
103
|
"scripts": {
|
|
95
104
|
"build": "unbuild",
|
|
96
|
-
"test": "vitest run",
|
|
105
|
+
"test": "vitest run --coverage",
|
|
106
|
+
"test:vue": "vue-demi-switch 3 && vitest run --dir ./src/vue",
|
|
107
|
+
"test:vue-2": "vue-demi-switch 2 vue-2 && vitest run --dir ./src/vue",
|
|
108
|
+
"test:vue-2.7": "vue-demi-switch 2.7 vue-2.7 && vitest run --dir ./src/vue",
|
|
97
109
|
"dev:test": "vitest",
|
|
98
110
|
"release": "release-it --ci",
|
|
99
|
-
"lint": "eslint . --cache --cache-location ./node_modules/.cache/eslint"
|
|
111
|
+
"lint": "eslint . --cache --cache-location ./node_modules/.cache/eslint",
|
|
112
|
+
"posttest:vue-2": "vue-demi-switch 3",
|
|
113
|
+
"posttest:vue-2.7": "vue-demi-switch 3"
|
|
100
114
|
}
|
|
101
115
|
}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|