You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The type of the containerRef returned from useFocusZone is RefObject<HTMLElement>. This prevents it from being assigned to any actual HTML elements, because HTML element ref prop types are invariant1. If you attempt to do the following you'll get a TypeScript error:
Type 'RefObject<HTMLElement>' is not assignable to type 'LegacyRef<HTMLDivElement> | undefined'.
Type 'RefObject<HTMLElement>' is not assignable to type 'RefObject<HTMLDivElement>'.
Property 'align' is missing in type 'HTMLElement' but required in type 'HTMLDivElement'.
Currently the only workaround is a typecast (containerRef as RefObject<HTMLDivElement>) or defining the ref outside the hook using useRef.
This could easily be fixed by adding a generic type parameter to useFocusZone so that the consumer could define an element type to be used, for example:
This is surprising, but it happens because HTML element ref props accept both object and callback refs. Thus they are typed as (with some simplification) (element: T | null) => void | {current: T | null}. The function type makes T contravariant while the object type makes T covariant, resulting in an invariant type that accepts only exactly T. For more details on covariance and contravariance see the TypeScript documentation. ↩
The text was updated successfully, but these errors were encountered:
Thanks for reporting. Looks like an open source contributor spun up a PR #5468 so I'm moving this to "In review" for the team to help get over the line.
The type of the
containerRef
returned fromuseFocusZone
isRefObject<HTMLElement>
. This prevents it from being assigned to any actual HTML elements, because HTML element ref prop types are invariant1. If you attempt to do the following you'll get a TypeScript error:Currently the only workaround is a typecast (
containerRef as RefObject<HTMLDivElement>
) or defining the ref outside the hook usinguseRef
.This could easily be fixed by adding a generic type parameter to
useFocusZone
so that the consumer could define an element type to be used, for example:Footnotes
This is surprising, but it happens because HTML element
ref
props accept both object and callback refs. Thus they are typed as (with some simplification)(element: T | null) => void | {current: T | null}
. The function type makesT
contravariant while the object type makesT
covariant, resulting in an invariant type that accepts only exactlyT
. For more details on covariance and contravariance see the TypeScript documentation. ↩The text was updated successfully, but these errors were encountered: