declare module 'astro:content' { interface Render { '.mdx': Promise<{ Content: import('astro').MarkdownInstance<{}>['Content']; headings: import('astro').MarkdownHeading[]; remarkPluginFrontmatter: Record; }>; } } declare module 'astro:content' { interface Render { '.md': Promise<{ Content: import('astro').MarkdownInstance<{}>['Content']; headings: import('astro').MarkdownHeading[]; remarkPluginFrontmatter: Record; }>; } } declare module 'astro:content' { export { z } from 'astro/zod'; 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; // This needs to be in sync with ImageMetadata export type ImageFunction = () => import('astro/zod').ZodObject<{ src: import('astro/zod').ZodString; width: import('astro/zod').ZodNumber; height: import('astro/zod').ZodNumber; format: import('astro/zod').ZodUnion< [ import('astro/zod').ZodLiteral<'png'>, import('astro/zod').ZodLiteral<'jpg'>, import('astro/zod').ZodLiteral<'jpeg'>, import('astro/zod').ZodLiteral<'tiff'>, import('astro/zod').ZodLiteral<'webp'>, import('astro/zod').ZodLiteral<'gif'>, import('astro/zod').ZodLiteral<'svg'>, import('astro/zod').ZodLiteral<'avif'>, ] >; }>; type BaseSchemaWithoutEffects = | import('astro/zod').AnyZodObject | import('astro/zod').ZodUnion<[BaseSchemaWithoutEffects, ...BaseSchemaWithoutEffects[]]> | import('astro/zod').ZodDiscriminatedUnion | import('astro/zod').ZodIntersection; type BaseSchema = | BaseSchemaWithoutEffects | import('astro/zod').ZodEffects; export type SchemaContext = { image: ImageFunction }; type DataCollectionConfig = { type: 'data'; schema?: S | ((context: SchemaContext) => S); }; type ContentCollectionConfig = { type?: 'content'; schema?: S | ((context: SchemaContext) => S); }; type CollectionConfig = ContentCollectionConfig | DataCollectionConfig; export function defineCollection( input: CollectionConfig ): CollectionConfig; type AllValuesOf = T extends any ? T[keyof T] : never; type ValidContentEntrySlug = AllValuesOf< ContentEntryMap[C] >['slug']; 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>; 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 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 = { "articles": { "en/2022.md": { id: "en/2022.md"; slug: "en/2022"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".md"] }; "en/2023.md": { id: "en/2023.md"; slug: "en/2023"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".md"] }; "en/after-effects-expressions.mdx": { id: "en/after-effects-expressions.mdx"; slug: "en/after-effects-expressions"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".mdx"] }; "en/faq.md": { id: "en/faq.md"; slug: "en/faq"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".md"] }; "en/gratuiste.md": { id: "en/gratuiste.md"; slug: "en/gratuiste"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".md"] }; "en/sci-hub-blocage.mdx": { id: "en/sci-hub-blocage.mdx"; slug: "en/sci-hub-blocage"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".mdx"] }; "en/the-day-I-jamd.mdx": { id: "en/the-day-I-jamd.mdx"; slug: "en/the-day-i-jamd"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".mdx"] }; "en/video-compression.mdx": { id: "en/video-compression.mdx"; slug: "en/video-compression"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".mdx"] }; "fr/2022.md": { id: "fr/2022.md"; slug: "fr/2022"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".md"] }; "fr/2023.md": { id: "fr/2023.md"; slug: "fr/2023"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".md"] }; "fr/after-effects-expressions.md": { id: "fr/after-effects-expressions.md"; slug: "fr/after-effects-expressions"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".md"] }; "fr/faq.md": { id: "fr/faq.md"; slug: "fr/faq"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".md"] }; "fr/gratuiste.md": { id: "fr/gratuiste.md"; slug: "fr/gratuiste"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".md"] }; "fr/sci-hub-blocage.mdx": { id: "fr/sci-hub-blocage.mdx"; slug: "fr/sci-hub-blocage"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".mdx"] }; "fr/the-day-I-jamd.mdx": { id: "fr/the-day-I-jamd.mdx"; slug: "fr/the-day-i-jamd"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".mdx"] }; "fr/video-compression.md": { id: "fr/video-compression.md"; slug: "fr/video-compression"; body: string; collection: "articles"; data: InferEntrySchema<"articles"> } & { render(): Render[".md"] }; }; "fragments": { "en/acme-sh-tls-cert.md": { id: "en/acme-sh-tls-cert.md"; slug: "en/acme-sh-tls-cert"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".md"] }; "en/array-vs-array.md": { id: "en/array-vs-array.md"; slug: "en/array-vs-array"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".md"] }; "en/buttons.md": { id: "en/buttons.md"; slug: "en/buttons"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".md"] }; "en/image-full.mdx": { id: "en/image-full.mdx"; slug: "en/image-full"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".mdx"] }; "en/nuxt-graphql-static.md": { id: "en/nuxt-graphql-static.md"; slug: "en/nuxt-graphql-static"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".md"] }; "en/super-cookies.mdx": { id: "en/super-cookies.mdx"; slug: "en/super-cookies"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".mdx"] }; "en/toulouse-fun.md": { id: "en/toulouse-fun.md"; slug: "en/toulouse-fun"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".md"] }; "en/visited-links.md": { id: "en/visited-links.md"; slug: "en/visited-links"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".md"] }; "fr/acme-sh-tls-cert.md": { id: "fr/acme-sh-tls-cert.md"; slug: "fr/acme-sh-tls-cert"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".md"] }; "fr/array-vs-array.md": { id: "fr/array-vs-array.md"; slug: "fr/array-vs-array"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".md"] }; "fr/buttons.mdx": { id: "fr/buttons.mdx"; slug: "fr/buttons"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".mdx"] }; "fr/image-full.mdx": { id: "fr/image-full.mdx"; slug: "fr/image-full"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".mdx"] }; "fr/nuxt-graphql-static.md": { id: "fr/nuxt-graphql-static.md"; slug: "fr/nuxt-graphql-static"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".md"] }; "fr/super-cookies.mdx": { id: "fr/super-cookies.mdx"; slug: "fr/super-cookies"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".mdx"] }; "fr/toulouse-fun.md": { id: "fr/toulouse-fun.md"; slug: "fr/toulouse-fun"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".md"] }; "fr/visited-links.md": { id: "fr/visited-links.md"; slug: "fr/visited-links"; body: string; collection: "fragments"; data: InferEntrySchema<"fragments"> } & { render(): Render[".md"] }; }; "references": { "en/3w.md": { id: "en/3w.md"; slug: "en/3w"; body: string; collection: "references"; data: InferEntrySchema<"references"> } & { render(): Render[".md"] }; "en/natureo.md": { id: "en/natureo.md"; slug: "en/natureo"; body: string; collection: "references"; data: InferEntrySchema<"references"> } & { render(): Render[".md"] }; "en/parole-expression.md": { id: "en/parole-expression.md"; slug: "en/parole-expression"; body: string; collection: "references"; data: InferEntrySchema<"references"> } & { render(): Render[".md"] }; "en/rose-primaire.md": { id: "en/rose-primaire.md"; slug: "en/rose-primaire"; body: string; collection: "references"; data: InferEntrySchema<"references"> } & { render(): Render[".md"] }; "fr/3w.md": { id: "fr/3w.md"; slug: "fr/3w"; body: string; collection: "references"; data: InferEntrySchema<"references"> } & { render(): Render[".md"] }; "fr/natureo.md": { id: "fr/natureo.md"; slug: "fr/natureo"; body: string; collection: "references"; data: InferEntrySchema<"references"> } & { render(): Render[".md"] }; "fr/parole-expression.md": { id: "fr/parole-expression.md"; slug: "fr/parole-expression"; body: string; collection: "references"; data: InferEntrySchema<"references"> } & { render(): Render[".md"] }; "fr/rose-primaire.md": { id: "fr/rose-primaire.md"; slug: "fr/rose-primaire"; body: string; collection: "references"; data: InferEntrySchema<"references"> } & { render(): Render[".md"] }; }; }; type DataEntryMap = { }; type AnyEntryMap = ContentEntryMap & DataEntryMap; type ContentConfig = typeof import("../src/content/config"); }