Created
August 24, 2017 12:51
-
-
Save dataday/3783e9bef25fa27b9472964f1bde3e70 to your computer and use it in GitHub Desktop.
React Native Common Icon
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/** | |
* # icon.js | |
* | |
* Component | |
* | |
* @author dataday | |
* | |
* @flow | |
*/ | |
'use strict' | |
/** | |
* ## Imports | |
* | |
* Necessary components | |
*/ | |
import React, { PropTypes } from 'react' | |
import VectorIcon from 'react-native-vector-icons/MaterialCommunityIcons' | |
import { STYLES, COLOURS, ICONS } from '../../constants/ui' | |
const InitialProps = { | |
size: ICONS.SIZE.XS, | |
color: COLOURS.iconInActive, | |
styleDefault: [ STYLES.icon ], | |
styleIconBox: [ STYLES.iconBox ] | |
} | |
export default class Icon extends React.Component { | |
static defaultProps = InitialProps | |
/** | |
* setNativeProps | |
* @see https://facebook.github.io/react-native/docs/direct-manipulation.html | |
* @param {Object} props Parent properties. | |
* @returns {Void} | |
*/ | |
setNativeProps = (props: Object) => { | |
this.children.forEach((child) => { | |
child.setNativeProps(props) | |
}) | |
} | |
render () { | |
const styleDefault = (this.props.size > 24) | |
? this.props.styleIconBox | |
: this.props.styleDefault | |
return ( | |
<VectorIcon | |
key={'icon' + this.props.name} | |
{...this.props} | |
style={[ styleDefault, this.props.style ]} | |
/> | |
) | |
} | |
} | |
Icon.propTypes = { | |
name: PropTypes.string.isRequired, | |
size: PropTypes.number, | |
color: PropTypes.string, | |
style: PropTypes.oneOfType([ | |
PropTypes.array, | |
PropTypes.number | |
]) | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment