DocSpace-client/web/ASC.Web.Components/src/components/tree-menu/index.js

139 lines
3.9 KiB
JavaScript
Raw Normal View History

2019-06-11 12:00:02 +00:00
import React from 'react';
import styled, { css } from 'styled-components';
import PropTypes from 'prop-types';
import Tree from 'rc-tree';
const StyledTreeMenu = styled(Tree)`
margin: 0;
padding: 5px;
2019-06-11 12:00:02 +00:00
&:not(.rc-tree-show-line) .rc-tree-switcher-noop {
background: none;
}
&.rc-tree-show-line li:not(:last-child) > ul {
background: url('') 0 0 repeat-y;
}
&.rc-tree-show-line li:not(:last-child) > .rc-tree-switcher-noop {
background-position: -56px -18px;
}
&.rc-tree-show-line li:last-child > .rc-tree-switcher-noop {
background-position: -56px -36px;
}
.rc-tree-child-tree {
display: none;
}
.rc-tree-child-tree-open {
display: block;
}
.rc-tree-treenode-disabled > span:not(.rc-tree-switcher),
.rc-tree-treenode-disabled > a,
.rc-tree-treenode-disabled > a span {
color: #767676;
cursor: not-allowed;
}
.rc-tree-icon__open {
margin-right: 2px;
background-position: -110px -16px;
vertical-align: top;
}
.rc-tree-icon__close {
margin-right: 2px;
background-position: -110px 0;
vertical-align: top;
}
.rc-tree-icon__docu {
margin-right: 2px;
background-position: -110px -32px;
vertical-align: top;
}
.rc-tree-icon__customize {
margin-right: 2px;
vertical-align: top;
}
${props => props.switcherIcon != null ?
css`
li span.rc-tree-switcher{
background: none;
}
`
: ''
}
2019-06-11 12:00:02 +00:00
`;
const TreeMenu = props => {
//console.log("TreeMenu render");
2019-06-11 12:00:02 +00:00
const { defaultExpandAll, defaultExpandParent, showIcon, showLine, multiple, disabled, draggable, checkable, children, switcherIcon, icon,
2019-08-13 07:10:46 +00:00
onDragStart, onDrop, onSelect, onDragEnter, onDragEnd, onDragLeave, onDragOver, onCheck, onExpand, onLoad, onMouseEnter, onMouseLeave, onRightClick,
2019-08-30 10:56:43 +00:00
defaultSelectedKeys, defaultExpandedKeys, defaultCheckedKeys, selectedKeys} = props;
2019-09-06 09:15:54 +00:00
const onTreeNodeSelect = (data, e) => {
const result = e.selected ? data : [e.node.props.eventKey];
onSelect(result, e);
}
2019-06-11 12:00:02 +00:00
return (
<StyledTreeMenu
checkable = {!!checkable}
draggable = {!!draggable}
disabled = {!!disabled}
multiple = {!!multiple}
showLine = {!!showLine}
showIcon = {!!showIcon}
defaultExpandAll = {!!defaultExpandAll}
defaultExpandParent = {!!defaultExpandParent}
icon = {icon}
2019-08-30 10:56:43 +00:00
selectedKeys={selectedKeys}
2019-08-13 07:10:46 +00:00
defaultSelectedKeys={defaultSelectedKeys}
defaultExpandedKeys={defaultExpandedKeys}
defaultCheckedKeys={defaultCheckedKeys}
2019-06-11 12:00:02 +00:00
onDragStart={onDragStart}
onDrop={onDrop}
onDragEnd={onDragEnd}
onDragLeave={onDragLeave}
onDragOver={onDragOver}
switcherIcon = {switcherIcon}
2019-09-06 09:15:54 +00:00
onSelect={onTreeNodeSelect}
2019-06-11 12:00:02 +00:00
onDragEnter={onDragEnter}
onCheck={onCheck}
onExpand={onExpand}
onLoad={onLoad}
onMouseEnter={onMouseEnter}
onMouseLeave={onMouseLeave}
onRightClick={onRightClick}
>
{children}
</StyledTreeMenu>
);
}
TreeMenu.propTypes = {
checkable: PropTypes.bool,
draggable: PropTypes.bool,
disabled: PropTypes.bool,
multiple: PropTypes.bool,
showIcon: PropTypes.bool,
showLine: PropTypes.bool,
defaultExpandAll: PropTypes.bool,
defaultExpandParent: PropTypes.bool,
icon: PropTypes.func,
onDragStart: PropTypes.func,
onDrop: PropTypes.func,
children: PropTypes.oneOfType([
PropTypes.arrayOf(PropTypes.node),
PropTypes.node
])
}
export default TreeMenu