Control Example
These are the default controls JSON Form provides:
- Demo
- Schema
- UI Schema
- Data
schema.json
{"type": "object","properties": {"string": {"type": "string"},"boolean": {"type": "boolean","description": "Boolean description as a tooltip"},"number": {"type": "number"},"integer": {"type": "integer"},"date": {"type": "string","format": "date"},"time": {"type": "string","format": "time"},"dateTime": {"type": "string","format": "date-time"},"enum": {"type": "string","enum": ["One","Two","Three"]}}}
uischema.json
{"type": "VerticalLayout","elements": [{"type": "Control","scope": "#/properties/string"},{"type": "Control","scope": "#/properties/boolean"},{"type": "Control","scope": "#/properties/number"},{"type": "Control","scope": "#/properties/integer"},{"type": "Control","scope": "#/properties/date"},{"type": "Control","scope": "#/properties/time"},{"type": "Control","scope": "#/properties/dateTime"},{"type": "Control","scope": "#/properties/enum"}]}
{"string": "This is a string","boolean": true,"number": 50.5,"integer": 50,"date": "2020-06-25","time": "23:08:00","dateTime": "2020-06-25T23:08:42+02:00","enum": "Two"}
Controls can be configured via options
, see the following examples:
- Demo
- Schema
- UI Schema
- Data
schema.json
{"type": "object","properties": {"multilineString": {"type": "string","description": "Multiline Example"},"slider": {"type": "number","minimum": 1,"maximum": 5,"default": 2,"description": "Slider Example"},"trimText": {"type": "string","description": "Trim indicates whether the control shall grab the full width available"},"restrictText": {"type": "string","maxLength": 5,"description": "Restricts the input length to the set value (in this case: 5)"},"unfocusedDescription": {"type": "string","description": "This description is shown even when the control is not focused"},"hideRequiredAsterisk": {"type": "string","description": "Hides the \"*\" symbol, when the field is required"},"toggle": {"type": "boolean","description": "The \"toggle\" option renders boolean values as a toggle."}},"required": ["hideRequiredAsterisk","restrictText"]}
uischema.json
{"type": "VerticalLayout","elements": [{"type": "Control","scope": "#/properties/multilineString","options": {"multi": true}},{"type": "Control","scope": "#/properties/slider","options": {"slider": true}},{"type": "Control","scope": "#/properties/trimText","options": {"trim": true}},{"type": "Control","scope": "#/properties/restrictText","options": {"restrict": true}},{"type": "Control","scope": "#/properties/unfocusedDescription","options": {"showUnfocusedDescription": true}},{"type": "Control","scope": "#/properties/hideRequiredAsterisk","options": {"hideRequiredAsterisk": true}},{"type": "Control","scope": "#/properties/toggle","label": "Boolean as Toggle","options": {"toggle": true}}]}
{"multilineString": "Multi-\nline\nexample","slider": 4,"trimText": "abcdefg","restrictText": "abcde","toggle": false}
To see the how the options
parameter is used, have a look at the UI Schema
tab in the demo above.
Available options
can be found here.