Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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
Extensible validation support in Volto forms #6181
Extensible validation support in Volto forms #6181
Changes from 29 commits
d02a64b
d4a6d70
bc7b779
ad3a0d6
1fa71ed
f6bba96
3a4b000
709ed59
84bc5bf
26c82f9
3378ade
0101fca
7f2cfaa
7963197
b135545
3d6ef22
80d7462
9ad0eea
6234d48
30db8cd
bef6a77
41da3fb
2a32edc
34490f9
3152854
b89d0ce
11c24c7
e11e9d5
8094fa4
0b4f253
ca2bdd2
641ce69
2a61300
091711a
79b9a0f
6cb3f2b
0999019
e787a8a
44001cb
aff0010
443f9c7
01a14cf
f8b7287
f7dee7e
2578cf5
a2afa51
0b2c26e
3140a42
2e2df93
c01bb39
f619cd8
461b188
5f32593
0eaf1ee
d50cda0
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
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.
Can we change the api call so it will be "flattened" to the root of the field so we only have 1 way specifying the format?
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 had this wish back in the day too, but it never happened, since we already had this "scape hatch" for all customizable things in Python schema hints. Maybe we can push again in the backend side for this to happen.
@davisagli do you think we could try to unify this also in the backend? Or do you remember the reason behind we never did it?
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.
It depends on the property. For things that are valid JSON Schema, it would make sense to have plone.restapi serialize them at the top level. For other properties that are not part of JSON Schema, it makes sense to keep them inside the widgetOptions.
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 is indeed part of the validation spec of json schema (same for maxLength, minLength, maxItems, pattern etc). Should we make these validators customisable? I think it would make more sense to have these "build-in" as validators since the name already implies what it should do.
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.
What we have today as built in:
We could implement the rest, for sure.
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.
In the above examples you have to specify in the json schema if the validator is enabled or not. In the registerUtility method you only specify if the validator is available or not. It seems in this example registering the validator will have it enabled by default. I think for consistency we should also specify it in the schema and not enable it by default.
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 will clarify which validators are included and enabled by default, and put it on the top, instead than at the bottom.
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.
Yeah, having that at the end of the docs, with a
seealso
where it was first mentioned, didn't feel right. This would be a good change.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.
@stevepiercy moved to the top.