Skip to content
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

[📝 Docs]: Improve Enum documentation #521

Open
1 task done
benjagm opened this issue Mar 13, 2024 · 25 comments · May be fixed by #1312
Open
1 task done

[📝 Docs]: Improve Enum documentation #521

benjagm opened this issue Mar 13, 2024 · 25 comments · May be fixed by #1312
Assignees
Labels
📝 Documentation Indicates improvements or additions to documentation. Status: Available No one has claimed responsibility for resolving this issue.

Comments

@benjagm
Copy link
Collaborator

benjagm commented Mar 13, 2024

What Docs changes are you proposing?

We received this feedback from the website and we think this is a great suggestion to improve our docs:

Page: /understanding-json-schema/reference/enum
Comment: It'd be nice to see enum defined in context - where does it live in an overall schema?

Code of Conduct

  • I agree to follow this project's Code of Conduct
@benjagm benjagm added 📝 Documentation Indicates improvements or additions to documentation. Status: Available No one has claimed responsibility for resolving this issue. labels Mar 13, 2024
@Adity20
Copy link
Contributor

Adity20 commented Mar 13, 2024

Can I work on this one @benjagm

@gregsdennis
Copy link
Member

Let's discuss what the improvement is in this issue before working on it.

@Adity20
Copy link
Contributor

Adity20 commented Mar 13, 2024

I guess telling the user where does enum live in overall schema using an example of enumerated values and then giving an example of using two different data types will be helpful.
In current json schema components we are showing the enum property only and not how it can be implemented withing overall schema

@gregsdennis
Copy link
Member

gregsdennis commented Mar 13, 2024

where does enum live in overall schema

This is my point: where would you say that enum "lives" in a schema? There's not a correct answer to this because it depends on the data you're trying to validate.

enum on it's own in a schema, as it's shown in the current page, is perfectly valid and actually encouraged.

@Adity20
Copy link
Contributor

Adity20 commented Mar 13, 2024

Agreed @gregsdennis it can vary depending on different schemas

@Adity20
Copy link
Contributor

Adity20 commented Mar 13, 2024

It's fine as it is or we can just add an example for an array of enumerated values
{
"type": "array",
"items": {
"type": "string",
"enum": ["one", "two", "three"]
}
}
like this

@gregsdennis
Copy link
Member

We shouldn't combine enum with other validation keywords (like type). enum lists valid values. Other validations are redundant.

We tell people this all the time, and they still do it. But we shouldn't promote this practice.

@Adity20
Copy link
Contributor

Adity20 commented Mar 13, 2024

Completely agree with you @gregsdennis.
So I guess we should leave it like that only to avoid any further confusion

@benjagm benjagm added Status: Triage This is the initial status for an issue that requires triage. and removed Status: Available No one has claimed responsibility for resolving this issue. labels Mar 13, 2024
@benjagm
Copy link
Collaborator Author

benjagm commented Mar 18, 2024

We just received more feedback regarding improving the docs of Enum:

  • Comment: Is "enum" a keyword or a user-defined name? For example, would "color": ["red", "green", "blue"] work?

@Adity20
Copy link
Contributor

Adity20 commented Mar 18, 2024

So what changes we should introduce in the documentation @benjagm ?
color is a property of the object and enum specifies the value of color so the value must be one of the three strings.
I don't think "color": ["red", "green", "blue"] will work because we can't substitute color for enum keyword.
Let me know if I'm wrong @benjagm and @gregsdennis.

@gregsdennis
Copy link
Member

I don't think that makes sense from a JSON Schema perspective.

However, I think it might make sense if they're trying to build a form, and they want a field called color to be one of those three values. However, I'd expect a form generator to understand "color": { "enum": [ "red", "green", "blue" ]}.

@Adity20
Copy link
Contributor

Adity20 commented Mar 18, 2024

Yeah agreed @gregsdennis
So we should add this to the enum documentation?

@gregsdennis
Copy link
Member

Add what? We can't document any form gen stuff because every form generator does things differently. There's no standard.

