Skip to content

Commit

Permalink
Add a size prop to IconButton
Browse files Browse the repository at this point in the history
  • Loading branch information
leMaik committed Mar 2, 2019
1 parent c0287df commit 0b0b4ad
Show file tree
Hide file tree
Showing 5 changed files with 26 additions and 1 deletion.
4 changes: 4 additions & 0 deletions docs/src/pages/demos/buttons/ButtonSizes.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import IconButton from '@material-ui/core/IconButton';
import AddIcon from '@material-ui/icons/Add';
import DeleteIcon from '@material-ui/icons/Delete';
import NavigationIcon from '@material-ui/icons/Navigation';
import ArrowDownwardIcon from '@material-ui/icons/ArrowDownward';

const styles = theme => ({
margin: {
Expand Down Expand Up @@ -92,6 +93,9 @@ function ButtonSizes(props) {
</Fab>
</div>
<div>
<IconButton aria-label="Delete" className={classes.margin} size="small">
<ArrowDownwardIcon fontSize="inherit" />
</IconButton>
<IconButton aria-label="Delete" className={classes.margin}>
<DeleteIcon fontSize="small" />
</IconButton>
Expand Down
1 change: 1 addition & 0 deletions packages/material-ui/src/IconButton/IconButton.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ export interface IconButtonProps extends StandardProps<ButtonBaseProps, IconButt
color?: PropTypes.Color;
disabled?: boolean;
disableRipple?: boolean;
size?: 'small' | 'medium';
}

export type IconButtonClassKey =
Expand Down
15 changes: 14 additions & 1 deletion packages/material-ui/src/IconButton/IconButton.js
Original file line number Diff line number Diff line change
Expand Up @@ -71,14 +71,20 @@ export const styles = theme => ({
alignItems: 'inherit',
justifyContent: 'inherit',
},
/* Styles applied to the root element if `size="small"`. */
sizeSmall: {
padding: 3,
minWidth: 24,
fontSize: 18,
},
});

/**
* Refer to the [Icons](/style/icons/) section of the documentation
* regarding the available icon options.
*/
const IconButton = React.forwardRef(function IconButton(props, ref) {
const { children, classes, className, color, disabled, ...other } = props;
const { children, classes, className, color, disabled, size, ...other } = props;

return (
<ButtonBase
Expand All @@ -87,6 +93,7 @@ const IconButton = React.forwardRef(function IconButton(props, ref) {
{
[classes[`color${capitalize(color)}`]]: color !== 'default',
[classes.disabled]: disabled,
[classes.sizeSmall]: size === 'small',
},
className,
)}
Expand Down Expand Up @@ -141,11 +148,17 @@ IconButton.propTypes = {
* If `true`, the button will be disabled.
*/
disabled: PropTypes.bool,
/**
* The size of the button.
* `small` is equivalent to the dense button styling.
*/
size: PropTypes.oneOf(['small', 'medium']),
};

IconButton.defaultProps = {
color: 'default',
disabled: false,
size: 'medium',
};

export default withStyles(styles, { name: 'MuiIconButton' })(IconButton);
5 changes: 5 additions & 0 deletions packages/material-ui/src/IconButton/IconButton.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,11 @@ describe('<IconButton />', () => {
assert.strictEqual(wrapper.props().centerRipple, true);
});

it('should render with sizeSmall class when prop size="small" provided', () => {
const wrapper = shallow(<IconButton size="small">book</IconButton>);
assert.strictEqual(wrapper.hasClass(classes.sizeSmall), true);
});

describe('prop: disabled', () => {
it('should disable the component', () => {
const wrapper = shallow(<IconButton disabled>book</IconButton>);
Expand Down
2 changes: 2 additions & 0 deletions pages/api/icon-button.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ regarding the available icon options.
| <span class="prop-name">classes</span> | <span class="prop-type">object</span> |   | Override or extend the styles applied to the component. See [CSS API](#css) below for more details. |
| <span class="prop-name">color</span> | <span class="prop-type">enum:&nbsp;'default'&nbsp;&#124;<br>&nbsp;'inherit'&nbsp;&#124;<br>&nbsp;'primary'&nbsp;&#124;<br>&nbsp;'secondary'<br></span> | <span class="prop-default">'default'</span> | The color of the component. It supports those theme colors that make sense for this component. |
| <span class="prop-name">disabled</span> | <span class="prop-type">bool</span> | <span class="prop-default">false</span> | If `true`, the button will be disabled. |
| <span class="prop-name">size</span> | <span class="prop-type">enum:&nbsp;'small'&nbsp;&#124;<br>&nbsp;'medium'<br></span> | <span class="prop-default">'medium'</span> | The size of the button. `small` is equivalent to the dense button styling. |

Any other properties supplied will be spread to the root element ([ButtonBase](/api/button-base/)).

Expand All @@ -40,6 +41,7 @@ This property accepts the following keys:
| <span class="prop-name">colorSecondary</span> | Styles applied to the root element if `color="secondary"`.
| <span class="prop-name">disabled</span> | Styles applied to the root element if `disabled={true}`.
| <span class="prop-name">label</span> | Styles applied to the children container element.
| <span class="prop-name">sizeSmall</span> | Styles applied to the root element if `size="small"`.

Have a look at [overriding with classes](/customization/overrides/#overriding-with-classes) section
and the [implementation of the component](https://github.com/mui-org/material-ui/blob/master/packages/material-ui/src/IconButton/IconButton.js)
Expand Down

0 comments on commit 0b0b4ad

Please sign in to comment.