fix(SW-3691): Setup one prettier config for whole repo * Setup prettierrc in root and remove other configs Approved-by: Joakim Jäderberg Approved-by: Linus Flood
25 lines
512 B
TypeScript
25 lines
512 B
TypeScript
import { cloneElement, isValidElement } from "react"
|
|
|
|
import { variants } from "./variants"
|
|
|
|
import type { TypographyProps } from "./types"
|
|
|
|
export function Typography({
|
|
variant,
|
|
className,
|
|
children,
|
|
}: TypographyProps): React.ReactNode {
|
|
if (!isValidElement(children)) return null
|
|
|
|
const classNames = variants({
|
|
variant,
|
|
})
|
|
|
|
return cloneElement(children, {
|
|
...children.props,
|
|
className: [className, children.props.className, classNames]
|
|
.filter(Boolean)
|
|
.join(" "),
|
|
})
|
|
}
|