@tanstack/solid-query 5.0.0-alpha.19 → 5.0.0-alpha.20
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/cjs/index.js +35 -6
- package/build/cjs/index.js.map +1 -1
- package/build/esm/index.js +37 -9
- package/build/esm/index.js.map +1 -1
- package/build/source/QueryClient.js +6 -0
- package/build/source/__tests__/createInfiniteQuery.test.jsx +56 -10
- package/build/source/__tests__/createQuery.test.jsx +44 -3
- package/build/source/__tests__/utils.jsx +1 -1
- package/build/source/createBaseQuery.js +22 -7
- package/build/source/index.js +1 -0
- package/build/types/QueryClient.d.ts +29 -0
- package/build/types/QueryClientProvider.d.ts +1 -1
- package/build/types/__tests__/utils.d.ts +1 -1
- package/build/types/createBaseQuery.d.ts +2 -1
- package/build/types/createInfiniteQuery.d.ts +2 -1
- package/build/types/createMutation.d.ts +2 -1
- package/build/types/createQueries.d.ts +2 -1
- package/build/types/createQuery.d.ts +2 -1
- package/build/types/index.d.ts +2 -0
- package/build/types/types.d.ts +2 -1
- package/build/types/useIsFetching.d.ts +2 -1
- package/build/types/useIsMutating.d.ts +2 -1
- package/build/umd/index.js +1 -1
- package/build/umd/index.js.map +1 -1
- package/package.json +1 -1
- package/src/QueryClient.ts +84 -0
- package/src/QueryClientProvider.tsx +1 -1
- package/src/__tests__/createInfiniteQuery.test.tsx +75 -16
- package/src/__tests__/createQuery.test.tsx +59 -4
- package/src/__tests__/utils.tsx +1 -1
- package/src/createBaseQuery.ts +38 -10
- package/src/createInfiniteQuery.ts +1 -1
- package/src/createMutation.ts +2 -1
- package/src/createQueries.ts +1 -1
- package/src/createQuery.ts +2 -1
- package/src/index.ts +7 -0
- package/src/types.ts +4 -2
- package/src/useIsFetching.ts +2 -1
- package/src/useIsMutating.ts +2 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { fireEvent, render, screen, waitFor } from 'solid-testing-library';
|
|
2
2
|
import { createQueryClient, sleep } from './utils';
|
|
3
|
-
import { createEffect, createRenderEffect, createSignal, For, Index, Match, Switch, } from 'solid-js';
|
|
3
|
+
import { createEffect, createRenderEffect, createSignal, For, Index, Match, Switch, on, } from 'solid-js';
|
|
4
4
|
import { createInfiniteQuery, QueryCache, QueryClientProvider, keepPreviousData, } from '..';
|
|
5
5
|
import { Blink, queryKey, setActTimeout } from './utils';
|
|
6
6
|
import { vi } from 'vitest';
|
|
@@ -154,7 +154,16 @@ describe('useInfiniteQuery', () => {
|
|
|
154
154
|
notifyOnChangeProps: 'all',
|
|
155
155
|
}));
|
|
156
156
|
createRenderEffect(() => {
|
|
157
|
-
states.push({
|
|
157
|
+
states.push({
|
|
158
|
+
data: state.data ? JSON.parse(JSON.stringify(state.data)) : undefined,
|
|
159
|
+
hasNextPage: state.hasNextPage,
|
|
160
|
+
hasPreviousPage: state.hasPreviousPage,
|
|
161
|
+
isFetching: state.isFetching,
|
|
162
|
+
isFetchingNextPage: state.isFetchingNextPage,
|
|
163
|
+
isFetchingPreviousPage: state.isFetchingPreviousPage,
|
|
164
|
+
isSuccess: state.isSuccess,
|
|
165
|
+
isPlaceholderData: state.isPlaceholderData,
|
|
166
|
+
});
|
|
158
167
|
});
|
|
159
168
|
return (<div>
|
|
160
169
|
<button onClick={() => state.fetchNextPage()}>fetchNextPage</button>
|
|
@@ -306,9 +315,14 @@ describe('useInfiniteQuery', () => {
|
|
|
306
315
|
getNextPageParam: () => 1,
|
|
307
316
|
defaultPageParam: 0,
|
|
308
317
|
}));
|
|
309
|
-
createRenderEffect(() => {
|
|
310
|
-
states.push({
|
|
311
|
-
|
|
318
|
+
createRenderEffect(on(() => ({ ...state }), () => {
|
|
319
|
+
states.push({
|
|
320
|
+
data: state.data
|
|
321
|
+
? JSON.parse(JSON.stringify(state.data))
|
|
322
|
+
: undefined,
|
|
323
|
+
isSuccess: state.isSuccess,
|
|
324
|
+
});
|
|
325
|
+
}));
|
|
312
326
|
return (<div>
|
|
313
327
|
<button onClick={() => state.fetchNextPage()}>fetchNextPage</button>
|
|
314
328
|
<div>data: {state.data?.pages.join(',') ?? 'null'}</div>
|
|
@@ -356,7 +370,15 @@ describe('useInfiniteQuery', () => {
|
|
|
356
370
|
notifyOnChangeProps: 'all',
|
|
357
371
|
}));
|
|
358
372
|
createRenderEffect(() => {
|
|
359
|
-
states.push({
|
|
373
|
+
states.push({
|
|
374
|
+
data: state.data ? JSON.parse(JSON.stringify(state.data)) : undefined,
|
|
375
|
+
hasNextPage: state.hasNextPage,
|
|
376
|
+
hasPreviousPage: state.hasPreviousPage,
|
|
377
|
+
isFetching: state.isFetching,
|
|
378
|
+
isFetchingNextPage: state.isFetchingNextPage,
|
|
379
|
+
isFetchingPreviousPage: state.isFetchingPreviousPage,
|
|
380
|
+
isSuccess: state.isSuccess,
|
|
381
|
+
});
|
|
360
382
|
});
|
|
361
383
|
createEffect(() => {
|
|
362
384
|
const fetchPreviousPage = state.fetchPreviousPage;
|
|
@@ -424,7 +446,13 @@ describe('useInfiniteQuery', () => {
|
|
|
424
446
|
notifyOnChangeProps: 'all',
|
|
425
447
|
}));
|
|
426
448
|
createRenderEffect(() => {
|
|
427
|
-
states.push({
|
|
449
|
+
states.push({
|
|
450
|
+
data: state.data ? JSON.parse(JSON.stringify(state.data)) : undefined,
|
|
451
|
+
isFetching: state.isFetching,
|
|
452
|
+
isFetchingNextPage: state.isFetchingNextPage,
|
|
453
|
+
isRefetching: state.isRefetching,
|
|
454
|
+
isFetchingPreviousPage: state.isFetchingPreviousPage,
|
|
455
|
+
});
|
|
428
456
|
});
|
|
429
457
|
return (<div>
|
|
430
458
|
<button onClick={() => state.fetchNextPage()}>fetchNextPage</button>
|
|
@@ -524,7 +552,13 @@ describe('useInfiniteQuery', () => {
|
|
|
524
552
|
notifyOnChangeProps: 'all',
|
|
525
553
|
}));
|
|
526
554
|
createRenderEffect(() => {
|
|
527
|
-
states.push({
|
|
555
|
+
states.push({
|
|
556
|
+
hasNextPage: state.hasNextPage,
|
|
557
|
+
data: state.data ? JSON.parse(JSON.stringify(state.data)) : undefined,
|
|
558
|
+
isFetching: state.isFetching,
|
|
559
|
+
isFetchingNextPage: state.isFetchingNextPage,
|
|
560
|
+
isSuccess: state.isSuccess,
|
|
561
|
+
});
|
|
528
562
|
});
|
|
529
563
|
createEffect(() => {
|
|
530
564
|
const { refetch, fetchNextPage } = state;
|
|
@@ -804,7 +838,13 @@ describe('useInfiniteQuery', () => {
|
|
|
804
838
|
defaultPageParam: firstPage(),
|
|
805
839
|
}));
|
|
806
840
|
createRenderEffect(() => {
|
|
807
|
-
states.push({
|
|
841
|
+
states.push({
|
|
842
|
+
hasNextPage: state.hasNextPage,
|
|
843
|
+
data: state.data ? JSON.parse(JSON.stringify(state.data)) : undefined,
|
|
844
|
+
isFetching: state.isFetching,
|
|
845
|
+
isFetchingNextPage: state.isFetchingNextPage,
|
|
846
|
+
isSuccess: state.isSuccess,
|
|
847
|
+
});
|
|
808
848
|
});
|
|
809
849
|
createEffect(() => {
|
|
810
850
|
const { refetch } = state;
|
|
@@ -879,7 +919,13 @@ describe('useInfiniteQuery', () => {
|
|
|
879
919
|
notifyOnChangeProps: 'all',
|
|
880
920
|
}));
|
|
881
921
|
createRenderEffect(() => {
|
|
882
|
-
states.push({
|
|
922
|
+
states.push({
|
|
923
|
+
data: JSON.parse(JSON.stringify(state.data)),
|
|
924
|
+
hasNextPage: state.hasNextPage,
|
|
925
|
+
isFetching: state.isFetching,
|
|
926
|
+
isFetchingNextPage: state.isFetchingNextPage,
|
|
927
|
+
isSuccess: state.isSuccess,
|
|
928
|
+
});
|
|
883
929
|
});
|
|
884
930
|
createEffect(() => {
|
|
885
931
|
const { fetchNextPage } = state;
|
|
@@ -4,6 +4,7 @@ import { fireEvent, render, screen, waitFor } from 'solid-testing-library';
|
|
|
4
4
|
import { createQuery, QueryCache, QueryClientProvider, keepPreviousData, } from '..';
|
|
5
5
|
import { Blink, createQueryClient, expectType, mockNavigatorOnLine, mockVisibilityState, queryKey, setActTimeout, sleep, } from './utils';
|
|
6
6
|
import { vi } from 'vitest';
|
|
7
|
+
import { reconcile } from 'solid-js/store';
|
|
7
8
|
describe('createQuery', () => {
|
|
8
9
|
const queryCache = new QueryCache();
|
|
9
10
|
const queryClient = createQueryClient({ queryCache });
|
|
@@ -965,7 +966,6 @@ describe('createQuery', () => {
|
|
|
965
966
|
count++;
|
|
966
967
|
return count === 1 ? result1 : result2;
|
|
967
968
|
},
|
|
968
|
-
notifyOnChangeProps: 'all',
|
|
969
969
|
}));
|
|
970
970
|
createRenderEffect(() => {
|
|
971
971
|
states.push({ ...state });
|
|
@@ -992,9 +992,8 @@ describe('createQuery', () => {
|
|
|
992
992
|
const newTodo2 = newTodos?.[1];
|
|
993
993
|
expect(todos).toEqual(result1);
|
|
994
994
|
expect(newTodos).toEqual(result2);
|
|
995
|
-
expect(newTodos).not.toBe(todos);
|
|
996
995
|
expect(newTodo1).toBe(todo1);
|
|
997
|
-
expect(newTodo2).
|
|
996
|
+
expect(newTodo2).toBe(todo2);
|
|
998
997
|
return null;
|
|
999
998
|
});
|
|
1000
999
|
it('should use query function from hook when the existing query does not have a query function', async () => {
|
|
@@ -2501,6 +2500,7 @@ describe('createQuery', () => {
|
|
|
2501
2500
|
queryFn: () => ({ count: 10 }),
|
|
2502
2501
|
staleTime: Infinity,
|
|
2503
2502
|
initialData: () => ({ count: count() }),
|
|
2503
|
+
reconcile: false,
|
|
2504
2504
|
}));
|
|
2505
2505
|
createRenderEffect(() => {
|
|
2506
2506
|
states.push({ ...state });
|
|
@@ -3503,6 +3503,47 @@ describe('createQuery', () => {
|
|
|
3503
3503
|
// effect should not be triggered again due to structural sharing
|
|
3504
3504
|
expect(states).toHaveLength(1);
|
|
3505
3505
|
});
|
|
3506
|
+
it('The reconcile fn callback should correctly maintain referential equality', async () => {
|
|
3507
|
+
const key1 = queryKey();
|
|
3508
|
+
const states = [];
|
|
3509
|
+
function Page() {
|
|
3510
|
+
const [forceValue, setForceValue] = createSignal(1);
|
|
3511
|
+
const state = createQuery(() => ({
|
|
3512
|
+
queryKey: key1,
|
|
3513
|
+
queryFn: async () => {
|
|
3514
|
+
await sleep(10);
|
|
3515
|
+
return [1, 2];
|
|
3516
|
+
},
|
|
3517
|
+
select: (res) => res.map((x) => x + 1),
|
|
3518
|
+
reconcile(oldData, newData) {
|
|
3519
|
+
return reconcile(newData)(oldData);
|
|
3520
|
+
},
|
|
3521
|
+
}));
|
|
3522
|
+
createEffect(() => {
|
|
3523
|
+
if (state.data) {
|
|
3524
|
+
states.push(state.data);
|
|
3525
|
+
}
|
|
3526
|
+
});
|
|
3527
|
+
const forceUpdate = () => {
|
|
3528
|
+
setForceValue((prev) => prev + 1);
|
|
3529
|
+
};
|
|
3530
|
+
return (<div>
|
|
3531
|
+
<h2>Data: {JSON.stringify(state.data)}</h2>
|
|
3532
|
+
<h2>forceValue: {forceValue}</h2>
|
|
3533
|
+
<button onClick={forceUpdate}>forceUpdate</button>
|
|
3534
|
+
</div>);
|
|
3535
|
+
}
|
|
3536
|
+
render(() => (<QueryClientProvider client={queryClient}>
|
|
3537
|
+
<Page />
|
|
3538
|
+
</QueryClientProvider>));
|
|
3539
|
+
await waitFor(() => screen.getByText('Data: [2,3]'));
|
|
3540
|
+
expect(states).toHaveLength(1);
|
|
3541
|
+
fireEvent.click(screen.getByRole('button', { name: /forceUpdate/i }));
|
|
3542
|
+
await waitFor(() => screen.getByText('forceValue: 2'));
|
|
3543
|
+
await waitFor(() => screen.getByText('Data: [2,3]'));
|
|
3544
|
+
// effect should not be triggered again due to structural sharing
|
|
3545
|
+
expect(states).toHaveLength(1);
|
|
3546
|
+
});
|
|
3506
3547
|
it('should cancel the query function when there are no more subscriptions', async () => {
|
|
3507
3548
|
const key = queryKey();
|
|
3508
3549
|
let cancelFn = vi.fn();
|
|
@@ -2,14 +2,25 @@ import { hydrate } from '@tanstack/query-core';
|
|
|
2
2
|
import { notifyManager } from '@tanstack/query-core';
|
|
3
3
|
import { isServer } from 'solid-js/web';
|
|
4
4
|
import { createComputed, createMemo, createResource, on, onCleanup, } from 'solid-js';
|
|
5
|
-
import { createStore, unwrap } from 'solid-js/store';
|
|
5
|
+
import { createStore, reconcile, unwrap } from 'solid-js/store';
|
|
6
6
|
import { useQueryClient } from './QueryClientProvider';
|
|
7
7
|
import { shouldThrowError } from './utils';
|
|
8
|
+
function reconcileFn(store, result, reconcileOption) {
|
|
9
|
+
if (reconcileOption === false)
|
|
10
|
+
return result;
|
|
11
|
+
if (typeof reconcileOption === 'function') {
|
|
12
|
+
const newData = reconcileOption(store.data, result.data);
|
|
13
|
+
return { ...result, data: newData };
|
|
14
|
+
}
|
|
15
|
+
const newData = reconcile(result.data, { key: reconcileOption })(store.data);
|
|
16
|
+
return { ...result, data: newData };
|
|
17
|
+
}
|
|
8
18
|
// Base Query Function that is used to create the query.
|
|
9
19
|
export function createBaseQuery(options, Observer, queryClient) {
|
|
10
20
|
const client = createMemo(() => useQueryClient(queryClient?.()));
|
|
11
21
|
const defaultedOptions = client().defaultQueryOptions(options());
|
|
12
22
|
defaultedOptions._optimisticResults = 'optimistic';
|
|
23
|
+
defaultedOptions.structuralSharing = false;
|
|
13
24
|
if (isServer) {
|
|
14
25
|
defaultedOptions.retry = false;
|
|
15
26
|
defaultedOptions.throwErrors = true;
|
|
@@ -49,17 +60,21 @@ export function createBaseQuery(options, Observer, queryClient) {
|
|
|
49
60
|
const createClientSubscriber = () => {
|
|
50
61
|
return observer.subscribe((result) => {
|
|
51
62
|
notifyManager.batchCalls(() => {
|
|
52
|
-
|
|
63
|
+
// @ts-expect-error - This will error because the reconcile option does not
|
|
64
|
+
// exist on the query-core QueryObserverResult type
|
|
65
|
+
const reconcileOptions = observer.options.reconcile;
|
|
53
66
|
// If the query has data we dont suspend but instead mutate the resource
|
|
54
67
|
// This could happen when placeholderData/initialData is defined
|
|
55
|
-
if (queryResource()?.data &&
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
68
|
+
if (queryResource()?.data && result.data && !queryResource.loading) {
|
|
69
|
+
setState((store) => {
|
|
70
|
+
return reconcileFn(store, result, reconcileOptions === undefined ? 'id' : reconcileOptions);
|
|
71
|
+
});
|
|
59
72
|
mutate(state);
|
|
60
73
|
}
|
|
61
74
|
else {
|
|
62
|
-
setState(
|
|
75
|
+
setState((store) => {
|
|
76
|
+
return reconcileFn(store, result, reconcileOptions === undefined ? 'id' : reconcileOptions);
|
|
77
|
+
});
|
|
63
78
|
refetch();
|
|
64
79
|
}
|
|
65
80
|
})();
|
package/build/source/index.js
CHANGED
|
@@ -5,6 +5,7 @@ import './setBatchUpdatesFn';
|
|
|
5
5
|
export * from '@tanstack/query-core';
|
|
6
6
|
// Solid Query
|
|
7
7
|
export * from './types';
|
|
8
|
+
export { QueryClient } from './QueryClient';
|
|
8
9
|
export { createQuery } from './createQuery';
|
|
9
10
|
export { QueryClientContext, QueryClientProvider, useQueryClient, } from './QueryClientProvider';
|
|
10
11
|
export { useIsFetching } from './useIsFetching';
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type { QueryClientConfig as QueryCoreClientConfig, DefaultOptions as CoreDefaultOptions, QueryObserverOptions as QueryCoreObserverOptions, InfiniteQueryObserverOptions as QueryCoreInfiniteQueryObserverOptions, DefaultError, QueryKey } from '@tanstack/query-core';
|
|
2
|
+
import { QueryClient as QueryCoreClient } from '@tanstack/query-core';
|
|
3
|
+
export interface QueryObserverOptions<TQueryFnData = unknown, TError = DefaultError, TData = TQueryFnData, TQueryData = TQueryFnData, TQueryKey extends QueryKey = QueryKey, TPageParam = never> extends Omit<QueryCoreObserverOptions<TQueryFnData, TError, TData, TQueryData, TQueryKey, TPageParam>, 'structuralSharing'> {
|
|
4
|
+
/**
|
|
5
|
+
* Set this to a reconciliation key to enable reconciliation between query results.
|
|
6
|
+
* Set this to `false` to disable reconciliation between query results.
|
|
7
|
+
* Set this to a function which accepts the old and new data and returns resolved data of the same type to implement custom reconciliation logic.
|
|
8
|
+
* Defaults reconciliation key to `id`.
|
|
9
|
+
*/
|
|
10
|
+
reconcile?: string | false | ((oldData: TData | undefined, newData: TData) => TData);
|
|
11
|
+
}
|
|
12
|
+
export interface InfiniteQueryObserverOptions<TQueryFnData = unknown, TError = DefaultError, TData = TQueryFnData, TQueryData = TQueryFnData, TQueryKey extends QueryKey = QueryKey, TPageParam = unknown> extends Omit<QueryCoreInfiniteQueryObserverOptions<TQueryFnData, TError, TData, TQueryData, TQueryKey, TPageParam>, 'structuralSharing'> {
|
|
13
|
+
/**
|
|
14
|
+
* Set this to a reconciliation key to enable reconciliation between query results.
|
|
15
|
+
* Set this to `false` to disable reconciliation between query results.
|
|
16
|
+
* Set this to a function which accepts the old and new data and returns resolved data of the same type to implement custom reconciliation logic.
|
|
17
|
+
* Defaults reconciliation key to `id`.
|
|
18
|
+
*/
|
|
19
|
+
reconcile?: string | false | ((oldData: TData | undefined, newData: TData) => TData);
|
|
20
|
+
}
|
|
21
|
+
export interface DefaultOptions<TError = DefaultError> extends CoreDefaultOptions<TError> {
|
|
22
|
+
queries?: QueryObserverOptions<unknown, TError>;
|
|
23
|
+
}
|
|
24
|
+
export interface QueryClientConfig extends QueryCoreClientConfig {
|
|
25
|
+
defaultOptions?: DefaultOptions;
|
|
26
|
+
}
|
|
27
|
+
export declare class QueryClient extends QueryCoreClient {
|
|
28
|
+
constructor(config?: QueryClientConfig);
|
|
29
|
+
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { QueryClient } from '
|
|
1
|
+
import type { QueryClient } from './QueryClient';
|
|
2
2
|
import type { JSX } from 'solid-js';
|
|
3
3
|
export declare const QueryClientContext: import("solid-js").Context<QueryClient | undefined>;
|
|
4
4
|
export declare const useQueryClient: (queryClient?: QueryClient) => QueryClient;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
2
|
import type { QueryClientConfig } from '@tanstack/query-core';
|
|
3
|
-
import { QueryClient } from '
|
|
3
|
+
import { QueryClient } from '../QueryClient';
|
|
4
4
|
import type { ParentProps } from 'solid-js';
|
|
5
5
|
export declare function queryKey(): Array<string>;
|
|
6
6
|
export declare const Blink: (props: {
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { QueryKey, QueryObserver, QueryObserverResult } from '@tanstack/query-core';
|
|
2
|
+
import type { QueryClient } from './QueryClient';
|
|
2
3
|
import type { Accessor } from 'solid-js';
|
|
3
4
|
import type { CreateBaseQueryOptions } from './types';
|
|
4
5
|
export declare function createBaseQuery<TQueryFnData, TError, TData, TQueryData, TQueryKey extends QueryKey>(options: Accessor<CreateBaseQueryOptions<TQueryFnData, TError, TData, TQueryData, TQueryKey>>, Observer: typeof QueryObserver, queryClient?: Accessor<QueryClient>): QueryObserverResult<TData, TError>;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import type { QueryKey,
|
|
1
|
+
import type { QueryKey, DefaultError, InfiniteData } from '@tanstack/query-core';
|
|
2
|
+
import type { QueryClient } from './QueryClient';
|
|
2
3
|
import type { CreateInfiniteQueryOptions, CreateInfiniteQueryResult } from './types';
|
|
3
4
|
import type { Accessor } from 'solid-js';
|
|
4
5
|
export declare function createInfiniteQuery<TQueryFnData, TError = DefaultError, TData = InfiniteData<TQueryFnData>, TQueryKey extends QueryKey = QueryKey, TPageParam = unknown>(options: CreateInfiniteQueryOptions<TQueryFnData, TError, TData, TQueryKey, TPageParam>, queryClient?: Accessor<QueryClient>): CreateInfiniteQueryResult<TData, TError>;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { DefaultError } from '@tanstack/query-core';
|
|
2
|
+
import type { QueryClient } from './QueryClient';
|
|
2
3
|
import type { CreateMutationOptions, CreateMutationResult } from './types';
|
|
3
4
|
import type { Accessor } from 'solid-js';
|
|
4
5
|
export declare function createMutation<TData = unknown, TError = DefaultError, TVariables = void, TContext = unknown>(options: CreateMutationOptions<TData, TError, TVariables, TContext>, queryClient?: Accessor<QueryClient>): CreateMutationResult<TData, TError, TVariables, TContext>;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import type { QueriesPlaceholderDataFunction,
|
|
1
|
+
import type { QueriesPlaceholderDataFunction, QueryFunction, QueryKey, DefaultError } from '@tanstack/query-core';
|
|
2
|
+
import type { QueryClient } from './QueryClient';
|
|
2
3
|
import type { Accessor } from 'solid-js';
|
|
3
4
|
import type { CreateQueryResult, SolidQueryOptions } from './types';
|
|
4
5
|
declare type CreateQueryOptionsForCreateQueries<TQueryFnData = unknown, TError = DefaultError, TData = TQueryFnData, TQueryKey extends QueryKey = QueryKey> = Omit<SolidQueryOptions<TQueryFnData, TError, TData, TQueryKey>, 'placeholderData'> & {
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { QueryKey, DefaultError } from '@tanstack/query-core';
|
|
2
|
+
import type { QueryClient } from './QueryClient';
|
|
2
3
|
import type { CreateQueryResult, DefinedCreateQueryResult, FunctionedParams, SolidQueryOptions } from './types';
|
|
3
4
|
declare type UndefinedInitialDataOptions<TQueryFnData = unknown, TError = DefaultError, TData = TQueryFnData, TQueryKey extends QueryKey = QueryKey> = FunctionedParams<SolidQueryOptions<TQueryFnData, TError, TData, TQueryKey> & {
|
|
4
5
|
initialData?: undefined;
|
package/build/types/index.d.ts
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import './setBatchUpdatesFn';
|
|
2
2
|
export * from '@tanstack/query-core';
|
|
3
3
|
export * from './types';
|
|
4
|
+
export { QueryClient } from './QueryClient';
|
|
5
|
+
export type { QueryObserverOptions, DefaultOptions, QueryClientConfig, InfiniteQueryObserverOptions, } from './QueryClient';
|
|
4
6
|
export { createQuery } from './createQuery';
|
|
5
7
|
export { QueryClientContext, QueryClientProvider, useQueryClient, } from './QueryClientProvider';
|
|
6
8
|
export type { QueryClientProviderProps } from './QueryClientProvider';
|
package/build/types/types.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import type { QueryKey,
|
|
1
|
+
import type { QueryKey, QueryObserverResult, MutateFunction, MutationObserverOptions, MutationObserverResult, DefinedQueryObserverResult, InfiniteQueryObserverResult, WithRequired, DefaultError } from '@tanstack/query-core';
|
|
2
|
+
import type { QueryObserverOptions, InfiniteQueryObserverOptions } from './QueryClient';
|
|
2
3
|
export declare type FunctionedParams<T> = () => T;
|
|
3
4
|
export interface CreateBaseQueryOptions<TQueryFnData = unknown, TError = DefaultError, TData = TQueryFnData, TQueryData = TQueryFnData, TQueryKey extends QueryKey = QueryKey> extends WithRequired<QueryObserverOptions<TQueryFnData, TError, TData, TQueryData, TQueryKey>, 'queryKey'> {
|
|
4
5
|
deferStream?: boolean;
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { QueryFilters } from '@tanstack/query-core';
|
|
2
|
+
import type { QueryClient } from './QueryClient';
|
|
2
3
|
import type { Accessor } from 'solid-js';
|
|
3
4
|
export declare function useIsFetching(filters?: Accessor<QueryFilters>, queryClient?: Accessor<QueryClient>): Accessor<number>;
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
import type { MutationFilters
|
|
1
|
+
import type { MutationFilters } from '@tanstack/query-core';
|
|
2
|
+
import type { QueryClient } from './QueryClient';
|
|
2
3
|
import type { Accessor } from 'solid-js';
|
|
3
4
|
export declare function useIsMutating(filters?: Accessor<MutationFilters>, queryClient?: Accessor<QueryClient>): Accessor<number>;
|
package/build/umd/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@tanstack/query-core"),require("solid-js"),require("solid-js/web"),require("solid-js/store")):"function"==typeof define&&define.amd?define(["exports","@tanstack/query-core","solid-js","solid-js/web","solid-js/store"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).index={},e.QueryCore,e.Solid,e.SolidWeb,e.SolidStore)}(this,(function(e,t,r,n,o){"use strict";t.notifyManager.setBatchNotifyFunction(r.batch);
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@tanstack/query-core"),require("solid-js"),require("solid-js/web"),require("solid-js/store")):"function"==typeof define&&define.amd?define(["exports","@tanstack/query-core","solid-js","solid-js/web","solid-js/store"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).index={},e.QueryCore,e.Solid,e.SolidWeb,e.SolidStore)}(this,(function(e,t,r,n,o){"use strict";t.notifyManager.setBatchNotifyFunction(r.batch);class i extends t.QueryClient{constructor(e={}){super(e)}}const s=r.createContext(void 0),u=e=>{const t=r.useContext(s);if(e)return e;if(!t)throw new Error("No QueryClient set, use QueryClientProvider to set one");return t};function a(e,t){return"function"==typeof e?e(...t):!!e}function c(e,t,r){if(!1===r)return t;if("function"==typeof r){const n=r(e.data,t.data);return{...t,data:n}}const n=o.reconcile(t.data,{key:r})(e.data);return{...t,data:n}}function l(e,i,s){const l=r.createMemo((()=>u(s?.()))),d=l().defaultQueryOptions(e());d._optimisticResults="optimistic",d.structuralSharing=!1,n.isServer&&(d.retry=!1,d.throwErrors=!0);const f=new i(l(),d),[p,y]=o.createStore(f.getOptimisticResult(d)),m=()=>f.subscribe((e=>{t.notifyManager.batchCalls((()=>{const t=f.options.reconcile;C()?.data&&e.data&&!C.loading?(y((r=>c(r,e,void 0===t?"id":t))),b(p)):(y((r=>c(r,e,void 0===t?"id":t))),g())}))()}));let h=null;const[C,{refetch:g,mutate:b}]=r.createResource((()=>new Promise(((e,r)=>{n.isServer?h=((e,r)=>f.subscribe((n=>{t.notifyManager.batchCalls((()=>{const t=f.getCurrentQuery(),{refetch:i,...s}=o.unwrap(n),u={...s,dataUpdateCount:t.state.dataUpdateCount,fetchFailureCount:t.state.fetchFailureCount,fetchFailureReason:t.state.fetchFailureReason,fetchMeta:t.state.fetchMeta,isInvalidated:t.state.isInvalidated};u.isError&&("development"===process.env.NODE_ENV&&console.error(u.error),r(u.error)),u.isSuccess&&e(u)}))()})))(e,r):h||(h=m()),p.isLoading||e(p)}))),{initialValue:p,ssrLoadFrom:e().initialData?"initial":"server",get deferStream(){return e().deferStream},onHydrated(e,r){if(r.value&&t.hydrate(l(),{queries:[{queryKey:d.queryKey,queryHash:d.queryHash,state:r.value}]}),!h){const e={...d};!d.staleTime&&d.initialData||(e.refetchOnMount=!1),f.setOptions(e),y(f.getOptimisticResult(e)),h=m()}}});r.onCleanup((()=>{h&&(h(),h=null)})),r.createComputed(r.on((()=>l().defaultQueryOptions(e())),(()=>f.setOptions(l().defaultQueryOptions(e()))),{defer:!0})),r.createComputed(r.on((()=>p.status),(()=>{if(p.isError&&!p.isFetching&&a(f.options.throwErrors,[p.error,f.getCurrentQuery()]))throw p.error})));return new Proxy(p,{get(e,t){const r=C()?.[t];return void 0!==r?r:Reflect.get(e,t)}})}function d(){}e.QueryClient=i,e.QueryClientContext=s,e.QueryClientProvider=e=>(r.onMount((()=>{e.client.mount()})),r.onCleanup((()=>e.client.unmount())),n.createComponent(s.Provider,{get value(){return e.client},get children(){return e.children}})),e.createInfiniteQuery=function(e,n){return l(r.createMemo((()=>e())),t.InfiniteQueryObserver,n)},e.createMutation=function(e,n){const i=u(n?.()),s=new t.MutationObserver(i,e()),c=(e,t)=>{s.mutate(e,t).catch(d)},[l,f]=o.createStore({...s.getCurrentResult(),mutate:c,mutateAsync:s.getCurrentResult().mutate});r.createComputed((()=>{s.setOptions(e())})),r.createComputed(r.on((()=>l.status),(()=>{if(l.isError&&a(s.options.throwErrors,[l.error]))throw l.error})));const p=s.subscribe((e=>{f({...e,mutate:c,mutateAsync:e.mutate})}));return r.onCleanup(p),l},e.createQueries=function(e,n){const i=u(n?.()),s=e().queries.map((e=>{const t=i.defaultQueryOptions(e);return t._optimisticResults="optimistic",t})),a=new t.QueriesObserver(i,s),[c,l]=o.createStore(a.getOptimisticResult(s)),d=a.subscribe((e=>{t.notifyManager.batchCalls((()=>{l(o.unwrap(e))}))()}));return r.onCleanup(d),r.onMount((()=>{a.setQueries(s,{listeners:!1})})),r.createComputed((()=>{const t=e().queries.map((e=>{const t=i.defaultQueryOptions(e);return t._optimisticResults="optimistic",t}));a.setQueries(t)})),c},e.createQuery=function(e,n){return l(r.createMemo((()=>e())),t.QueryObserver,n)},e.useIsFetching=function(e,t){const n=r.createMemo((()=>u(t?.()))),o=r.createMemo((()=>n().getQueryCache())),[i,s]=r.createSignal(n().isFetching(e?.())),a=o().subscribe((()=>{s(n().isFetching(e?.()))}));return r.onCleanup(a),i},e.useIsMutating=function(e,t){const n=r.createMemo((()=>u(t?.()))),o=r.createMemo((()=>n().getMutationCache())),[i,s]=r.createSignal(n().isMutating(e?.())),a=o().subscribe((t=>{s(n().isMutating(e?.()))}));return r.onCleanup(a),i},e.useQueryClient=u,Object.keys(t).forEach((function(r){"default"===r||e.hasOwnProperty(r)||Object.defineProperty(e,r,{enumerable:!0,get:function(){return t[r]}})}))}));
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/build/umd/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../src/setBatchUpdatesFn.ts","../../src/QueryClientProvider.tsx","../../src/utils.ts","../../src/createBaseQuery.ts","../../src/createMutation.ts","../../src/createInfiniteQuery.ts","../../src/createQueries.ts","../../src/createQuery.ts","../../src/useIsFetching.ts","../../src/useIsMutating.ts"],"sourcesContent":["import { notifyManager } from '@tanstack/query-core'\nimport { batch } from 'solid-js'\n\nnotifyManager.setBatchNotifyFunction(batch)\n","import type { QueryClient } from '@tanstack/query-core'\nimport type { JSX } from 'solid-js'\nimport { createContext, useContext, onMount, onCleanup } from 'solid-js'\n\nexport const QueryClientContext = createContext<QueryClient | undefined>(\n undefined,\n)\n\nexport const useQueryClient = (queryClient?: QueryClient) => {\n const client = useContext(QueryClientContext)\n\n if (queryClient) {\n return queryClient\n }\n\n if (!client) {\n throw new Error('No QueryClient set, use QueryClientProvider to set one')\n }\n\n return client\n}\n\nexport type QueryClientProviderProps = {\n client: QueryClient\n children?: JSX.Element\n}\n\nexport const QueryClientProvider = (\n props: QueryClientProviderProps,\n): JSX.Element => {\n onMount(() => {\n props.client.mount()\n })\n onCleanup(() => props.client.unmount())\n\n return (\n <QueryClientContext.Provider value={props.client}>\n {props.children}\n </QueryClientContext.Provider>\n )\n}\n","export function shouldThrowError<T extends (...args: any[]) => boolean>(\n throwError: boolean | T | undefined,\n params: Parameters<T>,\n): boolean {\n // Allow throwError function to override throwing behavior on a per-error basis\n if (typeof throwError === 'function') {\n return throwError(...params)\n }\n\n return !!throwError\n}\n","/* eslint-disable @typescript-eslint/no-unnecessary-condition */\n// Had to disable the lint rule because isServer type is defined as false\n// in solid-js/web package. I'll create a GitHub issue with them to see\n// why that happens.\nimport type {\n QueryClient,\n QueryKey,\n QueryObserver,\n QueryObserverResult,\n} from '@tanstack/query-core'\nimport { hydrate } from '@tanstack/query-core'\nimport { notifyManager } from '@tanstack/query-core'\nimport type { Accessor } from 'solid-js'\nimport { isServer } from 'solid-js/web'\nimport {\n createComputed,\n createMemo,\n createResource,\n on,\n onCleanup,\n} from 'solid-js'\nimport { createStore, unwrap } from 'solid-js/store'\nimport { useQueryClient } from './QueryClientProvider'\nimport type { CreateBaseQueryOptions } from './types'\nimport { shouldThrowError } from './utils'\n\n// Base Query Function that is used to create the query.\nexport function createBaseQuery<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey extends QueryKey,\n>(\n options: Accessor<\n CreateBaseQueryOptions<TQueryFnData, TError, TData, TQueryData, TQueryKey>\n >,\n Observer: typeof QueryObserver,\n queryClient?: Accessor<QueryClient>,\n) {\n const client = createMemo(() => useQueryClient(queryClient?.()))\n\n const defaultedOptions = client().defaultQueryOptions(options())\n defaultedOptions._optimisticResults = 'optimistic'\n if (isServer) {\n defaultedOptions.retry = false\n defaultedOptions.throwErrors = true\n }\n const observer = new Observer(client(), defaultedOptions)\n\n const [state, setState] = createStore<QueryObserverResult<TData, TError>>(\n observer.getOptimisticResult(defaultedOptions),\n )\n\n const createServerSubscriber = (\n resolve: (\n data:\n | QueryObserverResult<TData, TError>\n | PromiseLike<QueryObserverResult<TData, TError> | undefined>\n | undefined,\n ) => void,\n reject: (reason?: any) => void,\n ) => {\n return observer.subscribe((result) => {\n notifyManager.batchCalls(() => {\n const query = observer.getCurrentQuery()\n const { refetch, ...rest } = unwrap(result)\n const unwrappedResult = {\n ...rest,\n\n // hydrate() expects a QueryState object, which is similar but not\n // quite the same as a QueryObserverResult object. Thus, for now, we're\n // copying over the missing properties from state in order to support hydration\n dataUpdateCount: query.state.dataUpdateCount,\n fetchFailureCount: query.state.fetchFailureCount,\n fetchFailureReason: query.state.fetchFailureReason,\n fetchMeta: query.state.fetchMeta,\n isInvalidated: query.state.isInvalidated,\n }\n\n if (unwrappedResult.isError) {\n if (process.env['NODE_ENV'] === 'development') {\n console.error(unwrappedResult.error)\n }\n reject(unwrappedResult.error)\n }\n if (unwrappedResult.isSuccess) {\n // Use of any here is fine\n // We cannot include refetch since it is not serializable\n resolve(unwrappedResult as any)\n }\n })()\n })\n }\n\n const createClientSubscriber = () => {\n return observer.subscribe((result) => {\n notifyManager.batchCalls(() => {\n const unwrappedResult = { ...unwrap(result) }\n // If the query has data we dont suspend but instead mutate the resource\n // This could happen when placeholderData/initialData is defined\n if (\n queryResource()?.data &&\n unwrappedResult.data &&\n !queryResource.loading\n ) {\n setState(unwrappedResult)\n mutate(state)\n } else {\n setState(unwrappedResult)\n refetch()\n }\n })()\n })\n }\n\n /**\n * Unsubscribe is set lazily, so that we can subscribe after hydration when needed.\n */\n let unsubscribe: (() => void) | null = null\n\n const [queryResource, { refetch, mutate }] = createResource<\n QueryObserverResult<TData, TError> | undefined\n >(\n () => {\n return new Promise((resolve, reject) => {\n if (isServer) {\n unsubscribe = createServerSubscriber(resolve, reject)\n } else {\n if (!unsubscribe) {\n unsubscribe = createClientSubscriber()\n }\n }\n if (!state.isLoading) {\n resolve(state)\n }\n })\n },\n {\n initialValue: state,\n\n // If initialData is provided, we resolve the resource immediately\n ssrLoadFrom: options().initialData ? 'initial' : 'server',\n\n get deferStream() {\n return options().deferStream\n },\n\n /**\n * If this resource was populated on the server (either sync render, or streamed in over time), onHydrated\n * will be called. This is the point at which we can hydrate the query cache state, and setup the query subscriber.\n *\n * Leveraging onHydrated allows us to plug into the async and streaming support that solidjs resources already support.\n *\n * Note that this is only invoked on the client, for queries that were originally run on the server.\n */\n onHydrated(_k, info) {\n if (info.value) {\n hydrate(client(), {\n queries: [\n {\n queryKey: defaultedOptions.queryKey,\n queryHash: defaultedOptions.queryHash,\n state: info.value,\n },\n ],\n })\n }\n\n if (!unsubscribe) {\n /**\n * Do not refetch query on mount if query was fetched on server,\n * even if `staleTime` is not set.\n */\n const newOptions = { ...defaultedOptions }\n if (defaultedOptions.staleTime || !defaultedOptions.initialData) {\n newOptions.refetchOnMount = false\n }\n // Setting the options as an immutable object to prevent\n // wonky behavior with observer subscriptions\n observer.setOptions(newOptions)\n setState(observer.getOptimisticResult(newOptions))\n unsubscribe = createClientSubscriber()\n }\n },\n },\n )\n\n onCleanup(() => {\n if (unsubscribe) {\n unsubscribe()\n unsubscribe = null\n }\n })\n\n createComputed(\n on(\n () => client().defaultQueryOptions(options()),\n () => observer.setOptions(client().defaultQueryOptions(options())),\n {\n // Defer because we don't need to trigger on first render\n // This only cares about changes to options after the observer is created\n defer: true,\n },\n ),\n )\n\n createComputed(\n on(\n () => state.status,\n () => {\n if (\n state.isError &&\n !state.isFetching &&\n shouldThrowError(observer.options.throwErrors, [\n state.error,\n observer.getCurrentQuery(),\n ])\n ) {\n throw state.error\n }\n },\n ),\n )\n\n const handler = {\n get(\n target: QueryObserverResult<TData, TError>,\n prop: keyof QueryObserverResult<TData, TError>,\n ): any {\n const val = queryResource()?.[prop]\n return val !== undefined ? val : Reflect.get(target, prop)\n },\n }\n\n return new Proxy(state, handler)\n}\n","import type { QueryClient, DefaultError } from '@tanstack/query-core'\nimport { MutationObserver } from '@tanstack/query-core'\nimport { useQueryClient } from './QueryClientProvider'\nimport type {\n CreateMutateFunction,\n CreateMutationOptions,\n CreateMutationResult,\n} from './types'\nimport type { Accessor } from 'solid-js'\nimport { createComputed, onCleanup, on } from 'solid-js'\nimport { createStore } from 'solid-js/store'\nimport { shouldThrowError } from './utils'\n\n// HOOK\nexport function createMutation<\n TData = unknown,\n TError = DefaultError,\n TVariables = void,\n TContext = unknown,\n>(\n options: CreateMutationOptions<TData, TError, TVariables, TContext>,\n queryClient?: Accessor<QueryClient>,\n): CreateMutationResult<TData, TError, TVariables, TContext> {\n const client = useQueryClient(queryClient?.())\n\n const observer = new MutationObserver<TData, TError, TVariables, TContext>(\n client,\n options(),\n )\n\n const mutate: CreateMutateFunction<TData, TError, TVariables, TContext> = (\n variables,\n mutateOptions,\n ) => {\n observer.mutate(variables, mutateOptions).catch(noop)\n }\n\n const [state, setState] = createStore<\n CreateMutationResult<TData, TError, TVariables, TContext>\n >({\n ...observer.getCurrentResult(),\n mutate,\n mutateAsync: observer.getCurrentResult().mutate,\n })\n\n createComputed(() => {\n observer.setOptions(options())\n })\n\n createComputed(\n on(\n () => state.status,\n () => {\n if (\n state.isError &&\n shouldThrowError(observer.options.throwErrors, [state.error])\n ) {\n throw state.error\n }\n },\n ),\n )\n\n const unsubscribe = observer.subscribe((result) => {\n setState({\n ...result,\n mutate,\n mutateAsync: result.mutate,\n })\n })\n\n onCleanup(unsubscribe)\n\n return state\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n","import type {\n QueryObserver,\n QueryKey,\n QueryClient,\n DefaultError,\n InfiniteData,\n} from '@tanstack/query-core'\nimport { InfiniteQueryObserver } from '@tanstack/query-core'\nimport type {\n CreateInfiniteQueryOptions,\n CreateInfiniteQueryResult,\n} from './types'\nimport { createBaseQuery } from './createBaseQuery'\nimport { createMemo } from 'solid-js'\nimport type { Accessor } from 'solid-js'\n\nexport function createInfiniteQuery<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n >,\n queryClient?: Accessor<QueryClient>,\n): CreateInfiniteQueryResult<TData, TError> {\n return createBaseQuery(\n createMemo(() => options()),\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n InfiniteQueryObserver as typeof QueryObserver,\n queryClient,\n ) as CreateInfiniteQueryResult<TData, TError>\n}\n","import type {\n QueriesPlaceholderDataFunction,\n QueryClient,\n QueryFunction,\n QueryKey,\n DefaultError,\n} from '@tanstack/query-core'\nimport { notifyManager, QueriesObserver } from '@tanstack/query-core'\nimport type { Accessor } from 'solid-js'\nimport { createComputed, onCleanup, onMount } from 'solid-js'\nimport { createStore, unwrap } from 'solid-js/store'\nimport { useQueryClient } from './QueryClientProvider'\nimport type { CreateQueryResult, SolidQueryOptions } from './types'\n\n// This defines the `UseQueryOptions` that are accepted in `QueriesOptions` & `GetOptions`.\n// `placeholderData` function does not have a parameter\ntype CreateQueryOptionsForCreateQueries<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = Omit<\n SolidQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'placeholderData'\n> & {\n placeholderData?: TQueryFnData | QueriesPlaceholderDataFunction<TQueryFnData>\n}\n\n// Avoid TS depth-limit error in case of large array literal\ntype MAXIMUM_DEPTH = 20\n\ntype GetOptions<T> =\n // Part 1: responsible for applying explicit type parameter to function arguments, if object { queryFnData: TQueryFnData, error: TError, data: TData }\n T extends {\n queryFnData: infer TQueryFnData\n error?: infer TError\n data: infer TData\n }\n ? CreateQueryOptionsForCreateQueries<TQueryFnData, TError, TData>\n : T extends { queryFnData: infer TQueryFnData; error?: infer TError }\n ? CreateQueryOptionsForCreateQueries<TQueryFnData, TError>\n : T extends { data: infer TData; error?: infer TError }\n ? CreateQueryOptionsForCreateQueries<unknown, TError, TData>\n : // Part 2: responsible for applying explicit type parameter to function arguments, if tuple [TQueryFnData, TError, TData]\n T extends [infer TQueryFnData, infer TError, infer TData]\n ? CreateQueryOptionsForCreateQueries<TQueryFnData, TError, TData>\n : T extends [infer TQueryFnData, infer TError]\n ? CreateQueryOptionsForCreateQueries<TQueryFnData, TError>\n : T extends [infer TQueryFnData]\n ? CreateQueryOptionsForCreateQueries<TQueryFnData>\n : // Part 3: responsible for inferring and enforcing type if no explicit parameter was provided\n T extends {\n queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey>\n select: (data: any) => infer TData\n }\n ? CreateQueryOptionsForCreateQueries<TQueryFnData, Error, TData, TQueryKey>\n : T extends { queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey> }\n ? CreateQueryOptionsForCreateQueries<\n TQueryFnData,\n Error,\n TQueryFnData,\n TQueryKey\n >\n : // Fallback\n CreateQueryOptionsForCreateQueries\n\ntype GetResults<T> =\n // Part 1: responsible for mapping explicit type parameter to function result, if object\n T extends { queryFnData: any; error?: infer TError; data: infer TData }\n ? CreateQueryResult<TData, TError>\n : T extends { queryFnData: infer TQueryFnData; error?: infer TError }\n ? CreateQueryResult<TQueryFnData, TError>\n : T extends { data: infer TData; error?: infer TError }\n ? CreateQueryResult<TData, TError>\n : // Part 2: responsible for mapping explicit type parameter to function result, if tuple\n T extends [any, infer TError, infer TData]\n ? CreateQueryResult<TData, TError>\n : T extends [infer TQueryFnData, infer TError]\n ? CreateQueryResult<TQueryFnData, TError>\n : T extends [infer TQueryFnData]\n ? CreateQueryResult<TQueryFnData>\n : // Part 3: responsible for mapping inferred type to results, if no explicit parameter was provided\n T extends {\n queryFn?: QueryFunction<unknown, any>\n select: (data: any) => infer TData\n }\n ? CreateQueryResult<TData>\n : T extends { queryFn?: QueryFunction<infer TQueryFnData, any> }\n ? CreateQueryResult<TQueryFnData>\n : // Fallback\n CreateQueryResult\n\n/**\n * QueriesOptions reducer recursively unwraps function arguments to infer/enforce type param\n */\nexport type QueriesOptions<\n T extends any[],\n Result extends any[] = [],\n Depth extends ReadonlyArray<number> = [],\n> = Depth['length'] extends MAXIMUM_DEPTH\n ? CreateQueryOptionsForCreateQueries[]\n : T extends []\n ? []\n : T extends [infer Head]\n ? [...Result, GetOptions<Head>]\n : T extends [infer Head, ...infer Tail]\n ? QueriesOptions<[...Tail], [...Result, GetOptions<Head>], [...Depth, 1]>\n : unknown[] extends T\n ? T\n : // If T is *some* array but we couldn't assign unknown[] to it, then it must hold some known/homogenous type!\n // use this to infer the param types in the case of Array.map() argument\n T extends CreateQueryOptionsForCreateQueries<\n infer TQueryFnData,\n infer TError,\n infer TData,\n infer TQueryKey\n >[]\n ? CreateQueryOptionsForCreateQueries<TQueryFnData, TError, TData, TQueryKey>[]\n : // Fallback\n CreateQueryOptionsForCreateQueries[]\n\n/**\n * QueriesResults reducer recursively maps type param to results\n */\nexport type QueriesResults<\n T extends any[],\n Result extends any[] = [],\n Depth extends ReadonlyArray<number> = [],\n> = Depth['length'] extends MAXIMUM_DEPTH\n ? CreateQueryResult[]\n : T extends []\n ? []\n : T extends [infer Head]\n ? [...Result, GetResults<Head>]\n : T extends [infer Head, ...infer Tail]\n ? QueriesResults<[...Tail], [...Result, GetResults<Head>], [...Depth, 1]>\n : T extends CreateQueryOptionsForCreateQueries<\n infer TQueryFnData,\n infer TError,\n infer TData,\n any\n >[]\n ? // Dynamic-size (homogenous) UseQueryOptions array: map directly to array of results\n CreateQueryResult<\n unknown extends TData ? TQueryFnData : TData,\n unknown extends TError ? DefaultError : TError\n >[]\n : // Fallback\n CreateQueryResult[]\n\nexport function createQueries<T extends any[]>(\n queriesOptions: Accessor<{\n queries: readonly [...QueriesOptions<T>]\n }>,\n queryClient?: Accessor<QueryClient>,\n): QueriesResults<T> {\n const client = useQueryClient(queryClient?.())\n\n const defaultedQueries = queriesOptions().queries.map((options) => {\n const defaultedOptions = client.defaultQueryOptions(options)\n defaultedOptions._optimisticResults = 'optimistic'\n return defaultedOptions\n })\n\n const observer = new QueriesObserver(client, defaultedQueries)\n\n const [state, setState] = createStore(\n observer.getOptimisticResult(defaultedQueries),\n )\n\n const unsubscribe = observer.subscribe((result) => {\n notifyManager.batchCalls(() => {\n setState(unwrap(result))\n })()\n })\n\n onCleanup(unsubscribe)\n\n onMount(() => {\n observer.setQueries(defaultedQueries, { listeners: false })\n })\n\n createComputed(() => {\n const updatedQueries = queriesOptions().queries.map((options) => {\n const defaultedOptions = client.defaultQueryOptions(options)\n defaultedOptions._optimisticResults = 'optimistic'\n return defaultedOptions\n })\n observer.setQueries(updatedQueries)\n })\n\n return state as QueriesResults<T>\n}\n","import type { QueryClient, QueryKey, DefaultError } from '@tanstack/query-core'\nimport { QueryObserver } from '@tanstack/query-core'\nimport type { Accessor } from 'solid-js'\nimport { createMemo } from 'solid-js'\nimport { createBaseQuery } from './createBaseQuery'\nimport type {\n CreateQueryOptions,\n CreateQueryResult,\n DefinedCreateQueryResult,\n FunctionedParams,\n SolidQueryOptions,\n} from './types'\n\ntype UndefinedInitialDataOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = FunctionedParams<\n SolidQueryOptions<TQueryFnData, TError, TData, TQueryKey> & {\n initialData?: undefined\n }\n>\n\ntype DefinedInitialDataOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = FunctionedParams<\n SolidQueryOptions<TQueryFnData, TError, TData, TQueryKey> & {\n initialData: TQueryFnData | (() => TQueryFnData)\n }\n>\n\nexport function createQuery<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: UndefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,\n queryClient?: () => QueryClient,\n): CreateQueryResult<TData, TError>\n\nexport function createQuery<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: DefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,\n queryClient?: () => QueryClient,\n): DefinedCreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n queryClient?: Accessor<QueryClient>,\n) {\n return createBaseQuery(\n createMemo(() => options()),\n QueryObserver,\n queryClient,\n )\n}\n","import type { QueryClient, QueryFilters } from '@tanstack/query-core'\nimport type { Accessor } from 'solid-js'\nimport { createMemo, createSignal, onCleanup } from 'solid-js'\nimport { useQueryClient } from './QueryClientProvider'\n\nexport function useIsFetching(\n filters?: Accessor<QueryFilters>,\n queryClient?: Accessor<QueryClient>,\n): Accessor<number> {\n const client = createMemo(() => useQueryClient(queryClient?.()))\n const queryCache = createMemo(() => client().getQueryCache())\n\n const [fetches, setFetches] = createSignal(client().isFetching(filters?.()))\n\n const unsubscribe = queryCache().subscribe(() => {\n setFetches(client().isFetching(filters?.()))\n })\n\n onCleanup(unsubscribe)\n\n return fetches\n}\n","import type { MutationFilters, QueryClient } from '@tanstack/query-core'\nimport { useQueryClient } from './QueryClientProvider'\nimport type { Accessor } from 'solid-js'\nimport { createSignal, onCleanup, createMemo } from 'solid-js'\n\nexport function useIsMutating(\n filters?: Accessor<MutationFilters>,\n queryClient?: Accessor<QueryClient>,\n): Accessor<number> {\n const client = createMemo(() => useQueryClient(queryClient?.()))\n const mutationCache = createMemo(() => client().getMutationCache())\n\n const [mutations, setMutations] = createSignal(\n client().isMutating(filters?.()),\n )\n\n const unsubscribe = mutationCache().subscribe((_result) => {\n setMutations(client().isMutating(filters?.()))\n })\n\n onCleanup(unsubscribe)\n\n return mutations\n}\n"],"names":["notifyManager","setBatchNotifyFunction","batch","QueryClientContext","createContext","undefined","useQueryClient","queryClient","client","useContext","Error","shouldThrowError","throwError","params","createBaseQuery","options","Observer","createMemo","defaultedOptions","defaultQueryOptions","_optimisticResults","isServer","retry","throwErrors","observer","state","setState","createStore","getOptimisticResult","createClientSubscriber","subscribe","result","batchCalls","unwrappedResult","unwrap","queryResource","data","loading","mutate","refetch","unsubscribe","createResource","Promise","resolve","reject","query","getCurrentQuery","rest","dataUpdateCount","fetchFailureCount","fetchFailureReason","fetchMeta","isInvalidated","isError","process","env","console","error","isSuccess","createServerSubscriber","isLoading","initialValue","ssrLoadFrom","initialData","deferStream","onHydrated","_k","info","value","hydrate","queries","queryKey","queryHash","newOptions","staleTime","refetchOnMount","setOptions","onCleanup","createComputed","on","defer","status","isFetching","Proxy","get","target","prop","val","Reflect","noop","props","onMount","mount","unmount","_$createComponent","createComponent","Provider","children","InfiniteQueryObserver","MutationObserver","variables","mutateOptions","catch","getCurrentResult","mutateAsync","queriesOptions","defaultedQueries","map","QueriesObserver","setQueries","listeners","updatedQueries","QueryObserver","filters","queryCache","getQueryCache","fetches","setFetches","createSignal","mutationCache","getMutationCache","mutations","setMutations","isMutating","_result"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/setBatchUpdatesFn.ts","../../src/QueryClient.ts","../../src/QueryClientProvider.tsx","../../src/utils.ts","../../src/createBaseQuery.ts","../../src/createMutation.ts","../../src/createInfiniteQuery.ts","../../src/createQueries.ts","../../src/createQuery.ts","../../src/useIsFetching.ts","../../src/useIsMutating.ts"],"sourcesContent":["import { notifyManager } from '@tanstack/query-core'\nimport { batch } from 'solid-js'\n\nnotifyManager.setBatchNotifyFunction(batch)\n","import type {\n QueryClientConfig as QueryCoreClientConfig,\n DefaultOptions as CoreDefaultOptions,\n QueryObserverOptions as QueryCoreObserverOptions,\n InfiniteQueryObserverOptions as QueryCoreInfiniteQueryObserverOptions,\n DefaultError,\n QueryKey,\n} from '@tanstack/query-core'\nimport { QueryClient as QueryCoreClient } from '@tanstack/query-core'\n\nexport interface QueryObserverOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = never,\n> extends Omit<\n QueryCoreObserverOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey,\n TPageParam\n >,\n 'structuralSharing'\n > {\n /**\n * Set this to a reconciliation key to enable reconciliation between query results.\n * Set this to `false` to disable reconciliation between query results.\n * Set this to a function which accepts the old and new data and returns resolved data of the same type to implement custom reconciliation logic.\n * Defaults reconciliation key to `id`.\n */\n reconcile?:\n | string\n | false\n | ((oldData: TData | undefined, newData: TData) => TData)\n}\n\nexport interface InfiniteQueryObserverOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n> extends Omit<\n QueryCoreInfiniteQueryObserverOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey,\n TPageParam\n >,\n 'structuralSharing'\n > {\n /**\n * Set this to a reconciliation key to enable reconciliation between query results.\n * Set this to `false` to disable reconciliation between query results.\n * Set this to a function which accepts the old and new data and returns resolved data of the same type to implement custom reconciliation logic.\n * Defaults reconciliation key to `id`.\n */\n reconcile?:\n | string\n | false\n | ((oldData: TData | undefined, newData: TData) => TData)\n}\n\nexport interface DefaultOptions<TError = DefaultError>\n extends CoreDefaultOptions<TError> {\n queries?: QueryObserverOptions<unknown, TError>\n}\n\nexport interface QueryClientConfig extends QueryCoreClientConfig {\n defaultOptions?: DefaultOptions\n}\n\nexport class QueryClient extends QueryCoreClient {\n constructor(config: QueryClientConfig = {}) {\n super(config)\n }\n}\n","import type { QueryClient } from './QueryClient'\nimport type { JSX } from 'solid-js'\nimport { createContext, useContext, onMount, onCleanup } from 'solid-js'\n\nexport const QueryClientContext = createContext<QueryClient | undefined>(\n undefined,\n)\n\nexport const useQueryClient = (queryClient?: QueryClient) => {\n const client = useContext(QueryClientContext)\n\n if (queryClient) {\n return queryClient\n }\n\n if (!client) {\n throw new Error('No QueryClient set, use QueryClientProvider to set one')\n }\n\n return client\n}\n\nexport type QueryClientProviderProps = {\n client: QueryClient\n children?: JSX.Element\n}\n\nexport const QueryClientProvider = (\n props: QueryClientProviderProps,\n): JSX.Element => {\n onMount(() => {\n props.client.mount()\n })\n onCleanup(() => props.client.unmount())\n\n return (\n <QueryClientContext.Provider value={props.client}>\n {props.children}\n </QueryClientContext.Provider>\n )\n}\n","export function shouldThrowError<T extends (...args: any[]) => boolean>(\n throwError: boolean | T | undefined,\n params: Parameters<T>,\n): boolean {\n // Allow throwError function to override throwing behavior on a per-error basis\n if (typeof throwError === 'function') {\n return throwError(...params)\n }\n\n return !!throwError\n}\n","/* eslint-disable @typescript-eslint/no-unnecessary-condition */\n// Had to disable the lint rule because isServer type is defined as false\n// in solid-js/web package. I'll create a GitHub issue with them to see\n// why that happens.\nimport type {\n QueryKey,\n QueryObserver,\n QueryObserverResult,\n} from '@tanstack/query-core'\nimport type { QueryClient } from './QueryClient'\nimport { hydrate } from '@tanstack/query-core'\nimport { notifyManager } from '@tanstack/query-core'\nimport type { Accessor } from 'solid-js'\nimport { isServer } from 'solid-js/web'\nimport {\n createComputed,\n createMemo,\n createResource,\n on,\n onCleanup,\n} from 'solid-js'\nimport { createStore, reconcile, unwrap } from 'solid-js/store'\nimport { useQueryClient } from './QueryClientProvider'\nimport type { CreateBaseQueryOptions } from './types'\nimport { shouldThrowError } from './utils'\n\nfunction reconcileFn<TData, TError>(\n store: QueryObserverResult<TData, TError>,\n result: QueryObserverResult<TData, TError>,\n reconcileOption:\n | string\n | false\n | ((oldData: TData | undefined, newData: TData) => TData),\n): QueryObserverResult<TData, TError> {\n if (reconcileOption === false) return result\n if (typeof reconcileOption === 'function') {\n const newData = reconcileOption(store.data, result.data as TData)\n return { ...result, data: newData } as typeof result\n }\n const newData = reconcile(result.data, { key: reconcileOption })(store.data)\n return { ...result, data: newData } as typeof result\n}\n\n// Base Query Function that is used to create the query.\nexport function createBaseQuery<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey extends QueryKey,\n>(\n options: Accessor<\n CreateBaseQueryOptions<TQueryFnData, TError, TData, TQueryData, TQueryKey>\n >,\n Observer: typeof QueryObserver,\n queryClient?: Accessor<QueryClient>,\n) {\n const client = createMemo(() => useQueryClient(queryClient?.()))\n\n const defaultedOptions = client().defaultQueryOptions(options())\n defaultedOptions._optimisticResults = 'optimistic'\n defaultedOptions.structuralSharing = false\n if (isServer) {\n defaultedOptions.retry = false\n defaultedOptions.throwErrors = true\n }\n const observer = new Observer(client(), defaultedOptions)\n\n const [state, setState] = createStore<QueryObserverResult<TData, TError>>(\n observer.getOptimisticResult(defaultedOptions),\n )\n\n const createServerSubscriber = (\n resolve: (\n data:\n | QueryObserverResult<TData, TError>\n | PromiseLike<QueryObserverResult<TData, TError> | undefined>\n | undefined,\n ) => void,\n reject: (reason?: any) => void,\n ) => {\n return observer.subscribe((result) => {\n notifyManager.batchCalls(() => {\n const query = observer.getCurrentQuery()\n const { refetch, ...rest } = unwrap(result)\n const unwrappedResult = {\n ...rest,\n\n // hydrate() expects a QueryState object, which is similar but not\n // quite the same as a QueryObserverResult object. Thus, for now, we're\n // copying over the missing properties from state in order to support hydration\n dataUpdateCount: query.state.dataUpdateCount,\n fetchFailureCount: query.state.fetchFailureCount,\n fetchFailureReason: query.state.fetchFailureReason,\n fetchMeta: query.state.fetchMeta,\n isInvalidated: query.state.isInvalidated,\n }\n\n if (unwrappedResult.isError) {\n if (process.env['NODE_ENV'] === 'development') {\n console.error(unwrappedResult.error)\n }\n reject(unwrappedResult.error)\n }\n if (unwrappedResult.isSuccess) {\n // Use of any here is fine\n // We cannot include refetch since it is not serializable\n resolve(unwrappedResult as any)\n }\n })()\n })\n }\n\n const createClientSubscriber = () => {\n return observer.subscribe((result) => {\n notifyManager.batchCalls(() => {\n // @ts-expect-error - This will error because the reconcile option does not\n // exist on the query-core QueryObserverResult type\n const reconcileOptions = observer.options.reconcile\n // If the query has data we dont suspend but instead mutate the resource\n // This could happen when placeholderData/initialData is defined\n if (queryResource()?.data && result.data && !queryResource.loading) {\n setState((store) => {\n return reconcileFn(\n store,\n result,\n reconcileOptions === undefined ? 'id' : reconcileOptions,\n )\n })\n mutate(state)\n } else {\n setState((store) => {\n return reconcileFn(\n store,\n result,\n reconcileOptions === undefined ? 'id' : reconcileOptions,\n )\n })\n refetch()\n }\n })()\n })\n }\n\n /**\n * Unsubscribe is set lazily, so that we can subscribe after hydration when needed.\n */\n let unsubscribe: (() => void) | null = null\n\n const [queryResource, { refetch, mutate }] = createResource<\n QueryObserverResult<TData, TError> | undefined\n >(\n () => {\n return new Promise((resolve, reject) => {\n if (isServer) {\n unsubscribe = createServerSubscriber(resolve, reject)\n } else {\n if (!unsubscribe) {\n unsubscribe = createClientSubscriber()\n }\n }\n if (!state.isLoading) {\n resolve(state)\n }\n })\n },\n {\n initialValue: state,\n\n // If initialData is provided, we resolve the resource immediately\n ssrLoadFrom: options().initialData ? 'initial' : 'server',\n\n get deferStream() {\n return options().deferStream\n },\n\n /**\n * If this resource was populated on the server (either sync render, or streamed in over time), onHydrated\n * will be called. This is the point at which we can hydrate the query cache state, and setup the query subscriber.\n *\n * Leveraging onHydrated allows us to plug into the async and streaming support that solidjs resources already support.\n *\n * Note that this is only invoked on the client, for queries that were originally run on the server.\n */\n onHydrated(_k, info) {\n if (info.value) {\n hydrate(client(), {\n queries: [\n {\n queryKey: defaultedOptions.queryKey,\n queryHash: defaultedOptions.queryHash,\n state: info.value,\n },\n ],\n })\n }\n\n if (!unsubscribe) {\n /**\n * Do not refetch query on mount if query was fetched on server,\n * even if `staleTime` is not set.\n */\n const newOptions = { ...defaultedOptions }\n if (defaultedOptions.staleTime || !defaultedOptions.initialData) {\n newOptions.refetchOnMount = false\n }\n // Setting the options as an immutable object to prevent\n // wonky behavior with observer subscriptions\n observer.setOptions(newOptions)\n setState(observer.getOptimisticResult(newOptions))\n unsubscribe = createClientSubscriber()\n }\n },\n },\n )\n\n onCleanup(() => {\n if (unsubscribe) {\n unsubscribe()\n unsubscribe = null\n }\n })\n\n createComputed(\n on(\n () => client().defaultQueryOptions(options()),\n () => observer.setOptions(client().defaultQueryOptions(options())),\n {\n // Defer because we don't need to trigger on first render\n // This only cares about changes to options after the observer is created\n defer: true,\n },\n ),\n )\n\n createComputed(\n on(\n () => state.status,\n () => {\n if (\n state.isError &&\n !state.isFetching &&\n shouldThrowError(observer.options.throwErrors, [\n state.error,\n observer.getCurrentQuery(),\n ])\n ) {\n throw state.error\n }\n },\n ),\n )\n\n const handler = {\n get(\n target: QueryObserverResult<TData, TError>,\n prop: keyof QueryObserverResult<TData, TError>,\n ): any {\n const val = queryResource()?.[prop]\n return val !== undefined ? val : Reflect.get(target, prop)\n },\n }\n\n return new Proxy(state, handler)\n}\n","import type { DefaultError } from '@tanstack/query-core'\nimport type { QueryClient } from './QueryClient'\nimport { MutationObserver } from '@tanstack/query-core'\nimport { useQueryClient } from './QueryClientProvider'\nimport type {\n CreateMutateFunction,\n CreateMutationOptions,\n CreateMutationResult,\n} from './types'\nimport type { Accessor } from 'solid-js'\nimport { createComputed, onCleanup, on } from 'solid-js'\nimport { createStore } from 'solid-js/store'\nimport { shouldThrowError } from './utils'\n\n// HOOK\nexport function createMutation<\n TData = unknown,\n TError = DefaultError,\n TVariables = void,\n TContext = unknown,\n>(\n options: CreateMutationOptions<TData, TError, TVariables, TContext>,\n queryClient?: Accessor<QueryClient>,\n): CreateMutationResult<TData, TError, TVariables, TContext> {\n const client = useQueryClient(queryClient?.())\n\n const observer = new MutationObserver<TData, TError, TVariables, TContext>(\n client,\n options(),\n )\n\n const mutate: CreateMutateFunction<TData, TError, TVariables, TContext> = (\n variables,\n mutateOptions,\n ) => {\n observer.mutate(variables, mutateOptions).catch(noop)\n }\n\n const [state, setState] = createStore<\n CreateMutationResult<TData, TError, TVariables, TContext>\n >({\n ...observer.getCurrentResult(),\n mutate,\n mutateAsync: observer.getCurrentResult().mutate,\n })\n\n createComputed(() => {\n observer.setOptions(options())\n })\n\n createComputed(\n on(\n () => state.status,\n () => {\n if (\n state.isError &&\n shouldThrowError(observer.options.throwErrors, [state.error])\n ) {\n throw state.error\n }\n },\n ),\n )\n\n const unsubscribe = observer.subscribe((result) => {\n setState({\n ...result,\n mutate,\n mutateAsync: result.mutate,\n })\n })\n\n onCleanup(unsubscribe)\n\n return state\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n","import type {\n QueryObserver,\n QueryKey,\n DefaultError,\n InfiniteData,\n} from '@tanstack/query-core'\nimport type { QueryClient } from './QueryClient'\nimport { InfiniteQueryObserver } from '@tanstack/query-core'\nimport type {\n CreateInfiniteQueryOptions,\n CreateInfiniteQueryResult,\n} from './types'\nimport { createBaseQuery } from './createBaseQuery'\nimport { createMemo } from 'solid-js'\nimport type { Accessor } from 'solid-js'\n\nexport function createInfiniteQuery<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n >,\n queryClient?: Accessor<QueryClient>,\n): CreateInfiniteQueryResult<TData, TError> {\n return createBaseQuery(\n createMemo(() => options()),\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n InfiniteQueryObserver as typeof QueryObserver,\n queryClient,\n ) as CreateInfiniteQueryResult<TData, TError>\n}\n","import type {\n QueriesPlaceholderDataFunction,\n QueryFunction,\n QueryKey,\n DefaultError,\n} from '@tanstack/query-core'\nimport { notifyManager, QueriesObserver } from '@tanstack/query-core'\nimport type { QueryClient } from './QueryClient'\nimport type { Accessor } from 'solid-js'\nimport { createComputed, onCleanup, onMount } from 'solid-js'\nimport { createStore, unwrap } from 'solid-js/store'\nimport { useQueryClient } from './QueryClientProvider'\nimport type { CreateQueryResult, SolidQueryOptions } from './types'\n\n// This defines the `UseQueryOptions` that are accepted in `QueriesOptions` & `GetOptions`.\n// `placeholderData` function does not have a parameter\ntype CreateQueryOptionsForCreateQueries<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = Omit<\n SolidQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'placeholderData'\n> & {\n placeholderData?: TQueryFnData | QueriesPlaceholderDataFunction<TQueryFnData>\n}\n\n// Avoid TS depth-limit error in case of large array literal\ntype MAXIMUM_DEPTH = 20\n\ntype GetOptions<T> =\n // Part 1: responsible for applying explicit type parameter to function arguments, if object { queryFnData: TQueryFnData, error: TError, data: TData }\n T extends {\n queryFnData: infer TQueryFnData\n error?: infer TError\n data: infer TData\n }\n ? CreateQueryOptionsForCreateQueries<TQueryFnData, TError, TData>\n : T extends { queryFnData: infer TQueryFnData; error?: infer TError }\n ? CreateQueryOptionsForCreateQueries<TQueryFnData, TError>\n : T extends { data: infer TData; error?: infer TError }\n ? CreateQueryOptionsForCreateQueries<unknown, TError, TData>\n : // Part 2: responsible for applying explicit type parameter to function arguments, if tuple [TQueryFnData, TError, TData]\n T extends [infer TQueryFnData, infer TError, infer TData]\n ? CreateQueryOptionsForCreateQueries<TQueryFnData, TError, TData>\n : T extends [infer TQueryFnData, infer TError]\n ? CreateQueryOptionsForCreateQueries<TQueryFnData, TError>\n : T extends [infer TQueryFnData]\n ? CreateQueryOptionsForCreateQueries<TQueryFnData>\n : // Part 3: responsible for inferring and enforcing type if no explicit parameter was provided\n T extends {\n queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey>\n select: (data: any) => infer TData\n }\n ? CreateQueryOptionsForCreateQueries<TQueryFnData, Error, TData, TQueryKey>\n : T extends { queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey> }\n ? CreateQueryOptionsForCreateQueries<\n TQueryFnData,\n Error,\n TQueryFnData,\n TQueryKey\n >\n : // Fallback\n CreateQueryOptionsForCreateQueries\n\ntype GetResults<T> =\n // Part 1: responsible for mapping explicit type parameter to function result, if object\n T extends { queryFnData: any; error?: infer TError; data: infer TData }\n ? CreateQueryResult<TData, TError>\n : T extends { queryFnData: infer TQueryFnData; error?: infer TError }\n ? CreateQueryResult<TQueryFnData, TError>\n : T extends { data: infer TData; error?: infer TError }\n ? CreateQueryResult<TData, TError>\n : // Part 2: responsible for mapping explicit type parameter to function result, if tuple\n T extends [any, infer TError, infer TData]\n ? CreateQueryResult<TData, TError>\n : T extends [infer TQueryFnData, infer TError]\n ? CreateQueryResult<TQueryFnData, TError>\n : T extends [infer TQueryFnData]\n ? CreateQueryResult<TQueryFnData>\n : // Part 3: responsible for mapping inferred type to results, if no explicit parameter was provided\n T extends {\n queryFn?: QueryFunction<unknown, any>\n select: (data: any) => infer TData\n }\n ? CreateQueryResult<TData>\n : T extends { queryFn?: QueryFunction<infer TQueryFnData, any> }\n ? CreateQueryResult<TQueryFnData>\n : // Fallback\n CreateQueryResult\n\n/**\n * QueriesOptions reducer recursively unwraps function arguments to infer/enforce type param\n */\nexport type QueriesOptions<\n T extends any[],\n Result extends any[] = [],\n Depth extends ReadonlyArray<number> = [],\n> = Depth['length'] extends MAXIMUM_DEPTH\n ? CreateQueryOptionsForCreateQueries[]\n : T extends []\n ? []\n : T extends [infer Head]\n ? [...Result, GetOptions<Head>]\n : T extends [infer Head, ...infer Tail]\n ? QueriesOptions<[...Tail], [...Result, GetOptions<Head>], [...Depth, 1]>\n : unknown[] extends T\n ? T\n : // If T is *some* array but we couldn't assign unknown[] to it, then it must hold some known/homogenous type!\n // use this to infer the param types in the case of Array.map() argument\n T extends CreateQueryOptionsForCreateQueries<\n infer TQueryFnData,\n infer TError,\n infer TData,\n infer TQueryKey\n >[]\n ? CreateQueryOptionsForCreateQueries<TQueryFnData, TError, TData, TQueryKey>[]\n : // Fallback\n CreateQueryOptionsForCreateQueries[]\n\n/**\n * QueriesResults reducer recursively maps type param to results\n */\nexport type QueriesResults<\n T extends any[],\n Result extends any[] = [],\n Depth extends ReadonlyArray<number> = [],\n> = Depth['length'] extends MAXIMUM_DEPTH\n ? CreateQueryResult[]\n : T extends []\n ? []\n : T extends [infer Head]\n ? [...Result, GetResults<Head>]\n : T extends [infer Head, ...infer Tail]\n ? QueriesResults<[...Tail], [...Result, GetResults<Head>], [...Depth, 1]>\n : T extends CreateQueryOptionsForCreateQueries<\n infer TQueryFnData,\n infer TError,\n infer TData,\n any\n >[]\n ? // Dynamic-size (homogenous) UseQueryOptions array: map directly to array of results\n CreateQueryResult<\n unknown extends TData ? TQueryFnData : TData,\n unknown extends TError ? DefaultError : TError\n >[]\n : // Fallback\n CreateQueryResult[]\n\nexport function createQueries<T extends any[]>(\n queriesOptions: Accessor<{\n queries: readonly [...QueriesOptions<T>]\n }>,\n queryClient?: Accessor<QueryClient>,\n): QueriesResults<T> {\n const client = useQueryClient(queryClient?.())\n\n const defaultedQueries = queriesOptions().queries.map((options) => {\n const defaultedOptions = client.defaultQueryOptions(options)\n defaultedOptions._optimisticResults = 'optimistic'\n return defaultedOptions\n })\n\n const observer = new QueriesObserver(client, defaultedQueries)\n\n const [state, setState] = createStore(\n observer.getOptimisticResult(defaultedQueries),\n )\n\n const unsubscribe = observer.subscribe((result) => {\n notifyManager.batchCalls(() => {\n setState(unwrap(result))\n })()\n })\n\n onCleanup(unsubscribe)\n\n onMount(() => {\n observer.setQueries(defaultedQueries, { listeners: false })\n })\n\n createComputed(() => {\n const updatedQueries = queriesOptions().queries.map((options) => {\n const defaultedOptions = client.defaultQueryOptions(options)\n defaultedOptions._optimisticResults = 'optimistic'\n return defaultedOptions\n })\n observer.setQueries(updatedQueries)\n })\n\n return state as QueriesResults<T>\n}\n","import type { QueryKey, DefaultError } from '@tanstack/query-core'\nimport { QueryObserver } from '@tanstack/query-core'\nimport type { QueryClient } from './QueryClient'\nimport type { Accessor } from 'solid-js'\nimport { createMemo } from 'solid-js'\nimport { createBaseQuery } from './createBaseQuery'\nimport type {\n CreateQueryOptions,\n CreateQueryResult,\n DefinedCreateQueryResult,\n FunctionedParams,\n SolidQueryOptions,\n} from './types'\n\ntype UndefinedInitialDataOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = FunctionedParams<\n SolidQueryOptions<TQueryFnData, TError, TData, TQueryKey> & {\n initialData?: undefined\n }\n>\n\ntype DefinedInitialDataOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = FunctionedParams<\n SolidQueryOptions<TQueryFnData, TError, TData, TQueryKey> & {\n initialData: TQueryFnData | (() => TQueryFnData)\n }\n>\n\nexport function createQuery<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: UndefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,\n queryClient?: () => QueryClient,\n): CreateQueryResult<TData, TError>\n\nexport function createQuery<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: DefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,\n queryClient?: () => QueryClient,\n): DefinedCreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n queryClient?: Accessor<QueryClient>,\n) {\n return createBaseQuery(\n createMemo(() => options()),\n QueryObserver,\n queryClient,\n )\n}\n","import type { QueryFilters } from '@tanstack/query-core'\nimport type { QueryClient } from './QueryClient'\nimport type { Accessor } from 'solid-js'\nimport { createMemo, createSignal, onCleanup } from 'solid-js'\nimport { useQueryClient } from './QueryClientProvider'\n\nexport function useIsFetching(\n filters?: Accessor<QueryFilters>,\n queryClient?: Accessor<QueryClient>,\n): Accessor<number> {\n const client = createMemo(() => useQueryClient(queryClient?.()))\n const queryCache = createMemo(() => client().getQueryCache())\n\n const [fetches, setFetches] = createSignal(client().isFetching(filters?.()))\n\n const unsubscribe = queryCache().subscribe(() => {\n setFetches(client().isFetching(filters?.()))\n })\n\n onCleanup(unsubscribe)\n\n return fetches\n}\n","import type { MutationFilters } from '@tanstack/query-core'\nimport type { QueryClient } from './QueryClient'\nimport { useQueryClient } from './QueryClientProvider'\nimport type { Accessor } from 'solid-js'\nimport { createSignal, onCleanup, createMemo } from 'solid-js'\n\nexport function useIsMutating(\n filters?: Accessor<MutationFilters>,\n queryClient?: Accessor<QueryClient>,\n): Accessor<number> {\n const client = createMemo(() => useQueryClient(queryClient?.()))\n const mutationCache = createMemo(() => client().getMutationCache())\n\n const [mutations, setMutations] = createSignal(\n client().isMutating(filters?.()),\n )\n\n const unsubscribe = mutationCache().subscribe((_result) => {\n setMutations(client().isMutating(filters?.()))\n })\n\n onCleanup(unsubscribe)\n\n return mutations\n}\n"],"names":["notifyManager","setBatchNotifyFunction","batch","QueryClient","QueryCoreClient","constructor","config","super","QueryClientContext","createContext","undefined","useQueryClient","queryClient","client","useContext","Error","shouldThrowError","throwError","params","reconcileFn","store","result","reconcileOption","newData","data","reconcile","key","createBaseQuery","options","Observer","createMemo","defaultedOptions","defaultQueryOptions","_optimisticResults","structuralSharing","isServer","retry","throwErrors","observer","state","setState","createStore","getOptimisticResult","createClientSubscriber","subscribe","batchCalls","reconcileOptions","queryResource","loading","mutate","refetch","unsubscribe","createResource","Promise","resolve","reject","query","getCurrentQuery","rest","unwrap","unwrappedResult","dataUpdateCount","fetchFailureCount","fetchFailureReason","fetchMeta","isInvalidated","isError","process","env","console","error","isSuccess","createServerSubscriber","isLoading","initialValue","ssrLoadFrom","initialData","deferStream","onHydrated","_k","info","value","hydrate","queries","queryKey","queryHash","newOptions","staleTime","refetchOnMount","setOptions","onCleanup","createComputed","on","defer","status","isFetching","Proxy","get","target","prop","val","Reflect","noop","props","onMount","mount","unmount","_$createComponent","createComponent","Provider","children","InfiniteQueryObserver","MutationObserver","variables","mutateOptions","catch","getCurrentResult","mutateAsync","queriesOptions","defaultedQueries","map","QueriesObserver","setQueries","listeners","updatedQueries","QueryObserver","filters","queryCache","getQueryCache","fetches","setFetches","createSignal","mutationCache","getMutationCache","mutations","setMutations","isMutating","_result"],"mappings":"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"}
|
package/package.json
CHANGED