ElementNode.tsx
2 years ago
FieldNode.tsx
2 years ago
GatewayFieldNode.tsx
2 years ago
GroupNode.tsx
2 years ago
SectionNode.tsx
2 years ago
ElementNode.tsx
17 lines
| 1 | import {Element} from '@givewp/forms/types'; |
| 2 | import {useTemplateWrapper} from '../templates'; |
| 3 | import type {ElementProps} from '@givewp/forms/propTypes'; |
| 4 | import memoNode from '@givewp/forms/app/utilities/memoNode'; |
| 5 | |
| 6 | const formTemplates = window.givewp.form.templates; |
| 7 | |
| 8 | function ElementNode({node}: {node: Element}) { |
| 9 | const Element = useTemplateWrapper<ElementProps>(formTemplates.elements[node.type], 'div', node.name); |
| 10 | |
| 11 | return <Element key={node.name} {...node} />; |
| 12 | } |
| 13 | |
| 14 | const MemoizedElementNode = memoNode(ElementNode); |
| 15 | |
| 16 | export default MemoizedElementNode; |
| 17 |