'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _stringify = require('babel-runtime/core-js/json/stringify'); var _stringify2 = _interopRequireDefault(_stringify); var _keys = require('babel-runtime/core-js/object/keys'); var _keys2 = _interopRequireDefault(_keys); var _objectWithoutProperties2 = require('babel-runtime/helpers/objectWithoutProperties'); var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2); var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _warning = require('warning'); var _warning2 = _interopRequireDefault(_warning); var _createBreakpoints = require('../styles/createBreakpoints'); var _withWidth = require('../utils/withWidth'); var _withWidth2 = _interopRequireDefault(_withWidth); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var babelPluginFlowReactPropTypes_proptype_Node = require('react').babelPluginFlowReactPropTypes_proptype_Node || require('prop-types').any; var babelPluginFlowReactPropTypes_proptype_HiddenProps = require('./types').babelPluginFlowReactPropTypes_proptype_HiddenProps || require('prop-types').any; var babelPluginFlowReactPropTypes_proptype_Props = (0, _extends3.default)({}, babelPluginFlowReactPropTypes_proptype_HiddenProps === require('prop-types').any ? {} : babelPluginFlowReactPropTypes_proptype_HiddenProps, { /** * The content of the component. */ children: typeof babelPluginFlowReactPropTypes_proptype_Node === 'function' ? babelPluginFlowReactPropTypes_proptype_Node.isRequired ? babelPluginFlowReactPropTypes_proptype_Node.isRequired : babelPluginFlowReactPropTypes_proptype_Node : require('prop-types').shape(babelPluginFlowReactPropTypes_proptype_Node).isRequired, /** * @ignore * width prop provided by withWidth decorator */ width: require('prop-types').string.isRequired }); /** * @ignore - internal component. */ function HiddenJs(props) { var children = props.children, only = props.only, xsUp = props.xsUp, smUp = props.smUp, mdUp = props.mdUp, lgUp = props.lgUp, xlUp = props.xlUp, xsDown = props.xsDown, smDown = props.smDown, mdDown = props.mdDown, lgDown = props.lgDown, xlDown = props.xlDown, width = props.width, other = (0, _objectWithoutProperties3.default)(props, ['children', 'only', 'xsUp', 'smUp', 'mdUp', 'lgUp', 'xlUp', 'xsDown', 'smDown', 'mdDown', 'lgDown', 'xlDown', 'width']); process.env.NODE_ENV !== "production" ? (0, _warning2.default)((0, _keys2.default)(other).length === 0, 'Material-UI: unsupported properties received ' + (0, _stringify2.default)(other) + ' by ``.') : void 0; var visible = true; // `only` check is faster to get out sooner if used. if (only) { if (Array.isArray(only)) { for (var i = 0; i < only.length; i += 1) { var breakpoint = only[i]; if (width === breakpoint) { visible = false; break; } } } else if (only && width === only) { visible = false; } } // Allow `only` to be combined with other props. If already hidden, no need to check others. if (visible) { // determine visibility based on the smallest size up for (var _i = 0; _i < _createBreakpoints.keys.length; _i += 1) { var _breakpoint = _createBreakpoints.keys[_i]; var breakpointUp = props[_breakpoint + 'Up']; var breakpointDown = props[_breakpoint + 'Down']; if (breakpointUp && (0, _withWidth.isWidthUp)(_breakpoint, width) || breakpointDown && (0, _withWidth.isWidthDown)(_breakpoint, width)) { visible = false; break; } } } if (!visible) { return null; } return children; } exports.default = (0, _withWidth2.default)()(HiddenJs);