UNPKG

@huggingface/inference

Version:

Typescript client for the Hugging Face Inference Providers and Inference Endpoints

37 lines (32 loc) 1.53 kB
import type { TextToImageInput } from "@huggingface/tasks"; import { resolveProvider } from "../../lib/getInferenceProviderMapping"; import { getProviderHelper } from "../../lib/getProviderHelper"; import { makeRequestOptions } from "../../lib/makeRequestOptions"; import type { BaseArgs, Options } from "../../types"; import { innerRequest } from "../../utils/request"; export type TextToImageArgs = BaseArgs & TextToImageInput; interface TextToImageOptions extends Options { outputType?: "url" | "blob"; } /** * This task reads some text input and outputs an image. * Recommended model: stabilityai/stable-diffusion-2 */ export async function textToImage( args: TextToImageArgs, options?: TextToImageOptions & { outputType: "url" } ): Promise<string>; export async function textToImage( args: TextToImageArgs, options?: TextToImageOptions & { outputType?: undefined | "blob" } ): Promise<Blob>; export async function textToImage(args: TextToImageArgs, options?: TextToImageOptions): Promise<Blob | string> { const provider = await resolveProvider(args.provider, args.model, args.endpointUrl); const providerHelper = getProviderHelper(provider, "text-to-image"); const { data: res } = await innerRequest<Record<string, unknown>>(args, providerHelper, { ...options, task: "text-to-image", }); const { url, info } = await makeRequestOptions(args, providerHelper, { ...options, task: "text-to-image" }); return providerHelper.getResponse(res, url, info.headers as Record<string, string>, options?.outputType); }