How to register nested custom components? #20
-
I am trying to create a below structure. Section All the components within each level are custom components and not rsuite. I have specific predefined set of components of each level. The hierarchy must be respected but the structure is fairly static. Users can select any of the level and underlying hierarchy should be added with it. (eg. if user adds a section component on form, it should also add all subsections and controls within them to the section. This list is predefined and fairly static, however a user can also add control to another section/subsection independently. Basically my sections would be a container for subsections or controls, while my subsection is a container for controls. What I have tried:
However when I check the JSON of above, it creates the same as
What I would be expecting is
So that I can allow user to add further pre registered controls if they want, and also when I drag the MySubsectionControl on form, it drags the appropriate children along with it. |
Beta Was this translation helpful? Give feedback.
Replies: 2 comments 1 reply
-
Currently there is no way to restrict the type of component that can be used as a child node. This feature is useful and we have added it to our backlog. But you can use any number of properties of type import styled from '@emotion/styled'
import {boolean, define, node, oneOf} from '@react-form-builder/core'
import {Message} from 'rsuite'
const SMessage = styled(Message)`
.rs-message-header {
overflow: initial;
}
`
export const rsMessage = define(SMessage, 'RsMessage')
.name('Message')
.props({
children: node,
closeable: boolean,
header: node,
type: oneOf('info', 'success', 'warning', 'error').default('info')
}) Form example: {
"version": "1",
"form": {
"key": "Screen",
"type": "Screen",
"props": {},
"children": [
{
"key": "RsMessage 1",
"type": "RsMessage",
"props": {},
"children": [
{
"key": "RsHeader 1",
"type": "RsHeader",
"props": {},
"slot": "header"
},
{
"key": "RsImage 1",
"type": "RsImage",
"props": {}
}
]
}
]
},
"localization": {},
"languages": [
{
"code": "en",
"dialect": "US",
"name": "English",
"description": "American English",
"bidi": "ltr"
}
],
"defaultLanguage": "en-US"
} |
Beta Was this translation helpful? Give feedback.
-
This is just a component with two const SubSection = (props: any) => {
return <div {...props}>SubSection</div>
}
const subSection = define(SubSection, 'SubSection')
.name('SubSection')
.props({
})
const Section = (props: any) => {
const {subsection1, subsection2} = props
// defaults
const s1 = subsection1 ?? <SubSection style={{backgroundColor: 'green'}} />
const s2 = subsection2 ?? <SubSection style={{backgroundColor: 'orange'}}/>
return (
<div>
{s1}
{s2}
</div>
)
}
const section = define(Section, 'Section')
.name('Section')
.props({
subsection1: node,
subsection2: node,
})
There is no such public API for converting a component to JSON. All components are stored in a tree that is documented, but is not a public API (something can be changed).
|
Beta Was this translation helpful? Give feedback.
This is just a component with two
node
props. There are no default value for thenode
annotation. So you can do something like this: