-
-
Notifications
You must be signed in to change notification settings - Fork 14
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Remove deprecated ReactHTML
and ReactSVG
#362
Comments
Previously to type type UnwrapFactoryAttributes<F> = F extends DetailedHTMLFactory<infer P, any>
? P
: never
type UnwrapFactoryElement<F> = F extends DetailedHTMLFactory<any, infer P>
? P
: never
type HTMLAttributesWithoutMotionProps<
Attributes extends HTMLAttributes<Element>,
Element extends HTMLElement
> = { [K in Exclude<keyof Attributes, keyof MotionProps>]?: Attributes[K] }
export type HTMLMotionProps<TagName extends keyof ReactHTML> =
HTMLAttributesWithoutMotionProps<
UnwrapFactoryAttributes<ReactHTML[TagName]>,
UnwrapFactoryElement<ReactHTML[TagName]>
> &
MotionProps
export type HTMLMotionComponents = {
[K in HTMLElements]: ForwardRefComponent<
UnwrapFactoryElement<ReactHTML[K]>,
HTMLMotionProps<K>
>
} Which I've attempted to replace with interface HTMLElements {
a: HTMLAnchorElement
abbr: HTMLElement
address: HTMLElement
/** etc **/
}
type AttributesWithoutMotionProps<Attributes> = {
[K in Exclude<keyof Attributes, keyof MotionProps>]?: Attributes[K]
}
export type HTMLMotionProps<Tag extends keyof HTMLElements> = MotionProps &
AttributesWithoutMotionProps<DOMAttributes<HTMLElements[Tag]>> &
AttributesWithoutMotionProps<HTMLAttributes<HTMLElements[Tag]>>
export type HTMLMotionComponents = {
[Tag in keyof HTMLElements]: ForwardRefComponent<
HTMLElements[Tag],
HTMLMotionProps<Tag>
>
} But this hasn't proven to be a direct replacement - This is quite a complex change and |
Ah - I got it. The replacement for the props is AttributesWithoutMotionProps<JSX.IntrinsicElements[Tag]> And the whole thing can be replaced with AttributesWithoutMotionProps<Attributes> = {
[K in Exclude<keyof Attributes, keyof MotionProps>]?: Attributes[K]
}
export type HTMLMotionProps<Tag extends HTMLElementType> =
AttributesWithoutMotionProps<JSX.IntrinsicElements[Tag]> & MotionProps
export type HTMLMotionComponents = {
[Tag in HTMLElementType]: ForwardRefComponent<Tag, HTMLMotionProps<Tag>>
} |
ReactHMTL
andReactSVG
were related tocreateFactories
but we found usage using it as a list of possible built-in browser element types.We now have
HTMLElementType
andSVGElementType
which can be used instead ofkeyof ReactHTML
andkeyof ReactSVG
respectively.Needs real world codebase with usage to test on.
The text was updated successfully, but these errors were encountered: