/* * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT. * @generated-id: f539f36cd532 */ import { MutationKey, useMutation, UseMutationResult, } from "@tanstack/react-query"; import { GleanCore } from "../core.js"; import { indexingShortcutsUpload } from "../funcs/indexingShortcutsUpload.js"; import { combineSignals } from "../lib/primitives.js"; import { RequestOptions } from "../lib/sdks.js"; import * as components from "../models/components/index.js"; import { GleanBaseError } from "../models/errors/gleanbaseerror.js"; import { ConnectionError, InvalidRequestError, RequestAbortedError, RequestTimeoutError, UnexpectedClientError, } from "../models/errors/httpclienterrors.js"; import { ResponseValidationError } from "../models/errors/responsevalidationerror.js"; import { SDKValidationError } from "../models/errors/sdkvalidationerror.js"; import { unwrapAsync } from "../types/fp.js"; import { useGleanContext } from "./_context.js"; import { MutationHookOptions } from "./_types.js"; export type IndexingShortcutsUploadMutationVariables = { request: components.UploadShortcutsRequest; options?: RequestOptions; }; export type IndexingShortcutsUploadMutationData = void; export type IndexingShortcutsUploadMutationError = | GleanBaseError | ResponseValidationError | ConnectionError | RequestAbortedError | RequestTimeoutError | InvalidRequestError | UnexpectedClientError | SDKValidationError; /** * Upload shortcuts * * @remarks * Creates glean shortcuts for uploaded shortcuts info. Glean would host the shortcuts, and they can be managed in the knowledge tab once uploaded. */ export function useIndexingShortcutsUploadMutation( options?: MutationHookOptions< IndexingShortcutsUploadMutationData, IndexingShortcutsUploadMutationError, IndexingShortcutsUploadMutationVariables >, ): UseMutationResult< IndexingShortcutsUploadMutationData, IndexingShortcutsUploadMutationError, IndexingShortcutsUploadMutationVariables > { const client = useGleanContext(); return useMutation({ ...buildIndexingShortcutsUploadMutation(client, options), ...options, }); } export function mutationKeyIndexingShortcutsUpload(): MutationKey { return ["@gleanwork/api-client", "shortcuts", "upload"]; } export function buildIndexingShortcutsUploadMutation( client$: GleanCore, hookOptions?: RequestOptions, ): { mutationKey: MutationKey; mutationFn: ( variables: IndexingShortcutsUploadMutationVariables, ) => Promise; } { return { mutationKey: mutationKeyIndexingShortcutsUpload(), mutationFn: function indexingShortcutsUploadMutationFn({ request, options, }): Promise { const mergedOptions = { ...hookOptions, ...options, fetchOptions: { ...hookOptions?.fetchOptions, ...options?.fetchOptions, signal: combineSignals( hookOptions?.fetchOptions?.signal, options?.fetchOptions?.signal, ), }, }; return unwrapAsync(indexingShortcutsUpload( client$, request, mergedOptions, )); }, }; }