From 65a9a15079592cf07c629b14ec9201072df332df Mon Sep 17 00:00:00 2001 From: sarayourfriend <24264157+sarayourfriend@users.noreply.github.com> Date: Fri, 21 May 2021 13:04:26 -0700 Subject: [PATCH] compose: Add types to useMergeRefs (#31939) * compose: Add types to useMergeRefs * Narrow the return type * Use a more readable generic type parameter name --- packages/compose/README.md | 4 +-- .../compose/src/hooks/use-merge-refs/index.js | 25 +++++++++++++++---- packages/compose/tsconfig.json | 1 + 3 files changed, 23 insertions(+), 7 deletions(-) diff --git a/packages/compose/README.md b/packages/compose/README.md index 1a46e8fb19bf4..6092aa98a0a09 100644 --- a/packages/compose/README.md +++ b/packages/compose/README.md @@ -350,11 +350,11 @@ return
; _Parameters_ -- _refs_ `Array`: The refs to be merged. +- _refs_ `Array`: The refs to be merged. _Returns_ -- `RefCallback`: The merged ref callback. +- `import('react').RefCallback>`: The merged ref callback. # **usePrevious** diff --git a/packages/compose/src/hooks/use-merge-refs/index.js b/packages/compose/src/hooks/use-merge-refs/index.js index d9bd7e6ce4e1e..5b8b353a3b680 100644 --- a/packages/compose/src/hooks/use-merge-refs/index.js +++ b/packages/compose/src/hooks/use-merge-refs/index.js @@ -3,14 +3,25 @@ */ import { useRef, useCallback, useLayoutEffect } from '@wordpress/element'; -/** @typedef {import('@wordpress/element').RefObject} RefObject */ -/** @typedef {import('@wordpress/element').RefCallback} RefCallback */ +/* eslint-disable jsdoc/valid-types */ +/** + * @template T + * @typedef {T extends import('react').Ref ? R : never} TypeFromRef + */ +/* eslint-enable jsdoc/valid-types */ +/** + * @template T + * @param {import('react').Ref} ref + * @param {T} value + */ function assignRef( ref, value ) { if ( typeof ref === 'function' ) { ref( value ); } else if ( ref && ref.hasOwnProperty( 'current' ) ) { - ref.current = value; + /* eslint-disable jsdoc/no-undefined-types */ + /** @type {import('react').MutableRefObject} */ ( ref ).current = value; + /* eslint-enable jsdoc/no-undefined-types */ } } @@ -52,13 +63,17 @@ function assignRef( ref, value ) { * return
; * ``` * - * @param {Array} refs The refs to be merged. + * @template {import('react').Ref} TRef + * @param {Array} refs The refs to be merged. * - * @return {RefCallback} The merged ref callback. + * @return {import('react').RefCallback>} The merged ref callback. */ export default function useMergeRefs( refs ) { const element = useRef(); const didElementChange = useRef( false ); + /* eslint-disable jsdoc/no-undefined-types */ + /** @type {import('react').MutableRefObject} */ + /* eslint-enable jsdoc/no-undefined-types */ const previousRefs = useRef( [] ); const currentRefs = useRef( refs ); diff --git a/packages/compose/tsconfig.json b/packages/compose/tsconfig.json index 6adf71ba46430..e2db3de66affc 100644 --- a/packages/compose/tsconfig.json +++ b/packages/compose/tsconfig.json @@ -23,6 +23,7 @@ "src/hooks/use-previous/**/*", "src/hooks/use-media-query/**/*", "src/hooks/use-reduced-motion/**/*", + "src/hooks/use-merge-refs/**/*", "src/utils/**/*" ] }