@tanstack/solid-query 5.0.0-alpha.6 → 5.0.0-alpha.61

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 (161) hide show
  1. package/build/lib/QueryClient.cjs +12 -0
  2. package/build/lib/QueryClient.cjs.map +1 -0
  3. package/build/lib/QueryClient.d.ts +30 -0
  4. package/build/lib/QueryClient.d.ts.map +1 -0
  5. package/build/lib/QueryClient.js +10 -0
  6. package/build/lib/QueryClient.js.map +1 -0
  7. package/build/lib/QueryClientProvider.cjs +35 -0
  8. package/build/lib/QueryClientProvider.cjs.map +1 -0
  9. package/build/{types → lib}/QueryClientProvider.d.ts +3 -2
  10. package/build/lib/QueryClientProvider.d.ts.map +1 -0
  11. package/build/lib/QueryClientProvider.js +31 -0
  12. package/build/lib/QueryClientProvider.js.map +1 -0
  13. package/build/lib/__tests__/QueryClientProvider.test.d.ts +2 -0
  14. package/build/lib/__tests__/QueryClientProvider.test.d.ts.map +1 -0
  15. package/build/lib/__tests__/createInfiniteQuery.test.d.ts +2 -0
  16. package/build/lib/__tests__/createInfiniteQuery.test.d.ts.map +1 -0
  17. package/build/lib/__tests__/createMutation.test.d.ts +2 -0
  18. package/build/lib/__tests__/createMutation.test.d.ts.map +1 -0
  19. package/build/lib/__tests__/createQueries.test.d.ts +2 -0
  20. package/build/lib/__tests__/createQueries.test.d.ts.map +1 -0
  21. package/build/lib/__tests__/createQuery.test.d.ts +2 -0
  22. package/build/lib/__tests__/createQuery.test.d.ts.map +1 -0
  23. package/build/lib/__tests__/createQuery.types.test.d.ts +3 -0
  24. package/build/lib/__tests__/createQuery.types.test.d.ts.map +1 -0
  25. package/build/lib/__tests__/suspense.test.d.ts +2 -0
  26. package/build/lib/__tests__/suspense.test.d.ts.map +1 -0
  27. package/build/lib/__tests__/transition.test.d.ts +2 -0
  28. package/build/lib/__tests__/transition.test.d.ts.map +1 -0
  29. package/build/lib/__tests__/useIsFetching.test.d.ts +2 -0
  30. package/build/lib/__tests__/useIsFetching.test.d.ts.map +1 -0
  31. package/build/lib/__tests__/useIsMutating.test.d.ts +2 -0
  32. package/build/lib/__tests__/useIsMutating.test.d.ts.map +1 -0
  33. package/build/{types → lib}/__tests__/utils.d.ts +4 -3
  34. package/build/lib/__tests__/utils.d.ts.map +1 -0
  35. package/build/lib/createBaseQuery.cjs +192 -0
  36. package/build/lib/createBaseQuery.cjs.map +1 -0
  37. package/build/{types → lib}/createBaseQuery.d.ts +3 -1
  38. package/build/lib/createBaseQuery.d.ts.map +1 -0
  39. package/build/lib/createBaseQuery.js +190 -0
  40. package/build/lib/createBaseQuery.js.map +1 -0
  41. package/build/lib/createInfiniteQuery.cjs +14 -0
  42. package/build/lib/createInfiniteQuery.cjs.map +1 -0
  43. package/build/{types → lib}/createInfiniteQuery.d.ts +3 -1
  44. package/build/lib/createInfiniteQuery.d.ts.map +1 -0
  45. package/build/lib/createInfiniteQuery.js +12 -0
  46. package/build/lib/createInfiniteQuery.js.map +1 -0
  47. package/build/lib/createMutation.cjs +44 -0
  48. package/build/lib/createMutation.cjs.map +1 -0
  49. package/build/{types → lib}/createMutation.d.ts +3 -1
  50. package/build/lib/createMutation.d.ts.map +1 -0
  51. package/build/lib/createMutation.js +42 -0
  52. package/build/lib/createMutation.js.map +1 -0
  53. package/build/lib/createQueries.cjs +52 -0
  54. package/build/lib/createQueries.cjs.map +1 -0
  55. package/build/{types → lib}/createQueries.d.ts +12 -9
  56. package/build/lib/createQueries.d.ts.map +1 -0
  57. package/build/lib/createQueries.js +50 -0
  58. package/build/lib/createQueries.js.map +1 -0
  59. package/build/lib/createQuery.cjs +16 -0
  60. package/build/lib/createQuery.cjs.map +1 -0
  61. package/build/lib/createQuery.d.ts +15 -0
  62. package/build/lib/createQuery.d.ts.map +1 -0
  63. package/build/lib/createQuery.js +13 -0
  64. package/build/lib/createQuery.js.map +1 -0
  65. package/build/lib/index.cjs +33 -0
  66. package/build/lib/index.cjs.map +1 -0
  67. package/build/{types → lib}/index.d.ts +4 -1
  68. package/build/lib/index.d.ts.map +1 -0
  69. package/build/lib/index.js +11 -0
  70. package/build/lib/index.js.map +1 -0
  71. package/build/lib/setBatchUpdatesFn.cjs +7 -0
  72. package/build/lib/setBatchUpdatesFn.cjs.map +1 -0
  73. package/build/lib/setBatchUpdatesFn.d.ts +2 -0
  74. package/build/lib/setBatchUpdatesFn.d.ts.map +1 -0
  75. package/build/{source → lib}/setBatchUpdatesFn.js +2 -0
  76. package/build/lib/setBatchUpdatesFn.js.map +1 -0
  77. package/build/lib/types.d.ts +35 -0
  78. package/build/lib/types.d.ts.map +1 -0
  79. package/build/lib/useIsFetching.cjs +18 -0
  80. package/build/lib/useIsFetching.cjs.map +1 -0
  81. package/build/{types → lib}/useIsFetching.d.ts +3 -1
  82. package/build/lib/useIsFetching.d.ts.map +1 -0
  83. package/build/lib/useIsFetching.js +16 -0
  84. package/build/lib/useIsFetching.js.map +1 -0
  85. package/build/lib/useIsMutating.cjs +18 -0
  86. package/build/lib/useIsMutating.cjs.map +1 -0
  87. package/build/{types → lib}/useIsMutating.d.ts +3 -1
  88. package/build/lib/useIsMutating.d.ts.map +1 -0
  89. package/build/lib/useIsMutating.js +16 -0
  90. package/build/lib/useIsMutating.js.map +1 -0
  91. package/build/lib/utils.cjs +12 -0
  92. package/build/lib/utils.cjs.map +1 -0
  93. package/build/{types → lib}/utils.d.ts +1 -0
  94. package/build/lib/utils.d.ts.map +1 -0
  95. package/build/lib/utils.js +10 -0
  96. package/build/lib/utils.js.map +1 -0
  97. package/build/stats.html +6177 -0
  98. package/package.json +22 -28
  99. package/src/QueryClient.ts +84 -0
  100. package/src/QueryClientProvider.tsx +1 -1
  101. package/src/__tests__/QueryClientProvider.test.tsx +2 -3
  102. package/src/__tests__/createInfiniteQuery.test.tsx +83 -19
  103. package/src/__tests__/createMutation.test.tsx +5 -5
  104. package/src/__tests__/createQueries.test.tsx +6 -78
  105. package/src/__tests__/createQuery.test.tsx +66 -334
  106. package/src/__tests__/createQuery.types.test.tsx +21 -1
  107. package/src/__tests__/suspense.test.tsx +7 -90
  108. package/src/__tests__/transition.test.tsx +1 -1
  109. package/src/__tests__/useIsFetching.test.tsx +1 -1
  110. package/src/__tests__/useIsMutating.test.tsx +5 -7
  111. package/src/__tests__/utils.tsx +1 -1
  112. package/src/createBaseQuery.ts +73 -28
  113. package/src/createInfiniteQuery.ts +1 -1
  114. package/src/createMutation.ts +3 -2
  115. package/src/createQueries.ts +32 -14
  116. package/src/createQuery.ts +24 -1
  117. package/src/index.ts +8 -1
  118. package/src/types.ts +4 -2
  119. package/src/useIsFetching.ts +2 -1
  120. package/src/useIsMutating.ts +2 -1
  121. package/build/cjs/index.js +0 -300
  122. package/build/cjs/index.js.map +0 -1
  123. package/build/esm/index.js +0 -285
  124. package/build/esm/index.js.map +0 -1
  125. package/build/source/QueryClientProvider.jsx +0 -21
  126. package/build/source/__tests__/QueryClientProvider.test.jsx +0 -121
  127. package/build/source/__tests__/createInfiniteQuery.test.jsx +0 -1315
  128. package/build/source/__tests__/createMutation.test.jsx +0 -867
  129. package/build/source/__tests__/createQueries.test.jsx +0 -661
  130. package/build/source/__tests__/createQuery.test.jsx +0 -4608
  131. package/build/source/__tests__/createQuery.types.test.jsx +0 -135
  132. package/build/source/__tests__/suspense.test.jsx +0 -721
  133. package/build/source/__tests__/transition.test.jsx +0 -42
  134. package/build/source/__tests__/useIsFetching.test.jsx +0 -190
  135. package/build/source/__tests__/useIsMutating.test.jsx +0 -198
  136. package/build/source/__tests__/utils.jsx +0 -50
  137. package/build/source/createBaseQuery.js +0 -147
  138. package/build/source/createInfiniteQuery.js +0 -8
  139. package/build/source/createMutation.js +0 -38
  140. package/build/source/createQueries.js +0 -32
  141. package/build/source/createQuery.js +0 -6
  142. package/build/source/index.js +0 -14
  143. package/build/source/types.js +0 -2
  144. package/build/source/useIsFetching.js +0 -12
  145. package/build/source/useIsMutating.js +0 -12
  146. package/build/source/utils.js +0 -7
  147. package/build/types/__tests__/QueryClientProvider.test.d.ts +0 -1
  148. package/build/types/__tests__/createInfiniteQuery.test.d.ts +0 -1
  149. package/build/types/__tests__/createMutation.test.d.ts +0 -1
  150. package/build/types/__tests__/createQueries.test.d.ts +0 -1
  151. package/build/types/__tests__/createQuery.test.d.ts +0 -1
  152. package/build/types/__tests__/createQuery.types.test.d.ts +0 -2
  153. package/build/types/__tests__/suspense.test.d.ts +0 -1
  154. package/build/types/__tests__/transition.test.d.ts +0 -1
  155. package/build/types/__tests__/useIsFetching.test.d.ts +0 -1
  156. package/build/types/__tests__/useIsMutating.test.d.ts +0 -1
  157. package/build/types/createQuery.d.ts +0 -11
  158. package/build/types/setBatchUpdatesFn.d.ts +0 -1
  159. package/build/types/types.d.ts +0 -33
  160. package/build/umd/index.js +0 -2
  161. package/build/umd/index.js.map +0 -1
