UNPKG

rsuite

Version:

A suite of react components

256 lines (208 loc) 8.59 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); exports.__esModule = true; exports.default = void 0; var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _inheritsLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/inheritsLoose")); var React = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _domLib = require("dom-lib"); var _lodash = _interopRequireDefault(require("lodash")); var _classnames = _interopRequireDefault(require("classnames")); var _utils = require("rsuite-utils/lib/utils"); var _utils2 = require("../utils"); var _stringToObject2 = _interopRequireDefault(require("../utils/stringToObject")); var _Picker = require("../Picker"); var DropdownMenu = /*#__PURE__*/ function (_React$Component) { (0, _inheritsLoose2.default)(DropdownMenu, _React$Component); function DropdownMenu() { var _this; for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this; _this.menus = []; _this.handleSelect = function (layer, node, event) { var _this$props = _this.props, onSelect = _this$props.onSelect, childrenKey = _this$props.childrenKey; var children = node[childrenKey]; var isLeafNode = _lodash.default.isUndefined(children) || _lodash.default.isNull(children); var items = (children || []).map(function (item) { return (0, _extends2.default)({}, _this.stringToObject(item), { parent: node }); }); var _this$getCascadeItems = _this.getCascadeItems(items, layer + 1, node, isLeafNode), cascadeItems = _this$getCascadeItems.cascadeItems, cascadePathItems = _this$getCascadeItems.cascadePathItems; onSelect && onSelect(node, cascadeItems, cascadePathItems, isLeafNode, event); }; _this.addPrefix = function (name) { return (0, _utils2.prefix)(_this.props.classPrefix)(name); }; return _this; } var _proto = DropdownMenu.prototype; _proto.componentDidMount = function componentDidMount() { this.scrollToActiveItemTop(); }; _proto.getCascadeItems = function getCascadeItems(items, layer, node, isLeafNode) { var _this$props2 = this.props, _this$props2$cascadeI = _this$props2.cascadeItems, cascadeItems = _this$props2$cascadeI === void 0 ? [] : _this$props2$cascadeI, cascadePathItems = _this$props2.cascadePathItems; var nextItems = []; var nextPathItems = []; for (var i = 0; i < cascadeItems.length && i < layer; i += 1) { nextItems.push(cascadeItems[i]); if (i < layer - 1 && cascadePathItems) { nextPathItems.push(cascadePathItems[i]); } } nextPathItems.push(node); if (!isLeafNode) { nextItems.push(items); } return { cascadeItems: nextItems, cascadePathItems: nextPathItems }; }; _proto.stringToObject = function stringToObject(value) { var _this$props3 = this.props, labelKey = _this$props3.labelKey, valueKey = _this$props3.valueKey; return (0, _stringToObject2.default)(value, labelKey, valueKey); }; _proto.scrollToActiveItemTop = function scrollToActiveItemTop() { var _this2 = this; if (!this.menus) { return; } this.menus.forEach(function (menu) { if (!menu) { return; } var activeItem = menu.querySelector("." + _this2.addPrefix('item-focus')); if (!activeItem) { activeItem = menu.querySelector("." + _this2.addPrefix('item-active')); } if (activeItem) { var position = (0, _domLib.getPosition)(activeItem, menu); (0, _domLib.scrollTop)(menu, position.top); } }); }; _proto.renderCascadeNode = function renderCascadeNode(node, index, layer, focus) { var _this$props4 = this.props, activeItemValue = _this$props4.activeItemValue, valueKey = _this$props4.valueKey, labelKey = _this$props4.labelKey, childrenKey = _this$props4.childrenKey, disabledItemValues = _this$props4.disabledItemValues, renderMenuItem = _this$props4.renderMenuItem; var children = node[childrenKey]; var value = node[valueKey]; var label = node[labelKey]; var disabled = disabledItemValues.some(function (disabledValue) { return (0, _utils.shallowEqual)(disabledValue, value); }); // Use `value` in keys when If `value` is string or number var onlyKey = _lodash.default.isString(value) || _lodash.default.isNumber(value) ? value : index; return React.createElement(_Picker.DropdownMenuItem, { classPrefix: this.addPrefix('item'), key: layer + "-" + onlyKey, disabled: disabled, active: !_lodash.default.isUndefined(activeItemValue) && (0, _utils.shallowEqual)(activeItemValue, value), focus: focus, value: node, className: children ? this.addPrefix('has-children') : undefined, onSelect: this.handleSelect.bind(this, layer) }, renderMenuItem ? renderMenuItem(label, node) : label, children ? React.createElement("span", { className: this.addPrefix('caret') }) : null); }; _proto.renderCascade = function renderCascade() { var _this3 = this; var _this$props5 = this.props, menuWidth = _this$props5.menuWidth, menuHeight = _this$props5.menuHeight, valueKey = _this$props5.valueKey, renderMenu = _this$props5.renderMenu, _this$props5$cascadeI = _this$props5.cascadeItems, cascadeItems = _this$props5$cascadeI === void 0 ? [] : _this$props5$cascadeI, cascadePathItems = _this$props5.cascadePathItems; var styles = { width: cascadeItems.length * menuWidth }; var cascadeNodes = cascadeItems.map(function (children, layer) { var onlyKey = layer + "_" + children.length; var menu = React.createElement("ul", null, children.map(function (item, index) { return _this3.renderCascadeNode(item, index, layer, cascadePathItems[layer] && (0, _utils.shallowEqual)(cascadePathItems[layer][valueKey], item[valueKey])); })); var parentNode = cascadePathItems[layer - 1]; var node = React.createElement("div", { key: onlyKey, className: _this3.addPrefix('column'), ref: function ref(_ref) { _this3.menus[layer] = _ref; }, style: { height: menuHeight, width: menuWidth } }, renderMenu ? renderMenu(children, menu, parentNode) : menu); return node; }); return React.createElement("div", { style: styles }, cascadeNodes); }; _proto.render = function render() { var _this$props6 = this.props, className = _this$props6.className, rest = (0, _objectWithoutPropertiesLoose2.default)(_this$props6, ["className"]); var classes = (0, _classnames.default)(this.addPrefix('items'), className); var unhandled = (0, _utils2.getUnhandledProps)(DropdownMenu, rest); return React.createElement("div", (0, _extends2.default)({}, unhandled, { className: classes }), this.renderCascade()); }; return DropdownMenu; }(React.Component); DropdownMenu.propTypes = { classPrefix: _propTypes.default.string, data: _propTypes.default.array, disabledItemValues: _propTypes.default.array, activeItemValue: _propTypes.default.any, childrenKey: _propTypes.default.string, valueKey: _propTypes.default.string, labelKey: _propTypes.default.string, menuWidth: _propTypes.default.number, menuHeight: _propTypes.default.number, className: _propTypes.default.string, renderMenuItem: _propTypes.default.func, renderMenu: _propTypes.default.func, onSelect: _propTypes.default.func, cascadeItems: _propTypes.default.array, cascadePathItems: _propTypes.default.array }; DropdownMenu.defaultProps = { data: [], disabledItemValues: [], cascadeItems: [], cascadePathItems: [], menuWidth: 120, menuHeight: 200, childrenKey: 'children', valueKey: 'value', labelKey: 'label' }; DropdownMenu.handledProps = []; var _default = DropdownMenu; exports.default = _default; module.exports = exports.default;