-
-
Notifications
You must be signed in to change notification settings - Fork 1.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add note about ids having to be strings to content collection docs #10612
Conversation
✅ Deploy Preview for astro-docs-2 ready!Built without sensitive environment variables
To edit notification comments on pull requests, go to your Netlify site configuration. |
Lunaria Status Overview🌕 This pull request will trigger status changes. Learn moreBy default, every PR changing files present in the Lunaria configuration's You can change this by adding one of the keywords present in the Tracked Files
Warnings reference
|
@@ -223,7 +223,7 @@ Schemas enforce consistent frontmatter or entry data within a collection through | |||
|
|||
Schemas also power Astro's automatic TypeScript typings for your content. When you define a schema for your collection, Astro will automatically generate and apply a TypeScript interface to it. The result is full TypeScript support when you query your collection, including property autocompletion and type-checking. | |||
|
|||
Every frontmatter or data property of your collection entries must be defined using a Zod data type: | |||
Every frontmatter or data property of your collection entries must be defined using a Zod data type. When defining your schema, make sure that if you provide an `id` property, it is a string: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This should say that an id field is required, so if you provide a schema it must include the id field.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@ascorbic Would
When defining your schema, make sure that you provide an `id` property and that it is a string:
be fine?
@@ -223,7 +223,7 @@ Schemas enforce consistent frontmatter or entry data within a collection through | |||
|
|||
Schemas also power Astro's automatic TypeScript typings for your content. When you define a schema for your collection, Astro will automatically generate and apply a TypeScript interface to it. The result is full TypeScript support when you query your collection, including property autocompletion and type-checking. | |||
|
|||
Every frontmatter or data property of your collection entries must be defined using a Zod data type: | |||
Every frontmatter or data property of your collection entries must be defined using a Zod data type. When defining your schema, make sure that if you provide an `id` property, it is a string: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This feels a little off here. This is currently talking about the schema including "Every frontmatter or data property" (ie properties of the data itself) and the example below does not show defining id
. In fact, when we describe the built in glob
loader we say id
is automatically generated, but we say nothing about needing to define it in a schema. So, it's confusing (even to me!) -- obviously you don't always put the id
in the schema (we didn't for glob()
. So, when do you need to put it in the schema?)
In any case, I think we could intro this a bit better with something like:
Every frontmatter or data property of your collection entries must be defined using a Zod data type. When defining your schema, make sure that if you provide an `id` property, it is a string: | |
Every frontmatter or data property of your collection entries must be defined using a Zod data type. Your content loader may provide this schema for you based on the data you are importing. If not, you must define your own schema as a property of your collection. | |
The example below shows defining a schema based on frontmatter properties in local Markdown files that are loaded by Astro's built-in `glob()` loader: |
This adds the idea that some loaders define the schema for you. But, even in the example below, we're defining a schema but not id
.
So it feels weird to describe defining id
when that's not a part of the basic intro to what schemas are. We need some kind of linkage, something like (this is not correct because I don't know when this is necessary):
In addition to defining properties of your data entries in your schema, you can type the entry
id
itself asz.string()
. This may be useful/necessary when the entry is not automatically generated for you by your loader...."
And, maybe this even comes AFTER the code example if it's kind of an edge case?
Again, my issue is that it's confusing to talk about typing id
when our example does not show doing that, so this can't just be one sentence tacked on but needs some smoothing to make it make sense.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@sarah11918 I do agree, it feels off to put this here. However, at no point in the docs is it mentioned that the ID
must be a string. That's really the intent behind this change, but I had no better spot to put this. Maybe this is just a case of saying nothing would be better since the PR to Astro improves the error?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@louisescher I agree, and looking at the error message, it's less about defining your id
as a string in the schema and more about making sure IDs are strings, I think?
I think the error message is sufficient and would suggest closing this PR, I think? How about you?
EDIT:
Should we maybe be specifying something here instead? I noticed we show examples in this section, but don't explicity state the type of string
, for example: https://docs.astro.build/en/reference/modules/astro-content/#id
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree with the location you proposed in your edit, that seems like a nice spot to put it. I'll revert the original change and add a sentence to that part, as well as changing the "Example Type: ..." to "Type: string
". Would that be OK?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If you're going to document a type, then you need @ArmandPhilippot 's permission, not mine! 😅
Here's the official pattern we use: https://contribute.docs.astro.build/reference/api-references/
(But yes, I would say revert what you've got on the Content Collections guide page itself!)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
😄 Well, at first sight, I'd say if id
is necessarily a string, yes, using Type: string
instead of the Example type:
makes sense to me! But, I'm a bit concerned about the location.
If I understand the issue correctly, the problem lies rather at the time of declaring the schema (with a custom loader?) than at the time of receiving the collection entries.
It seems to me that the CollectionEntry
type matches the returned entries. So I'm not sure it will prevent errors... I'd say the correct location would be id
in DataEntry
, but the type is already set to string
. So I'm a bit confused about what to do. I feel like the docs is already defining the right type... and maybe the error covered by the linked PR is enough to inform the user?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The reason I proposed a change to docs in the first place is because I know a lot of people only read the guides and not the actual reference. I felt like having a small sentence clarifying that only strings are accepted might save some headaches but after going through this I agree that the error itself is probably enough. Feel free to close this PR!
Alright, thanks for everything everyone! I think we've decided that the error message works! We can always revisit this topic if it turns out the error message isn't sufficient! |
Description (required)
This PR adds a sentence to clarify that the IDs of content collections always have to be strings. This is undocumented behavior and lead to confusion, see Custom content loader:
entry missing id
when using an id from the source data on the Astro Discord server.Related issues & labels (optional)