react-native-web-headroom
Version:
React Native Web Headroom
65 lines (48 loc) • 1.7 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _createStyles = require('../styles/createStyles');
var _createStyles2 = _interopRequireDefault(_createStyles);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/**
* A view for object property names.
*
* If the property name is enumerable (in Object.keys(object)),
* the property name will be rendered normally.
*
* If the property name is not enumerable (`Object.prototype.propertyIsEnumerable()`),
* the property name will be dimmed to show the difference.
*/
var ObjectName = function ObjectName(_ref, _ref2) {
var name = _ref.name,
dimmed = _ref.dimmed,
styles = _ref.styles;
var theme = _ref2.theme;
var themeStyles = (0, _createStyles2.default)('ObjectName', theme);
var appliedStyles = (0, _extends3.default)({}, themeStyles.base, dimmed ? themeStyles['dimmed'] : {}, styles);
return _react2.default.createElement(
'span',
{ style: appliedStyles },
name
);
};
ObjectName.propTypes = {
/** Property name */
name: _propTypes2.default.string,
/** Should property name be dimmed */
dimmed: _propTypes2.default.bool
};
ObjectName.defaultProps = {
dimmed: false
};
ObjectName.contextTypes = {
theme: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.object])
};
exports.default = ObjectName;