declare module 'astro:content' { interface Render { '.mdx': Promise<{ Content: import('astro').MarkdownInstance<{}>['Content']; headings: import('astro').MarkdownHeading[]; remarkPluginFrontmatter: Record; components: import('astro').MDXInstance<{}>['components']; }>; } } declare module 'astro:content' { export interface RenderResult { Content: import('astro/runtime/server/index.js').AstroComponentFactory; headings: import('astro').MarkdownHeading[]; remarkPluginFrontmatter: Record; } interface Render { '.md': Promise; } export interface RenderedContent { html: string; metadata?: { imagePaths: Array; [key: string]: unknown; }; } } declare module 'astro:content' { type Flatten = T extends { [K: string]: infer U } ? U : never; export type CollectionKey = keyof AnyEntryMap; export type CollectionEntry = Flatten; export type ContentCollectionKey = keyof ContentEntryMap; export type DataCollectionKey = keyof DataEntryMap; type AllValuesOf = T extends any ? T[keyof T] : never; type ValidContentEntrySlug = AllValuesOf< ContentEntryMap[C] >['slug']; /** @deprecated Use `getEntry` instead. */ export function getEntryBySlug< C extends keyof ContentEntryMap, E extends ValidContentEntrySlug | (string & {}), >( collection: C, // Note that this has to accept a regular string too, for SSR entrySlug: E, ): E extends ValidContentEntrySlug ? Promise> : Promise | undefined>; /** @deprecated Use `getEntry` instead. */ export function getDataEntryById( collection: C, entryId: E, ): Promise>; export function getCollection>( collection: C, filter?: (entry: CollectionEntry) => entry is E, ): Promise; export function getCollection( collection: C, filter?: (entry: CollectionEntry) => unknown, ): Promise[]>; export function getEntry< C extends keyof ContentEntryMap, E extends ValidContentEntrySlug | (string & {}), >(entry: { collection: C; slug: E; }): E extends ValidContentEntrySlug ? Promise> : Promise | undefined>; export function getEntry< C extends keyof DataEntryMap, E extends keyof DataEntryMap[C] | (string & {}), >(entry: { collection: C; id: E; }): E extends keyof DataEntryMap[C] ? Promise : Promise | undefined>; export function getEntry< C extends keyof ContentEntryMap, E extends ValidContentEntrySlug | (string & {}), >( collection: C, slug: E, ): E extends ValidContentEntrySlug ? Promise> : Promise | undefined>; export function getEntry< C extends keyof DataEntryMap, E extends keyof DataEntryMap[C] | (string & {}), >( collection: C, id: E, ): E extends keyof DataEntryMap[C] ? Promise : Promise | undefined>; /** Resolve an array of entry references from the same collection */ export function getEntries( entries: { collection: C; slug: ValidContentEntrySlug; }[], ): Promise[]>; export function getEntries( entries: { collection: C; id: keyof DataEntryMap[C]; }[], ): Promise[]>; export function render( entry: AnyEntryMap[C][string], ): Promise; export function reference( collection: C, ): import('astro/zod').ZodEffects< import('astro/zod').ZodString, C extends keyof ContentEntryMap ? { collection: C; slug: ValidContentEntrySlug; } : { collection: C; id: keyof DataEntryMap[C]; } >; // Allow generic `string` to avoid excessive type errors in the config // if `dev` is not running to update as you edit. // Invalid collection names will be caught at build time. export function reference( collection: C, ): import('astro/zod').ZodEffects; type ReturnTypeOrOriginal = T extends (...args: any[]) => infer R ? R : T; type InferEntrySchema = import('astro/zod').infer< ReturnTypeOrOriginal['schema']> >; type ContentEntryMap = { "blog": { "first-post.md": { id: "first-post.md"; slug: "first-post"; body: string; collection: "blog"; data: InferEntrySchema<"blog"> } & { render(): Render[".md"] }; "markdown-style-guide.md": { id: "markdown-style-guide.md"; slug: "markdown-style-guide"; body: string; collection: "blog"; data: InferEntrySchema<"blog"> } & { render(): Render[".md"] }; "second-post.md": { id: "second-post.md"; slug: "second-post"; body: string; collection: "blog"; data: InferEntrySchema<"blog"> } & { render(): Render[".md"] }; "third-post.md": { id: "third-post.md"; slug: "third-post"; body: string; collection: "blog"; data: InferEntrySchema<"blog"> } & { render(): Render[".md"] }; "using-mdx.mdx": { id: "using-mdx.mdx"; slug: "using-mdx"; body: string; collection: "blog"; data: InferEntrySchema<"blog"> } & { render(): Render[".mdx"] }; }; }; type DataEntryMap = { "countries": Record; rendered?: RenderedContent; filePath?: string; }>; }; type AnyEntryMap = ContentEntryMap & DataEntryMap; export type ContentConfig = typeof import("../src/content/config.js"); }