/* * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT. * @generated-id: fac897f6e749 */ import { MutationKey, useMutation, UseMutationResult, } from "@tanstack/react-query"; import { GleanCore } from "../core.js"; import { clientShortcutsDelete } from "../funcs/clientShortcutsDelete.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 ClientShortcutsDeleteMutationVariables = { deleteShortcutRequest: components.DeleteShortcutRequest; locale?: string | undefined; options?: RequestOptions; }; export type ClientShortcutsDeleteMutationData = void; export type ClientShortcutsDeleteMutationError = | GleanBaseError | ResponseValidationError | ConnectionError | RequestAbortedError | RequestTimeoutError | InvalidRequestError | UnexpectedClientError | SDKValidationError; /** * Delete shortcut * * @remarks * Delete an existing user-generated shortcut. */ export function useClientShortcutsDeleteMutation( options?: MutationHookOptions< ClientShortcutsDeleteMutationData, ClientShortcutsDeleteMutationError, ClientShortcutsDeleteMutationVariables >, ): UseMutationResult< ClientShortcutsDeleteMutationData, ClientShortcutsDeleteMutationError, ClientShortcutsDeleteMutationVariables > { const client = useGleanContext(); return useMutation({ ...buildClientShortcutsDeleteMutation(client, options), ...options, }); } export function mutationKeyClientShortcutsDelete(): MutationKey { return ["@gleanwork/api-client", "shortcuts", "delete"]; } export function buildClientShortcutsDeleteMutation( client$: GleanCore, hookOptions?: RequestOptions, ): { mutationKey: MutationKey; mutationFn: ( variables: ClientShortcutsDeleteMutationVariables, ) => Promise; } { return { mutationKey: mutationKeyClientShortcutsDelete(), mutationFn: function clientShortcutsDeleteMutationFn({ deleteShortcutRequest, locale, options, }): Promise { const mergedOptions = { ...hookOptions, ...options, fetchOptions: { ...hookOptions?.fetchOptions, ...options?.fetchOptions, signal: combineSignals( hookOptions?.fetchOptions?.signal, options?.fetchOptions?.signal, ), }, }; return unwrapAsync(clientShortcutsDelete( client$, deleteShortcutRequest, locale, mergedOptions, )); }, }; }