| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163 |
- "use strict";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.convertChildrenToData = convertChildrenToData;
- exports.fillAdditionalInfo = fillAdditionalInfo;
- exports.fillLegacyProps = fillLegacyProps;
- var _vue = require("vue");
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
- var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
- var _propsUtil = require("../../_util/props-util");
- var _warning = require("../../vc-util/warning");
- var _TreeNode = _interopRequireDefault(require("../TreeNode"));
- var _excluded = ["title", "switcherIcon"];
- function isTreeSelectNode(node) {
- return node && node.type && node.type.isTreeSelectNode;
- }
- function convertChildrenToData(rootNodes) {
- function dig() {
- var treeNodes = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
- return (0, _propsUtil.filterEmpty)(treeNodes).map(function (treeNode) {
- var _slots$title, _slots$switcherIcon, _slots$default;
- // Filter invalidate node
- if (!isTreeSelectNode(treeNode)) {
- (0, _warning.warning)(!treeNode, 'TreeSelect/TreeSelectNode can only accept TreeSelectNode as children.');
- return null;
- }
- var slots = treeNode.children || {};
- var key = treeNode.key;
- var props = {};
- for (var _i = 0, _Object$entries = Object.entries(treeNode.props); _i < _Object$entries.length; _i++) {
- var _Object$entries$_i = (0, _slicedToArray2.default)(_Object$entries[_i], 2),
- k = _Object$entries$_i[0],
- v = _Object$entries$_i[1];
- props[(0, _vue.camelize)(k)] = v;
- }
- var isLeaf = props.isLeaf,
- checkable = props.checkable,
- selectable = props.selectable,
- disabled = props.disabled,
- disableCheckbox = props.disableCheckbox;
- // 默认值为 undefined
- var newProps = {
- isLeaf: isLeaf || isLeaf === '' || undefined,
- checkable: checkable || checkable === '' || undefined,
- selectable: selectable || selectable === '' || undefined,
- disabled: disabled || disabled === '' || undefined,
- disableCheckbox: disableCheckbox || disableCheckbox === '' || undefined
- };
- var slotsProps = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, props), newProps);
- var _props$title = props.title,
- title = _props$title === void 0 ? (_slots$title = slots.title) === null || _slots$title === void 0 ? void 0 : _slots$title.call(slots, slotsProps) : _props$title,
- _props$switcherIcon = props.switcherIcon,
- switcherIcon = _props$switcherIcon === void 0 ? (_slots$switcherIcon = slots.switcherIcon) === null || _slots$switcherIcon === void 0 ? void 0 : _slots$switcherIcon.call(slots, slotsProps) : _props$switcherIcon,
- rest = (0, _objectWithoutProperties2.default)(props, _excluded);
- var children = (_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots);
- var dataNode = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, rest), {}, {
- title: title,
- switcherIcon: switcherIcon,
- key: key,
- isLeaf: isLeaf
- }, newProps);
- var parsedChildren = dig(children);
- if (parsedChildren.length) {
- dataNode.children = parsedChildren;
- }
- return dataNode;
- });
- }
- return dig(rootNodes);
- }
- function fillLegacyProps(dataNode) {
- // Skip if not dataNode exist
- if (!dataNode) {
- return dataNode;
- }
- var cloneNode = (0, _objectSpread2.default)({}, dataNode);
- if (!('props' in cloneNode)) {
- Object.defineProperty(cloneNode, 'props', {
- get: function get() {
- (0, _warning.warning)(false, 'New `vc-tree-select` not support return node instance as argument anymore. Please consider to remove `props` access.');
- return cloneNode;
- }
- });
- }
- return cloneNode;
- }
- function fillAdditionalInfo(extra, triggerValue, checkedValues, treeData, showPosition, fieldNames) {
- 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 (option, index) {
- var pos = "".concat(level, "-").concat(index);
- var value = option[fieldNames.value];
- var included = checkedValues.includes(value);
- var children = dig(option[fieldNames.children] || [], pos, included);
- var node = (0, _vue.createVNode)(_TreeNode.default, option, {
- default: function _default() {
- return [children.map(function (child) {
- return child.node;
- })];
- }
- });
- // Link with trigger node
- if (triggerValue === 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() {
- (0, _warning.warning)(false, '`triggerNode` is deprecated. Please consider decoupling data with node.');
- generateMap();
- return triggerNode;
- }
- });
- Object.defineProperty(extra, 'allCheckedNodes', {
- get: function get() {
- (0, _warning.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;
- });
- }
- });
- }
|