UNPKG

@alifd/next

Version:

A configurable component library for web built on React.

228 lines (176 loc) 7.36 kB
'use strict'; exports.__esModule = true; exports.default = undefined; var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); var _class, _temp; var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _icon = require('../../icon'); var _icon2 = _interopRequireDefault(_icon); var _util = require('../../util'); var _item = require('./item'); var _item2 = _interopRequireDefault(_item); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var bindCtx = _util.func.bindCtx; var pickOthers = _util.obj.pickOthers; /** * Menu.Item * @order 0 */ var SelectableItem = (_temp = _class = function (_Component) { (0, _inherits3.default)(SelectableItem, _Component); function SelectableItem(props) { (0, _classCallCheck3.default)(this, SelectableItem); var _this = (0, _possibleConstructorReturn3.default)(this, _Component.call(this, props)); bindCtx(_this, ['handleKeyDown', 'handleClick']); return _this; } SelectableItem.prototype.getSelected = function getSelected() { var _props = this.props, _key = _props._key, root = _props.root, selected = _props.selected; var selectMode = root.props.selectMode; var selectedKeys = root.state.selectedKeys; return selected || !!selectMode && selectedKeys.indexOf(_key) > -1; }; SelectableItem.prototype.handleSelect = function handleSelect(e) { var _props2 = this.props, _key = _props2._key, root = _props2.root, onSelect = _props2.onSelect; if (onSelect) { onSelect(!this.getSelected(), this, e); } else { root.handleSelect(_key, !this.getSelected(), this); } }; SelectableItem.prototype.handleKeyDown = function handleKeyDown(e) { if (e.keyCode === _util.KEYCODE.SPACE && !this.props.disabled) { this.handleSelect(e); } this.props.onKeyDown && this.props.onKeyDown(e); }; SelectableItem.prototype.handleClick = function handleClick(e) { this.handleSelect(e); this.props.onClick && this.props.onClick(e); }; SelectableItem.prototype.renderSelectedIcon = function renderSelectedIcon(selected) { var _cx; var _props3 = this.props, root = _props3.root, inlineIndent = _props3.inlineIndent, needIndent = _props3.needIndent, hasSelectedIcon = _props3.hasSelectedIcon, isSelectIconRight = _props3.isSelectIconRight, type = _props3.type; var _root$props = root.props, prefix = _root$props.prefix, rootSelectedIcon = _root$props.hasSelectedIcon, rootSelectIconRight = _root$props.isSelectIconRight, icons = _root$props.icons; var iconsSelect = icons.select; if (!(0, _react.isValidElement)(icons.select) && icons.select) { iconsSelect = _react2.default.createElement( 'span', null, icons.select ); } var cls = (0, _classnames2.default)((_cx = {}, _cx[prefix + 'menu-icon-selected'] = true, _cx[prefix + 'menu-symbol-icon-selected'] = !iconsSelect, _cx[prefix + 'menu-icon-right'] = ('isSelectIconRight' in this.props ? isSelectIconRight : rootSelectIconRight) && type !== 'submenu', _cx)); return ('hasSelectedIcon' in this.props ? hasSelectedIcon : rootSelectedIcon) && selected ? _react2.default.cloneElement(iconsSelect || _react2.default.createElement(_icon2.default, { type: 'select' }), { style: needIndent && inlineIndent > 0 ? { left: inlineIndent + 'px' } : null, className: cls }) : null; }; SelectableItem.prototype.render = function render() { var _cx2; var _props4 = this.props, _key = _props4._key, root = _props4.root, className = _props4.className, disabled = _props4.disabled, helper = _props4.helper, children = _props4.children, needIndent = _props4.needIndent; var prefix = root.props.prefix; var others = pickOthers(Object.keys(SelectableItem.propTypes), this.props); var selected = this.getSelected(); var newProps = (0, _extends3.default)({ _key: _key, root: root, disabled: disabled, type: 'item', className: (0, _classnames2.default)((_cx2 = {}, _cx2[prefix + 'selected'] = selected, _cx2[className] = !!className, _cx2)), onKeyDown: this.handleKeyDown, onClick: !disabled ? this.handleClick : this.props.onClick, needIndent: needIndent }, others); if (!('title' in newProps) && typeof children === 'string') { newProps.title = children; } var textProps = {}; if ('selectMode' in root.props) { textProps['aria-selected'] = selected; } return _react2.default.createElement( _item2.default, newProps, this.renderSelectedIcon(selected), _react2.default.createElement( 'span', (0, _extends3.default)({ className: prefix + 'menu-item-text' }, textProps), children ), helper ? _react2.default.createElement( 'div', { className: prefix + 'menu-item-helper' }, helper ) : null ); }; return SelectableItem; }(_react.Component), _class.menuChildType = 'item', _class.propTypes = { _key: _propTypes2.default.string, root: _propTypes2.default.object, selected: _propTypes2.default.bool, onSelect: _propTypes2.default.func, inlineIndent: _propTypes2.default.number, /** * 是否禁用 */ disabled: _propTypes2.default.bool, /** * 帮助文本 */ helper: _propTypes2.default.node, /** * 菜单项标签内容 */ children: _propTypes2.default.node, className: _propTypes2.default.string, onKeyDown: _propTypes2.default.func, onClick: _propTypes2.default.func, needIndent: _propTypes2.default.bool, hasSelectedIcon: _propTypes2.default.bool, isSelectIconRight: _propTypes2.default.bool, icons: _propTypes2.default.object }, _class.defaultProps = { disabled: false, needIndent: true, icons: {} }, _temp); SelectableItem.displayName = 'SelectableItem'; exports.default = SelectableItem; module.exports = exports['default'];