Skip to content
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

[core] Enable innerRef on Backdrop, List, MenuList and Paper #13722

Merged
Merged
4 changes: 2 additions & 2 deletions .size-limit.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,13 +16,13 @@ module.exports = [
name: 'The initial cost paid for using one component',
webpack: true,
path: 'packages/material-ui/build/Paper/index.js',
limit: '18.5 KB',
limit: '18.6 KB',
},
{
name: 'The size of the @material-ui/core modules',
webpack: true,
path: 'packages/material-ui/build/index.js',
limit: '94.8 KB',
limit: '94.9 KB',
},
{
name: 'The size of the @material-ui/styles modules',
Expand Down
5 changes: 4 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@
"jsonlint:files": "find . -name \"*.json\" | grep -v -f .eslintignore",
"lint": "eslint . --cache && echo \"eslint: no lint errors\"",
"lint:fix": "eslint . --cache --fix && echo \"eslint: no lint errors\"",
"prepare": "patch-package",
"prettier": "yarn babel-node ./scripts/prettier.js",
"prettier:all": "yarn babel-node ./scripts/prettier.js write",
"size": "size-limit",
Expand Down Expand Up @@ -122,9 +123,11 @@
"markdown-to-jsx": "^6.8.3",
"material-ui-popup-state": "^1.0.1",
"mocha": "^5.0.0",
"next": "^7.0.0",
"next": "7.0.2-canary.31",
"nyc": "^13.0.0",
"patch-package": "^5.1.1",
eps1lon marked this conversation as resolved.
Show resolved Hide resolved
"postcss": "^7.0.0",
"postinstall-prepare": "^1.0.1",
"prettier": "^1.8.2",
"puppeteer": "^1.5.0",
"raw-loader": "^0.5.1",
Expand Down
7 changes: 5 additions & 2 deletions packages/material-ui/src/Backdrop/Backdrop.js
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ export const styles = {
},
};

function Backdrop(props) {
const Backdrop = React.forwardRef((props, ref) => {
const { classes, className, invisible, open, transitionDuration, ...other } = props;

return (
Expand All @@ -40,10 +40,13 @@ function Backdrop(props) {
className,
)}
aria-hidden="true"
ref={ref}
/>
</Fade>
);
}
});

Backdrop.displayName = 'Backdrop';
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

See facebook/react#14319 for full explanation.


