diff --git a/src/BottomNavigation/BottomNavigationAction.react.js b/src/BottomNavigation/BottomNavigationAction.react.js old mode 100644 new mode 100755 index 01b39ba1..129f7ea3 --- a/src/BottomNavigation/BottomNavigationAction.react.js +++ b/src/BottomNavigation/BottomNavigationAction.react.js @@ -10,8 +10,13 @@ import Icon from '../Icon'; const propTypes = { /** * Will be rendered above the label as a content of the action. + * If string, result will be + * If ReactElement, will be used as is */ - icon: PropTypes.string.isRequired, + icon: PropTypes.oneOfType([ + PropTypes.element, + PropTypes.string, + ]).isRequired, /** * Will be rendered under the icon as a content of the action. */ @@ -79,16 +84,29 @@ function getStyles(props, context) { class BottomNavigationAction extends PureComponent { + + renderIcon(icon, styles, color) { + let element; + if (React.isValidElement(icon)) { + element = icon; + } else { + element = ; + } + return element; + } + render() { const { icon, label, onPress } = this.props; const styles = getStyles(this.props, this.context); const color = StyleSheet.flatten(styles.icon).color; + const iconElement = this.renderIcon(icon, styles, color); + return ( - + {iconElement} {label}