material-ui-datetime-range-picker
Version:
React Datetime Range Picker Component that Implements Google's Material Design Via Material-UI.
384 lines (331 loc) • 38.9 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
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 _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 _events = require('../utils/events');
var _events2 = _interopRequireDefault(_events);
var _keycode = require('keycode');
var _keycode2 = _interopRequireDefault(_keycode);
var _FocusRipple = require('./FocusRipple');
var _FocusRipple2 = _interopRequireDefault(_FocusRipple);
var _TouchRipple = require('./TouchRipple');
var _TouchRipple2 = _interopRequireDefault(_TouchRipple);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
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; }
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; }
var styleInjected = false;
var listening = false;
var tabPressed = false;
function injectStyle() {
if (!styleInjected) {
// Remove inner padding and border in Firefox 4+.
var style = document.createElement('style');
style.innerHTML = '\n button::-moz-focus-inner,\n input::-moz-focus-inner {\n border: 0;\n padding: 0;\n }\n ';
document.body.appendChild(style);
styleInjected = true;
}
}
function listenForTabPresses() {
if (!listening) {
_events2.default.on(window, 'keydown', function (event) {
tabPressed = (0, _keycode2.default)(event) === 'tab';
});
listening = true;
}
}
var EnhancedButton = function (_Component) {
_inherits(EnhancedButton, _Component);
function EnhancedButton() {
var _ref;
var _temp, _this, _ret;
_classCallCheck(this, EnhancedButton);
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = EnhancedButton.__proto__ || Object.getPrototypeOf(EnhancedButton)).call.apply(_ref, [this].concat(args))), _this), _this.state = {
isKeyboardFocused: false
}, _this.handleKeyDown = function (event) {
if (!_this.props.disabled && !_this.props.disableKeyboardFocus) {
if ((0, _keycode2.default)(event) === 'enter' && _this.state.isKeyboardFocused) {
_this.handleTouchTap(event);
}
if ((0, _keycode2.default)(event) === 'esc' && _this.state.isKeyboardFocused) {
_this.removeKeyboardFocus(event);
}
}
_this.props.onKeyDown(event);
}, _this.handleKeyUp = function (event) {
if (!_this.props.disabled && !_this.props.disableKeyboardFocus) {
if ((0, _keycode2.default)(event) === 'space' && _this.state.isKeyboardFocused) {
_this.handleTouchTap(event);
}
}
_this.props.onKeyUp(event);
}, _this.handleBlur = function (event) {
_this.cancelFocusTimeout();
_this.removeKeyboardFocus(event);
_this.props.onBlur(event);
}, _this.handleFocus = function (event) {
if (event) event.persist();
if (!_this.props.disabled && !_this.props.disableKeyboardFocus) {
// setTimeout is needed because the focus event fires first
// Wait so that we can capture if this was a keyboard focus
// or touch focus
_this.focusTimeout = setTimeout(function () {
if (tabPressed) {
_this.setKeyboardFocus(event);
tabPressed = false;
}
}, 150);
_this.props.onFocus(event);
}
}, _this.handleTouchTap = function (event) {
_this.cancelFocusTimeout();
if (!_this.props.disabled) {
tabPressed = false;
_this.removeKeyboardFocus(event);
_this.props.onClick(event);
}
}, _temp), _possibleConstructorReturn(_this, _ret);
}
_createClass(EnhancedButton, [{
key: 'componentWillMount',
value: function componentWillMount() {
var _props = this.props,
disabled = _props.disabled,
disableKeyboardFocus = _props.disableKeyboardFocus,
keyboardFocused = _props.keyboardFocused;
if (!disabled && keyboardFocused && !disableKeyboardFocus) {
this.setState({ isKeyboardFocused: true });
}
}
}, {
key: 'componentDidMount',
value: function componentDidMount() {
injectStyle();
listenForTabPresses();
if (this.state.isKeyboardFocused) {
this.button.focus();
this.props.onKeyboardFocus(null, true);
}
}
}, {
key: 'componentWillReceiveProps',
value: function componentWillReceiveProps(nextProps) {
if ((nextProps.disabled || nextProps.disableKeyboardFocus) && this.state.isKeyboardFocused) {
this.setState({ isKeyboardFocused: false });
if (nextProps.onKeyboardFocus) {
nextProps.onKeyboardFocus(null, false);
}
}
}
}, {
key: 'componentWillUnmount',
value: function componentWillUnmount() {
if (this.focusTimeout) {
clearTimeout(this.focusTimeout);
}
}
}, {
key: 'isKeyboardFocused',
value: function isKeyboardFocused() {
return this.state.isKeyboardFocused;
}
}, {
key: 'removeKeyboardFocus',
value: function removeKeyboardFocus(event) {
if (this.state.isKeyboardFocused) {
this.setState({ isKeyboardFocused: false });
this.props.onKeyboardFocus(event, false);
}
}
}, {
key: 'setKeyboardFocus',
value: function setKeyboardFocus(event) {
if (!this.state.isKeyboardFocused) {
this.setState({ isKeyboardFocused: true });
this.props.onKeyboardFocus(event, true);
}
}
}, {
key: 'cancelFocusTimeout',
value: function cancelFocusTimeout() {
if (this.focusTimeout) {
clearTimeout(this.focusTimeout);
this.focusTimeout = null;
}
}
}, {
key: 'createButtonChildren',
value: function createButtonChildren() {
var _props2 = this.props,
centerRipple = _props2.centerRipple,
children = _props2.children,
disabled = _props2.disabled,
disableFocusRipple = _props2.disableFocusRipple,
disableKeyboardFocus = _props2.disableKeyboardFocus,
disableTouchRipple = _props2.disableTouchRipple,
focusRippleColor = _props2.focusRippleColor,
focusRippleOpacity = _props2.focusRippleOpacity,
touchRippleColor = _props2.touchRippleColor,
touchRippleOpacity = _props2.touchRippleOpacity;
var isKeyboardFocused = this.state.isKeyboardFocused;
// Focus Ripple
var focusRipple = isKeyboardFocused && !disabled && !disableFocusRipple && !disableKeyboardFocus ? _react2.default.createElement(_FocusRipple2.default, {
color: focusRippleColor,
opacity: focusRippleOpacity,
show: isKeyboardFocused,
style: {
overflow: 'hidden'
},
key: 'focusRipple'
}) : undefined;
// Touch Ripple
var touchRipple = !disabled && !disableTouchRipple ? _react2.default.createElement(
_TouchRipple2.default,
{
centerRipple: centerRipple,
color: touchRippleColor,
opacity: touchRippleOpacity,
key: 'touchRipple'
},
children
) : undefined;
return [focusRipple, touchRipple, touchRipple ? undefined : children];
}
}, {
key: 'render',
value: function render() {
var _this2 = this;
var _props3 = this.props,
centerRipple = _props3.centerRipple,
children = _props3.children,
containerElement = _props3.containerElement,
disabled = _props3.disabled,
disableFocusRipple = _props3.disableFocusRipple,
disableKeyboardFocus = _props3.disableKeyboardFocus,
disableTouchRipple = _props3.disableTouchRipple,
focusRippleColor = _props3.focusRippleColor,
focusRippleOpacity = _props3.focusRippleOpacity,
href = _props3.href,
keyboardFocused = _props3.keyboardFocused,
touchRippleColor = _props3.touchRippleColor,
touchRippleOpacity = _props3.touchRippleOpacity,
onBlur = _props3.onBlur,
onClick = _props3.onClick,
onFocus = _props3.onFocus,
onKeyUp = _props3.onKeyUp,
onKeyDown = _props3.onKeyDown,
onKeyboardFocus = _props3.onKeyboardFocus,
style = _props3.style,
tabIndex = _props3.tabIndex,
type = _props3.type,
other = _objectWithoutProperties(_props3, ['centerRipple', 'children', 'containerElement', 'disabled', 'disableFocusRipple', 'disableKeyboardFocus', 'disableTouchRipple', 'focusRippleColor', 'focusRippleOpacity', 'href', 'keyboardFocused', 'touchRippleColor', 'touchRippleOpacity', 'onBlur', 'onClick', 'onFocus', 'onKeyUp', 'onKeyDown', 'onKeyboardFocus', 'style', 'tabIndex', 'type']);
var _context$muiTheme = this.context.muiTheme,
prepareStyles = _context$muiTheme.prepareStyles,
enhancedButton = _context$muiTheme.enhancedButton;
var mergedStyles = (0, _simpleAssign2.default)({
border: 10,
boxSizing: 'border-box',
display: 'inline-block',
fontFamily: this.context.muiTheme.baseTheme.fontFamily,
WebkitTapHighlightColor: enhancedButton.tapHighlightColor, // Remove mobile color flashing (deprecated)
cursor: disabled ? 'default' : 'pointer',
textDecoration: 'none',
margin: 0,
padding: 0,
outline: 'none',
fontSize: 'inherit',
fontWeight: 'inherit',
position: 'relative', // This is needed so that ripples do not bleed past border radius.
verticalAlign: href ? 'middle' : null
}, style);
// Passing both background:none & backgroundColor can break due to object iteration order
if (!mergedStyles.backgroundColor && !mergedStyles.background) {
mergedStyles.background = 'none';
}
if (disabled && href) {
return _react2.default.createElement(
'span',
_extends({}, other, {
style: mergedStyles
}),
children
);
}
var buttonProps = _extends({}, other, {
style: prepareStyles(mergedStyles),
ref: function ref(node) {
return _this2.button = node;
},
disabled: disabled,
onBlur: this.handleBlur,
onFocus: this.handleFocus,
onKeyUp: this.handleKeyUp,
onKeyDown: this.handleKeyDown,
onClick: this.handleTouchTap,
tabIndex: disabled || disableKeyboardFocus ? -1 : tabIndex
});
if (href) buttonProps.href = href;
var buttonChildren = this.createButtonChildren();
if (_react2.default.isValidElement(containerElement)) {
return _react2.default.cloneElement(containerElement, buttonProps, buttonChildren);
}
if (!href && containerElement === 'button') {
buttonProps.type = type;
}
return _react2.default.createElement(href ? 'a' : containerElement, buttonProps, buttonChildren);
}
}]);
return EnhancedButton;
}(_react.Component);
EnhancedButton.propTypes = {
centerRipple: _propTypes2.default.bool,
children: _propTypes2.default.node,
containerElement: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.element]),
disableFocusRipple: _propTypes2.default.bool,
disableKeyboardFocus: _propTypes2.default.bool,
disableTouchRipple: _propTypes2.default.bool,
disabled: _propTypes2.default.bool,
focusRippleColor: _propTypes2.default.string,
focusRippleOpacity: _propTypes2.default.number,
href: _propTypes2.default.string,
keyboardFocused: _propTypes2.default.bool,
onBlur: _propTypes2.default.func,
onClick: _propTypes2.default.func,
onFocus: _propTypes2.default.func,
onKeyDown: _propTypes2.default.func,
onKeyUp: _propTypes2.default.func,
onKeyboardFocus: _propTypes2.default.func,
style: _propTypes2.default.object,
tabIndex: _propTypes2.default.number,
touchRippleColor: _propTypes2.default.string,
touchRippleOpacity: _propTypes2.default.number,
type: _propTypes2.default.string
};
EnhancedButton.defaultProps = {
containerElement: 'button',
onBlur: function onBlur() {},
onClick: function onClick() {},
onFocus: function onFocus() {},
onKeyDown: function onKeyDown() {},
onKeyUp: function onKeyUp() {},
onKeyboardFocus: function onKeyboardFocus() {},
tabIndex: 0,
type: 'button'
};
EnhancedButton.contextTypes = {
muiTheme: _propTypes2.default.object.isRequired
};
exports.default = EnhancedButton;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/internal/EnhancedButton.js"],"names":["styleInjected","listening","tabPressed","injectStyle","style","document","createElement","innerHTML","body","appendChild","listenForTabPresses","Events","on","window","event","EnhancedButton","state","isKeyboardFocused","handleKeyDown","props","disabled","disableKeyboardFocus","handleTouchTap","removeKeyboardFocus","onKeyDown","handleKeyUp","onKeyUp","handleBlur","cancelFocusTimeout","onBlur","handleFocus","persist","focusTimeout","setTimeout","setKeyboardFocus","onFocus","onClick","keyboardFocused","setState","button","focus","onKeyboardFocus","nextProps","clearTimeout","centerRipple","children","disableFocusRipple","disableTouchRipple","focusRippleColor","focusRippleOpacity","touchRippleColor","touchRippleOpacity","focusRipple","overflow","undefined","touchRipple","containerElement","href","tabIndex","type","other","context","muiTheme","prepareStyles","enhancedButton","mergedStyles","border","boxSizing","display","fontFamily","baseTheme","WebkitTapHighlightColor","tapHighlightColor","cursor","textDecoration","margin","padding","outline","fontSize","fontWeight","position","verticalAlign","backgroundColor","background","buttonProps","ref","node","buttonChildren","createButtonChildren","React","isValidElement","cloneElement","Component","propTypes","PropTypes","bool","oneOfType","string","element","number","func","object","defaultProps","contextTypes","isRequired"],"mappings":";;;;;;;;;;;;;;AAAA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;;;;;;;;;;;AAEA,IAAIA,gBAAgB,KAApB;AACA,IAAIC,YAAY,KAAhB;AACA,IAAIC,aAAa,KAAjB;;AAEA,SAASC,WAAT,GAAuB;AACrB,MAAI,CAACH,aAAL,EAAoB;AAClB;AACA,QAAMI,QAAQC,SAASC,aAAT,CAAuB,OAAvB,CAAd;AACAF,UAAMG,SAAN;;AAQAF,aAASG,IAAT,CAAcC,WAAd,CAA0BL,KAA1B;AACAJ,oBAAgB,IAAhB;AACD;AACF;;AAED,SAASU,mBAAT,GAA+B;AAC7B,MAAI,CAACT,SAAL,EAAgB;AACdU,qBAAOC,EAAP,CAAUC,MAAV,EAAkB,SAAlB,EAA6B,UAACC,KAAD,EAAW;AACtCZ,mBAAa,uBAAQY,KAAR,MAAmB,KAAhC;AACD,KAFD;AAGAb,gBAAY,IAAZ;AACD;AACF;;IAEKc,c;;;;;;;;;;;;;;sMA6CJC,K,GAAQ;AACNC,yBAAmB;AADb,K,QA4GRC,a,GAAgB,UAACJ,KAAD,EAAW;AACzB,UAAI,CAAC,MAAKK,KAAL,CAAWC,QAAZ,IAAwB,CAAC,MAAKD,KAAL,CAAWE,oBAAxC,EAA8D;AAC5D,YAAI,uBAAQP,KAAR,MAAmB,OAAnB,IAA8B,MAAKE,KAAL,CAAWC,iBAA7C,EAAgE;AAC9D,gBAAKK,cAAL,CAAoBR,KAApB;AACD;AACD,YAAI,uBAAQA,KAAR,MAAmB,KAAnB,IAA4B,MAAKE,KAAL,CAAWC,iBAA3C,EAA8D;AAC5D,gBAAKM,mBAAL,CAAyBT,KAAzB;AACD;AACF;AACD,YAAKK,KAAL,CAAWK,SAAX,CAAqBV,KAArB;AACD,K,QAEDW,W,GAAc,UAACX,KAAD,EAAW;AACvB,UAAI,CAAC,MAAKK,KAAL,CAAWC,QAAZ,IAAwB,CAAC,MAAKD,KAAL,CAAWE,oBAAxC,EAA8D;AAC5D,YAAI,uBAAQP,KAAR,MAAmB,OAAnB,IAA8B,MAAKE,KAAL,CAAWC,iBAA7C,EAAgE;AAC9D,gBAAKK,cAAL,CAAoBR,KAApB;AACD;AACF;AACD,YAAKK,KAAL,CAAWO,OAAX,CAAmBZ,KAAnB;AACD,K,QAEDa,U,GAAa,UAACb,KAAD,EAAW;AACtB,YAAKc,kBAAL;AACA,YAAKL,mBAAL,CAAyBT,KAAzB;AACA,YAAKK,KAAL,CAAWU,MAAX,CAAkBf,KAAlB;AACD,K,QAEDgB,W,GAAc,UAAChB,KAAD,EAAW;AACvB,UAAIA,KAAJ,EAAWA,MAAMiB,OAAN;AACX,UAAI,CAAC,MAAKZ,KAAL,CAAWC,QAAZ,IAAwB,CAAC,MAAKD,KAAL,CAAWE,oBAAxC,EAA8D;AAC5D;AACA;AACA;AACA,cAAKW,YAAL,GAAoBC,WAAW,YAAM;AACnC,cAAI/B,UAAJ,EAAgB;AACd,kBAAKgC,gBAAL,CAAsBpB,KAAtB;AACAZ,yBAAa,KAAb;AACD;AACF,SALmB,EAKjB,GALiB,CAApB;;AAOA,cAAKiB,KAAL,CAAWgB,OAAX,CAAmBrB,KAAnB;AACD;AACF,K,QAEDQ,c,GAAiB,UAACR,KAAD,EAAW;AAC1B,YAAKc,kBAAL;AACA,UAAI,CAAC,MAAKT,KAAL,CAAWC,QAAhB,EAA0B;AACxBlB,qBAAa,KAAb;AACA,cAAKqB,mBAAL,CAAyBT,KAAzB;AACA,cAAKK,KAAL,CAAWiB,OAAX,CAAmBtB,KAAnB;AACD;AACF,K;;;;;yCA3JoB;AAAA,mBACuC,KAAKK,KAD5C;AAAA,UACZC,QADY,UACZA,QADY;AAAA,UACFC,oBADE,UACFA,oBADE;AAAA,UACoBgB,eADpB,UACoBA,eADpB;;AAEnB,UAAI,CAACjB,QAAD,IAAaiB,eAAb,IAAgC,CAAChB,oBAArC,EAA2D;AACzD,aAAKiB,QAAL,CAAc,EAACrB,mBAAmB,IAApB,EAAd;AACD;AACF;;;wCAEmB;AAClBd;AACAO;AACA,UAAI,KAAKM,KAAL,CAAWC,iBAAf,EAAkC;AAChC,aAAKsB,MAAL,CAAYC,KAAZ;AACA,aAAKrB,KAAL,CAAWsB,eAAX,CAA2B,IAA3B,EAAiC,IAAjC;AACD;AACF;;;8CAEyBC,S,EAAW;AACnC,UAAI,CAACA,UAAUtB,QAAV,IAAsBsB,UAAUrB,oBAAjC,KACF,KAAKL,KAAL,CAAWC,iBADb,EACgC;AAC9B,aAAKqB,QAAL,CAAc,EAACrB,mBAAmB,KAApB,EAAd;AACA,YAAIyB,UAAUD,eAAd,EAA+B;AAC7BC,oBAAUD,eAAV,CAA0B,IAA1B,EAAgC,KAAhC;AACD;AACF;AACF;;;2CAEsB;AACrB,UAAI,KAAKT,YAAT,EAAuB;AACrBW,qBAAa,KAAKX,YAAlB;AACD;AACF;;;wCAEmB;AAClB,aAAO,KAAKhB,KAAL,CAAWC,iBAAlB;AACD;;;wCAEmBH,K,EAAO;AACzB,UAAI,KAAKE,KAAL,CAAWC,iBAAf,EAAkC;AAChC,aAAKqB,QAAL,CAAc,EAACrB,mBAAmB,KAApB,EAAd;AACA,aAAKE,KAAL,CAAWsB,eAAX,CAA2B3B,KAA3B,EAAkC,KAAlC;AACD;AACF;;;qCAEgBA,K,EAAO;AACtB,UAAI,CAAC,KAAKE,KAAL,CAAWC,iBAAhB,EAAmC;AACjC,aAAKqB,QAAL,CAAc,EAACrB,mBAAmB,IAApB,EAAd;AACA,aAAKE,KAAL,CAAWsB,eAAX,CAA2B3B,KAA3B,EAAkC,IAAlC;AACD;AACF;;;yCAEoB;AACnB,UAAI,KAAKkB,YAAT,EAAuB;AACrBW,qBAAa,KAAKX,YAAlB;AACA,aAAKA,YAAL,GAAoB,IAApB;AACD;AACF;;;2CAEsB;AAAA,oBAYjB,KAAKb,KAZY;AAAA,UAEnByB,YAFmB,WAEnBA,YAFmB;AAAA,UAGnBC,QAHmB,WAGnBA,QAHmB;AAAA,UAInBzB,QAJmB,WAInBA,QAJmB;AAAA,UAKnB0B,kBALmB,WAKnBA,kBALmB;AAAA,UAMnBzB,oBANmB,WAMnBA,oBANmB;AAAA,UAOnB0B,kBAPmB,WAOnBA,kBAPmB;AAAA,UAQnBC,gBARmB,WAQnBA,gBARmB;AAAA,UASnBC,kBATmB,WASnBA,kBATmB;AAAA,UAUnBC,gBAVmB,WAUnBA,gBAVmB;AAAA,UAWnBC,kBAXmB,WAWnBA,kBAXmB;AAAA,UAadlC,iBAbc,GAaO,KAAKD,KAbZ,CAadC,iBAbc;;AAerB;;AACA,UAAMmC,cAAcnC,qBAAqB,CAACG,QAAtB,IAAkC,CAAC0B,kBAAnC,IAAyD,CAACzB,oBAA1D,GAClB,8BAAC,qBAAD;AACE,eAAO2B,gBADT;AAEE,iBAASC,kBAFX;AAGE,cAAMhC,iBAHR;AAIE,eAAO;AACLoC,oBAAU;AADL,SAJT;AAOE,aAAI;AAPN,QADkB,GAUhBC,SAVJ;;AAYA;AACA,UAAMC,cAAc,CAACnC,QAAD,IAAa,CAAC2B,kBAAd,GAClB;AAAC,6BAAD;AAAA;AACE,wBAAcH,YADhB;AAEE,iBAAOM,gBAFT;AAGE,mBAASC,kBAHX;AAIE,eAAI;AAJN;AAMGN;AANH,OADkB,GAShBS,SATJ;;AAWA,aAAO,CACLF,WADK,EAELG,WAFK,EAGLA,cAAcD,SAAd,GAA0BT,QAHrB,CAAP;AAKD;;;6BAuDQ;AAAA;;AAAA,oBAyBH,KAAK1B,KAzBF;AAAA,UAELyB,YAFK,WAELA,YAFK;AAAA,UAGLC,QAHK,WAGLA,QAHK;AAAA,UAILW,gBAJK,WAILA,gBAJK;AAAA,UAKLpC,QALK,WAKLA,QALK;AAAA,UAML0B,kBANK,WAMLA,kBANK;AAAA,UAOLzB,oBAPK,WAOLA,oBAPK;AAAA,UAQL0B,kBARK,WAQLA,kBARK;AAAA,UASLC,gBATK,WASLA,gBATK;AAAA,UAULC,kBAVK,WAULA,kBAVK;AAAA,UAWLQ,IAXK,WAWLA,IAXK;AAAA,UAYLpB,eAZK,WAYLA,eAZK;AAAA,UAaLa,gBAbK,WAaLA,gBAbK;AAAA,UAcLC,kBAdK,WAcLA,kBAdK;AAAA,UAeLtB,MAfK,WAeLA,MAfK;AAAA,UAgBLO,OAhBK,WAgBLA,OAhBK;AAAA,UAiBLD,OAjBK,WAiBLA,OAjBK;AAAA,UAkBLT,OAlBK,WAkBLA,OAlBK;AAAA,UAmBLF,SAnBK,WAmBLA,SAnBK;AAAA,UAoBLiB,eApBK,WAoBLA,eApBK;AAAA,UAqBLrC,KArBK,WAqBLA,KArBK;AAAA,UAsBLsD,QAtBK,WAsBLA,QAtBK;AAAA,UAuBLC,IAvBK,WAuBLA,IAvBK;AAAA,UAwBFC,KAxBE;;AAAA,8BA8BH,KAAKC,OAAL,CAAaC,QA9BV;AAAA,UA4BLC,aA5BK,qBA4BLA,aA5BK;AAAA,UA6BLC,cA7BK,qBA6BLA,cA7BK;;;AAgCP,UAAMC,eAAe,4BAAc;AACjCC,gBAAQ,EADyB;AAEjCC,mBAAW,YAFsB;AAGjCC,iBAAS,cAHwB;AAIjCC,oBAAY,KAAKR,OAAL,CAAaC,QAAb,CAAsBQ,SAAtB,CAAgCD,UAJX;AAKjCE,iCAAyBP,eAAeQ,iBALP,EAK0B;AAC3DC,gBAAQrD,WAAW,SAAX,GAAuB,SANE;AAOjCsD,wBAAgB,MAPiB;AAQjCC,gBAAQ,CARyB;AASjCC,iBAAS,CATwB;AAUjCC,iBAAS,MAVwB;AAWjCC,kBAAU,SAXuB;AAYjCC,oBAAY,SAZqB;AAajCC,kBAAU,UAbuB,EAaX;AACtBC,uBAAexB,OAAO,QAAP,GAAkB;AAdA,OAAd,EAelBrD,KAfkB,CAArB;;AAkBA;AACA,UAAI,CAAC6D,aAAaiB,eAAd,IAAiC,CAACjB,aAAakB,UAAnD,EAA+D;AAC7DlB,qBAAakB,UAAb,GAA0B,MAA1B;AACD;;AAED,UAAI/D,YAAYqC,IAAhB,EAAsB;AACpB,eACE;AAAA;AAAA,uBACMG,KADN;AAEE,mBAAOK;AAFT;AAIGpB;AAJH,SADF;AAQD;;AAED,UAAMuC,2BACDxB,KADC;AAEJxD,eAAO2D,cAAcE,YAAd,CAFH;AAGJoB,aAAK,aAACC,IAAD;AAAA,iBAAU,OAAK/C,MAAL,GAAc+C,IAAxB;AAAA,SAHD;AAIJlE,kBAAUA,QAJN;AAKJS,gBAAQ,KAAKF,UALT;AAMJQ,iBAAS,KAAKL,WANV;AAOJJ,iBAAS,KAAKD,WAPV;AAQJD,mBAAW,KAAKN,aARZ;AASJkB,iBAAS,KAAKd,cATV;AAUJoC,kBAAUtC,YAAYC,oBAAZ,GAAmC,CAAC,CAApC,GAAwCqC;AAV9C,QAAN;;AAaA,UAAID,IAAJ,EAAU2B,YAAY3B,IAAZ,GAAmBA,IAAnB;;AAEV,UAAM8B,iBAAiB,KAAKC,oBAAL,EAAvB;;AAEA,UAAIC,gBAAMC,cAAN,CAAqBlC,gBAArB,CAAJ,EAA4C;AAC1C,eAAOiC,gBAAME,YAAN,CAAmBnC,gBAAnB,EAAqC4B,WAArC,EAAkDG,cAAlD,CAAP;AACD;;AAED,UAAI,CAAC9B,IAAD,IAASD,qBAAqB,QAAlC,EAA4C;AAC1C4B,oBAAYzB,IAAZ,GAAmBA,IAAnB;AACD;;AAED,aAAO8B,gBAAMnF,aAAN,CAAoBmD,OAAO,GAAP,GAAaD,gBAAjC,EAAmD4B,WAAnD,EAAgEG,cAAhE,CAAP;AACD;;;;EA1S0BK,gB;;AAAvB7E,c,CACG8E,S,GAAY;AACjBjD,gBAAckD,oBAAUC,IADP;AAEjBlD,YAAUiD,oBAAUR,IAFH;AAGjB9B,oBAAkBsC,oBAAUE,SAAV,CAAoB,CACpCF,oBAAUG,MAD0B,EAEpCH,oBAAUI,OAF0B,CAApB,CAHD;AAOjBpD,sBAAoBgD,oBAAUC,IAPb;AAQjB1E,wBAAsByE,oBAAUC,IARf;AASjBhD,sBAAoB+C,oBAAUC,IATb;AAUjB3E,YAAU0E,oBAAUC,IAVH;AAWjB/C,oBAAkB8C,oBAAUG,MAXX;AAYjBhD,sBAAoB6C,oBAAUK,MAZb;AAajB1C,QAAMqC,oBAAUG,MAbC;AAcjB5D,mBAAiByD,oBAAUC,IAdV;AAejBlE,UAAQiE,oBAAUM,IAfD;AAgBjBhE,WAAS0D,oBAAUM,IAhBF;AAiBjBjE,WAAS2D,oBAAUM,IAjBF;AAkBjB5E,aAAWsE,oBAAUM,IAlBJ;AAmBjB1E,WAASoE,oBAAUM,IAnBF;AAoBjB3D,mBAAiBqD,oBAAUM,IApBV;AAqBjBhG,SAAO0F,oBAAUO,MArBA;AAsBjB3C,YAAUoC,oBAAUK,MAtBH;AAuBjBjD,oBAAkB4C,oBAAUG,MAvBX;AAwBjB9C,sBAAoB2C,oBAAUK,MAxBb;AAyBjBxC,QAAMmC,oBAAUG;AAzBC,C;AADflF,c,CA6BGuF,Y,GAAe;AACpB9C,oBAAkB,QADE;AAEpB3B,UAAQ,kBAAM,CAAE,CAFI;AAGpBO,WAAS,mBAAM,CAAE,CAHG;AAIpBD,WAAS,mBAAM,CAAE,CAJG;AAKpBX,aAAW,qBAAM,CAAE,CALC;AAMpBE,WAAS,mBAAM,CAAE,CANG;AAOpBe,mBAAiB,2BAAM,CAAE,CAPL;AAQpBiB,YAAU,CARU;AASpBC,QAAM;AATc,C;AA7BlB5C,c,CAyCGwF,Y,GAAe;AACpBzC,YAAUgC,oBAAUO,MAAV,CAAiBG;AADP,C;kBAoQTzF,c","file":"EnhancedButton.js","sourcesContent":["import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport Events from '../utils/events';\nimport keycode from 'keycode';\nimport FocusRipple from './FocusRipple';\nimport TouchRipple from './TouchRipple';\n\nlet styleInjected = false;\nlet listening = false;\nlet tabPressed = false;\n\nfunction injectStyle() {\n  if (!styleInjected) {\n    // Remove inner padding and border in Firefox 4+.\n    const style = document.createElement('style');\n    style.innerHTML = `\n      button::-moz-focus-inner,\n      input::-moz-focus-inner {\n        border: 0;\n        padding: 0;\n      }\n    `;\n\n    document.body.appendChild(style);\n    styleInjected = true;\n  }\n}\n\nfunction listenForTabPresses() {\n  if (!listening) {\n    Events.on(window, 'keydown', (event) => {\n      tabPressed = keycode(event) === 'tab';\n    });\n    listening = true;\n  }\n}\n\nclass EnhancedButton extends Component {\n  static propTypes = {\n    centerRipple: PropTypes.bool,\n    children: PropTypes.node,\n    containerElement: PropTypes.oneOfType([\n      PropTypes.string,\n      PropTypes.element,\n    ]),\n    disableFocusRipple: PropTypes.bool,\n    disableKeyboardFocus: PropTypes.bool,\n    disableTouchRipple: PropTypes.bool,\n    disabled: PropTypes.bool,\n    focusRippleColor: PropTypes.string,\n    focusRippleOpacity: PropTypes.number,\n    href: PropTypes.string,\n    keyboardFocused: PropTypes.bool,\n    onBlur: PropTypes.func,\n    onClick: PropTypes.func,\n    onFocus: PropTypes.func,\n    onKeyDown: PropTypes.func,\n    onKeyUp: PropTypes.func,\n    onKeyboardFocus: PropTypes.func,\n    style: PropTypes.object,\n    tabIndex: PropTypes.number,\n    touchRippleColor: PropTypes.string,\n    touchRippleOpacity: PropTypes.number,\n    type: PropTypes.string,\n  };\n\n  static defaultProps = {\n    containerElement: 'button',\n    onBlur: () => {},\n    onClick: () => {},\n    onFocus: () => {},\n    onKeyDown: () => {},\n    onKeyUp: () => {},\n    onKeyboardFocus: () => {},\n    tabIndex: 0,\n    type: 'button',\n  };\n\n  static contextTypes = {\n    muiTheme: PropTypes.object.isRequired,\n  };\n\n  state = {\n    isKeyboardFocused: false,\n  };\n\n  componentWillMount() {\n    const {disabled, disableKeyboardFocus, keyboardFocused} = this.props;\n    if (!disabled && keyboardFocused && !disableKeyboardFocus) {\n      this.setState({isKeyboardFocused: true});\n    }\n  }\n\n  componentDidMount() {\n    injectStyle();\n    listenForTabPresses();\n    if (this.state.isKeyboardFocused) {\n      this.button.focus();\n      this.props.onKeyboardFocus(null, true);\n    }\n  }\n\n  componentWillReceiveProps(nextProps) {\n    if ((nextProps.disabled || nextProps.disableKeyboardFocus) &&\n      this.state.isKeyboardFocused) {\n      this.setState({isKeyboardFocused: false});\n      if (nextProps.onKeyboardFocus) {\n        nextProps.onKeyboardFocus(null, false);\n      }\n    }\n  }\n\n  componentWillUnmount() {\n    if (this.focusTimeout) {\n      clearTimeout(this.focusTimeout);\n    }\n  }\n\n  isKeyboardFocused() {\n    return this.state.isKeyboardFocused;\n  }\n\n  removeKeyboardFocus(event) {\n    if (this.state.isKeyboardFocused) {\n      this.setState({isKeyboardFocused: false});\n      this.props.onKeyboardFocus(event, false);\n    }\n  }\n\n  setKeyboardFocus(event) {\n    if (!this.state.isKeyboardFocused) {\n      this.setState({isKeyboardFocused: true});\n      this.props.onKeyboardFocus(event, true);\n    }\n  }\n\n  cancelFocusTimeout() {\n    if (this.focusTimeout) {\n      clearTimeout(this.focusTimeout);\n      this.focusTimeout = null;\n    }\n  }\n\n  createButtonChildren() {\n    const {\n      centerRipple,\n      children,\n      disabled,\n      disableFocusRipple,\n      disableKeyboardFocus,\n      disableTouchRipple,\n      focusRippleColor,\n      focusRippleOpacity,\n      touchRippleColor,\n      touchRippleOpacity,\n    } = this.props;\n    const {isKeyboardFocused} = this.state;\n\n    // Focus Ripple\n    const focusRipple = isKeyboardFocused && !disabled && !disableFocusRipple && !disableKeyboardFocus ? (\n      <FocusRipple\n        color={focusRippleColor}\n        opacity={focusRippleOpacity}\n        show={isKeyboardFocused}\n        style={{\n          overflow: 'hidden',\n        }}\n        key=\"focusRipple\"\n      />\n    ) : undefined;\n\n    // Touch Ripple\n    const touchRipple = !disabled && !disableTouchRipple ? (\n      <TouchRipple\n        centerRipple={centerRipple}\n        color={touchRippleColor}\n        opacity={touchRippleOpacity}\n        key=\"touchRipple\"\n      >\n        {children}\n      </TouchRipple>\n    ) : undefined;\n\n    return [\n      focusRipple,\n      touchRipple,\n      touchRipple ? undefined : children,\n    ];\n  }\n\n  handleKeyDown = (event) => {\n    if (!this.props.disabled && !this.props.disableKeyboardFocus) {\n      if (keycode(event) === 'enter' && this.state.isKeyboardFocused) {\n        this.handleTouchTap(event);\n      }\n      if (keycode(event) === 'esc' && this.state.isKeyboardFocused) {\n        this.removeKeyboardFocus(event);\n      }\n    }\n    this.props.onKeyDown(event);\n  };\n\n  handleKeyUp = (event) => {\n    if (!this.props.disabled && !this.props.disableKeyboardFocus) {\n      if (keycode(event) === 'space' && this.state.isKeyboardFocused) {\n        this.handleTouchTap(event);\n      }\n    }\n    this.props.onKeyUp(event);\n  };\n\n  handleBlur = (event) => {\n    this.cancelFocusTimeout();\n    this.removeKeyboardFocus(event);\n    this.props.onBlur(event);\n  };\n\n  handleFocus = (event) => {\n    if (event) event.persist();\n    if (!this.props.disabled && !this.props.disableKeyboardFocus) {\n      // setTimeout is needed because the focus event fires first\n      // Wait so that we can capture if this was a keyboard focus\n      // or touch focus\n      this.focusTimeout = setTimeout(() => {\n        if (tabPressed) {\n          this.setKeyboardFocus(event);\n          tabPressed = false;\n        }\n      }, 150);\n\n      this.props.onFocus(event);\n    }\n  };\n\n  handleTouchTap = (event) => {\n    this.cancelFocusTimeout();\n    if (!this.props.disabled) {\n      tabPressed = false;\n      this.removeKeyboardFocus(event);\n      this.props.onClick(event);\n    }\n  };\n\n  render() {\n    const {\n      centerRipple, // eslint-disable-line no-unused-vars\n      children,\n      containerElement,\n      disabled,\n      disableFocusRipple, // eslint-disable-line no-unused-vars\n      disableKeyboardFocus, // eslint-disable-line no-unused-vars\n      disableTouchRipple, // eslint-disable-line no-unused-vars\n      focusRippleColor, // eslint-disable-line no-unused-vars\n      focusRippleOpacity, // eslint-disable-line no-unused-vars\n      href,\n      keyboardFocused, // eslint-disable-line no-unused-vars\n      touchRippleColor, // eslint-disable-line no-unused-vars\n      touchRippleOpacity, // eslint-disable-line no-unused-vars\n      onBlur, // eslint-disable-line no-unused-vars\n      onClick, // eslint-disable-line no-unused-vars\n      onFocus, // eslint-disable-line no-unused-vars\n      onKeyUp, // eslint-disable-line no-unused-vars\n      onKeyDown, // eslint-disable-line no-unused-vars\n      onKeyboardFocus, // eslint-disable-line no-unused-vars\n      style,\n      tabIndex,\n      type,\n      ...other\n    } = this.props;\n\n    const {\n      prepareStyles,\n      enhancedButton,\n    } = this.context.muiTheme;\n\n    const mergedStyles = Object.assign({\n      border: 10,\n      boxSizing: 'border-box',\n      display: 'inline-block',\n      fontFamily: this.context.muiTheme.baseTheme.fontFamily,\n      WebkitTapHighlightColor: enhancedButton.tapHighlightColor, // Remove mobile color flashing (deprecated)\n      cursor: disabled ? 'default' : 'pointer',\n      textDecoration: 'none',\n      margin: 0,\n      padding: 0,\n      outline: 'none',\n      fontSize: 'inherit',\n      fontWeight: 'inherit',\n      position: 'relative', // This is needed so that ripples do not bleed past border radius.\n      verticalAlign: href ? 'middle' : null,\n    }, style);\n\n\n    // Passing both background:none & backgroundColor can break due to object iteration order\n    if (!mergedStyles.backgroundColor && !mergedStyles.background) {\n      mergedStyles.background = 'none';\n    }\n\n    if (disabled && href) {\n      return (\n        <span\n          {...other}\n          style={mergedStyles}\n        >\n          {children}\n        </span>\n      );\n    }\n\n    const buttonProps = {\n      ...other,\n      style: prepareStyles(mergedStyles),\n      ref: (node) => this.button = node,\n      disabled: disabled,\n      onBlur: this.handleBlur,\n      onFocus: this.handleFocus,\n      onKeyUp: this.handleKeyUp,\n      onKeyDown: this.handleKeyDown,\n      onClick: this.handleTouchTap,\n      tabIndex: disabled || disableKeyboardFocus ? -1 : tabIndex,\n    };\n\n    if (href) buttonProps.href = href;\n\n    const buttonChildren = this.createButtonChildren();\n\n    if (React.isValidElement(containerElement)) {\n      return React.cloneElement(containerElement, buttonProps, buttonChildren);\n    }\n\n    if (!href && containerElement === 'button') {\n      buttonProps.type = type;\n    }\n\n    return React.createElement(href ? 'a' : containerElement, buttonProps, buttonChildren);\n  }\n}\n\nexport default EnhancedButton;\n"]}
;