Backdrop.propTypes = {
/**
Expand Down
12 changes: 11 additions & 1 deletion packages/material-ui/src/Backdrop/Backdrop.test.js
Original file line number Diff line number Diff line change
@@ -1,20 +1,30 @@
import React from 'react';
import { assert } from 'chai';
import { createShallow, getClasses } from '@material-ui/core/test-utils';
import { createMount, createShallow, getClasses, testRef } from '@material-ui/core/test-utils';
import Backdrop from './Backdrop';

describe('<Backdrop />', () => {
let mount;
let shallow;
let classes;

before(() => {
mount = createMount();
shallow = createShallow({ dive: true });
classes = getClasses(<Backdrop open />);
});

after(() => {
mount.cleanUp();
});

it('should render a backdrop div', () => {
const wrapper = shallow(<Backdrop open className="woofBackdrop" />);
assert.strictEqual(wrapper.childAt(0).hasClass('woofBackdrop'), true);
assert.strictEqual(wrapper.childAt(0).hasClass(classes.root), true);
});

it('does forward refs', () => {
testRef(<Backdrop open />, mount);
});
});
7 changes: 5 additions & 2 deletions packages/material-ui/src/List/List.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ export const styles = {
},
};

function List(props) {
const List = React.forwardRef((props, ref) => {
const {
children,
classes,
Expand All @@ -51,6 +51,7 @@ function List(props) {
},
className,
)}
ref={ref}
{...other}
>
<ListContext.Provider value={{ dense }}>
Expand All @@ -59,7 +60,9 @@ function List(props) {
</ListContext.Provider>
</Component>
);
}
});

List.displayName = 'List';

List.propTypes = {
/**
Expand Down
12 changes: 11 additions & 1 deletion packages/material-ui/src/List/List.test.js
Original file line number Diff line number Diff line change
@@ -1,18 +1,24 @@
import React from 'react';
import { assert } from 'chai';
import { createShallow, getClasses } from '@material-ui/core/test-utils';
import { createMount, createShallow, getClasses, testRef } from '@material-ui/core/test-utils';
import ListSubheader from '../ListSubheader';
import List from './List';

describe('<List />', () => {
let mount;
let shallow;
let classes;

before(() => {
mount = createMount();
shallow = createShallow({ dive: true });
classes = getClasses(<List />);
});

after(() => {
mount.cleanUp();
});

it('should render a div', () => {
const wrapper = shallow(<List component="div" />);
assert.strictEqual(wrapper.name(), 'div');
Expand Down Expand Up @@ -40,6 +46,10 @@ describe('<List />', () => {
);
});

it('does forward refs', () => {
testRef(<List />, mount);
});

describe('prop: subheader', () => {
it('should render with subheader class', () => {
const wrapper = shallow(<List subheader={<ListSubheader>Title</ListSubheader>} />);
Expand Down
12 changes: 11 additions & 1 deletion packages/material-ui/src/MenuList/MenuList.test.js
Original file line number Diff line number Diff line change
@@ -1,15 +1,25 @@
import React from 'react';
import { assert } from 'chai';
import { createShallow } from '@material-ui/core/test-utils';
import { createMount, createShallow, testRef } from '@material-ui/core/test-utils';
import MenuList from './MenuList';

describe('<MenuList />', () => {
let mount;
let shallow;

before(() => {
mount = createMount();
shallow = createShallow({ dive: true, disableLifecycleMethods: true });
});

after(() => {
mount.cleanUp();
});

it('does forward refs', () => {
testRef(<MenuList />, mount);
});

describe('list node', () => {
let wrapper;

Expand Down
8 changes: 5 additions & 3 deletions packages/material-ui/src/Paper/Paper.js
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ export const styles = theme => {
};
};

function Paper(props) {
const Paper = React.forwardRef((props, ref) => {
const {
classes,
className: classNameProp,
Expand All @@ -49,8 +49,10 @@ function Paper(props) {
classNameProp,
);

return <Component className={className} {...other} />;
}
return <Component className={className} ref={ref} {...other} />;
});

Paper.displayName = 'Paper';

Paper.propTypes = {
/**
Expand Down
12 changes: 11 additions & 1 deletion packages/material-ui/src/Paper/Paper.test.js
Original file line number Diff line number Diff line change
@@ -1,17 +1,23 @@
import React from 'react';
import { assert } from 'chai';
import { createShallow, getClasses } from '@material-ui/core/test-utils';
import { createMount, createShallow, getClasses, testRef } from '@material-ui/core/test-utils';
import Paper from './Paper';

describe('<Paper />', () => {
let mount;
let shallow;
let classes;

before(() => {
mount = createMount();
shallow = createShallow({ dive: true });
classes = getClasses(<Paper />);
});

after(() => {
mount.cleanUp();
});

it('should render a div', () => {
const wrapper = shallow(<Paper>Hello World</Paper>);
assert.strictEqual(wrapper.name(), 'div');
Expand Down Expand Up @@ -49,6 +55,10 @@ describe('<Paper />', () => {
);
});

it('does forward refs', () => {
testRef(<Paper />, mount);
});

describe('prop: component', () => {
it('should render a header', () => {
const wrapper = shallow(<Paper component="header">Hello World</Paper>);
Expand Down
1 change: 1 addition & 0 deletions packages/material-ui/src/test-utils/index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,5 @@ export { default as createMount } from './createMount';
export { default as createRender } from './createRender';
export { default as findOutermostIntrinsic } from './findOutermostIntrinsic';
export { default as getClasses } from './getClasses';
export { default as testRef } from './testRef';
export { default as unwrap } from './unwrap';
1 change: 1 addition & 0 deletions packages/material-ui/src/test-utils/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,5 @@ export { default as createMount } from './createMount';
export { default as createRender } from './createRender';
export { default as findOutermostIntrinsic } from './findOutermostIntrinsic';
export { default as getClasses } from './getClasses';
export { default as testRef } from './testRef';
export { default as unwrap } from './unwrap';
12 changes: 12 additions & 0 deletions packages/material-ui/src/test-utils/testRef.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import * as React from 'react';
import createMount from './createMount';

/**
* Utility method to make assertions about the ref on an element
* @param onRef - Make your assertions here
*/
export default function testRef<T>(
element: React.ReactElement<{ innerRef: React.RefObject<T> }>,
mount: ReturnType<typeof createMount>,
onRef: (ref: T) => void,
): void;
21 changes: 21 additions & 0 deletions packages/material-ui/src/test-utils/testRef.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
import React from 'react';
import { assert } from 'chai';

function assertDOMNode(node) {
// duck typing a DOM node
assert.ok(node.nodeName);
}

/**
*
* @param {React.ReactElement} element - The element should have a component wrapped
* in withStyles as the root
* @param {function} mount - Should be returnvalue of createMount
* @param {function} onRef - Callback, first arg is the ref.
* Assert that the ref is a DOM node by default
*/
export default function testRef(element, mount, onRef = assertDOMNode) {
const ref = React.createRef();
mount(<>{React.cloneElement(element, { innerRef: ref })}</>);
onRef(ref.current);
}
Loading