material-ui
Version:
React Components that Implement Google's Material Design.
210 lines (170 loc) • 6.39 kB
JavaScript
'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 _simpleAssign = require('simple-assign');
var _simpleAssign2 = _interopRequireDefault(_simpleAssign);
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _EnhancedButton = require('../internal/EnhancedButton');
var _EnhancedButton2 = _interopRequireDefault(_EnhancedButton);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function getStyles(props, context) {
var tabs = context.muiTheme.tabs;
return {
root: {
color: props.selected ? tabs.selectedTextColor : tabs.textColor,
fontWeight: 500,
fontSize: 14,
width: props.width,
textTransform: 'uppercase',
padding: 0
},
button: {
display: 'flex',
flexDirection: 'column',
alignItems: 'center',
justifyContent: 'center',
height: props.label && props.icon ? 72 : 48
}
};
}
var Tab = function (_Component) {
(0, _inherits3.default)(Tab, _Component);
function Tab() {
var _ref;
var _temp, _this, _ret;
(0, _classCallCheck3.default)(this, Tab);
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = Tab.__proto__ || (0, _getPrototypeOf2.default)(Tab)).call.apply(_ref, [this].concat(args))), _this), _this.handleClick = function (event) {
if (_this.props.onClick) {
_this.props.onClick(_this.props.value, event, _this);
}
}, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret);
}
(0, _createClass3.default)(Tab, [{
key: 'render',
value: function render() {
var _props = this.props,
icon = _props.icon,
index = _props.index,
onActive = _props.onActive,
onClick = _props.onClick,
selected = _props.selected,
label = _props.label,
buttonStyle = _props.buttonStyle,
style = _props.style,
value = _props.value,
width = _props.width,
other = (0, _objectWithoutProperties3.default)(_props, ['icon', 'index', 'onActive', 'onClick', 'selected', 'label', 'buttonStyle', 'style', 'value', 'width']);
var styles = getStyles(this.props, this.context);
var iconElement = void 0;
if (icon && _react2.default.isValidElement(icon)) {
iconElement = _react2.default.cloneElement(icon, {
style: {
fontSize: 24,
color: icon.props && icon.props.style && icon.props.style.color ? icon.props.style.color : styles.root.color,
marginBottom: label ? 5 : 0
}
});
}
var rippleOpacity = 0.3;
var rippleColor = this.context.muiTheme.tabs.selectedTextColor;
return _react2.default.createElement(
_EnhancedButton2.default,
(0, _extends3.default)({}, other, {
style: (0, _simpleAssign2.default)(styles.root, style),
focusRippleColor: rippleColor,
touchRippleColor: rippleColor,
focusRippleOpacity: rippleOpacity,
touchRippleOpacity: rippleOpacity,
onClick: this.handleClick
}),
_react2.default.createElement(
'div',
{ style: (0, _simpleAssign2.default)(styles.button, buttonStyle) },
iconElement,
label
)
);
}
}]);
return Tab;
}(_react.Component);
Tab.muiName = 'Tab';
Tab.contextTypes = {
muiTheme: _propTypes2.default.object.isRequired
};
Tab.propTypes = process.env.NODE_ENV !== "production" ? {
/**
* Override the inline-styles of the button element.
*/
buttonStyle: _propTypes2.default.object,
/**
* The css class name of the root element.
*/
className: _propTypes2.default.string,
/**
* Sets the icon of the tab, you can pass `FontIcon` or `SvgIcon` elements.
*/
icon: _propTypes2.default.node,
/**
* @ignore
*/
index: _propTypes2.default.any,
/**
* Sets the text value of the tab item to the string specified.
*/
label: _propTypes2.default.node,
/**
* Fired when the active tab changes by touch or tap.
* Use this event to specify any functionality when an active tab changes.
* For example - we are using this to route to home when the third tab becomes active.
* This function will always recieve the active tab as it\'s first argument.
*/
onActive: _propTypes2.default.func,
/**
* @ignore
* This property is overriden by the Tabs component.
*/
onClick: _propTypes2.default.func,
/**
* @ignore
* Defines if the current tab is selected or not.
* The Tabs component is responsible for setting this property.
*/
selected: _propTypes2.default.bool,
/**
* Override the inline-styles of the root element.
*/
style: _propTypes2.default.object,
/**
* If value prop passed to Tabs component, this value prop is also required.
* It assigns a value to the tab so that it can be selected by the Tabs.
*/
value: _propTypes2.default.any,
/**
* @ignore
* This property is overriden by the Tabs component.
*/
width: _propTypes2.default.string
} : {};
exports.default = Tab;