@connectrpc/connect-query
Version:
TypeScript-first expansion pack for TanStack Query that gives you Protobuf superpowers.
47 lines • 2 kB
JavaScript
;
// Copyright 2021-2023 The Connect Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
Object.defineProperty(exports, "__esModule", { value: true });
exports.createUseQueryOptions = void 0;
const call_unary_method_js_1 = require("./call-unary-method.js");
const connect_query_key_js_1 = require("./connect-query-key.js");
const utils_js_1 = require("./utils.js");
function createUnaryQueryFn(methodType, input, { callOptions, transport, }) {
return async (context) => {
(0, utils_js_1.assert)(input !== utils_js_1.disableQuery, "Disabled query cannot be fetched");
return (0, call_unary_method_js_1.callUnaryMethod)(methodType, input, {
callOptions: {
...callOptions,
signal: callOptions?.signal ?? context.signal,
},
transport,
});
};
}
/**
* Creates all options required to make a query. Useful in combination with `useQueries` from tanstack/react-query.
*/
function createUseQueryOptions(methodSig, input, { transport, callOptions, }) {
const queryKey = (0, connect_query_key_js_1.createConnectQueryKey)(methodSig, input);
return {
queryKey,
queryFn: createUnaryQueryFn(methodSig, input, {
transport,
callOptions,
}),
enabled: input === utils_js_1.disableQuery ? false : undefined,
};
}
exports.createUseQueryOptions = createUseQueryOptions;
//# sourceMappingURL=create-use-query-options.js.map