react-conventions
Version:
An open source set of React components that implement Ambassador's Design and UX patterns.
55 lines (44 loc) • 1.41 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _icons = require('../../assets/icons/icons.svg');
var _icons2 = _interopRequireDefault(_icons);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var Icon = function Icon(props) {
return _react2.default.createElement(
'svg',
_extends({ role: 'img' }, props),
_react2.default.createElement('use', { xlinkHref: _icons2.default + '#' + props.name })
);
};
Icon.defaultProps = {
height: '24',
width: '24'
};
Icon.propTypes = {
/**
* The name of the button (see Iconography).
*/
name: _react2.default.PropTypes.string.isRequired,
/**
* The width of the button.
*/
width: _react2.default.PropTypes.string,
/**
* The height of the button.
*/
height: _react2.default.PropTypes.string,
/**
* The color (fill) of the icon.
*/
fill: _react2.default.PropTypes.string,
/**
* The CSS class of the icon.
*/
className: _react2.default.PropTypes.string
};
exports.default = Icon;