@tanstack/ai
Version:
Core TanStack AI library - Open source AI SDK
75 lines (74 loc) • 3.44 kB
TypeScript
import { ImageGenerationOptions, ImageGenerationResult } from '../../types.js';
/**
* Resolve the size type for a model from the model-size map.
* If the map has an index signature (i.e. no explicit keys), falls back to string.
* If the model is an explicit key, uses its mapped size type.
* Otherwise falls back to string.
*/
/**
* Configuration for image adapter instances
*/
export interface ImageAdapterConfig {
apiKey?: string;
baseUrl?: string;
timeout?: number;
maxRetries?: number;
headers?: Record<string, string>;
}
/**
* Image adapter interface with pre-resolved generics.
*
* An adapter is created by a provider function: `provider('model')` → `adapter`
* All type resolution happens at the provider call site, not in this interface.
*
* Generic parameters:
* - TModel: The specific model name (e.g., 'dall-e-3')
* - TProviderOptions: Base provider-specific options (already resolved)
* - TModelProviderOptionsByName: Map from model name to its specific provider options
* - TModelSizeByName: Map from model name to its supported sizes
*/
export interface ImageAdapter<TModel extends string = string, TProviderOptions extends object = Record<string, unknown>, TModelProviderOptionsByName extends Record<string, any> = Record<string, any>, TModelSizeByName extends Record<string, string> = Record<string, string>> {
/** Discriminator for adapter kind - used by generate() to determine API shape */
readonly kind: 'image';
/** Adapter name identifier */
readonly name: string;
/** The model this adapter is configured for */
readonly model: TModel;
/**
* @internal Type-only properties for inference. Not assigned at runtime.
*/
'~types': {
providerOptions: TProviderOptions;
modelProviderOptionsByName: TModelProviderOptionsByName;
modelSizeByName: TModelSizeByName;
};
/**
* Generate images from a prompt
*/
generateImages: (options: ImageGenerationOptions<TProviderOptions, TModelSizeByName[TModel]>) => Promise<ImageGenerationResult>;
}
/**
* An ImageAdapter with any/unknown type parameters.
* Useful as a constraint in generic functions and interfaces.
*/
export type AnyImageAdapter = ImageAdapter<any, any, any, any>;
/**
* Abstract base class for image generation adapters.
* Extend this class to implement an image adapter for a specific provider.
*
* Generic parameters match ImageAdapter - all pre-resolved by the provider function.
*/
export declare abstract class BaseImageAdapter<TModel extends string = string, TProviderOptions extends object = Record<string, unknown>, TModelProviderOptionsByName extends Record<string, any> = Record<string, any>, TModelSizeByName extends Record<string, string> = Record<string, string>> implements ImageAdapter<TModel, TProviderOptions, TModelProviderOptionsByName, TModelSizeByName> {
readonly kind: "image";
abstract readonly name: string;
readonly model: TModel;
'~types': {
providerOptions: TProviderOptions;
modelProviderOptionsByName: TModelProviderOptionsByName;
modelSizeByName: TModelSizeByName;
};
protected config: ImageAdapterConfig;
constructor(config: ImageAdapterConfig | undefined, model: TModel);
abstract generateImages(options: ImageGenerationOptions<TProviderOptions, TModelSizeByName[TModel]>): Promise<ImageGenerationResult>;
protected generateId(): string;
}