@Adity20
Copy link
Contributor

Adity20 commented Mar 18, 2024

Comment: Is "enum" a keyword or a user-defined name? For example, would "color": ["red", "green", "blue"] work?

This comment

@gregsdennis
Copy link
Member

I don't understand how adding that improves the docs.

@gregsdennis
Copy link
Member

gregsdennis commented Mar 18, 2024

I think the docs are actually quite clear that it's a keyword. The examples on the page use it as a keyword. JSON Schema is comprised of keywords. I'm not sure how else it can be interpreted. I don't know what the commenter means by "user-defined name" because there's no such thing in JSON Schema. There are custom keywords, but those are also keywords.

The page STARTS with "The enum keyword..."

@rishabhsdev
Copy link

rishabhsdev commented Mar 30, 2024

After going through this thread, I came up with a couple suggestions:

1. To further enrich the enum documentation:

We can add required constraint to the docs.

{
  "type": "object",
  "properties": {
    "color": {
      "enum": ["red", "blue", "green"]
    },
    "shape": {
      "enum": ["circle", "square", "triangle"]
    }
  },
  "required": ["color", "shape"]
}

Also, I agree with @gregsdennis , using type with enum is redundant, because we are already specifying valid values in enum, that's kind of the purpose of enum.

2. In response to the comment received Is "enum" a keyword or a user-defined name? For example, would "color": ["red", "green", "blue"] work?

It seems like a common query beginners might have. The code above perfectly shows how to use enum with a custom field. But if we want to answer this query explicitly, we can add "custom_key": { "enum": ["value1", "value2", "value3"] } to the documentation.

@benjagm Let me know if this task can be Assigned to me. Thanks.

@benjagm benjagm moved this to Todo in JSON Schema Docs Apr 11, 2024
@keys-i
Copy link

keys-i commented Apr 13, 2024

is this free?

@gregsdennis
Copy link
Member

@radhesh1 what needs doing is unclear. I don't think that anything needs to be done and this issue can be closed. If you see a way to make things more clear, please make a proposal here before creating a PR.

Copy link

github-actions bot commented Jun 2, 2024

Hello! 👋

This issue has been automatically marked as stale due to inactivity 😴

It will be closed in 180 days if no further activity occurs. To keep it active, please add a comment with more details.

There can be many reasons why a specific issue has no activity. The most probable cause is a lack of time, not a lack of interest.

Let us figure out together how to push this issue forward. Connect with us through our slack channel : https://json-schema.org/slack

Thank you for your patience ❤️

@github-actions github-actions bot added the Status: Stale It's believed that this issue is no longer important to the requestor. label Jun 2, 2024
@benjagm benjagm removed Status: Triage This is the initial status for an issue that requires triage. Status: Stale It's believed that this issue is no longer important to the requestor. labels Aug 21, 2024
@benjagm benjagm added the Status: Available No one has claimed responsibility for resolving this issue. label Aug 21, 2024
@benjagm
Copy link
Collaborator Author

benjagm commented Aug 21, 2024

This issue has been automatically marked as stale due to inactivity 😴

We'd love this issue to stay open.

@jagpreetrahi
Copy link

Hii @benjagm , I came across website and try to understand the application so my concern is we should work on providing more details for specific topic and give more language specific example like for JS and TS . And we can also add search bar for faster access the topic.
Looking forward to the opportunity to collaborate with you

@techmannih
Copy link
Contributor

techmannih commented Oct 24, 2024

@benjagm may I work on this issue, please review this, looks better
image

@techmannih
Copy link
Contributor

@benjagm @valeriahhdez May I work on this issue, there is no activity from last 2 months

@valeriahhdez
Copy link
Contributor

@techmannih Yes, you can

@techmannih techmannih linked a pull request Jan 14, 2025 that will close this issue
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
📝 Documentation Indicates improvements or additions to documentation. Status: Available No one has claimed responsibility for resolving this issue.
Projects
Status: Todo
Development

Successfully merging a pull request may close this issue.

8 participants