You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
130 lines
3.6 KiB
130 lines
3.6 KiB
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
|
|
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
|
|
import React from 'react';
|
|
import toArray from "rc-util/es/Children/toArray";
|
|
import warning from "rc-util/es/warning";
|
|
import TreeNode from '../TreeNode';
|
|
export function convertChildrenToData(nodes) {
|
|
return toArray(nodes).map(function (node) {
|
|
if (!React.isValidElement(node) || !node.type) {
|
|
return null;
|
|
}
|
|
|
|
var key = node.key,
|
|
_node$props = node.props,
|
|
children = _node$props.children,
|
|
value = _node$props.value,
|
|
restProps = _objectWithoutProperties(_node$props, ["children", "value"]);
|
|
|
|
var data = _objectSpread({
|
|
key: key,
|
|
value: value
|
|
}, restProps);
|
|
|
|
var childData = convertChildrenToData(children);
|
|
|
|
if (childData.length) {
|
|
data.children = childData;
|
|
}
|
|
|
|
return data;
|
|
}).filter(function (data) {
|
|
return data;
|
|
});
|
|
}
|
|
export function fillLegacyProps(dataNode) {
|
|
// Skip if not dataNode exist
|
|
if (!dataNode) {
|
|
return dataNode;
|
|
}
|
|
|
|
var cloneNode = _objectSpread({}, dataNode);
|
|
|
|
if (!('props' in cloneNode)) {
|
|
Object.defineProperty(cloneNode, 'props', {
|
|
get: function get() {
|
|
warning(false, 'New `rc-tree-select` not support return node instance as argument anymore. Please consider to remove `props` access.');
|
|
return cloneNode;
|
|
}
|
|
});
|
|
}
|
|
|
|
return cloneNode;
|
|
}
|
|
export function fillAdditionalInfo(extra, triggerValue, checkedValues, treeData, showPosition) {
|
|
var triggerNode = null;
|
|
var nodeList = null;
|
|
|
|
function generateMap() {
|
|
function dig(list) {
|
|
var level = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '0';
|
|
var parentIncluded = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
return list.map(function (dataNode, index) {
|
|
var pos = "".concat(level, "-").concat(index);
|
|
var included = checkedValues.includes(dataNode.value);
|
|
var children = dig(dataNode.children || [], pos, included);
|
|
var node = React.createElement(TreeNode, Object.assign({}, dataNode), children.map(function (child) {
|
|
return child.node;
|
|
})); // Link with trigger node
|
|
|
|
if (triggerValue === dataNode.value) {
|
|
triggerNode = node;
|
|
}
|
|
|
|
if (included) {
|
|
var checkedNode = {
|
|
pos: pos,
|
|
node: node,
|
|
children: children
|
|
};
|
|
|
|
if (!parentIncluded) {
|
|
nodeList.push(checkedNode);
|
|
}
|
|
|
|
return checkedNode;
|
|
}
|
|
|
|
return null;
|
|
}).filter(function (node) {
|
|
return node;
|
|
});
|
|
}
|
|
|
|
if (!nodeList) {
|
|
nodeList = [];
|
|
dig(treeData); // Sort to keep the checked node length
|
|
|
|
nodeList.sort(function (_ref, _ref2) {
|
|
var val1 = _ref.node.props.value;
|
|
var val2 = _ref2.node.props.value;
|
|
var index1 = checkedValues.indexOf(val1);
|
|
var index2 = checkedValues.indexOf(val2);
|
|
return index1 - index2;
|
|
});
|
|
}
|
|
}
|
|
|
|
Object.defineProperty(extra, 'triggerNode', {
|
|
get: function get() {
|
|
warning(false, '`triggerNode` is deprecated. Please consider decoupling data with node.');
|
|
generateMap();
|
|
return triggerNode;
|
|
}
|
|
});
|
|
Object.defineProperty(extra, 'allCheckedNodes', {
|
|
get: function get() {
|
|
warning(false, '`allCheckedNodes` is deprecated. Please consider decoupling data with node.');
|
|
generateMap();
|
|
|
|
if (showPosition) {
|
|
return nodeList;
|
|
}
|
|
|
|
return nodeList.map(function (_ref3) {
|
|
var node = _ref3.node;
|
|
return node;
|
|
});
|
|
}
|
|
});
|
|
} |