redux-toggle
Version:
Track toggle state in Redux
88 lines (69 loc) • 2.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 _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _reactRedux = require('react-redux');
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _Toggle = require('./Toggle');
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 Toggleable(_ref) {
var children = _ref.children,
className = _ref.className,
data = _ref.data,
hideOnClick = _ref.hideOnClick,
group = _ref.group,
id = _ref.id,
showOnClick = _ref.showOnClick,
showOnHover = _ref.showOnHover,
toggleOnClick = _ref.toggleOnClick,
props = _objectWithoutProperties(_ref, ['children', 'className', 'data', 'hideOnClick', 'group', 'id', 'showOnClick', 'showOnHover', 'toggleOnClick']);
var childProps = _extends({
className: (0, _classnames2.default)(children.props.className, className)
}, props);
if (hideOnClick) {
childProps.onClick = function () {
return props.replaceToggle(group, null, data);
};
}
if (showOnClick) {
childProps.onClick = function () {
return props.replaceToggle(group, id, data);
};
}
if (showOnHover) {
childProps.onMouseEnter = function () {
return props.toggleToggle(group, id, data);
};
childProps.onMouseLeave = function () {
return props.toggleToggle(group, null, data);
};
}
if (toggleOnClick) {
childProps.onClick = function () {
return props.toggleToggle(group, id, data);
};
}
return _react2.default.cloneElement(children, childProps);
}
Toggleable.propTypes = {
children: _react2.default.PropTypes.node,
className: _react2.default.PropTypes.string,
data: _react2.default.PropTypes.any, // eslint-disable-line react/forbid-prop-types
group: _react2.default.PropTypes.string,
hideOnClick: _react2.default.PropTypes.bool,
id: _react2.default.PropTypes.string,
replaceToggle: _react2.default.PropTypes.func,
showOnClick: _react2.default.PropTypes.bool,
showOnHover: _react2.default.PropTypes.bool,
toggleOnClick: _react2.default.PropTypes.bool,
toggleToggle: _react2.default.PropTypes.func
};
exports.default = (0, _reactRedux.connect)(null, {
replaceToggle: _Toggle.replaceToggle,
toggleToggle: _Toggle.toggleToggle
})(Toggleable);