@tanstack/solid-query 4.35.7 → 4.39.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +3 -10
- package/build/lib/QueryClientProvider.esm.js +0 -74
- package/build/lib/QueryClientProvider.esm.js.map +0 -1
- package/build/lib/QueryClientProvider.js +0 -80
- package/build/lib/QueryClientProvider.js.map +0 -1
- package/build/lib/QueryClientProvider.mjs +0 -74
- package/build/lib/QueryClientProvider.mjs.map +0 -1
- package/build/lib/createBaseQuery.esm.js +0 -94
- package/build/lib/createBaseQuery.esm.js.map +0 -1
- package/build/lib/createBaseQuery.js +0 -98
- package/build/lib/createBaseQuery.js.map +0 -1
- package/build/lib/createBaseQuery.mjs +0 -94
- package/build/lib/createBaseQuery.mjs.map +0 -1
- package/build/lib/createInfiniteQuery.esm.js +0 -20
- package/build/lib/createInfiniteQuery.esm.js.map +0 -1
- package/build/lib/createInfiniteQuery.js +0 -24
- package/build/lib/createInfiniteQuery.js.map +0 -1
- package/build/lib/createInfiniteQuery.mjs +0 -20
- package/build/lib/createInfiniteQuery.mjs.map +0 -1
- package/build/lib/createMutation.esm.js +0 -45
- package/build/lib/createMutation.esm.js.map +0 -1
- package/build/lib/createMutation.js +0 -49
- package/build/lib/createMutation.js.map +0 -1
- package/build/lib/createMutation.mjs +0 -45
- package/build/lib/createMutation.mjs.map +0 -1
- package/build/lib/createQueries.esm.js +0 -52
- package/build/lib/createQueries.esm.js.map +0 -1
- package/build/lib/createQueries.js +0 -56
- package/build/lib/createQueries.js.map +0 -1
- package/build/lib/createQueries.mjs +0 -52
- package/build/lib/createQueries.mjs.map +0 -1
- package/build/lib/createQuery.esm.js +0 -20
- package/build/lib/createQuery.esm.js.map +0 -1
- package/build/lib/createQuery.js +0 -24
- package/build/lib/createQuery.js.map +0 -1
- package/build/lib/createQuery.mjs +0 -20
- package/build/lib/createQuery.mjs.map +0 -1
- package/build/lib/index.esm.js +0 -9
- package/build/lib/index.esm.js.map +0 -1
- package/build/lib/index.js +0 -31
- package/build/lib/index.js.map +0 -1
- package/build/lib/index.mjs +0 -9
- package/build/lib/index.mjs.map +0 -1
- package/build/lib/useIsFetching.esm.js +0 -29
- package/build/lib/useIsFetching.esm.js.map +0 -1
- package/build/lib/useIsFetching.js +0 -33
- package/build/lib/useIsFetching.js.map +0 -1
- package/build/lib/useIsFetching.mjs +0 -29
- package/build/lib/useIsFetching.mjs.map +0 -1
- package/build/lib/useIsMutating.esm.js +0 -22
- package/build/lib/useIsMutating.esm.js.map +0 -1
- package/build/lib/useIsMutating.js +0 -26
- package/build/lib/useIsMutating.js.map +0 -1
- package/build/lib/useIsMutating.mjs +0 -22
- package/build/lib/useIsMutating.mjs.map +0 -1
- package/build/lib/utils.esm.js +0 -63
- package/build/lib/utils.esm.js.map +0 -1
- package/build/lib/utils.js +0 -72
- package/build/lib/utils.js.map +0 -1
- package/build/lib/utils.mjs +0 -63
- package/build/lib/utils.mjs.map +0 -1
- package/build/umd/index.development.js +0 -3678
- package/build/umd/index.development.js.map +0 -1
- package/build/umd/index.production.js +0 -2
- package/build/umd/index.production.js.map +0 -1
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { InfiniteQueryObserver } from '@tanstack/query-core';
|
|
2
|
-
import { createComputed } from 'solid-js';
|
|
3
|
-
import { createStore } from 'solid-js/store';
|
|
4
|
-
import { createBaseQuery } from './createBaseQuery.esm.js';
|
|
5
|
-
import { parseQueryArgs } from './utils.esm.js';
|
|
6
|
-
|
|
7
|
-
function createInfiniteQuery(arg1, arg2, arg3) {
|
|
8
|
-
// The parseQuery Args functions helps normalize the arguments into the correct form.
|
|
9
|
-
// Whatever the parameters are, they are normalized into the correct form.
|
|
10
|
-
const [parsedOptions, setParsedOptions] = createStore(parseQueryArgs(arg1, arg2, arg3)); // Watch for changes in the options and update the parsed options.
|
|
11
|
-
|
|
12
|
-
createComputed(() => {
|
|
13
|
-
const newParsedOptions = parseQueryArgs(arg1, arg2, arg3);
|
|
14
|
-
setParsedOptions(newParsedOptions);
|
|
15
|
-
});
|
|
16
|
-
return createBaseQuery(parsedOptions, InfiniteQueryObserver);
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export { createInfiniteQuery };
|
|
20
|
-
//# sourceMappingURL=createInfiniteQuery.esm.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createInfiniteQuery.esm.js","sources":["../../src/createInfiniteQuery.ts"],"sourcesContent":["import { InfiniteQueryObserver } from '@tanstack/query-core'\nimport { createComputed } from 'solid-js'\nimport { createStore } from 'solid-js/store'\nimport { createBaseQuery } from './createBaseQuery'\nimport { parseQueryArgs } from './utils'\nimport type {\n CreateInfiniteQueryOptions,\n CreateInfiniteQueryResult,\n SolidQueryKey,\n} from './types'\nimport type {\n QueryFunction,\n QueryObserver,\n QueryOptions,\n} from '@tanstack/query-core'\n\nexport function createInfiniteQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n options: CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n): CreateInfiniteQueryResult<TData, TError>\nexport function createInfiniteQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n options?: Omit<\n CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n 'queryKey'\n >,\n): CreateInfiniteQueryResult<TData, TError>\nexport function createInfiniteQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n queryFn: QueryFunction<TQueryFnData, ReturnType<TQueryKey>>,\n options?: Omit<\n CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n 'queryKey' | 'queryFn'\n >,\n): CreateInfiniteQueryResult<TData, TError>\nexport function createInfiniteQuery<\n TQueryFnData,\n TError,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n arg1:\n | TQueryKey\n | CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n arg2?:\n | QueryFunction<TQueryFnData, ReturnType<TQueryKey>>\n | CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n arg3?: CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n): CreateInfiniteQueryResult<TData, TError> {\n // The parseQuery Args functions helps normalize the arguments into the correct form.\n // Whatever the parameters are, they are normalized into the correct form.\n const [parsedOptions, setParsedOptions] = createStore(\n parseQueryArgs(arg1, arg2, arg3),\n )\n\n // Watch for changes in the options and update the parsed options.\n createComputed(() => {\n const newParsedOptions = parseQueryArgs(arg1, arg2, arg3)\n setParsedOptions(newParsedOptions)\n })\n\n return createBaseQuery(\n parsedOptions as QueryOptions<any, any, any, ReturnType<TQueryKey>>,\n InfiniteQueryObserver as typeof QueryObserver,\n ) as CreateInfiniteQueryResult<TData, TError>\n}\n"],"names":["createInfiniteQuery","arg1","arg2","arg3","parsedOptions","setParsedOptions","createStore","parseQueryArgs","createComputed","newParsedOptions","createBaseQuery","InfiniteQueryObserver"],"mappings":";;;;;;AAmEO,SAASA,mBAAT,CAMLC,IANK,EAeLC,IAfK,EAwBLC,IAxBK,EA+BqC;AAC1C;AACA;AACA,EAAA,MAAM,CAACC,aAAD,EAAgBC,gBAAhB,CAAA,GAAoCC,WAAW,CACnDC,cAAc,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CADqC,CAArD,CAH0C;;AAQ1CK,EAAAA,cAAc,CAAC,MAAM;IACnB,MAAMC,gBAAgB,GAAGF,cAAc,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CAAvC,CAAA;IACAE,gBAAgB,CAACI,gBAAD,CAAhB,CAAA;AACD,GAHa,CAAd,CAAA;AAKA,EAAA,OAAOC,eAAe,CACpBN,aADoB,EAEpBO,qBAFoB,CAAtB,CAAA;AAID;;;;"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var queryCore = require('@tanstack/query-core');
|
|
6
|
-
var solidJs = require('solid-js');
|
|
7
|
-
var store = require('solid-js/store');
|
|
8
|
-
var createBaseQuery = require('./createBaseQuery.js');
|
|
9
|
-
var utils = require('./utils.js');
|
|
10
|
-
|
|
11
|
-
function createInfiniteQuery(arg1, arg2, arg3) {
|
|
12
|
-
// The parseQuery Args functions helps normalize the arguments into the correct form.
|
|
13
|
-
// Whatever the parameters are, they are normalized into the correct form.
|
|
14
|
-
const [parsedOptions, setParsedOptions] = store.createStore(utils.parseQueryArgs(arg1, arg2, arg3)); // Watch for changes in the options and update the parsed options.
|
|
15
|
-
|
|
16
|
-
solidJs.createComputed(() => {
|
|
17
|
-
const newParsedOptions = utils.parseQueryArgs(arg1, arg2, arg3);
|
|
18
|
-
setParsedOptions(newParsedOptions);
|
|
19
|
-
});
|
|
20
|
-
return createBaseQuery.createBaseQuery(parsedOptions, queryCore.InfiniteQueryObserver);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
exports.createInfiniteQuery = createInfiniteQuery;
|
|
24
|
-
//# sourceMappingURL=createInfiniteQuery.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createInfiniteQuery.js","sources":["../../src/createInfiniteQuery.ts"],"sourcesContent":["import { InfiniteQueryObserver } from '@tanstack/query-core'\nimport { createComputed } from 'solid-js'\nimport { createStore } from 'solid-js/store'\nimport { createBaseQuery } from './createBaseQuery'\nimport { parseQueryArgs } from './utils'\nimport type {\n CreateInfiniteQueryOptions,\n CreateInfiniteQueryResult,\n SolidQueryKey,\n} from './types'\nimport type {\n QueryFunction,\n QueryObserver,\n QueryOptions,\n} from '@tanstack/query-core'\n\nexport function createInfiniteQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n options: CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n): CreateInfiniteQueryResult<TData, TError>\nexport function createInfiniteQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n options?: Omit<\n CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n 'queryKey'\n >,\n): CreateInfiniteQueryResult<TData, TError>\nexport function createInfiniteQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n queryFn: QueryFunction<TQueryFnData, ReturnType<TQueryKey>>,\n options?: Omit<\n CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n 'queryKey' | 'queryFn'\n >,\n): CreateInfiniteQueryResult<TData, TError>\nexport function createInfiniteQuery<\n TQueryFnData,\n TError,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n arg1:\n | TQueryKey\n | CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n arg2?:\n | QueryFunction<TQueryFnData, ReturnType<TQueryKey>>\n | CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n arg3?: CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n): CreateInfiniteQueryResult<TData, TError> {\n // The parseQuery Args functions helps normalize the arguments into the correct form.\n // Whatever the parameters are, they are normalized into the correct form.\n const [parsedOptions, setParsedOptions] = createStore(\n parseQueryArgs(arg1, arg2, arg3),\n )\n\n // Watch for changes in the options and update the parsed options.\n createComputed(() => {\n const newParsedOptions = parseQueryArgs(arg1, arg2, arg3)\n setParsedOptions(newParsedOptions)\n })\n\n return createBaseQuery(\n parsedOptions as QueryOptions<any, any, any, ReturnType<TQueryKey>>,\n InfiniteQueryObserver as typeof QueryObserver,\n ) as CreateInfiniteQueryResult<TData, TError>\n}\n"],"names":["createInfiniteQuery","arg1","arg2","arg3","parsedOptions","setParsedOptions","createStore","parseQueryArgs","createComputed","newParsedOptions","createBaseQuery","InfiniteQueryObserver"],"mappings":";;;;;;;;;;AAmEO,SAASA,mBAAT,CAMLC,IANK,EAeLC,IAfK,EAwBLC,IAxBK,EA+BqC;AAC1C;AACA;AACA,EAAA,MAAM,CAACC,aAAD,EAAgBC,gBAAhB,CAAA,GAAoCC,iBAAW,CACnDC,oBAAc,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CADqC,CAArD,CAH0C;;AAQ1CK,EAAAA,sBAAc,CAAC,MAAM;IACnB,MAAMC,gBAAgB,GAAGF,oBAAc,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CAAvC,CAAA;IACAE,gBAAgB,CAACI,gBAAD,CAAhB,CAAA;AACD,GAHa,CAAd,CAAA;AAKA,EAAA,OAAOC,+BAAe,CACpBN,aADoB,EAEpBO,+BAFoB,CAAtB,CAAA;AAID;;;;"}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { InfiniteQueryObserver } from '@tanstack/query-core';
|
|
2
|
-
import { createComputed } from 'solid-js';
|
|
3
|
-
import { createStore } from 'solid-js/store';
|
|
4
|
-
import { createBaseQuery } from './createBaseQuery.mjs';
|
|
5
|
-
import { parseQueryArgs } from './utils.mjs';
|
|
6
|
-
|
|
7
|
-
function createInfiniteQuery(arg1, arg2, arg3) {
|
|
8
|
-
// The parseQuery Args functions helps normalize the arguments into the correct form.
|
|
9
|
-
// Whatever the parameters are, they are normalized into the correct form.
|
|
10
|
-
const [parsedOptions, setParsedOptions] = createStore(parseQueryArgs(arg1, arg2, arg3)); // Watch for changes in the options and update the parsed options.
|
|
11
|
-
|
|
12
|
-
createComputed(() => {
|
|
13
|
-
const newParsedOptions = parseQueryArgs(arg1, arg2, arg3);
|
|
14
|
-
setParsedOptions(newParsedOptions);
|
|
15
|
-
});
|
|
16
|
-
return createBaseQuery(parsedOptions, InfiniteQueryObserver);
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export { createInfiniteQuery };
|
|
20
|
-
//# sourceMappingURL=createInfiniteQuery.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createInfiniteQuery.mjs","sources":["../../src/createInfiniteQuery.ts"],"sourcesContent":["import { InfiniteQueryObserver } from '@tanstack/query-core'\nimport { createComputed } from 'solid-js'\nimport { createStore } from 'solid-js/store'\nimport { createBaseQuery } from './createBaseQuery'\nimport { parseQueryArgs } from './utils'\nimport type {\n CreateInfiniteQueryOptions,\n CreateInfiniteQueryResult,\n SolidQueryKey,\n} from './types'\nimport type {\n QueryFunction,\n QueryObserver,\n QueryOptions,\n} from '@tanstack/query-core'\n\nexport function createInfiniteQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n options: CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n): CreateInfiniteQueryResult<TData, TError>\nexport function createInfiniteQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n options?: Omit<\n CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n 'queryKey'\n >,\n): CreateInfiniteQueryResult<TData, TError>\nexport function createInfiniteQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n queryFn: QueryFunction<TQueryFnData, ReturnType<TQueryKey>>,\n options?: Omit<\n CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n 'queryKey' | 'queryFn'\n >,\n): CreateInfiniteQueryResult<TData, TError>\nexport function createInfiniteQuery<\n TQueryFnData,\n TError,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n arg1:\n | TQueryKey\n | CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n arg2?:\n | QueryFunction<TQueryFnData, ReturnType<TQueryKey>>\n | CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n arg3?: CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n): CreateInfiniteQueryResult<TData, TError> {\n // The parseQuery Args functions helps normalize the arguments into the correct form.\n // Whatever the parameters are, they are normalized into the correct form.\n const [parsedOptions, setParsedOptions] = createStore(\n parseQueryArgs(arg1, arg2, arg3),\n )\n\n // Watch for changes in the options and update the parsed options.\n createComputed(() => {\n const newParsedOptions = parseQueryArgs(arg1, arg2, arg3)\n setParsedOptions(newParsedOptions)\n })\n\n return createBaseQuery(\n parsedOptions as QueryOptions<any, any, any, ReturnType<TQueryKey>>,\n InfiniteQueryObserver as typeof QueryObserver,\n ) as CreateInfiniteQueryResult<TData, TError>\n}\n"],"names":["createInfiniteQuery","arg1","arg2","arg3","parsedOptions","setParsedOptions","createStore","parseQueryArgs","createComputed","newParsedOptions","createBaseQuery","InfiniteQueryObserver"],"mappings":";;;;;;AAmEO,SAASA,mBAAT,CAMLC,IANK,EAeLC,IAfK,EAwBLC,IAxBK,EA+BqC;AAC1C;AACA;AACA,EAAA,MAAM,CAACC,aAAD,EAAgBC,gBAAhB,CAAA,GAAoCC,WAAW,CACnDC,cAAc,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CADqC,CAArD,CAH0C;;AAQ1CK,EAAAA,cAAc,CAAC,MAAM;IACnB,MAAMC,gBAAgB,GAAGF,cAAc,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CAAvC,CAAA;IACAE,gBAAgB,CAACI,gBAAD,CAAhB,CAAA;AACD,GAHa,CAAd,CAAA;AAKA,EAAA,OAAOC,eAAe,CACpBN,aADoB,EAEpBO,qBAFoB,CAAtB,CAAA;AAID;;;;"}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import { parseMutationArgs, MutationObserver } from '@tanstack/query-core';
|
|
2
|
-
import { createComputed, on, onCleanup } from 'solid-js';
|
|
3
|
-
import { createStore } from 'solid-js/store';
|
|
4
|
-
import { useQueryClient } from './QueryClientProvider.esm.js';
|
|
5
|
-
import { shouldThrowError } from './utils.esm.js';
|
|
6
|
-
|
|
7
|
-
function createMutation(arg1, arg2, arg3) {
|
|
8
|
-
const [options, setOptions] = createStore(parseMutationArgs(arg1, arg2, arg3));
|
|
9
|
-
const queryClient = useQueryClient({
|
|
10
|
-
context: options.context
|
|
11
|
-
});
|
|
12
|
-
const observer = new MutationObserver(queryClient, options);
|
|
13
|
-
|
|
14
|
-
const mutate = (variables, mutateOptions) => {
|
|
15
|
-
observer.mutate(variables, mutateOptions).catch(noop);
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
const [state, setState] = createStore({ ...observer.getCurrentResult(),
|
|
19
|
-
mutate,
|
|
20
|
-
mutateAsync: observer.getCurrentResult().mutate
|
|
21
|
-
});
|
|
22
|
-
createComputed(() => {
|
|
23
|
-
const newParsedOptions = parseMutationArgs(arg1, arg2, arg3);
|
|
24
|
-
setOptions(newParsedOptions);
|
|
25
|
-
observer.setOptions(newParsedOptions);
|
|
26
|
-
});
|
|
27
|
-
createComputed(on(() => state.status, () => {
|
|
28
|
-
if (state.isError && shouldThrowError(observer.options.useErrorBoundary, [state.error])) {
|
|
29
|
-
throw state.error;
|
|
30
|
-
}
|
|
31
|
-
}));
|
|
32
|
-
const unsubscribe = observer.subscribe(result => {
|
|
33
|
-
setState({ ...result,
|
|
34
|
-
mutate,
|
|
35
|
-
mutateAsync: result.mutate
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
onCleanup(unsubscribe);
|
|
39
|
-
return state;
|
|
40
|
-
} // eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
41
|
-
|
|
42
|
-
function noop() {}
|
|
43
|
-
|
|
44
|
-
export { createMutation };
|
|
45
|
-
//# sourceMappingURL=createMutation.esm.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createMutation.esm.js","sources":["../../src/createMutation.ts"],"sourcesContent":["import { MutationObserver, parseMutationArgs } from '@tanstack/query-core'\nimport { createComputed, on, onCleanup } from 'solid-js'\nimport { createStore } from 'solid-js/store'\nimport { useQueryClient } from './QueryClientProvider'\nimport { shouldThrowError } from './utils'\nimport type {\n CreateMutateFunction,\n CreateMutationOptions,\n CreateMutationResult,\n} from './types'\nimport type { MutationFunction, MutationKey } from '@tanstack/query-core'\n\n// HOOK\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n options: CreateMutationOptions<TData, TError, TVariables, TContext>,\n): CreateMutationResult<TData, TError, TVariables, TContext>\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n mutationFn: MutationFunction<TData, TVariables>,\n options?: Omit<\n CreateMutationOptions<TData, TError, TVariables, TContext>,\n 'mutationFn'\n >,\n): CreateMutationResult<TData, TError, TVariables, TContext>\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n mutationKey: MutationKey,\n options?: Omit<\n CreateMutationOptions<TData, TError, TVariables, TContext>,\n 'mutationKey'\n >,\n): CreateMutationResult<TData, TError, TVariables, TContext>\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n mutationKey: MutationKey,\n mutationFn?: MutationFunction<TData, TVariables>,\n options?: Omit<\n CreateMutationOptions<TData, TError, TVariables, TContext>,\n 'mutationKey' | 'mutationFn'\n >,\n): CreateMutationResult<TData, TError, TVariables, TContext>\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n arg1:\n | MutationKey\n | MutationFunction<TData, TVariables>\n | CreateMutationOptions<TData, TError, TVariables, TContext>,\n arg2?:\n | MutationFunction<TData, TVariables>\n | CreateMutationOptions<TData, TError, TVariables, TContext>,\n arg3?: CreateMutationOptions<TData, TError, TVariables, TContext>,\n): CreateMutationResult<TData, TError, TVariables, TContext> {\n const [options, setOptions] = createStore(parseMutationArgs(arg1, arg2, arg3))\n const queryClient = useQueryClient({ context: options.context })\n\n const observer = new MutationObserver<TData, TError, TVariables, TContext>(\n queryClient,\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 const newParsedOptions = parseMutationArgs(arg1, arg2, arg3)\n setOptions(newParsedOptions)\n observer.setOptions(newParsedOptions)\n })\n\n createComputed(\n on(\n () => state.status,\n () => {\n if (\n state.isError &&\n shouldThrowError(observer.options.useErrorBoundary, [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"],"names":["createMutation","arg1","arg2","arg3","options","setOptions","createStore","parseMutationArgs","queryClient","useQueryClient","context","observer","MutationObserver","mutate","variables","mutateOptions","catch","noop","state","setState","getCurrentResult","mutateAsync","createComputed","newParsedOptions","on","status","isError","shouldThrowError","useErrorBoundary","error","unsubscribe","subscribe","result","onCleanup"],"mappings":";;;;;;AA0DO,SAASA,cAAT,CAMLC,IANK,EAULC,IAVK,EAaLC,IAbK,EAcsD;AAC3D,EAAA,MAAM,CAACC,OAAD,EAAUC,UAAV,IAAwBC,WAAW,CAACC,iBAAiB,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CAAlB,CAAzC,CAAA;EACA,MAAMK,WAAW,GAAGC,cAAc,CAAC;IAAEC,OAAO,EAAEN,OAAO,CAACM,OAAAA;AAAnB,GAAD,CAAlC,CAAA;EAEA,MAAMC,QAAQ,GAAG,IAAIC,gBAAJ,CACfJ,WADe,EAEfJ,OAFe,CAAjB,CAAA;;AAKA,EAAA,MAAMS,MAAiE,GAAG,CACxEC,SADwE,EAExEC,aAFwE,KAGrE;IACHJ,QAAQ,CAACE,MAAT,CAAgBC,SAAhB,EAA2BC,aAA3B,CAAA,CAA0CC,KAA1C,CAAgDC,IAAhD,CAAA,CAAA;GAJF,CAAA;;AAOA,EAAA,MAAM,CAACC,KAAD,EAAQC,QAAR,CAAoBb,GAAAA,WAAW,CAEnC,EACA,GAAGK,QAAQ,CAACS,gBAAT,EADH;IAEAP,MAFA;AAGAQ,IAAAA,WAAW,EAAEV,QAAQ,CAACS,gBAAT,EAA4BP,CAAAA,MAAAA;AAHzC,GAFmC,CAArC,CAAA;AAQAS,EAAAA,cAAc,CAAC,MAAM;IACnB,MAAMC,gBAAgB,GAAGhB,iBAAiB,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CAA1C,CAAA;IACAE,UAAU,CAACkB,gBAAD,CAAV,CAAA;IACAZ,QAAQ,CAACN,UAAT,CAAoBkB,gBAApB,CAAA,CAAA;AACD,GAJa,CAAd,CAAA;EAMAD,cAAc,CACZE,EAAE,CACA,MAAMN,KAAK,CAACO,MADZ,EAEA,MAAM;AACJ,IAAA,IACEP,KAAK,CAACQ,OAAN,IACAC,gBAAgB,CAAChB,QAAQ,CAACP,OAAT,CAAiBwB,gBAAlB,EAAoC,CAACV,KAAK,CAACW,KAAP,CAApC,CAFlB,EAGE;MACA,MAAMX,KAAK,CAACW,KAAZ,CAAA;AACD,KAAA;AACF,GATD,CADU,CAAd,CAAA;AAcA,EAAA,MAAMC,WAAW,GAAGnB,QAAQ,CAACoB,SAAT,CAAoBC,MAAD,IAAY;IACjDb,QAAQ,CAAC,EACP,GAAGa,MADI;MAEPnB,MAFO;MAGPQ,WAAW,EAAEW,MAAM,CAACnB,MAAAA;AAHb,KAAD,CAAR,CAAA;AAKD,GANmB,CAApB,CAAA;EAQAoB,SAAS,CAACH,WAAD,CAAT,CAAA;AAEA,EAAA,OAAOZ,KAAP,CAAA;AACD;;AAGD,SAASD,IAAT,GAAgB;;;;"}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var queryCore = require('@tanstack/query-core');
|
|
6
|
-
var solidJs = require('solid-js');
|
|
7
|
-
var store = require('solid-js/store');
|
|
8
|
-
var QueryClientProvider = require('./QueryClientProvider.js');
|
|
9
|
-
var utils = require('./utils.js');
|
|
10
|
-
|
|
11
|
-
function createMutation(arg1, arg2, arg3) {
|
|
12
|
-
const [options, setOptions] = store.createStore(queryCore.parseMutationArgs(arg1, arg2, arg3));
|
|
13
|
-
const queryClient = QueryClientProvider.useQueryClient({
|
|
14
|
-
context: options.context
|
|
15
|
-
});
|
|
16
|
-
const observer = new queryCore.MutationObserver(queryClient, options);
|
|
17
|
-
|
|
18
|
-
const mutate = (variables, mutateOptions) => {
|
|
19
|
-
observer.mutate(variables, mutateOptions).catch(noop);
|
|
20
|
-
};
|
|
21
|
-
|
|
22
|
-
const [state, setState] = store.createStore({ ...observer.getCurrentResult(),
|
|
23
|
-
mutate,
|
|
24
|
-
mutateAsync: observer.getCurrentResult().mutate
|
|
25
|
-
});
|
|
26
|
-
solidJs.createComputed(() => {
|
|
27
|
-
const newParsedOptions = queryCore.parseMutationArgs(arg1, arg2, arg3);
|
|
28
|
-
setOptions(newParsedOptions);
|
|
29
|
-
observer.setOptions(newParsedOptions);
|
|
30
|
-
});
|
|
31
|
-
solidJs.createComputed(solidJs.on(() => state.status, () => {
|
|
32
|
-
if (state.isError && utils.shouldThrowError(observer.options.useErrorBoundary, [state.error])) {
|
|
33
|
-
throw state.error;
|
|
34
|
-
}
|
|
35
|
-
}));
|
|
36
|
-
const unsubscribe = observer.subscribe(result => {
|
|
37
|
-
setState({ ...result,
|
|
38
|
-
mutate,
|
|
39
|
-
mutateAsync: result.mutate
|
|
40
|
-
});
|
|
41
|
-
});
|
|
42
|
-
solidJs.onCleanup(unsubscribe);
|
|
43
|
-
return state;
|
|
44
|
-
} // eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
45
|
-
|
|
46
|
-
function noop() {}
|
|
47
|
-
|
|
48
|
-
exports.createMutation = createMutation;
|
|
49
|
-
//# sourceMappingURL=createMutation.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createMutation.js","sources":["../../src/createMutation.ts"],"sourcesContent":["import { MutationObserver, parseMutationArgs } from '@tanstack/query-core'\nimport { createComputed, on, onCleanup } from 'solid-js'\nimport { createStore } from 'solid-js/store'\nimport { useQueryClient } from './QueryClientProvider'\nimport { shouldThrowError } from './utils'\nimport type {\n CreateMutateFunction,\n CreateMutationOptions,\n CreateMutationResult,\n} from './types'\nimport type { MutationFunction, MutationKey } from '@tanstack/query-core'\n\n// HOOK\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n options: CreateMutationOptions<TData, TError, TVariables, TContext>,\n): CreateMutationResult<TData, TError, TVariables, TContext>\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n mutationFn: MutationFunction<TData, TVariables>,\n options?: Omit<\n CreateMutationOptions<TData, TError, TVariables, TContext>,\n 'mutationFn'\n >,\n): CreateMutationResult<TData, TError, TVariables, TContext>\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n mutationKey: MutationKey,\n options?: Omit<\n CreateMutationOptions<TData, TError, TVariables, TContext>,\n 'mutationKey'\n >,\n): CreateMutationResult<TData, TError, TVariables, TContext>\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n mutationKey: MutationKey,\n mutationFn?: MutationFunction<TData, TVariables>,\n options?: Omit<\n CreateMutationOptions<TData, TError, TVariables, TContext>,\n 'mutationKey' | 'mutationFn'\n >,\n): CreateMutationResult<TData, TError, TVariables, TContext>\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n arg1:\n | MutationKey\n | MutationFunction<TData, TVariables>\n | CreateMutationOptions<TData, TError, TVariables, TContext>,\n arg2?:\n | MutationFunction<TData, TVariables>\n | CreateMutationOptions<TData, TError, TVariables, TContext>,\n arg3?: CreateMutationOptions<TData, TError, TVariables, TContext>,\n): CreateMutationResult<TData, TError, TVariables, TContext> {\n const [options, setOptions] = createStore(parseMutationArgs(arg1, arg2, arg3))\n const queryClient = useQueryClient({ context: options.context })\n\n const observer = new MutationObserver<TData, TError, TVariables, TContext>(\n queryClient,\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 const newParsedOptions = parseMutationArgs(arg1, arg2, arg3)\n setOptions(newParsedOptions)\n observer.setOptions(newParsedOptions)\n })\n\n createComputed(\n on(\n () => state.status,\n () => {\n if (\n state.isError &&\n shouldThrowError(observer.options.useErrorBoundary, [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"],"names":["createMutation","arg1","arg2","arg3","options","setOptions","createStore","parseMutationArgs","queryClient","useQueryClient","context","observer","MutationObserver","mutate","variables","mutateOptions","catch","noop","state","setState","getCurrentResult","mutateAsync","createComputed","newParsedOptions","on","status","isError","shouldThrowError","useErrorBoundary","error","unsubscribe","subscribe","result","onCleanup"],"mappings":";;;;;;;;;;AA0DO,SAASA,cAAT,CAMLC,IANK,EAULC,IAVK,EAaLC,IAbK,EAcsD;AAC3D,EAAA,MAAM,CAACC,OAAD,EAAUC,UAAV,IAAwBC,iBAAW,CAACC,2BAAiB,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CAAlB,CAAzC,CAAA;EACA,MAAMK,WAAW,GAAGC,kCAAc,CAAC;IAAEC,OAAO,EAAEN,OAAO,CAACM,OAAAA;AAAnB,GAAD,CAAlC,CAAA;EAEA,MAAMC,QAAQ,GAAG,IAAIC,0BAAJ,CACfJ,WADe,EAEfJ,OAFe,CAAjB,CAAA;;AAKA,EAAA,MAAMS,MAAiE,GAAG,CACxEC,SADwE,EAExEC,aAFwE,KAGrE;IACHJ,QAAQ,CAACE,MAAT,CAAgBC,SAAhB,EAA2BC,aAA3B,CAAA,CAA0CC,KAA1C,CAAgDC,IAAhD,CAAA,CAAA;GAJF,CAAA;;AAOA,EAAA,MAAM,CAACC,KAAD,EAAQC,QAAR,CAAoBb,GAAAA,iBAAW,CAEnC,EACA,GAAGK,QAAQ,CAACS,gBAAT,EADH;IAEAP,MAFA;AAGAQ,IAAAA,WAAW,EAAEV,QAAQ,CAACS,gBAAT,EAA4BP,CAAAA,MAAAA;AAHzC,GAFmC,CAArC,CAAA;AAQAS,EAAAA,sBAAc,CAAC,MAAM;IACnB,MAAMC,gBAAgB,GAAGhB,2BAAiB,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CAA1C,CAAA;IACAE,UAAU,CAACkB,gBAAD,CAAV,CAAA;IACAZ,QAAQ,CAACN,UAAT,CAAoBkB,gBAApB,CAAA,CAAA;AACD,GAJa,CAAd,CAAA;EAMAD,sBAAc,CACZE,UAAE,CACA,MAAMN,KAAK,CAACO,MADZ,EAEA,MAAM;AACJ,IAAA,IACEP,KAAK,CAACQ,OAAN,IACAC,sBAAgB,CAAChB,QAAQ,CAACP,OAAT,CAAiBwB,gBAAlB,EAAoC,CAACV,KAAK,CAACW,KAAP,CAApC,CAFlB,EAGE;MACA,MAAMX,KAAK,CAACW,KAAZ,CAAA;AACD,KAAA;AACF,GATD,CADU,CAAd,CAAA;AAcA,EAAA,MAAMC,WAAW,GAAGnB,QAAQ,CAACoB,SAAT,CAAoBC,MAAD,IAAY;IACjDb,QAAQ,CAAC,EACP,GAAGa,MADI;MAEPnB,MAFO;MAGPQ,WAAW,EAAEW,MAAM,CAACnB,MAAAA;AAHb,KAAD,CAAR,CAAA;AAKD,GANmB,CAApB,CAAA;EAQAoB,iBAAS,CAACH,WAAD,CAAT,CAAA;AAEA,EAAA,OAAOZ,KAAP,CAAA;AACD;;AAGD,SAASD,IAAT,GAAgB;;;;"}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import { parseMutationArgs, MutationObserver } from '@tanstack/query-core';
|
|
2
|
-
import { createComputed, on, onCleanup } from 'solid-js';
|
|
3
|
-
import { createStore } from 'solid-js/store';
|
|
4
|
-
import { useQueryClient } from './QueryClientProvider.mjs';
|
|
5
|
-
import { shouldThrowError } from './utils.mjs';
|
|
6
|
-
|
|
7
|
-
function createMutation(arg1, arg2, arg3) {
|
|
8
|
-
const [options, setOptions] = createStore(parseMutationArgs(arg1, arg2, arg3));
|
|
9
|
-
const queryClient = useQueryClient({
|
|
10
|
-
context: options.context
|
|
11
|
-
});
|
|
12
|
-
const observer = new MutationObserver(queryClient, options);
|
|
13
|
-
|
|
14
|
-
const mutate = (variables, mutateOptions) => {
|
|
15
|
-
observer.mutate(variables, mutateOptions).catch(noop);
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
const [state, setState] = createStore({ ...observer.getCurrentResult(),
|
|
19
|
-
mutate,
|
|
20
|
-
mutateAsync: observer.getCurrentResult().mutate
|
|
21
|
-
});
|
|
22
|
-
createComputed(() => {
|
|
23
|
-
const newParsedOptions = parseMutationArgs(arg1, arg2, arg3);
|
|
24
|
-
setOptions(newParsedOptions);
|
|
25
|
-
observer.setOptions(newParsedOptions);
|
|
26
|
-
});
|
|
27
|
-
createComputed(on(() => state.status, () => {
|
|
28
|
-
if (state.isError && shouldThrowError(observer.options.useErrorBoundary, [state.error])) {
|
|
29
|
-
throw state.error;
|
|
30
|
-
}
|
|
31
|
-
}));
|
|
32
|
-
const unsubscribe = observer.subscribe(result => {
|
|
33
|
-
setState({ ...result,
|
|
34
|
-
mutate,
|
|
35
|
-
mutateAsync: result.mutate
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
onCleanup(unsubscribe);
|
|
39
|
-
return state;
|
|
40
|
-
} // eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
41
|
-
|
|
42
|
-
function noop() {}
|
|
43
|
-
|
|
44
|
-
export { createMutation };
|
|
45
|
-
//# sourceMappingURL=createMutation.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createMutation.mjs","sources":["../../src/createMutation.ts"],"sourcesContent":["import { MutationObserver, parseMutationArgs } from '@tanstack/query-core'\nimport { createComputed, on, onCleanup } from 'solid-js'\nimport { createStore } from 'solid-js/store'\nimport { useQueryClient } from './QueryClientProvider'\nimport { shouldThrowError } from './utils'\nimport type {\n CreateMutateFunction,\n CreateMutationOptions,\n CreateMutationResult,\n} from './types'\nimport type { MutationFunction, MutationKey } from '@tanstack/query-core'\n\n// HOOK\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n options: CreateMutationOptions<TData, TError, TVariables, TContext>,\n): CreateMutationResult<TData, TError, TVariables, TContext>\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n mutationFn: MutationFunction<TData, TVariables>,\n options?: Omit<\n CreateMutationOptions<TData, TError, TVariables, TContext>,\n 'mutationFn'\n >,\n): CreateMutationResult<TData, TError, TVariables, TContext>\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n mutationKey: MutationKey,\n options?: Omit<\n CreateMutationOptions<TData, TError, TVariables, TContext>,\n 'mutationKey'\n >,\n): CreateMutationResult<TData, TError, TVariables, TContext>\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n mutationKey: MutationKey,\n mutationFn?: MutationFunction<TData, TVariables>,\n options?: Omit<\n CreateMutationOptions<TData, TError, TVariables, TContext>,\n 'mutationKey' | 'mutationFn'\n >,\n): CreateMutationResult<TData, TError, TVariables, TContext>\nexport function createMutation<\n TData = unknown,\n TError = unknown,\n TVariables = void,\n TContext = unknown,\n>(\n arg1:\n | MutationKey\n | MutationFunction<TData, TVariables>\n | CreateMutationOptions<TData, TError, TVariables, TContext>,\n arg2?:\n | MutationFunction<TData, TVariables>\n | CreateMutationOptions<TData, TError, TVariables, TContext>,\n arg3?: CreateMutationOptions<TData, TError, TVariables, TContext>,\n): CreateMutationResult<TData, TError, TVariables, TContext> {\n const [options, setOptions] = createStore(parseMutationArgs(arg1, arg2, arg3))\n const queryClient = useQueryClient({ context: options.context })\n\n const observer = new MutationObserver<TData, TError, TVariables, TContext>(\n queryClient,\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 const newParsedOptions = parseMutationArgs(arg1, arg2, arg3)\n setOptions(newParsedOptions)\n observer.setOptions(newParsedOptions)\n })\n\n createComputed(\n on(\n () => state.status,\n () => {\n if (\n state.isError &&\n shouldThrowError(observer.options.useErrorBoundary, [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"],"names":["createMutation","arg1","arg2","arg3","options","setOptions","createStore","parseMutationArgs","queryClient","useQueryClient","context","observer","MutationObserver","mutate","variables","mutateOptions","catch","noop","state","setState","getCurrentResult","mutateAsync","createComputed","newParsedOptions","on","status","isError","shouldThrowError","useErrorBoundary","error","unsubscribe","subscribe","result","onCleanup"],"mappings":";;;;;;AA0DO,SAASA,cAAT,CAMLC,IANK,EAULC,IAVK,EAaLC,IAbK,EAcsD;AAC3D,EAAA,MAAM,CAACC,OAAD,EAAUC,UAAV,IAAwBC,WAAW,CAACC,iBAAiB,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CAAlB,CAAzC,CAAA;EACA,MAAMK,WAAW,GAAGC,cAAc,CAAC;IAAEC,OAAO,EAAEN,OAAO,CAACM,OAAAA;AAAnB,GAAD,CAAlC,CAAA;EAEA,MAAMC,QAAQ,GAAG,IAAIC,gBAAJ,CACfJ,WADe,EAEfJ,OAFe,CAAjB,CAAA;;AAKA,EAAA,MAAMS,MAAiE,GAAG,CACxEC,SADwE,EAExEC,aAFwE,KAGrE;IACHJ,QAAQ,CAACE,MAAT,CAAgBC,SAAhB,EAA2BC,aAA3B,CAAA,CAA0CC,KAA1C,CAAgDC,IAAhD,CAAA,CAAA;GAJF,CAAA;;AAOA,EAAA,MAAM,CAACC,KAAD,EAAQC,QAAR,CAAoBb,GAAAA,WAAW,CAEnC,EACA,GAAGK,QAAQ,CAACS,gBAAT,EADH;IAEAP,MAFA;AAGAQ,IAAAA,WAAW,EAAEV,QAAQ,CAACS,gBAAT,EAA4BP,CAAAA,MAAAA;AAHzC,GAFmC,CAArC,CAAA;AAQAS,EAAAA,cAAc,CAAC,MAAM;IACnB,MAAMC,gBAAgB,GAAGhB,iBAAiB,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CAA1C,CAAA;IACAE,UAAU,CAACkB,gBAAD,CAAV,CAAA;IACAZ,QAAQ,CAACN,UAAT,CAAoBkB,gBAApB,CAAA,CAAA;AACD,GAJa,CAAd,CAAA;EAMAD,cAAc,CACZE,EAAE,CACA,MAAMN,KAAK,CAACO,MADZ,EAEA,MAAM;AACJ,IAAA,IACEP,KAAK,CAACQ,OAAN,IACAC,gBAAgB,CAAChB,QAAQ,CAACP,OAAT,CAAiBwB,gBAAlB,EAAoC,CAACV,KAAK,CAACW,KAAP,CAApC,CAFlB,EAGE;MACA,MAAMX,KAAK,CAACW,KAAZ,CAAA;AACD,KAAA;AACF,GATD,CADU,CAAd,CAAA;AAcA,EAAA,MAAMC,WAAW,GAAGnB,QAAQ,CAACoB,SAAT,CAAoBC,MAAD,IAAY;IACjDb,QAAQ,CAAC,EACP,GAAGa,MADI;MAEPnB,MAFO;MAGPQ,WAAW,EAAEW,MAAM,CAACnB,MAAAA;AAHb,KAAD,CAAR,CAAA;AAKD,GANmB,CAApB,CAAA;EAQAoB,SAAS,CAACH,WAAD,CAAT,CAAA;AAEA,EAAA,OAAOZ,KAAP,CAAA;AACD;;AAGD,SAASD,IAAT,GAAgB;;;;"}
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import { onCleanup, onMount, createComputed } from 'solid-js';
|
|
2
|
-
import { QueriesObserver } from '@tanstack/query-core';
|
|
3
|
-
import { createStore, unwrap } from 'solid-js/store';
|
|
4
|
-
import { useQueryClient } from './QueryClientProvider.esm.js';
|
|
5
|
-
import { scheduleMicrotask } from './utils.esm.js';
|
|
6
|
-
|
|
7
|
-
function createQueries(queriesOptions) {
|
|
8
|
-
const queryClient = useQueryClient({
|
|
9
|
-
context: queriesOptions.context
|
|
10
|
-
});
|
|
11
|
-
|
|
12
|
-
const normalizeOptions = options => {
|
|
13
|
-
const normalizedOptions = { ...options,
|
|
14
|
-
queryKey: options.queryKey == null ? void 0 : options.queryKey()
|
|
15
|
-
};
|
|
16
|
-
const defaultedOptions = queryClient.defaultQueryOptions(normalizedOptions);
|
|
17
|
-
defaultedOptions._optimisticResults = 'optimistic';
|
|
18
|
-
return defaultedOptions;
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
const defaultedQueries = queriesOptions.queries.map(options => normalizeOptions(options));
|
|
22
|
-
const observer = new QueriesObserver(queryClient, defaultedQueries);
|
|
23
|
-
const [state, setState] = createStore(observer.getOptimisticResult(defaultedQueries));
|
|
24
|
-
const taskQueue = [];
|
|
25
|
-
const unsubscribe = observer.subscribe(result => {
|
|
26
|
-
taskQueue.push(() => {
|
|
27
|
-
setState(unwrap(result));
|
|
28
|
-
});
|
|
29
|
-
scheduleMicrotask(() => {
|
|
30
|
-
const taskToRun = taskQueue.pop();
|
|
31
|
-
|
|
32
|
-
if (taskToRun) {
|
|
33
|
-
taskToRun();
|
|
34
|
-
taskQueue.splice(0, taskQueue.length);
|
|
35
|
-
}
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
onCleanup(unsubscribe);
|
|
39
|
-
onMount(() => {
|
|
40
|
-
observer.setQueries(defaultedQueries, {
|
|
41
|
-
listeners: false
|
|
42
|
-
});
|
|
43
|
-
});
|
|
44
|
-
createComputed(() => {
|
|
45
|
-
const updateDefaultedQueries = queriesOptions.queries.map(options => normalizeOptions(options));
|
|
46
|
-
observer.setQueries(updateDefaultedQueries);
|
|
47
|
-
});
|
|
48
|
-
return state;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
export { createQueries };
|
|
52
|
-
//# sourceMappingURL=createQueries.esm.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createQueries.esm.js","sources":["../../src/createQueries.ts"],"sourcesContent":["import { createComputed, onCleanup, onMount } from 'solid-js'\nimport { QueriesObserver } from '@tanstack/query-core'\nimport { createStore, unwrap } from 'solid-js/store'\nimport { useQueryClient } from './QueryClientProvider'\nimport { scheduleMicrotask } from './utils'\nimport type {\n CreateQueryOptions,\n CreateQueryResult,\n SolidQueryKey,\n} from './types'\nimport type { QueryFunction } from '@tanstack/query-core'\n\n// This defines the `UseQueryOptions` that are accepted in `QueriesOptions` & `GetOptions`.\n// - `context` is omitted as it is passed as a root-level option to `useQueries` instead.\ntype CreateQueryOptionsForCreateQueries<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n> = Omit<CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>, 'context'>\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<\n TQueryFnData,\n unknown,\n TData,\n () => TQueryKey\n >\n : T extends { queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey> }\n ? CreateQueryOptionsForCreateQueries<\n TQueryFnData,\n unknown,\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<unknown extends TData ? TQueryFnData : TData, TError>[]\n : // Fallback\n CreateQueryResult[]\n\ntype ArrType<T> = T extends (infer U)[] ? U : never\n\nexport function createQueries<T extends any[]>(queriesOptions: {\n queries: readonly [...QueriesOptions<T>]\n context?: CreateQueryOptions['context']\n}): QueriesResults<T> {\n const queryClient = useQueryClient({ context: queriesOptions.context })\n\n const normalizeOptions = (\n options: ArrType<typeof queriesOptions.queries>,\n ) => {\n const normalizedOptions = { ...options, queryKey: options.queryKey?.() }\n const defaultedOptions = queryClient.defaultQueryOptions(normalizedOptions)\n defaultedOptions._optimisticResults = 'optimistic'\n return defaultedOptions\n }\n\n const defaultedQueries = queriesOptions.queries.map((options) =>\n normalizeOptions(options),\n )\n\n const observer = new QueriesObserver(queryClient, defaultedQueries)\n\n const [state, setState] = createStore(\n observer.getOptimisticResult(defaultedQueries),\n )\n\n const taskQueue: Array<() => void> = []\n\n const unsubscribe = observer.subscribe((result) => {\n taskQueue.push(() => {\n setState(unwrap(result))\n })\n\n scheduleMicrotask(() => {\n const taskToRun = taskQueue.pop()\n if (taskToRun) {\n taskToRun()\n taskQueue.splice(0, taskQueue.length)\n }\n })\n })\n\n onCleanup(unsubscribe)\n\n onMount(() => {\n observer.setQueries(defaultedQueries, { listeners: false })\n })\n\n createComputed(() => {\n const updateDefaultedQueries = queriesOptions.queries.map((options) =>\n normalizeOptions(options),\n )\n observer.setQueries(updateDefaultedQueries)\n })\n\n return state as QueriesResults<T>\n}\n"],"names":["createQueries","queriesOptions","queryClient","useQueryClient","context","normalizeOptions","options","normalizedOptions","queryKey","defaultedOptions","defaultQueryOptions","_optimisticResults","defaultedQueries","queries","map","observer","QueriesObserver","state","setState","createStore","getOptimisticResult","taskQueue","unsubscribe","subscribe","result","push","unwrap","scheduleMicrotask","taskToRun","pop","splice","length","onCleanup","onMount","setQueries","listeners","createComputed","updateDefaultedQueries"],"mappings":";;;;;;AAmJO,SAASA,aAAT,CAAwCC,cAAxC,EAGe;EACpB,MAAMC,WAAW,GAAGC,cAAc,CAAC;IAAEC,OAAO,EAAEH,cAAc,CAACG,OAAAA;AAA1B,GAAD,CAAlC,CAAA;;EAEA,MAAMC,gBAAgB,GACpBC,OADuB,IAEpB;AACH,IAAA,MAAMC,iBAAiB,GAAG,EAAE,GAAGD,OAAL;AAAcE,MAAAA,QAAQ,EAAEF,OAAO,CAACE,QAAV,IAAEF,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,OAAO,CAACE,QAAR,EAAA;KAAlD,CAAA;AACA,IAAA,MAAMC,gBAAgB,GAAGP,WAAW,CAACQ,mBAAZ,CAAgCH,iBAAhC,CAAzB,CAAA;IACAE,gBAAgB,CAACE,kBAAjB,GAAsC,YAAtC,CAAA;AACA,IAAA,OAAOF,gBAAP,CAAA;GANF,CAAA;;AASA,EAAA,MAAMG,gBAAgB,GAAGX,cAAc,CAACY,OAAf,CAAuBC,GAAvB,CAA4BR,OAAD,IAClDD,gBAAgB,CAACC,OAAD,CADO,CAAzB,CAAA;EAIA,MAAMS,QAAQ,GAAG,IAAIC,eAAJ,CAAoBd,WAApB,EAAiCU,gBAAjC,CAAjB,CAAA;AAEA,EAAA,MAAM,CAACK,KAAD,EAAQC,QAAR,CAAoBC,GAAAA,WAAW,CACnCJ,QAAQ,CAACK,mBAAT,CAA6BR,gBAA7B,CADmC,CAArC,CAAA;EAIA,MAAMS,SAA4B,GAAG,EAArC,CAAA;AAEA,EAAA,MAAMC,WAAW,GAAGP,QAAQ,CAACQ,SAAT,CAAoBC,MAAD,IAAY;IACjDH,SAAS,CAACI,IAAV,CAAe,MAAM;AACnBP,MAAAA,QAAQ,CAACQ,MAAM,CAACF,MAAD,CAAP,CAAR,CAAA;KADF,CAAA,CAAA;AAIAG,IAAAA,iBAAiB,CAAC,MAAM;AACtB,MAAA,MAAMC,SAAS,GAAGP,SAAS,CAACQ,GAAV,EAAlB,CAAA;;AACA,MAAA,IAAID,SAAJ,EAAe;QACbA,SAAS,EAAA,CAAA;AACTP,QAAAA,SAAS,CAACS,MAAV,CAAiB,CAAjB,EAAoBT,SAAS,CAACU,MAA9B,CAAA,CAAA;AACD,OAAA;AACF,KANgB,CAAjB,CAAA;AAOD,GAZmB,CAApB,CAAA;EAcAC,SAAS,CAACV,WAAD,CAAT,CAAA;AAEAW,EAAAA,OAAO,CAAC,MAAM;AACZlB,IAAAA,QAAQ,CAACmB,UAAT,CAAoBtB,gBAApB,EAAsC;AAAEuB,MAAAA,SAAS,EAAE,KAAA;KAAnD,CAAA,CAAA;AACD,GAFM,CAAP,CAAA;AAIAC,EAAAA,cAAc,CAAC,MAAM;AACnB,IAAA,MAAMC,sBAAsB,GAAGpC,cAAc,CAACY,OAAf,CAAuBC,GAAvB,CAA4BR,OAAD,IACxDD,gBAAgB,CAACC,OAAD,CADa,CAA/B,CAAA;IAGAS,QAAQ,CAACmB,UAAT,CAAoBG,sBAApB,CAAA,CAAA;AACD,GALa,CAAd,CAAA;AAOA,EAAA,OAAOpB,KAAP,CAAA;AACD;;;;"}
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var solidJs = require('solid-js');
|
|
6
|
-
var queryCore = require('@tanstack/query-core');
|
|
7
|
-
var store = require('solid-js/store');
|
|
8
|
-
var QueryClientProvider = require('./QueryClientProvider.js');
|
|
9
|
-
var utils = require('./utils.js');
|
|
10
|
-
|
|
11
|
-
function createQueries(queriesOptions) {
|
|
12
|
-
const queryClient = QueryClientProvider.useQueryClient({
|
|
13
|
-
context: queriesOptions.context
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
const normalizeOptions = options => {
|
|
17
|
-
const normalizedOptions = { ...options,
|
|
18
|
-
queryKey: options.queryKey == null ? void 0 : options.queryKey()
|
|
19
|
-
};
|
|
20
|
-
const defaultedOptions = queryClient.defaultQueryOptions(normalizedOptions);
|
|
21
|
-
defaultedOptions._optimisticResults = 'optimistic';
|
|
22
|
-
return defaultedOptions;
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
const defaultedQueries = queriesOptions.queries.map(options => normalizeOptions(options));
|
|
26
|
-
const observer = new queryCore.QueriesObserver(queryClient, defaultedQueries);
|
|
27
|
-
const [state, setState] = store.createStore(observer.getOptimisticResult(defaultedQueries));
|
|
28
|
-
const taskQueue = [];
|
|
29
|
-
const unsubscribe = observer.subscribe(result => {
|
|
30
|
-
taskQueue.push(() => {
|
|
31
|
-
setState(store.unwrap(result));
|
|
32
|
-
});
|
|
33
|
-
utils.scheduleMicrotask(() => {
|
|
34
|
-
const taskToRun = taskQueue.pop();
|
|
35
|
-
|
|
36
|
-
if (taskToRun) {
|
|
37
|
-
taskToRun();
|
|
38
|
-
taskQueue.splice(0, taskQueue.length);
|
|
39
|
-
}
|
|
40
|
-
});
|
|
41
|
-
});
|
|
42
|
-
solidJs.onCleanup(unsubscribe);
|
|
43
|
-
solidJs.onMount(() => {
|
|
44
|
-
observer.setQueries(defaultedQueries, {
|
|
45
|
-
listeners: false
|
|
46
|
-
});
|
|
47
|
-
});
|
|
48
|
-
solidJs.createComputed(() => {
|
|
49
|
-
const updateDefaultedQueries = queriesOptions.queries.map(options => normalizeOptions(options));
|
|
50
|
-
observer.setQueries(updateDefaultedQueries);
|
|
51
|
-
});
|
|
52
|
-
return state;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
exports.createQueries = createQueries;
|
|
56
|
-
//# sourceMappingURL=createQueries.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createQueries.js","sources":["../../src/createQueries.ts"],"sourcesContent":["import { createComputed, onCleanup, onMount } from 'solid-js'\nimport { QueriesObserver } from '@tanstack/query-core'\nimport { createStore, unwrap } from 'solid-js/store'\nimport { useQueryClient } from './QueryClientProvider'\nimport { scheduleMicrotask } from './utils'\nimport type {\n CreateQueryOptions,\n CreateQueryResult,\n SolidQueryKey,\n} from './types'\nimport type { QueryFunction } from '@tanstack/query-core'\n\n// This defines the `UseQueryOptions` that are accepted in `QueriesOptions` & `GetOptions`.\n// - `context` is omitted as it is passed as a root-level option to `useQueries` instead.\ntype CreateQueryOptionsForCreateQueries<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n> = Omit<CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>, 'context'>\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<\n TQueryFnData,\n unknown,\n TData,\n () => TQueryKey\n >\n : T extends { queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey> }\n ? CreateQueryOptionsForCreateQueries<\n TQueryFnData,\n unknown,\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<unknown extends TData ? TQueryFnData : TData, TError>[]\n : // Fallback\n CreateQueryResult[]\n\ntype ArrType<T> = T extends (infer U)[] ? U : never\n\nexport function createQueries<T extends any[]>(queriesOptions: {\n queries: readonly [...QueriesOptions<T>]\n context?: CreateQueryOptions['context']\n}): QueriesResults<T> {\n const queryClient = useQueryClient({ context: queriesOptions.context })\n\n const normalizeOptions = (\n options: ArrType<typeof queriesOptions.queries>,\n ) => {\n const normalizedOptions = { ...options, queryKey: options.queryKey?.() }\n const defaultedOptions = queryClient.defaultQueryOptions(normalizedOptions)\n defaultedOptions._optimisticResults = 'optimistic'\n return defaultedOptions\n }\n\n const defaultedQueries = queriesOptions.queries.map((options) =>\n normalizeOptions(options),\n )\n\n const observer = new QueriesObserver(queryClient, defaultedQueries)\n\n const [state, setState] = createStore(\n observer.getOptimisticResult(defaultedQueries),\n )\n\n const taskQueue: Array<() => void> = []\n\n const unsubscribe = observer.subscribe((result) => {\n taskQueue.push(() => {\n setState(unwrap(result))\n })\n\n scheduleMicrotask(() => {\n const taskToRun = taskQueue.pop()\n if (taskToRun) {\n taskToRun()\n taskQueue.splice(0, taskQueue.length)\n }\n })\n })\n\n onCleanup(unsubscribe)\n\n onMount(() => {\n observer.setQueries(defaultedQueries, { listeners: false })\n })\n\n createComputed(() => {\n const updateDefaultedQueries = queriesOptions.queries.map((options) =>\n normalizeOptions(options),\n )\n observer.setQueries(updateDefaultedQueries)\n })\n\n return state as QueriesResults<T>\n}\n"],"names":["createQueries","queriesOptions","queryClient","useQueryClient","context","normalizeOptions","options","normalizedOptions","queryKey","defaultedOptions","defaultQueryOptions","_optimisticResults","defaultedQueries","queries","map","observer","QueriesObserver","state","setState","createStore","getOptimisticResult","taskQueue","unsubscribe","subscribe","result","push","unwrap","scheduleMicrotask","taskToRun","pop","splice","length","onCleanup","onMount","setQueries","listeners","createComputed","updateDefaultedQueries"],"mappings":";;;;;;;;;;AAmJO,SAASA,aAAT,CAAwCC,cAAxC,EAGe;EACpB,MAAMC,WAAW,GAAGC,kCAAc,CAAC;IAAEC,OAAO,EAAEH,cAAc,CAACG,OAAAA;AAA1B,GAAD,CAAlC,CAAA;;EAEA,MAAMC,gBAAgB,GACpBC,OADuB,IAEpB;AACH,IAAA,MAAMC,iBAAiB,GAAG,EAAE,GAAGD,OAAL;AAAcE,MAAAA,QAAQ,EAAEF,OAAO,CAACE,QAAV,IAAEF,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,OAAO,CAACE,QAAR,EAAA;KAAlD,CAAA;AACA,IAAA,MAAMC,gBAAgB,GAAGP,WAAW,CAACQ,mBAAZ,CAAgCH,iBAAhC,CAAzB,CAAA;IACAE,gBAAgB,CAACE,kBAAjB,GAAsC,YAAtC,CAAA;AACA,IAAA,OAAOF,gBAAP,CAAA;GANF,CAAA;;AASA,EAAA,MAAMG,gBAAgB,GAAGX,cAAc,CAACY,OAAf,CAAuBC,GAAvB,CAA4BR,OAAD,IAClDD,gBAAgB,CAACC,OAAD,CADO,CAAzB,CAAA;EAIA,MAAMS,QAAQ,GAAG,IAAIC,yBAAJ,CAAoBd,WAApB,EAAiCU,gBAAjC,CAAjB,CAAA;AAEA,EAAA,MAAM,CAACK,KAAD,EAAQC,QAAR,CAAoBC,GAAAA,iBAAW,CACnCJ,QAAQ,CAACK,mBAAT,CAA6BR,gBAA7B,CADmC,CAArC,CAAA;EAIA,MAAMS,SAA4B,GAAG,EAArC,CAAA;AAEA,EAAA,MAAMC,WAAW,GAAGP,QAAQ,CAACQ,SAAT,CAAoBC,MAAD,IAAY;IACjDH,SAAS,CAACI,IAAV,CAAe,MAAM;AACnBP,MAAAA,QAAQ,CAACQ,YAAM,CAACF,MAAD,CAAP,CAAR,CAAA;KADF,CAAA,CAAA;AAIAG,IAAAA,uBAAiB,CAAC,MAAM;AACtB,MAAA,MAAMC,SAAS,GAAGP,SAAS,CAACQ,GAAV,EAAlB,CAAA;;AACA,MAAA,IAAID,SAAJ,EAAe;QACbA,SAAS,EAAA,CAAA;AACTP,QAAAA,SAAS,CAACS,MAAV,CAAiB,CAAjB,EAAoBT,SAAS,CAACU,MAA9B,CAAA,CAAA;AACD,OAAA;AACF,KANgB,CAAjB,CAAA;AAOD,GAZmB,CAApB,CAAA;EAcAC,iBAAS,CAACV,WAAD,CAAT,CAAA;AAEAW,EAAAA,eAAO,CAAC,MAAM;AACZlB,IAAAA,QAAQ,CAACmB,UAAT,CAAoBtB,gBAApB,EAAsC;AAAEuB,MAAAA,SAAS,EAAE,KAAA;KAAnD,CAAA,CAAA;AACD,GAFM,CAAP,CAAA;AAIAC,EAAAA,sBAAc,CAAC,MAAM;AACnB,IAAA,MAAMC,sBAAsB,GAAGpC,cAAc,CAACY,OAAf,CAAuBC,GAAvB,CAA4BR,OAAD,IACxDD,gBAAgB,CAACC,OAAD,CADa,CAA/B,CAAA;IAGAS,QAAQ,CAACmB,UAAT,CAAoBG,sBAApB,CAAA,CAAA;AACD,GALa,CAAd,CAAA;AAOA,EAAA,OAAOpB,KAAP,CAAA;AACD;;;;"}
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import { onCleanup, onMount, createComputed } from 'solid-js';
|
|
2
|
-
import { QueriesObserver } from '@tanstack/query-core';
|
|
3
|
-
import { createStore, unwrap } from 'solid-js/store';
|
|
4
|
-
import { useQueryClient } from './QueryClientProvider.mjs';
|
|
5
|
-
import { scheduleMicrotask } from './utils.mjs';
|
|
6
|
-
|
|
7
|
-
function createQueries(queriesOptions) {
|
|
8
|
-
const queryClient = useQueryClient({
|
|
9
|
-
context: queriesOptions.context
|
|
10
|
-
});
|
|
11
|
-
|
|
12
|
-
const normalizeOptions = options => {
|
|
13
|
-
const normalizedOptions = { ...options,
|
|
14
|
-
queryKey: options.queryKey == null ? void 0 : options.queryKey()
|
|
15
|
-
};
|
|
16
|
-
const defaultedOptions = queryClient.defaultQueryOptions(normalizedOptions);
|
|
17
|
-
defaultedOptions._optimisticResults = 'optimistic';
|
|
18
|
-
return defaultedOptions;
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
const defaultedQueries = queriesOptions.queries.map(options => normalizeOptions(options));
|
|
22
|
-
const observer = new QueriesObserver(queryClient, defaultedQueries);
|
|
23
|
-
const [state, setState] = createStore(observer.getOptimisticResult(defaultedQueries));
|
|
24
|
-
const taskQueue = [];
|
|
25
|
-
const unsubscribe = observer.subscribe(result => {
|
|
26
|
-
taskQueue.push(() => {
|
|
27
|
-
setState(unwrap(result));
|
|
28
|
-
});
|
|
29
|
-
scheduleMicrotask(() => {
|
|
30
|
-
const taskToRun = taskQueue.pop();
|
|
31
|
-
|
|
32
|
-
if (taskToRun) {
|
|
33
|
-
taskToRun();
|
|
34
|
-
taskQueue.splice(0, taskQueue.length);
|
|
35
|
-
}
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
onCleanup(unsubscribe);
|
|
39
|
-
onMount(() => {
|
|
40
|
-
observer.setQueries(defaultedQueries, {
|
|
41
|
-
listeners: false
|
|
42
|
-
});
|
|
43
|
-
});
|
|
44
|
-
createComputed(() => {
|
|
45
|
-
const updateDefaultedQueries = queriesOptions.queries.map(options => normalizeOptions(options));
|
|
46
|
-
observer.setQueries(updateDefaultedQueries);
|
|
47
|
-
});
|
|
48
|
-
return state;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
export { createQueries };
|
|
52
|
-
//# sourceMappingURL=createQueries.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createQueries.mjs","sources":["../../src/createQueries.ts"],"sourcesContent":["import { createComputed, onCleanup, onMount } from 'solid-js'\nimport { QueriesObserver } from '@tanstack/query-core'\nimport { createStore, unwrap } from 'solid-js/store'\nimport { useQueryClient } from './QueryClientProvider'\nimport { scheduleMicrotask } from './utils'\nimport type {\n CreateQueryOptions,\n CreateQueryResult,\n SolidQueryKey,\n} from './types'\nimport type { QueryFunction } from '@tanstack/query-core'\n\n// This defines the `UseQueryOptions` that are accepted in `QueriesOptions` & `GetOptions`.\n// - `context` is omitted as it is passed as a root-level option to `useQueries` instead.\ntype CreateQueryOptionsForCreateQueries<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n> = Omit<CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>, 'context'>\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<\n TQueryFnData,\n unknown,\n TData,\n () => TQueryKey\n >\n : T extends { queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey> }\n ? CreateQueryOptionsForCreateQueries<\n TQueryFnData,\n unknown,\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<unknown extends TData ? TQueryFnData : TData, TError>[]\n : // Fallback\n CreateQueryResult[]\n\ntype ArrType<T> = T extends (infer U)[] ? U : never\n\nexport function createQueries<T extends any[]>(queriesOptions: {\n queries: readonly [...QueriesOptions<T>]\n context?: CreateQueryOptions['context']\n}): QueriesResults<T> {\n const queryClient = useQueryClient({ context: queriesOptions.context })\n\n const normalizeOptions = (\n options: ArrType<typeof queriesOptions.queries>,\n ) => {\n const normalizedOptions = { ...options, queryKey: options.queryKey?.() }\n const defaultedOptions = queryClient.defaultQueryOptions(normalizedOptions)\n defaultedOptions._optimisticResults = 'optimistic'\n return defaultedOptions\n }\n\n const defaultedQueries = queriesOptions.queries.map((options) =>\n normalizeOptions(options),\n )\n\n const observer = new QueriesObserver(queryClient, defaultedQueries)\n\n const [state, setState] = createStore(\n observer.getOptimisticResult(defaultedQueries),\n )\n\n const taskQueue: Array<() => void> = []\n\n const unsubscribe = observer.subscribe((result) => {\n taskQueue.push(() => {\n setState(unwrap(result))\n })\n\n scheduleMicrotask(() => {\n const taskToRun = taskQueue.pop()\n if (taskToRun) {\n taskToRun()\n taskQueue.splice(0, taskQueue.length)\n }\n })\n })\n\n onCleanup(unsubscribe)\n\n onMount(() => {\n observer.setQueries(defaultedQueries, { listeners: false })\n })\n\n createComputed(() => {\n const updateDefaultedQueries = queriesOptions.queries.map((options) =>\n normalizeOptions(options),\n )\n observer.setQueries(updateDefaultedQueries)\n })\n\n return state as QueriesResults<T>\n}\n"],"names":["createQueries","queriesOptions","queryClient","useQueryClient","context","normalizeOptions","options","normalizedOptions","queryKey","defaultedOptions","defaultQueryOptions","_optimisticResults","defaultedQueries","queries","map","observer","QueriesObserver","state","setState","createStore","getOptimisticResult","taskQueue","unsubscribe","subscribe","result","push","unwrap","scheduleMicrotask","taskToRun","pop","splice","length","onCleanup","onMount","setQueries","listeners","createComputed","updateDefaultedQueries"],"mappings":";;;;;;AAmJO,SAASA,aAAT,CAAwCC,cAAxC,EAGe;EACpB,MAAMC,WAAW,GAAGC,cAAc,CAAC;IAAEC,OAAO,EAAEH,cAAc,CAACG,OAAAA;AAA1B,GAAD,CAAlC,CAAA;;EAEA,MAAMC,gBAAgB,GACpBC,OADuB,IAEpB;AACH,IAAA,MAAMC,iBAAiB,GAAG,EAAE,GAAGD,OAAL;AAAcE,MAAAA,QAAQ,EAAEF,OAAO,CAACE,QAAV,IAAEF,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,OAAO,CAACE,QAAR,EAAA;KAAlD,CAAA;AACA,IAAA,MAAMC,gBAAgB,GAAGP,WAAW,CAACQ,mBAAZ,CAAgCH,iBAAhC,CAAzB,CAAA;IACAE,gBAAgB,CAACE,kBAAjB,GAAsC,YAAtC,CAAA;AACA,IAAA,OAAOF,gBAAP,CAAA;GANF,CAAA;;AASA,EAAA,MAAMG,gBAAgB,GAAGX,cAAc,CAACY,OAAf,CAAuBC,GAAvB,CAA4BR,OAAD,IAClDD,gBAAgB,CAACC,OAAD,CADO,CAAzB,CAAA;EAIA,MAAMS,QAAQ,GAAG,IAAIC,eAAJ,CAAoBd,WAApB,EAAiCU,gBAAjC,CAAjB,CAAA;AAEA,EAAA,MAAM,CAACK,KAAD,EAAQC,QAAR,CAAoBC,GAAAA,WAAW,CACnCJ,QAAQ,CAACK,mBAAT,CAA6BR,gBAA7B,CADmC,CAArC,CAAA;EAIA,MAAMS,SAA4B,GAAG,EAArC,CAAA;AAEA,EAAA,MAAMC,WAAW,GAAGP,QAAQ,CAACQ,SAAT,CAAoBC,MAAD,IAAY;IACjDH,SAAS,CAACI,IAAV,CAAe,MAAM;AACnBP,MAAAA,QAAQ,CAACQ,MAAM,CAACF,MAAD,CAAP,CAAR,CAAA;KADF,CAAA,CAAA;AAIAG,IAAAA,iBAAiB,CAAC,MAAM;AACtB,MAAA,MAAMC,SAAS,GAAGP,SAAS,CAACQ,GAAV,EAAlB,CAAA;;AACA,MAAA,IAAID,SAAJ,EAAe;QACbA,SAAS,EAAA,CAAA;AACTP,QAAAA,SAAS,CAACS,MAAV,CAAiB,CAAjB,EAAoBT,SAAS,CAACU,MAA9B,CAAA,CAAA;AACD,OAAA;AACF,KANgB,CAAjB,CAAA;AAOD,GAZmB,CAApB,CAAA;EAcAC,SAAS,CAACV,WAAD,CAAT,CAAA;AAEAW,EAAAA,OAAO,CAAC,MAAM;AACZlB,IAAAA,QAAQ,CAACmB,UAAT,CAAoBtB,gBAApB,EAAsC;AAAEuB,MAAAA,SAAS,EAAE,KAAA;KAAnD,CAAA,CAAA;AACD,GAFM,CAAP,CAAA;AAIAC,EAAAA,cAAc,CAAC,MAAM;AACnB,IAAA,MAAMC,sBAAsB,GAAGpC,cAAc,CAACY,OAAf,CAAuBC,GAAvB,CAA4BR,OAAD,IACxDD,gBAAgB,CAACC,OAAD,CADa,CAA/B,CAAA;IAGAS,QAAQ,CAACmB,UAAT,CAAoBG,sBAApB,CAAA,CAAA;AACD,GALa,CAAd,CAAA;AAOA,EAAA,OAAOpB,KAAP,CAAA;AACD;;;;"}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { QueryObserver } from '@tanstack/query-core';
|
|
2
|
-
import { createComputed } from 'solid-js';
|
|
3
|
-
import { createStore } from 'solid-js/store';
|
|
4
|
-
import { parseQueryArgs } from './utils.esm.js';
|
|
5
|
-
import { createBaseQuery } from './createBaseQuery.esm.js';
|
|
6
|
-
|
|
7
|
-
function createQuery(arg1, arg2, arg3) {
|
|
8
|
-
// The parseQuery Args functions helps normalize the arguments into the correct form.
|
|
9
|
-
// Whatever the parameters are, they are normalized into the correct form.
|
|
10
|
-
const [parsedOptions, setParsedOptions] = createStore(parseQueryArgs(arg1, arg2, arg3)); // Watch for changes in the options and update the parsed options.
|
|
11
|
-
|
|
12
|
-
createComputed(() => {
|
|
13
|
-
const newParsedOptions = parseQueryArgs(arg1, arg2, arg3);
|
|
14
|
-
setParsedOptions(newParsedOptions);
|
|
15
|
-
});
|
|
16
|
-
return createBaseQuery(parsedOptions, QueryObserver);
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export { createQuery };
|
|
20
|
-
//# sourceMappingURL=createQuery.esm.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createQuery.esm.js","sources":["../../src/createQuery.ts"],"sourcesContent":["import { QueryObserver } from '@tanstack/query-core'\nimport { createComputed } from 'solid-js'\nimport { createStore } from 'solid-js/store'\nimport { parseQueryArgs } from './utils'\nimport { createBaseQuery } from './createBaseQuery'\nimport type {\n CreateQueryOptions,\n CreateQueryResult,\n DefinedCreateQueryResult,\n SolidQueryKey,\n} from './types'\nimport type { QueryFunction, QueryOptions } from '@tanstack/query-core'\n\n// There are several ways to create a query.\n// 1. createQuery(options: CreateQueryOptions)\n// 2. createQuery(querykey: () => Serializable[], options: CreateQueryOptions)\n// 3. createQuery(querykey: () => Serializable[], queryFunc: Fetcher Function, options: CreateQueryOptions)\n// 4. The fourth overload is a combination of all three function params\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n options: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'initialData'\n > & {\n initialData?: () => undefined\n },\n): CreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n options: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'initialData'\n > & {\n initialData: TQueryFnData | (() => TQueryFnData)\n },\n): DefinedCreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n options: CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n): CreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n options?: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'queryKey' | 'initialData'\n > & { initialData?: () => undefined },\n): CreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n options?: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'queryKey' | 'initialData'\n > & { initialData: TQueryFnData | (() => TQueryFnData) },\n): DefinedCreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n options?: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'queryKey'\n >,\n): CreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n // TODO(lukemurray): not sure if we want to use return type here\n queryFn: QueryFunction<TQueryFnData, ReturnType<TQueryKey>>,\n options?: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'queryKey' | 'queryFn' | 'initialData'\n > & { initialData?: () => undefined },\n): CreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n queryFn: QueryFunction<TQueryFnData, ReturnType<TQueryKey>>,\n options?: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'queryKey' | 'queryFn' | 'initialData'\n > & { initialData: TQueryFnData | (() => TQueryFnData) },\n): DefinedCreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n queryFn: QueryFunction<TQueryFnData, ReturnType<TQueryKey>>,\n options?: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'queryKey' | 'queryFn'\n >,\n): CreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData,\n TError,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n arg1: TQueryKey | CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n arg2?:\n | QueryFunction<TQueryFnData, ReturnType<TQueryKey>>\n | CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n arg3?: CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n): CreateQueryResult<TData, TError> {\n // The parseQuery Args functions helps normalize the arguments into the correct form.\n // Whatever the parameters are, they are normalized into the correct form.\n const [parsedOptions, setParsedOptions] = createStore(\n parseQueryArgs(arg1, arg2, arg3),\n )\n\n // Watch for changes in the options and update the parsed options.\n createComputed(() => {\n const newParsedOptions = parseQueryArgs(arg1, arg2, arg3)\n setParsedOptions(newParsedOptions)\n })\n\n return createBaseQuery(\n parsedOptions as QueryOptions<any, any, any, ReturnType<TQueryKey>>,\n QueryObserver,\n )\n}\n"],"names":["createQuery","arg1","arg2","arg3","parsedOptions","setParsedOptions","createStore","parseQueryArgs","createComputed","newParsedOptions","createBaseQuery","QueryObserver"],"mappings":";;;;;;AAgIO,SAASA,WAAT,CAMLC,IANK,EAOLC,IAPK,EAULC,IAVK,EAW6B;AAClC;AACA;AACA,EAAA,MAAM,CAACC,aAAD,EAAgBC,gBAAhB,CAAA,GAAoCC,WAAW,CACnDC,cAAc,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CADqC,CAArD,CAHkC;;AAQlCK,EAAAA,cAAc,CAAC,MAAM;IACnB,MAAMC,gBAAgB,GAAGF,cAAc,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CAAvC,CAAA;IACAE,gBAAgB,CAACI,gBAAD,CAAhB,CAAA;AACD,GAHa,CAAd,CAAA;AAKA,EAAA,OAAOC,eAAe,CACpBN,aADoB,EAEpBO,aAFoB,CAAtB,CAAA;AAID;;;;"}
|
package/build/lib/createQuery.js
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var queryCore = require('@tanstack/query-core');
|
|
6
|
-
var solidJs = require('solid-js');
|
|
7
|
-
var store = require('solid-js/store');
|
|
8
|
-
var utils = require('./utils.js');
|
|
9
|
-
var createBaseQuery = require('./createBaseQuery.js');
|
|
10
|
-
|
|
11
|
-
function createQuery(arg1, arg2, arg3) {
|
|
12
|
-
// The parseQuery Args functions helps normalize the arguments into the correct form.
|
|
13
|
-
// Whatever the parameters are, they are normalized into the correct form.
|
|
14
|
-
const [parsedOptions, setParsedOptions] = store.createStore(utils.parseQueryArgs(arg1, arg2, arg3)); // Watch for changes in the options and update the parsed options.
|
|
15
|
-
|
|
16
|
-
solidJs.createComputed(() => {
|
|
17
|
-
const newParsedOptions = utils.parseQueryArgs(arg1, arg2, arg3);
|
|
18
|
-
setParsedOptions(newParsedOptions);
|
|
19
|
-
});
|
|
20
|
-
return createBaseQuery.createBaseQuery(parsedOptions, queryCore.QueryObserver);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
exports.createQuery = createQuery;
|
|
24
|
-
//# sourceMappingURL=createQuery.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createQuery.js","sources":["../../src/createQuery.ts"],"sourcesContent":["import { QueryObserver } from '@tanstack/query-core'\nimport { createComputed } from 'solid-js'\nimport { createStore } from 'solid-js/store'\nimport { parseQueryArgs } from './utils'\nimport { createBaseQuery } from './createBaseQuery'\nimport type {\n CreateQueryOptions,\n CreateQueryResult,\n DefinedCreateQueryResult,\n SolidQueryKey,\n} from './types'\nimport type { QueryFunction, QueryOptions } from '@tanstack/query-core'\n\n// There are several ways to create a query.\n// 1. createQuery(options: CreateQueryOptions)\n// 2. createQuery(querykey: () => Serializable[], options: CreateQueryOptions)\n// 3. createQuery(querykey: () => Serializable[], queryFunc: Fetcher Function, options: CreateQueryOptions)\n// 4. The fourth overload is a combination of all three function params\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n options: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'initialData'\n > & {\n initialData?: () => undefined\n },\n): CreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n options: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'initialData'\n > & {\n initialData: TQueryFnData | (() => TQueryFnData)\n },\n): DefinedCreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n options: CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n): CreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n options?: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'queryKey' | 'initialData'\n > & { initialData?: () => undefined },\n): CreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n options?: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'queryKey' | 'initialData'\n > & { initialData: TQueryFnData | (() => TQueryFnData) },\n): DefinedCreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n options?: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'queryKey'\n >,\n): CreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n // TODO(lukemurray): not sure if we want to use return type here\n queryFn: QueryFunction<TQueryFnData, ReturnType<TQueryKey>>,\n options?: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'queryKey' | 'queryFn' | 'initialData'\n > & { initialData?: () => undefined },\n): CreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n queryFn: QueryFunction<TQueryFnData, ReturnType<TQueryKey>>,\n options?: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'queryKey' | 'queryFn' | 'initialData'\n > & { initialData: TQueryFnData | (() => TQueryFnData) },\n): DefinedCreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData = unknown,\n TError = unknown,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n queryKey: TQueryKey,\n queryFn: QueryFunction<TQueryFnData, ReturnType<TQueryKey>>,\n options?: Omit<\n CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'queryKey' | 'queryFn'\n >,\n): CreateQueryResult<TData, TError>\nexport function createQuery<\n TQueryFnData,\n TError,\n TData = TQueryFnData,\n TQueryKey extends SolidQueryKey = SolidQueryKey,\n>(\n arg1: TQueryKey | CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n arg2?:\n | QueryFunction<TQueryFnData, ReturnType<TQueryKey>>\n | CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n arg3?: CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n): CreateQueryResult<TData, TError> {\n // The parseQuery Args functions helps normalize the arguments into the correct form.\n // Whatever the parameters are, they are normalized into the correct form.\n const [parsedOptions, setParsedOptions] = createStore(\n parseQueryArgs(arg1, arg2, arg3),\n )\n\n // Watch for changes in the options and update the parsed options.\n createComputed(() => {\n const newParsedOptions = parseQueryArgs(arg1, arg2, arg3)\n setParsedOptions(newParsedOptions)\n })\n\n return createBaseQuery(\n parsedOptions as QueryOptions<any, any, any, ReturnType<TQueryKey>>,\n QueryObserver,\n )\n}\n"],"names":["createQuery","arg1","arg2","arg3","parsedOptions","setParsedOptions","createStore","parseQueryArgs","createComputed","newParsedOptions","createBaseQuery","QueryObserver"],"mappings":";;;;;;;;;;AAgIO,SAASA,WAAT,CAMLC,IANK,EAOLC,IAPK,EAULC,IAVK,EAW6B;AAClC;AACA;AACA,EAAA,MAAM,CAACC,aAAD,EAAgBC,gBAAhB,CAAA,GAAoCC,iBAAW,CACnDC,oBAAc,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CADqC,CAArD,CAHkC;;AAQlCK,EAAAA,sBAAc,CAAC,MAAM;IACnB,MAAMC,gBAAgB,GAAGF,oBAAc,CAACN,IAAD,EAAOC,IAAP,EAAaC,IAAb,CAAvC,CAAA;IACAE,gBAAgB,CAACI,gBAAD,CAAhB,CAAA;AACD,GAHa,CAAd,CAAA;AAKA,EAAA,OAAOC,+BAAe,CACpBN,aADoB,EAEpBO,uBAFoB,CAAtB,CAAA;AAID;;;;"}
|