import _extends from "@babel/runtime/helpers/esm/extends"; import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose"; import _assertThisInitialized from "@babel/runtime/helpers/esm/assertThisInitialized"; import _inheritsLoose from "@babel/runtime/helpers/esm/inheritsLoose"; import React from "react"; import PropTypes from 'prop-types'; import Button from "./Button"; import classNames from 'classnames'; import { mapToCssModules } from './utils'; var propTypes = { onClick: PropTypes.func, onBlur: PropTypes.func, onFocus: PropTypes.func, defaultValue: PropTypes.bool }; var defaultProps = { defaultValue: false }; var ButtonToggle = /*#__PURE__*/ function (_React$Component) { _inheritsLoose(ButtonToggle, _React$Component); function ButtonToggle(props) { var _this; _this = _React$Component.call(this, props) || this; _this.state = { toggled: props.defaultValue, focus: false }; _this.onBlur = _this.onBlur.bind(_assertThisInitialized(_this)); _this.onFocus = _this.onFocus.bind(_assertThisInitialized(_this)); _this.onClick = _this.onClick.bind(_assertThisInitialized(_this)); return _this; } var _proto = ButtonToggle.prototype; _proto.onBlur = function onBlur(e) { if (this.props.onBlur) { this.props.onBlur(e); } this.setState({ focus: false }); }; _proto.onFocus = function onFocus(e) { if (this.props.onFocus) { this.props.onFocus(e); } this.setState({ focus: true }); }; _proto.onClick = function onClick(e) { if (this.props.onClick) { this.props.onClick(e); } this.setState(function (_ref) { var toggled = _ref.toggled; return { toggled: !toggled }; }); }; _proto.render = function render() { var _this$props = this.props, className = _this$props.className, attributes = _objectWithoutPropertiesLoose(_this$props, ["className"]); var classes = mapToCssModules(classNames(className, { focus: this.state.focus }), this.props.cssModule); return React.createElement(Button, _extends({ active: this.state.toggled, onBlur: this.onBlur, onFocus: this.onFocus, onClick: this.onClick, className: classes }, attributes)); }; return ButtonToggle; }(React.Component); ButtonToggle.propTypes = propTypes; ButtonToggle.defaultProps = defaultProps; export default ButtonToggle;