-
-
Notifications
You must be signed in to change notification settings - Fork 734
Description
Is your feature request related to a problem? Please describe
For the development of the new website for the 3D printing conference Printed-Amsterdam, I chose Nuxt 3 with @nuxt/content in combination with Nuxt Studio. This setup was intended to provide an intuitive and user-friendly experience, especially for non-technical users.
However, while creating the data schema, I encountered two fundamental missing features:
- Content files with
type == dataschemas are not validated (this enhancement issue). - Nested collections for relationships are not supported (see feat(content): support nested collection relations #3352 ).
The code is available in this open-source repository for the community:
https://github.com/toddeTV/printed-amsterdam.com
Describe the solution you'd like
It would be helpful if, during the build process, all files within the content folder were validated. Since all collections are already loaded during the build, it would be feasible to crawl the corresponding source folders, open all related files, and validate them against a schema - if one is provided.
Currently, it's possible to define a content config like this:
import { defineCollection, defineContentConfig, z } from '@nuxt/content'
export default defineContentConfig({
collections: {
talks: defineCollection({
type: 'data',
source: 'talks/**/*.json',
schema: z.object({
title: z.string(),
description: z.string(),
}),
}),
},
})And include a file like /content/talks/foo.json with the following content:
{
"title": 2
}This file passes through the build without errors and is even included in the SQLite database under the talks collection. However, this should not happen: the description field is missing - even though it's required - and the title field is a number instead of a string.
Describe alternatives you've considered
Validating a collection's schema against all its files naturally incurs a performance cost. However, skipping validation allows errors to slip through easily and makes scaling with @nuxt/content more difficult.
A possible solution would be to make schema validation optional - controlled via a flag or configuration option. For example, validation could be enabled in feature branches via CI workflows, enforced as a required step before merging, and disabled on the main branch to speed up regular builds.
Additional context
None.