@@ -1,4 +1,4 @@
1
- import { fireEvent, render, screen, waitFor } from 'solid-testing-library'
1
+ import { fireEvent, render, screen, waitFor } from '@solidjs/testing-library'
2
2
 
3
3
  import { createEffect, createRenderEffect, createSignal, Show } from 'solid-js'
4
4
  import { createQuery, QueryCache, QueryClientProvider, useIsFetching } from '..'
@@ -1,11 +1,9 @@
1
- import { fireEvent, screen, waitFor } from 'solid-testing-library'
1
+ import { fireEvent, render, screen, waitFor } from '@solidjs/testing-library'
2
2
  import { createMutation, QueryClientProvider, useIsMutating } from '..'
3
- import { createQueryClient, sleep } from './utils'
3
+ import { createQueryClient, sleep, setActTimeout } from './utils'
4
4
 
5
5
  import { createEffect, createRenderEffect, createSignal, Show } from 'solid-js'
6
- import { render } from 'solid-testing-library'
7
- import * as MutationCacheModule from '../../../query-core/src/mutationCache'
8
- import { setActTimeout } from './utils'
6
+ import * as QueryCore from '@tanstack/query-core'
9
7
  import { vi } from 'vitest'
10
8
 
11
9
  describe('useIsMutating', () => {
@@ -188,7 +186,7 @@ describe('useIsMutating', () => {
188
186
  it('should not change state if unmounted', async () => {
189
187
  // We have to mock the MutationCache to not unsubscribe
190
188
  // the listener when the component is unmounted
191
- class MutationCacheMock extends MutationCacheModule.MutationCache {
189
+ class MutationCacheMock extends QueryCore.MutationCache {
192
190
  subscribe(listener: any) {
193
191
  super.subscribe(listener)
194
192
  return () => void 0
@@ -196,7 +194,7 @@ describe('useIsMutating', () => {
196
194
  }
197
195
 
198
196
  const MutationCacheSpy = vi
199
- .spyOn(MutationCacheModule, 'MutationCache')
197
+ .spyOn(QueryCore, 'MutationCache')
200
198
  .mockImplementation((fn) => {
201
199
  return new MutationCacheMock(fn)
202
200
  })
@@ -1,5 +1,5 @@
1
1
  import type { QueryClientConfig } from '@tanstack/query-core'
2
- import { QueryClient } from '@tanstack/query-core'
2
+ import { QueryClient } from '../QueryClient'
3
3
  import type { ParentProps } from 'solid-js'
4
4
  import { createEffect, createSignal, onCleanup, Show } from 'solid-js'
5
5
  import { vi } from 'vitest'
@@ -3,13 +3,12 @@
3
3
  // in solid-js/web package. I'll create a GitHub issue with them to see
4
4
  // why that happens.
5
5
  import type {
6
- QueryClient,
7
6
  QueryKey,
8
7
  QueryObserver,
9
8
  QueryObserverResult,
10
9
  } from '@tanstack/query-core'
11
- import { hydrate } from '@tanstack/query-core'
12
- import { notifyManager } from '@tanstack/query-core'
10
+ import type { QueryClient } from './QueryClient'
11
+ import { hydrate, notifyManager } from '@tanstack/query-core'
13
12
  import type { Accessor } from 'solid-js'
14
13
  import { isServer } from 'solid-js/web'
15
14
  import {
@@ -18,13 +17,29 @@ import {
18
17
  createResource,
19
18
  on,
20
19
  onCleanup,
21
- onMount,
22
20
  } from 'solid-js'
23
- import { createStore, unwrap } from 'solid-js/store'
21
+ import { createStore, reconcile, unwrap } from 'solid-js/store'
24
22
  import { useQueryClient } from './QueryClientProvider'
25
23
  import type { CreateBaseQueryOptions } from './types'
26
24
  import { shouldThrowError } from './utils'
27
25
 
26
+ function reconcileFn<TData, TError>(
27
+ store: QueryObserverResult<TData, TError>,
28
+ result: QueryObserverResult<TData, TError>,
29
+ reconcileOption:
30
+ | string
31
+ | false
32
+ | ((oldData: TData | undefined, newData: TData) => TData),
33
+ ): QueryObserverResult<TData, TError> {
34
+ if (reconcileOption === false) return result
35
+ if (typeof reconcileOption === 'function') {
36
+ const newData = reconcileOption(store.data, result.data as TData)
37
+ return { ...result, data: newData } as typeof result
38
+ }
39
+ const newData = reconcile(result.data, { key: reconcileOption })(store.data)
40
+ return { ...result, data: newData } as typeof result
41
+ }
42
+
28
43
  // Base Query Function that is used to create the query.
29
44
  export function createBaseQuery<
30
45
  TQueryFnData,
@@ -43,9 +58,10 @@ export function createBaseQuery<
43
58
 
44
59
  const defaultedOptions = client().defaultQueryOptions(options())
45
60
  defaultedOptions._optimisticResults = 'optimistic'
61
+ defaultedOptions.structuralSharing = false
46
62
  if (isServer) {
47
63
  defaultedOptions.retry = false
48
- defaultedOptions.throwErrors = true
64
+ defaultedOptions.throwOnError = true
49
65
  }
50
66
  const observer = new Observer(client(), defaultedOptions)
51
67
 
@@ -64,7 +80,22 @@ export function createBaseQuery<
64
80
  ) => {
65
81
  return observer.subscribe((result) => {
66
82
  notifyManager.batchCalls(() => {
67
- const unwrappedResult = { ...unwrap(result) }
83
+ const query = observer.getCurrentQuery()
84
+ const { refetch, ...rest } = unwrap(result)
85
+ const unwrappedResult = {
86
+ ...rest,
87
+
88
+ // hydrate() expects a QueryState object, which is similar but not
89
+ // quite the same as a QueryObserverResult object. Thus, for now, we're
90
+ // copying over the missing properties from state in order to support hydration
91
+ dataUpdateCount: query.state.dataUpdateCount,
92
+ fetchFailureCount: query.state.fetchFailureCount,
93
+ // Removing these properties since they might not be serializable
94
+ // fetchFailureReason: query.state.fetchFailureReason,
95
+ // fetchMeta: query.state.fetchMeta,
96
+ isInvalidated: query.state.isInvalidated,
97
+ }
98
+
68
99
  if (unwrappedResult.isError) {
69
100
  if (process.env['NODE_ENV'] === 'development') {
70
101
  console.error(unwrappedResult.error)
@@ -72,7 +103,9 @@ export function createBaseQuery<
72
103
  reject(unwrappedResult.error)
73
104
  }
74
105
  if (unwrappedResult.isSuccess) {
75
- resolve(unwrappedResult)
106
+ // Use of any here is fine
107
+ // We cannot include refetch since it is not serializable
108
+ resolve(unwrappedResult as any)
76
109
  }
77
110
  })()
78
111
  })
@@ -81,18 +114,28 @@ export function createBaseQuery<
81
114
  const createClientSubscriber = () => {
82
115
  return observer.subscribe((result) => {
83
116
  notifyManager.batchCalls(() => {
84
- const unwrappedResult = { ...unwrap(result) }
117
+ // @ts-expect-error - This will error because the reconcile option does not
118
+ // exist on the query-core QueryObserverResult type
119
+ const reconcileOptions = observer.options.reconcile
85
120
  // If the query has data we dont suspend but instead mutate the resource
86
121
  // This could happen when placeholderData/initialData is defined
87
- if (
88
- queryResource()?.data &&
89
- unwrappedResult.data &&
90
- !queryResource.loading
91
- ) {
92
- setState(unwrappedResult)
122
+ if (queryResource()?.data && result.data && !queryResource.loading) {
123
+ setState((store) => {
124
+ return reconcileFn(
125
+ store,
126
+ result,
127
+ reconcileOptions === undefined ? 'id' : reconcileOptions,
128
+ )
129
+ })
93
130
  mutate(state)
94
131
  } else {
95
- setState(unwrappedResult)
132
+ setState((store) => {
133
+ return reconcileFn(
134
+ store,
135
+ result,
136
+ reconcileOptions === undefined ? 'id' : reconcileOptions,
137
+ )
138
+ })
96
139
  refetch()
97
140
  }
98
141
  })()
@@ -178,13 +221,17 @@ export function createBaseQuery<
178
221
  }
179
222
  })
180
223
 
181
- onMount(() => {
182
- observer.setOptions(defaultedOptions, { listeners: false })
183
- })
184
-
185
- createComputed(() => {
186
- observer.setOptions(client().defaultQueryOptions(options()))
187
- })
224
+ createComputed(
225
+ on(
226
+ () => client().defaultQueryOptions(options()),
227
+ () => observer.setOptions(client().defaultQueryOptions(options())),
228
+ {
229
+ // Defer because we don't need to trigger on first render
230
+ // This only cares about changes to options after the observer is created
231
+ defer: true,
232
+ },
233
+ ),
234
+ )
188
235
 
189
236
  createComputed(
190
237
  on(
@@ -193,7 +240,7 @@ export function createBaseQuery<
193
240
  if (
194
241
  state.isError &&
195
242
  !state.isFetching &&
196
- shouldThrowError(observer.options.throwErrors, [
243
+ shouldThrowError(observer.options.throwOnError, [
197
244
  state.error,
198
245
  observer.getCurrentQuery(),
199
246
  ])
@@ -209,10 +256,8 @@ export function createBaseQuery<
209
256
  target: QueryObserverResult<TData, TError>,
210
257
  prop: keyof QueryObserverResult<TData, TError>,
211
258
  ): any {
212
- if (prop === 'data') {
213
- return queryResource()?.data
214
- }
215
- return Reflect.get(target, prop)
259
+ const val = queryResource()?.[prop]
260
+ return val !== undefined ? val : Reflect.get(target, prop)
216
261
  },
217
262
  }
218
263
 
@@ -1,10 +1,10 @@
1
1
  import type {
2
2
  QueryObserver,
3
3
  QueryKey,
4
- QueryClient,
5
4
  DefaultError,
6
5
  InfiniteData,
7
6
  } from '@tanstack/query-core'
7
+ import type { QueryClient } from './QueryClient'
8
8
  import { InfiniteQueryObserver } from '@tanstack/query-core'
9
9
  import type {
10
10
  CreateInfiniteQueryOptions,
@@ -1,4 +1,5 @@
1
- import type { QueryClient, DefaultError } from '@tanstack/query-core'
1
+ import type { DefaultError } from '@tanstack/query-core'
2
+ import type { QueryClient } from './QueryClient'
2
3
  import { MutationObserver } from '@tanstack/query-core'
3
4
  import { useQueryClient } from './QueryClientProvider'
4
5
  import type {
@@ -53,7 +54,7 @@ export function createMutation<
53
54
  () => {
54
55
  if (
55
56
  state.isError &&
56
- shouldThrowError(observer.options.throwErrors, [state.error])
57
+ shouldThrowError(observer.options.throwOnError, [state.error])
57
58
  ) {
58
59
  throw state.error
59
60
  }
@@ -1,13 +1,14 @@
1
1
  import type {
2
2
  QueriesPlaceholderDataFunction,
3
- QueryClient,
4
3
  QueryFunction,
5
4
  QueryKey,
6
5
  DefaultError,
6
+ QueriesObserverOptions,
7
7
  } from '@tanstack/query-core'
8
8
  import { notifyManager, QueriesObserver } from '@tanstack/query-core'
9
+ import type { QueryClient } from './QueryClient'
9
10
  import type { Accessor } from 'solid-js'
10
- import { createComputed, onCleanup, onMount } from 'solid-js'
11
+ import { createComputed, onCleanup } from 'solid-js'
11
12
  import { createStore, unwrap } from 'solid-js/store'
12
13
  import { useQueryClient } from './QueryClientProvider'
13
14
  import type { CreateQueryResult, SolidQueryOptions } from './types'
@@ -148,12 +149,16 @@ export type QueriesResults<
148
149
  : // Fallback
149
150
  CreateQueryResult[]
150
151
 
151
- export function createQueries<T extends any[]>(
152
+ export function createQueries<
153
+ T extends any[],
154
+ TCombinedResult = QueriesResults<T>,
155
+ >(
152
156
  queriesOptions: Accessor<{
153
157
  queries: readonly [...QueriesOptions<T>]
158
+ combine?: (result: QueriesResults<T>) => TCombinedResult
154
159
  }>,
155
160
  queryClient?: Accessor<QueryClient>,
156
- ): QueriesResults<T> {
161
+ ): TCombinedResult {
157
162
  const client = useQueryClient(queryClient?.())
158
163
 
159
164
  const defaultedQueries = queriesOptions().queries.map((options) => {
@@ -162,32 +167,45 @@ export function createQueries<T extends any[]>(
162
167
  return defaultedOptions
163
168
  })
164
169
 
165
- const observer = new QueriesObserver(client, defaultedQueries)
170
+ const observer = new QueriesObserver(
171
+ client,
172
+ defaultedQueries,
173
+ queriesOptions().combine
174
+ ? ({
175
+ combine: queriesOptions().combine,
176
+ } as QueriesObserverOptions<TCombinedResult>)
177
+ : undefined,
178
+ )
166
179
 
167
- const [state, setState] = createStore(
168
- observer.getOptimisticResult(defaultedQueries),
180
+ // @ts-expect-error - Types issue with solid-js createStore
181
+ const [state, setState] = createStore<TCombinedResult>(
182
+ observer.getOptimisticResult(defaultedQueries)[1](),
169
183
  )
170
184
 
171
185
  const unsubscribe = observer.subscribe((result) => {
172
186
  notifyManager.batchCalls(() => {
173
- setState(unwrap(result))
187
+ setState(unwrap(result) as unknown as TCombinedResult)
174
188
  })()
175
189
  })
176
190
 
177
191
  onCleanup(unsubscribe)
178
192
 
179
- onMount(() => {
180
- observer.setQueries(defaultedQueries, { listeners: false })
181
- })
182
-
183
193
  createComputed(() => {
184
194
  const updatedQueries = queriesOptions().queries.map((options) => {
185
195
  const defaultedOptions = client.defaultQueryOptions(options)
186
196
  defaultedOptions._optimisticResults = 'optimistic'
187
197
  return defaultedOptions
188
198
  })
189
- observer.setQueries(updatedQueries)
199
+ observer.setQueries(
200
+ updatedQueries,
201
+ queriesOptions().combine
202
+ ? ({
203
+ combine: queriesOptions().combine,
204
+ } as QueriesObserverOptions<TCombinedResult>)
205
+ : undefined,
206
+ { listeners: false },
207
+ )
190
208
  })
191
209
 
192
- return state as QueriesResults<T>
210
+ return state
193
211
  }
@@ -1,5 +1,6 @@
1
- import type { QueryClient, QueryKey, DefaultError } from '@tanstack/query-core'
1
+ import type { QueryKey, DefaultError } from '@tanstack/query-core'
2
2
  import { QueryObserver } from '@tanstack/query-core'
3
+ import type { QueryClient } from './QueryClient'
3
4
  import type { Accessor } from 'solid-js'
4
5
  import { createMemo } from 'solid-js'
5
6
  import { createBaseQuery } from './createBaseQuery'
@@ -33,6 +34,28 @@ type DefinedInitialDataOptions<
33
34
  }
34
35
  >
35
36
 
37
+ export function queryOptions<
38
+ TQueryFnData = unknown,
39
+ TError = unknown,
40
+ TData = TQueryFnData,
41
+ TQueryKey extends QueryKey = QueryKey,
42
+ >(
43
+ options: UndefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,
44
+ ): UndefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>
45
+
46
+ export function queryOptions<
47
+ TQueryFnData = unknown,
48
+ TError = unknown,
49
+ TData = TQueryFnData,
50
+ TQueryKey extends QueryKey = QueryKey,
51
+ >(
52
+ options: DefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,
53
+ ): DefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>
54
+
55
+ export function queryOptions(options: unknown) {
56
+ return options
57
+ }
58
+
36
59
  export function createQuery<
37
60
  TQueryFnData = unknown,
38
61
  TError = DefaultError,
package/src/index.ts CHANGED
@@ -8,7 +8,14 @@ export * from '@tanstack/query-core'
8
8
 
9
9
  // Solid Query
10
10
  export * from './types'
11
- export { createQuery } from './createQuery'
11
+ export { QueryClient } from './QueryClient'
12
+ export type {
13
+ QueryObserverOptions,
14
+ DefaultOptions,
15
+ QueryClientConfig,
16
+ InfiniteQueryObserverOptions,
17
+ } from './QueryClient'
18
+ export { createQuery, queryOptions } from './createQuery'
12
19
  export {
13
20
  QueryClientContext,
14
21
  QueryClientProvider,
package/src/types.ts CHANGED
@@ -2,17 +2,19 @@
2
2
 
3
3
  import type {
4
4
  QueryKey,
5
- QueryObserverOptions,
6
5
  QueryObserverResult,
7
6
  MutateFunction,
8
7
  MutationObserverOptions,
9
8
  MutationObserverResult,
10
9
  DefinedQueryObserverResult,
11
- InfiniteQueryObserverOptions,
12
10
  InfiniteQueryObserverResult,
13
11
  WithRequired,
14
12
  DefaultError,
15
13
  } from '@tanstack/query-core'
14
+ import type {
15
+ QueryObserverOptions,
16
+ InfiniteQueryObserverOptions,
17
+ } from './QueryClient'
16
18
 
17
19
  export type FunctionedParams<T> = () => T
18
20
 
@@ -1,4 +1,5 @@
1
- import type { QueryClient, QueryFilters } from '@tanstack/query-core'
1
+ import type { QueryFilters } from '@tanstack/query-core'
2
+ import type { QueryClient } from './QueryClient'
2
3
  import type { Accessor } from 'solid-js'
3
4
  import { createMemo, createSignal, onCleanup } from 'solid-js'
4
5
  import { useQueryClient } from './QueryClientProvider'
@@ -1,4 +1,5 @@
1
- import type { MutationFilters, QueryClient } from '@tanstack/query-core'
1
+ import type { MutationFilters } from '@tanstack/query-core'
2
+ import type { QueryClient } from './QueryClient'
2
3
  import { useQueryClient } from './QueryClientProvider'
3
4
  import type { Accessor } from 'solid-js'
4
5
  import { createSignal, onCleanup, createMemo } from 'solid-js'