useTransformRef.js 707 B

123456789101112131415161718
  1. import { assignRef } from './assignRef';
  2. import { useCallbackRef } from './useRef';
  3. /**
  4. * Create a _lense_ on Ref, making it possible to transform ref value
  5. * @param {ReactRef} ref
  6. * @param {Function} transformer. 👉 Ref would be __NOT updated__ on `transformer` update.
  7. * @returns {RefObject}
  8. *
  9. * @see https://github.com/theKashey/use-callback-ref#usetransformref-to-replace-reactuseimperativehandle
  10. * @example
  11. *
  12. * const ResizableWithRef = forwardRef((props, ref) =>
  13. * <Resizable {...props} ref={useTransformRef(ref, i => i ? i.resizable : null)}/>
  14. * );
  15. */
  16. export function useTransformRef(ref, transformer) {
  17. return useCallbackRef(null, (value) => assignRef(ref, transformer(value)));
  18. }