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

207 lines
22 KiB
JavaScript
Raw Normal View History

2019-07-04 12:10:56 +00:00
import React from 'react';
2019-06-11 12:00:02 +00:00
import styled , { css } from 'styled-components';
2019-07-04 12:10:56 +00:00
import { Icons } from '../icons';
import { getCssFromSvg } from '../icons/get-css-from-svg';
2019-06-11 12:00:02 +00:00
import {TreeNode} from 'rc-tree';
import ReactDOMServer from 'react-dom/server';
2019-06-11 12:00:02 +00:00
var checkboxIcon,
checkboxСheckedIcon,
сheckboxDisabledIcon,
сheckboxHoverIcon,
сheckboxIndeterminateIcon,
checkboxCheckedDisabledIcon,
checkboxCheckedHoverIcon,
checkboxIndeterminateDisabledIcon,
checkboxIndeterminateHoverIcon;
(function(){
checkboxIcon = getCssFromSvg(ReactDOMServer.renderToString(<Icons.CheckboxIcon />));
checkboxСheckedIcon= getCssFromSvg(ReactDOMServer.renderToString(<Icons.CheckboxCheckedIcon />));
сheckboxDisabledIcon = getCssFromSvg(ReactDOMServer.renderToString(<Icons.CheckboxDisabledIcon />));
сheckboxHoverIcon = getCssFromSvg(ReactDOMServer.renderToString(<Icons.CheckboxHoverIcon />));
сheckboxIndeterminateIcon = getCssFromSvg(ReactDOMServer.renderToString(<Icons.CheckboxIndeterminateIcon />));
checkboxCheckedDisabledIcon= getCssFromSvg(ReactDOMServer.renderToString(<Icons.CheckboxCheckedDisabledIcon />));
checkboxCheckedHoverIcon = getCssFromSvg(ReactDOMServer.renderToString(<Icons.CheckboxCheckedHoverIcon />));
checkboxIndeterminateDisabledIcon = getCssFromSvg(ReactDOMServer.renderToString(<Icons.CheckboxIndeterminateDisabledIcon />));
checkboxIndeterminateHoverIcon = getCssFromSvg(ReactDOMServer.renderToString(<Icons.CheckboxIndeterminateHoverIcon />));
}());
2019-06-11 12:00:02 +00:00
const TreeNodeMenu = styled(TreeNode)`
padding: 0;
margin: 0 0 0 0;
list-style: none;
white-space: nowrap;
outline: 0;
font-family: Open Sans;
font-style: normal;
font-weight: 600;
font-size: 14px;
line-height: 24px;
.draggable {
color: #333;
-moz-user-select: none;
-khtml-user-select: none;
-webkit-user-select: none;
-ms-user-select: none;
user-select: none;
/* Required to make elements draggable in old WebKit */
-khtml-user-drag: element;
-webkit-user-drag: element;
2019-06-11 12:00:02 +00:00
}
&.drag-over > .draggable {
background-color: #316ac5;
color: white;
border: 1px #316ac5 solid;
opacity: 0.8;
2019-06-11 12:00:02 +00:00
}
&.drag-over-gap-top > .draggable {
border-top: 2px blue solid;
2019-06-11 12:00:02 +00:00
}
&.drag-over-gap-bottom > .draggable {
border-bottom: 2px blue solid;
2019-06-11 12:00:02 +00:00
}
&.filter-node > .rc-tree-node-content-wrapper {
color: #a60000!important;
font-weight: bold!important;
}
ul {
margin: 0;
padding: 0 0 0 8px;
}
.rc-tree-node-content-wrapper {
width: auto;
max-width: 100%;
display: inline-block;
padding: 1px 5px 0 4px;
margin: 0 0 12px 0;
cursor: pointer;
height: 24px;
text-decoration: none;
vertical-align: top;
}
span.rc-tree-switcher,
span.rc-tree-iconEle {
line-height: 0;
margin-right: 5px;
margin-bottom: 2px;
width: 16px;
height: 16px;
display: inline-block;
vertical-align: top;
border: 0 none;
cursor: pointer;
outline: none;
background-color: transparent;
background-repeat: no-repeat;
background-attachment: scroll;
background-image: url('
}
span.rc-tree-iconEle{
margin: 3px 7px 3px 0px;
height: 17px;
width: 17px;
}
span.rc-tree-switcher{
margin: 9px 4px 0 1px;
height: 8px;
width: 8px;
}
span.rc-tree-switcher.rc-tree-icon__customize,
span.rc-tree-checkbox.rc-tree-icon__customize,
span.rc-tree-iconEle.rc-tree-icon__customize {
background-image: none;
}
span.rc-tree-icon_loading {
margin-right: 2px;
vertical-align: top;
background: url('') no-repeat scroll 0 0 transparent;
}
span.rc-tree-switcher.rc-tree-switcher-noop {
cursor: auto;
}
span.rc-tree-switcher.rc-tree-switcher_open {
background-position: -93px -56px;
}
span.rc-tree-switcher.rc-tree-switcher_close {
background-position: -75px -56px;
}
span.rc-tree-checkbox {
line-height: 16px;
margin-right: 5px;
margin-bottom: 2px;
display: inline-block;
vertical-align: middle;
border: 0 none;
cursor: pointer;
outline: none;
width: 16px;
height: 16px;
margin: 0 3px;
background-repeat: no-repeat;
background-image: url("data:image/svg+xml,${checkboxIcon}");
}
span.rc-tree-checkbox:hover {
background-image: url("data:image/svg+xml,${сheckboxHoverIcon}");
}
span.rc-tree-checkbox.rc-tree-checkbox-checked:hover {
background-image: url("data:image/svg+xml,${checkboxCheckedHoverIcon}");
}
span.rc-tree-checkbox-indeterminate:hover {
background-image: url("data:image/svg+xml,${checkboxIndeterminateHoverIcon}");
}
span.rc-tree-checkbox-checked {
background-image: url("data:image/svg+xml,${checkboxСheckedIcon}");
}
span.rc-tree-checkbox-indeterminate {
background-image: url("data:image/svg+xml,${сheckboxIndeterminateIcon}");
}
span.rc-tree-checkbox-disabled,
span.rc-tree-checkbox-disabled:hover {
background-image: url("data:image/svg+xml,${сheckboxDisabledIcon}");
}
span.rc-tree-checkbox.rc-tree-checkbox-checked.rc-tree-checkbox-disabled {
background-image: url("data:image/svg+xml,${checkboxCheckedDisabledIcon}");
}
span.rc-tree-checkbox.rc-tree-checkbox-indeterminate.rc-tree-checkbox-disabled {
background-image: url("data:image/svg+xml,${checkboxIndeterminateDisabledIcon}");
}
span.rc-tree-checkbox.rc-tree-checkbox-indeterminate.rc-tree-checkbox-disabled::after {
content: ' ';
-webkit-transform: scale(1);
transform: scale(1);
position: absolute;
left: 3px;
top: 5px;
width: 5px;
height: 0;
border: 2px solid #fff;
border-top: 0;
border-left: 0;
}
span.rc-tree-title{
display: inline-block;
width: auto;
max-width: calc(100% - 18px);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.rc-tree-node-selected {
background: #DFE2E3;
mix-blend-mode: normal;
border-radius: 3px;
opacity: 0.8;
2019-06-11 12:00:02 +00:00
}
`;
export default TreeNodeMenu;