UNPKG

@compositor/kit

Version:

Components for development environments, style guides, and demos

87 lines (61 loc) 2.67 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _objectWithoutProperties2 = require('babel-runtime/helpers/objectWithoutProperties'); var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2); var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf); var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _webfont = require('@compositor/webfont'); var _webfont2 = _interopRequireDefault(_webfont); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var Font = function (_React$Component) { (0, _inherits3.default)(Font, _React$Component); function Font() { (0, _classCallCheck3.default)(this, Font); return (0, _possibleConstructorReturn3.default)(this, (Font.__proto__ || (0, _getPrototypeOf2.default)(Font)).apply(this, arguments)); } (0, _createClass3.default)(Font, [{ key: 'render', value: function render() { var _props = this.props, fontFamily = _props.fontFamily, lineHeight = _props.lineHeight, color = _props.color, props = (0, _objectWithoutProperties3.default)(_props, ['fontFamily', 'lineHeight', 'color']); var url = _webfont2.default.getURL(fontFamily); return _react2.default.createElement( _react2.default.Fragment, null, url && _react2.default.createElement('link', { rel: 'stylesheet', href: url }), _react2.default.createElement('div', (0, _extends3.default)({}, props, { style: { fontFamily: fontFamily, lineHeight: lineHeight, color: color, '--color': color } })) ); } }]); return Font; }(_react2.default.Component); Font.defaultProps = { fontFamily: 'system-ui, sans-serif', lineHeight: 1.5, color: '#000' }; exports.default = Font;