feat(增加上、下、左、右、空格快捷键):

This commit is contained in:
wanghaoo 2018-12-19 15:10:15 +08:00
parent cb7e3ebd8b
commit 2a62867341
4 changed files with 164 additions and 10 deletions

File diff suppressed because one or more lines are too long

View File

@ -20,6 +20,8 @@ var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes); var _propTypes2 = _interopRequireDefault(_propTypes);
var _tinperBeeCore = require('tinper-bee-core');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; } function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; }
@ -197,14 +199,30 @@ var Tree = function (_React$Component) {
node: treeNode node: treeNode
}); });
}; };
/**
*
*
* @param {*} treeNode 当前操作的节点
* @param {*} keyType 键盘事件通用的key类型 left 为收起right为展开
* @returns
* @memberof Tree
*/
Tree.prototype.onExpand = function onExpand(treeNode) {
Tree.prototype.onExpand = function onExpand(treeNode, keyType) {
var _this2 = this; var _this2 = this;
var expanded = !treeNode.props.expanded; var expanded = !treeNode.props.expanded;
var controlled = 'expandedKeys' in this.props; var controlled = 'expandedKeys' in this.props;
var expandedKeys = [].concat(_toConsumableArray(this.state.expandedKeys)); var expandedKeys = [].concat(_toConsumableArray(this.state.expandedKeys));
var index = expandedKeys.indexOf(treeNode.props.eventKey); var index = expandedKeys.indexOf(treeNode.props.eventKey);
if (keyType == 'left') {
expanded = false;
} else if (keyType == 'right') {
expanded = true;
}
if (expanded && index === -1) { if (expanded && index === -1) {
expandedKeys.push(treeNode.props.eventKey); expandedKeys.push(treeNode.props.eventKey);
} else if (!expanded && index > -1) { } else if (!expanded && index > -1) {
@ -305,7 +323,7 @@ var Tree = function (_React$Component) {
Tree.prototype.onSelect = function onSelect(treeNode) { Tree.prototype.onSelect = function onSelect(treeNode) {
var props = this.props; var props = this.props;
var selectedKeys = [].concat(_toConsumableArray(this.state.selectedKeys)); var selectedKeys = [].concat(_toConsumableArray(this.state.selectedKeys));
var eventKey = treeNode.props.eventKey; var eventKey = treeNode.props.eventKey || treeNode.key;
var index = selectedKeys.indexOf(eventKey); var index = selectedKeys.indexOf(eventKey);
var selected = void 0; var selected = void 0;
//cancelUnSelect为true时第二次点击时不取消选中 //cancelUnSelect为true时第二次点击时不取消选中
@ -400,11 +418,122 @@ var Tree = function (_React$Component) {
}); });
}; };
Tree.prototype.getTreeNode = function getTreeNode() {
var props = this.props;
};
Tree.prototype.goDown = function goDown(currentPos, currentIndex, e, treeNode) {
var props = this.props;
var nextIndex = parseInt(currentIndex) + 1;
var nextPos = void 0,
backNextPos = void 0;
var nextTreeNode = void 0,
backNextTreeNode = void 0;
//是否为展开的节点,如果展开获取第一个子节点的信息,如果没有取相邻节点,若也没有相邻节点则获取父节点的下一个节点
if (props.expandedKeys.indexOf(treeNode.props.eventKey) > -1) {
nextPos = currentPos + '-0';
} else {
nextPos = currentPos.substr(0, currentPos.lastIndexOf('-') + 1) + nextIndex;
//若向下的节点没有了,找到父级相邻节点
var tempPosArr = currentPos.split('-');
var tempPosArrLength = tempPosArr.length;
backNextPos = tempPosArrLength > 2 && tempPosArr.slice(0, tempPosArrLength - 2).join('-') + '-' + (parseInt(tempPosArr[tempPosArrLength - 2]) + 1);
}
//选中下一个相邻的节点
(0, _util.loopAllChildren)(props.children, function (item, index, pos, newKey) {
if (pos == nextPos) {
nextTreeNode = item;
} else if (backNextPos && pos == backNextPos) {
backNextTreeNode = item;
}
});
//如果没有下一个节点,则获取父节点的下一个节点
if (!nextTreeNode) {
nextTreeNode = backNextTreeNode;
nextPos = backNextPos;
}
//查询的下一个节点不为空的话,则选中
if (nextTreeNode) {
var queryInfo = 'a[pos="' + nextPos + '"]';
var focusEle = e.target.parentElement.parentElement.parentElement.parentElement.querySelector(queryInfo);
focusEle && focusEle.focus();
this.onSelect(nextTreeNode);
}
};
Tree.prototype.goUp = function goUp(currentPos, currentIndex, e, treeNode) {
var props = this.props;
if (currentIndex == 0 && currentPos.length === 3) {
return;
}
// 向上键Up
var preIndex = parseInt(currentIndex) - 1;
var prePos = void 0;
if (preIndex >= 0) {
prePos = currentPos.substr(0, currentPos.lastIndexOf('-') + 1) + preIndex;
} else {
prePos = currentPos.substr(0, currentPos.lastIndexOf('-'));
}
var prevTreeNode = void 0,
preElement = void 0;
//选中上一个相邻的节点
(0, _util.loopAllChildren)(props.children, function (item, index, pos, newKey) {
if (pos == prePos) {
prevTreeNode = item;
}
});
//查询的上一个节点不为空的话,则选中
if (prevTreeNode) {
if (preIndex >= 0) {
//如果上面的节点展开则默认选择最后一个子节点
if (props.expandedKeys.indexOf(prevTreeNode.key) > -1) {
preElement = e.target.parentElement.previousElementSibling.querySelector('ul li:last-child a');
prePos = preElement.getAttribute('pos');
(0, _util.loopAllChildren)(props.children, function (item, index, pos, newKey) {
if (pos == prePos) {
prevTreeNode = item;
}
});
} else {
//上一个节点没有展开
preElement = e.target.parentElement.previousElementSibling.querySelector('a');
}
} else {
// 不存在上一个节点时,选中它的父节点
preElement = e.target.parentElement.parentElement.parentElement.querySelector('a');
}
}
preElement && preElement.focus();
this.onSelect(prevTreeNode);
};
// all keyboard events callbacks run from here at first // all keyboard events callbacks run from here at first
Tree.prototype.onKeyDown = function onKeyDown(e) { Tree.prototype.onKeyDown = function onKeyDown(e, treeNode) {
e.preventDefault(); event.preventDefault();
// console.log('-----'+e.keyCode);
var props = this.props;
var currentPos = treeNode.props.pos;
var currentIndex = currentPos.substr(currentPos.lastIndexOf('-') + 1);
//向下键down
if (e.keyCode == _tinperBeeCore.KeyCode.DOWN) {
this.goDown(currentPos, currentIndex, e, treeNode);
} else if (e.keyCode == _tinperBeeCore.KeyCode.UP) {
this.goUp(currentPos, currentIndex, e, treeNode);
} else if (e.keyCode == _tinperBeeCore.KeyCode.LEFT) {
// 收起树节点
this.onExpand(treeNode, 'left');
} else if (e.keyCode == _tinperBeeCore.KeyCode.RIGHT) {
// 展开树节点
this.onExpand(treeNode, 'right');
} else if (e.keyCode == _tinperBeeCore.KeyCode.SPACE && props.checkable) {
// 如果是多选tree则进行选中或者反选该节点
this.onCheck(treeNode);
}
// e.preventDefault();
}; };
Tree.prototype.getFilterExpandedKeys = function getFilterExpandedKeys(props, expandKeyProp, expandAll) { Tree.prototype.getFilterExpandedKeys = function getFilterExpandedKeys(props, expandKeyProp, expandAll) {
@ -555,6 +684,7 @@ var Tree = function (_React$Component) {
onMouseLeave: props.onMouseLeave, onMouseLeave: props.onMouseLeave,
onRightClick: props.onRightClick, onRightClick: props.onRightClick,
onDoubleClick: props.onDoubleClick, onDoubleClick: props.onDoubleClick,
onKeyDown: props.onKeyDown,
prefixCls: props.prefixCls, prefixCls: props.prefixCls,
showLine: props.showLine, showLine: props.showLine,
showIcon: props.showIcon, showIcon: props.showIcon,
@ -569,7 +699,9 @@ var Tree = function (_React$Component) {
openAnimation: props.openAnimation, openAnimation: props.openAnimation,
filterTreeNode: this.filterTreeNode.bind(this), filterTreeNode: this.filterTreeNode.bind(this),
openIcon: props.openIcon, openIcon: props.openIcon,
closeIcon: props.closeIcon closeIcon: props.closeIcon,
focusable: props.focusable,
tabIndexKey: state.selectedKeys[0]
}; };
if (props.checkable) { if (props.checkable) {
cloneProps.checkable = props.checkable; cloneProps.checkable = props.checkable;
@ -609,8 +741,8 @@ var Tree = function (_React$Component) {
}; };
if (props.focusable) { if (props.focusable) {
domProps.tabIndex = '0'; // domProps.tabIndex = '0';//需求改成了默认选择第一个节点或者选中的节点
domProps.onKeyDown = this.onKeyDown; // domProps.onKeyDown = this.onKeyDown;//添加到具体的treeNode上了
} }
var getTreeNodesStates = function getTreeNodesStates() { var getTreeNodesStates = function getTreeNodesStates() {
_this4.treeNodesStates = {}; _this4.treeNodesStates = {};
@ -705,6 +837,7 @@ Tree.propTypes = {
onDragEnd: _propTypes2["default"].func, onDragEnd: _propTypes2["default"].func,
filterTreeNode: _propTypes2["default"].func, filterTreeNode: _propTypes2["default"].func,
openTransitionName: _propTypes2["default"].string, openTransitionName: _propTypes2["default"].string,
focusable: _propTypes2["default"].bool,
openAnimation: _propTypes2["default"].oneOfType([_propTypes2["default"].string, _propTypes2["default"].object]) openAnimation: _propTypes2["default"].oneOfType([_propTypes2["default"].string, _propTypes2["default"].object])
}; };

View File

@ -12,6 +12,10 @@ var _react = require('react');
var _react2 = _interopRequireDefault(_react); var _react2 = _interopRequireDefault(_react);
var _reactDom = require('react-dom');
var _reactDom2 = _interopRequireDefault(_reactDom);
var _classnames = require('classnames'); var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames); var _classnames2 = _interopRequireDefault(_classnames);
@ -53,7 +57,7 @@ var TreeNode = function (_React$Component) {
var _this2 = _possibleConstructorReturn(this, _React$Component.call(this, props)); var _this2 = _possibleConstructorReturn(this, _React$Component.call(this, props));
['onExpand', 'onCheck', 'onContextMenu', 'onMouseEnter', 'onMouseLeave', 'onDragStart', 'onDragEnter', 'onDragOver', 'onDragLeave', 'onDrop', 'onDragEnd', 'onDoubleClick'].forEach(function (m) { ['onExpand', 'onCheck', 'onContextMenu', 'onMouseEnter', 'onMouseLeave', 'onDragStart', 'onDragEnter', 'onDragOver', 'onDragLeave', 'onDrop', 'onDragEnd', 'onDoubleClick', 'onKeyDown'].forEach(function (m) {
_this2[m] = _this2[m].bind(_this2); _this2[m] = _this2[m].bind(_this2);
}); });
_this2.state = { _this2.state = {
@ -191,6 +195,7 @@ var TreeNode = function (_React$Component) {
TreeNode.prototype.onKeyDown = function onKeyDown(e) { TreeNode.prototype.onKeyDown = function onKeyDown(e) {
this.props.root.onKeyDown(e, this);
e.preventDefault(); e.preventDefault();
}; };
@ -422,9 +427,22 @@ var TreeNode = function (_React$Component) {
domProps.onDragStart = _this4.onDragStart; domProps.onDragStart = _this4.onDragStart;
} }
} }
//设置tabIndex
if (props.focusable) {
domProps.onKeyDown = _this4.onKeyDown;
domProps.tabIndex = -1;
if (props.tabIndexKey) {
if (props.eventKey == props.tabIndexKey) {
domProps.tabIndex = 0;
}
} else if (props.pos == '0-0') {
domProps.tabIndex = 0;
}
}
return _react2["default"].createElement( return _react2["default"].createElement(
'a', 'a',
_extends({ ref: 'selectHandle', title: typeof content === 'string' ? content : '' }, domProps), _extends({ ref: 'selectHandle', pos: props.pos, title: typeof content === 'string' ? content : '' }, domProps),
icon, icon,
title title
); );

View File

@ -1,6 +1,6 @@
{ {
"name": "bee-tree", "name": "bee-tree",
"version": "1.1.6", "version": "1.1.7",
"description": "Tree ui component for react", "description": "Tree ui component for react",
"keywords": [ "keywords": [
"react", "react",