UNPKG

rsuite

Version:

A suite of react components

167 lines (128 loc) 5.72 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); exports.__esModule = true; exports.default = exports.SidenavContext = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose")); var _inheritsLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/inheritsLoose")); var _remove2 = _interopRequireDefault(require("lodash/remove")); var _clone2 = _interopRequireDefault(require("lodash/clone")); var _isUndefined2 = _interopRequireDefault(require("lodash/isUndefined")); var React = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _classnames = _interopRequireDefault(require("classnames")); var _recompose = require("recompose"); var _Transition = _interopRequireDefault(require("../Animation/Transition")); var _shallowEqual = _interopRequireDefault(require("../utils/shallowEqual")); var _SidenavBody = _interopRequireDefault(require("./SidenavBody")); var _SidenavHeader = _interopRequireDefault(require("./SidenavHeader")); var _SidenavToggle = _interopRequireDefault(require("./SidenavToggle")); var _utils = require("../utils"); var SidenavContext = (0, _utils.createContext)(null); exports.SidenavContext = SidenavContext; var Sidenav = /*#__PURE__*/ function (_React$Component) { (0, _inheritsLoose2.default)(Sidenav, _React$Component); function Sidenav(props) { var _this; _this = _React$Component.call(this, props) || this; _this.getOpenKeys = function () { var openKeys = _this.props.openKeys; if ((0, _isUndefined2.default)(openKeys)) { return _this.state.openKeys; } return openKeys; }; _this.handleSelect = function (eventKey, event) { var _this$props$onSelect, _this$props; (_this$props$onSelect = (_this$props = _this.props).onSelect) === null || _this$props$onSelect === void 0 ? void 0 : _this$props$onSelect.call(_this$props, eventKey, event); }; _this.handleOpenChange = function (eventKey, event) { var _this$props$onOpenCha, _this$props2; var find = function find(key) { return (0, _shallowEqual.default)(key, eventKey); }; var openKeys = (0, _clone2.default)(_this.getOpenKeys()) || []; if (openKeys.some(find)) { (0, _remove2.default)(openKeys, find); } else { openKeys.push(eventKey); } _this.setState({ openKeys: openKeys }); (_this$props$onOpenCha = (_this$props2 = _this.props).onOpenChange) === null || _this$props$onOpenCha === void 0 ? void 0 : _this$props$onOpenCha.call(_this$props2, openKeys, event); }; _this.state = { openKeys: props.defaultOpenKeys || [] }; return _this; } var _proto = Sidenav.prototype; _proto.render = function render() { var _this$props3 = this.props, className = _this$props3.className, classPrefix = _this$props3.classPrefix, appearance = _this$props3.appearance, expanded = _this$props3.expanded, activeKey = _this$props3.activeKey, Component = _this$props3.componentClass, props = (0, _objectWithoutPropertiesLoose2.default)(_this$props3, ["className", "classPrefix", "appearance", "expanded", "activeKey", "componentClass"]); var addPrefix = (0, _utils.prefix)(classPrefix); var classes = (0, _classnames.default)(classPrefix, addPrefix(appearance), className); var unhandled = (0, _utils.getUnhandledProps)(Sidenav, props); return React.createElement(SidenavContext.Provider, { value: { expanded: expanded, activeKey: activeKey, sidenav: true, openKeys: this.getOpenKeys(), onOpenChange: this.handleOpenChange, onSelect: this.handleSelect } }, React.createElement(_Transition.default, { in: expanded, timeout: 300, exitedClassName: addPrefix('collapse-out'), exitingClassName: addPrefix(['collapse-out', 'collapsing']), enteredClassName: addPrefix('collapse-in'), enteringClassName: addPrefix(['collapse-in', 'collapsing']) }, function (props, ref) { var className = props.className, rest = (0, _objectWithoutPropertiesLoose2.default)(props, ["className"]); return React.createElement(Component, (0, _extends2.default)({}, rest, unhandled, { ref: ref, className: (0, _classnames.default)(classes, className), role: "navigation" })); })); }; return Sidenav; }(React.Component); Sidenav.propTypes = { classPrefix: _propTypes.default.string, className: _propTypes.default.string, expanded: _propTypes.default.bool, appearance: _propTypes.default.oneOf(['default', 'inverse', 'subtle']), defaultOpenKeys: _propTypes.default.array, openKeys: _propTypes.default.array, onOpenChange: _propTypes.default.func, activeKey: _propTypes.default.any, onSelect: _propTypes.default.func, componentClass: _propTypes.default.elementType }; Sidenav.defaultProps = { appearance: 'default', expanded: true }; var EnhancedSidenav = (0, _utils.defaultProps)({ classPrefix: 'sidenav', componentClass: 'div' })(Sidenav); (0, _recompose.setStatic)('Header', _SidenavHeader.default)(EnhancedSidenav); (0, _recompose.setStatic)('Body', _SidenavBody.default)(EnhancedSidenav); (0, _recompose.setStatic)('Toggle', _SidenavToggle.default)(EnhancedSidenav); var _default = EnhancedSidenav; exports.default = _default;