diff --git a/.size-limit.js b/.size-limit.js index 47131acdd4dc0c..5d8db07dd5af59 100644 --- a/.size-limit.js +++ b/.size-limit.js @@ -27,7 +27,7 @@ module.exports = [ name: 'The size of all the modules of material-ui.', webpack: true, path: 'packages/material-ui/build/index.js', - limit: '95.1 KB', + limit: '95.2 KB', }, { name: 'The main bundle of the docs', diff --git a/packages/material-ui/src/RootRef/RootRef.js b/packages/material-ui/src/RootRef/RootRef.js index 1d9afc474b0872..41ad39eb436b78 100644 --- a/packages/material-ui/src/RootRef/RootRef.js +++ b/packages/material-ui/src/RootRef/RootRef.js @@ -3,6 +3,14 @@ import ReactDOM from 'react-dom'; import PropTypes from 'prop-types'; import exactProp from '../utils/exactProp'; +function setRef(ref, value) { + if (typeof ref === 'function') { + ref(value); + } else if (ref) { + ref.current = value; + } +} + /** * Helper component to allow attaching a ref to a * wrapped element to access the underlying DOM element. @@ -35,22 +43,18 @@ import exactProp from '../utils/exactProp'; */ class RootRef extends React.Component { componentDidMount() { - const rootRef = this.props.rootRef; - const node = ReactDOM.findDOMNode(this); - if (typeof rootRef === 'function') { - rootRef(node); - } else if (rootRef) { - rootRef.current = node; + setRef(this.props.rootRef, ReactDOM.findDOMNode(this)); + } + + componentDidUpdate(prevProps) { + if (prevProps.rootRef !== this.props.rootRef) { + setRef(prevProps.rootRef, null); + setRef(this.props.rootRef, ReactDOM.findDOMNode(this)); } } componentWillUnmount() { - const rootRef = this.props.rootRef; - if (typeof rootRef === 'function') { - rootRef(null); - } else if (rootRef) { - rootRef.current = null; - } + setRef(this.props.rootRef, null); } render() { diff --git a/packages/material-ui/src/RootRef/RootRef.test.js b/packages/material-ui/src/RootRef/RootRef.test.js index 6c0619b35c477f..dd5e12b693db4c 100644 --- a/packages/material-ui/src/RootRef/RootRef.test.js +++ b/packages/material-ui/src/RootRef/RootRef.test.js @@ -3,6 +3,8 @@ import { assert } from 'chai'; import { createMount } from '../test-utils'; import RootRef from './RootRef'; +const Fn = () =>
; + describe('