({
defaultTagName,
props,
render,
state = {} as TState,
stateAttributesMapping,
}: UseRenderOptions<TElement, TState>)
| 39 | } |
| 40 | |
| 41 | function useRender< |
| 42 | TElement extends React.ElementType, |
| 43 | TState extends RenderState = RenderState, |
| 44 | >({ |
| 45 | defaultTagName, |
| 46 | props, |
| 47 | render, |
| 48 | state = {} as TState, |
| 49 | stateAttributesMapping, |
| 50 | }: UseRenderOptions<TElement, TState>) { |
| 51 | const elementProps = mergeProps<TElement>( |
| 52 | getStateAttributes(state, stateAttributesMapping), |
| 53 | props |
| 54 | ) |
| 55 | |
| 56 | if (!render) { |
| 57 | return React.createElement(defaultTagName, elementProps) |
| 58 | } |
| 59 | |
| 60 | if (typeof render === "function") { |
| 61 | return render(elementProps, state) |
| 62 | } |
| 63 | |
| 64 | if (!React.isValidElement(render)) { |
| 65 | return null |
| 66 | } |
| 67 | |
| 68 | const renderProps = render.props as Record<string, unknown> |
| 69 | const propsWithRenderProps = mergeProps<TElement>(elementProps, renderProps) |
| 70 | const propsWithRef = { |
| 71 | ...propsWithRenderProps, |
| 72 | ref: composeRefs( |
| 73 | elementProps.ref as React.Ref<unknown> | undefined, |
| 74 | renderProps.ref as React.Ref<unknown> | undefined |
| 75 | ), |
| 76 | } |
| 77 | |
| 78 | return React.cloneElement( |
| 79 | render, |
| 80 | propsWithRef as React.Attributes & Record<string, unknown> |
| 81 | ) |
| 82 | } |
| 83 | |
| 84 | function mergeProps<TElement extends React.ElementType>( |
| 85 | ...sources: Array< |
no test coverage detected