(
...sources: Array<
React.ComponentPropsWithRef<TElement> | Record<string, unknown> | undefined
>
)
| 82 | } |
| 83 | |
| 84 | function mergeProps<TElement extends React.ElementType>( |
| 85 | ...sources: Array< |
| 86 | React.ComponentPropsWithRef<TElement> | Record<string, unknown> | undefined |
| 87 | > |
| 88 | ) { |
| 89 | const result: Record<string, unknown> = {} |
| 90 | |
| 91 | for (const source of sources) { |
| 92 | if (!source) { |
| 93 | continue |
| 94 | } |
| 95 | |
| 96 | const sourceProps = source as Record<string, unknown> |
| 97 | |
| 98 | for (const key of Object.keys(sourceProps)) { |
| 99 | const value = sourceProps[key] |
| 100 | |
| 101 | if (value === undefined) { |
| 102 | continue |
| 103 | } |
| 104 | |
| 105 | const current = result[key] |
| 106 | |
| 107 | if (key === "className") { |
| 108 | result[key] = [current, value].filter(Boolean).join(" ") |
| 109 | } else if (key === "style") { |
| 110 | result[key] = { |
| 111 | ...(current as React.CSSProperties | undefined), |
| 112 | ...(value as React.CSSProperties | undefined), |
| 113 | } |
| 114 | } else if (key === "ref") { |
| 115 | result[key] = composeRefs( |
| 116 | current as React.Ref<unknown> | undefined, |
| 117 | value as React.Ref<unknown> | undefined |
| 118 | ) |
| 119 | } else if ( |
| 120 | isEventHandler(key) && |
| 121 | typeof current === "function" && |
| 122 | typeof value === "function" |
| 123 | ) { |
| 124 | result[key] = composeEventHandlers( |
| 125 | value as EventHandler, |
| 126 | current as EventHandler |
| 127 | ) |
| 128 | } else { |
| 129 | result[key] = value |
| 130 | } |
| 131 | } |
| 132 | } |
| 133 | |
| 134 | return result as React.ComponentPropsWithRef<TElement> |
| 135 | } |
| 136 | |
| 137 | function getStateAttributes<TState extends RenderState>( |
| 138 | state: TState, |
no test coverage detected