UNPKG

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
'use strict'; 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":"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","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"]}