UNPKG

rmwc

Version:

A thin React wrapper for Material Design (Web) Components

200 lines (152 loc) 7.44 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.Icon = exports.IconRoot = undefined; var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; var _react = require('react'); var React = _interopRequireWildcard(_react); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _propTypes = require('prop-types'); var PropTypes = _interopRequireWildcard(_propTypes); var _Provider = require('../Provider'); var _Base = require('../Base'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } var IconRoot = exports.IconRoot = (0, _Base.simpleTag)({ displayName: 'IconRoot', tag: 'i' }); // prettier-ignore var renderLigature = function renderLigature(_ref) { var content = _ref.content, rest = _objectWithoutProperties(_ref, ['content']); return React.createElement( IconRoot, rest, content ); }; var renderClassName = function renderClassName(_ref2) { var content = _ref2.content, rest = _objectWithoutProperties(_ref2, ['content']); return React.createElement(IconRoot, rest); }; var renderUrl = function renderUrl(_ref3) { var content = _ref3.content, rest = _objectWithoutProperties(_ref3, ['content']); return React.createElement(IconRoot, Object.assign({ tag: 'img', src: content }, rest)); }; var renderComponent = function renderComponent(_ref4) { var content = _ref4.content, rest = _objectWithoutProperties(_ref4, ['content']); return React.createElement( IconRoot, rest, content ); }; var iconRenderMap = { ligature: renderLigature, className: renderClassName, url: renderUrl, component: renderComponent, auto: undefined }; /** * Given content, tries to figure out an appropriate strategy for it */ var processAutoStrategy = function processAutoStrategy(content) { // check for URLS if (typeof content === 'string' && (content.startsWith('/') || content.startsWith('http://') || content.startsWith('https://'))) { return 'url'; } // handle JSX components if ((typeof content === 'undefined' ? 'undefined' : _typeof(content)) === 'object') { return 'component'; } // we dont know what it is, default to ligature for compat with material icons return 'ligature'; }; /** * Get the actual icon strategy to use */ var getIconStrategy = function getIconStrategy(content, strategy, defaultStrategy) { strategy = strategy || defaultStrategy; if (strategy === 'auto') { return processAutoStrategy(content); } return strategy; }; /** * An Icon component. Most of these options can be set once globally, read the documentation on Provider for more info. */ var Icon = exports.Icon = function (_React$PureComponent) { _inherits(Icon, _React$PureComponent); function Icon() { _classCallCheck(this, Icon); return _possibleConstructorReturn(this, (Icon.__proto__ || Object.getPrototypeOf(Icon)).apply(this, arguments)); } _createClass(Icon, [{ key: 'componentWillMount', value: function componentWillMount() { this.providerOptions = (0, _Provider.getProviderOptions)(this.context); } }, { key: 'render', value: function render() { var _props = this.props, use = _props.use, children = _props.children, render = _props.render, strategy = _props.strategy, prefix = _props.prefix, basename = _props.basename, rest = _objectWithoutProperties(_props, ['use', 'children', 'render', 'strategy', 'prefix', 'basename']); var _providerOptions = this.providerOptions, defaultBasename = _providerOptions.iconClassNameBase, defaultPrefix = _providerOptions.iconClassNamePrefix, defaultStrategy = _providerOptions.iconStrategy, defaultCustomRender = _providerOptions.iconRender; var content = use || children; var strategyToUse = getIconStrategy(content, strategy || null, defaultStrategy || null); var prefixToUse = prefix || defaultPrefix; var basenameToUse = basename === undefined ? defaultBasename : basename; var iconClassName = strategyToUse === 'className' && typeof content === 'string' ? '' + String(prefixToUse) + content : null; var renderToUse = strategyToUse === 'custom' ? render || defaultCustomRender : !!strategyToUse && iconRenderMap[strategyToUse] !== undefined ? iconRenderMap[strategyToUse] : undefined; if (!renderToUse) { console.error('Icon: rendering not implemented for ' + String(strategyToUse) + '.'); return null; } //$FlowFixMe return renderToUse(Object.assign({}, rest, { content: content, className: (0, _classnames2.default)(basenameToUse, rest.className, iconClassName) })); } }]); return Icon; }(React.PureComponent); Object.defineProperty(Icon, 'displayName', { enumerable: true, writable: true, value: 'Icon' }); Object.defineProperty(Icon, 'defaultProps', { enumerable: true, writable: true, value: { use: undefined } }); Object.defineProperty(Icon, 'contextTypes', { enumerable: true, writable: true, value: { RMWCOptions: PropTypes.object } }); exports.default = Icon;