@wufengteam/inputs
Version:
平台提供的右侧属性编辑器,需要在主工程中注册
226 lines • 10.2 kB
JavaScript
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
/* eslint-disable react/no-unused-prop-types */
import React, { useState, useEffect } from 'react';
import { Tree, Space, Input, Checkbox, Empty } from 'antd';
import difference from 'lodash.difference';
import { formateTreeData } from '../../tool';
import "./index.css";
var Search = Input.Search;
var prefixCls = ' inputs-default-org';
var ZeroCodeOrgTree = function ZeroCodeOrgTree(_ref) {
var treeData = _ref.treeData,
onSearch = _ref.onSearch,
_ref$initValues = _ref.initValues,
initValues = _ref$initValues === void 0 ? [] : _ref$initValues,
_onCheck = _ref.onCheck,
_ref$checkable = _ref.checkable,
checkable = _ref$checkable === void 0 ? true : _ref$checkable,
_ref$selectedKeys = _ref.selectedKeys,
selectedKeys = _ref$selectedKeys === void 0 ? [] : _ref$selectedKeys,
_onSelect = _ref.onSelect,
_ref$hasSearch = _ref.hasSearch,
hasSearch = _ref$hasSearch === void 0 ? true : _ref$hasSearch,
loadData = _ref.loadData,
_ref$height = _ref.height,
height = _ref$height === void 0 ? 360 : _ref$height,
_ref$emptyNode = _ref.emptyNode,
emptyNode = _ref$emptyNode === void 0 ? /*#__PURE__*/React.createElement(Empty, {
description: "\u6682\u65E0\u90E8\u95E8\u6570\u636E"
}) : _ref$emptyNode,
checkAllChange = _ref.checkAllChange;
var _useState = useState([]),
_useState2 = _slicedToArray(_useState, 2),
sOrgList = _useState2[0],
setSOrgtList = _useState2[1]; // 展示,传给后端的数据
var _useState3 = useState([]),
_useState4 = _slicedToArray(_useState3, 2),
checkedKeys = _useState4[0],
setCheckedKeys = _useState4[1]; // 组织不受控,实际的选择人数
var _useState5 = useState(false),
_useState6 = _slicedToArray(_useState5, 2),
checkedAll = _useState6[0],
setCheckedAll = _useState6[1];
/**
* 递归返回部门ID
* @param children
* @returns
*/
var recursionOrgIds = function recursionOrgIds(children) {
if (children && Array.isArray(children) && checkedAll) {
var allOrgIds = [];
children.forEach(function (item) {
var orgId = item.orgId,
_item$children = item.children,
hasChildren = _item$children === void 0 ? [] : _item$children;
if (hasChildren && Array.isArray(hasChildren) && hasChildren.length) {
allOrgIds = [].concat(_toConsumableArray(recursionOrgIds(hasChildren)), _toConsumableArray(allOrgIds));
}
allOrgIds.push(orgId);
});
return allOrgIds;
}
return [];
};
useEffect(function () {
setSOrgtList(initValues);
var initOrgIds = [];
initValues.forEach(function (item) {
var isSonOrg = item.isSonOrg,
children = item.children,
orgId = item.orgId;
initOrgIds.push(orgId);
if ("".concat(isSonOrg) === '1') {
var checkes = recursionOrgIds(children);
initOrgIds = [].concat(_toConsumableArray(initOrgIds), _toConsumableArray(checkes));
}
});
setCheckedKeys(initOrgIds);
}, [JSON.stringify(initValues)]);
/**
* 递归返回全部数据
* @param children
* @returns
*/
var recursionOrgData = function recursionOrgData(children, checkedIds, curOrgId) {
if (children && Array.isArray(children)) {
var orgData = [];
children.forEach(function (item) {
var _item$children2 = item.children,
hasChildren = _item$children2 === void 0 ? [] : _item$children2,
orgId = item.orgId;
if (hasChildren && Array.isArray(hasChildren) && hasChildren.length) {
orgData = [].concat(_toConsumableArray(recursionOrgData(hasChildren)), _toConsumableArray(orgData));
}
if (checkedIds && Array.isArray(checkedIds) && !checkedIds.includes(orgId) && orgId !== curOrgId) {
orgData.push(item);
}
});
return orgData;
}
return [];
};
var formateAllTreeData = function formateAllTreeData(cKeys, node) {
var checked = node.checked,
children = node.children;
if (!checked) {
// 选中
var orgIds = recursionOrgIds(children);
setCheckedKeys(cKeys.concat(orgIds));
} else {
// 取消
// eslint-disable-next-line no-lonely-if
if (checkedAll) {
// 包含子部门的情况
var childrenIds = recursionOrgIds(children);
var otherOrgIds = difference(cKeys, childrenIds);
setCheckedKeys(otherOrgIds);
} else {
setCheckedKeys(cKeys);
}
}
};
var maxHeight = height || (hasSearch ? '360px' : '410px');
return /*#__PURE__*/React.createElement(Space, {
direction: "vertical",
style: {
width: '100%'
}
}, /*#__PURE__*/React.createElement("div", {
className: "".concat(prefixCls, "-checkbox"),
style: {
textAlign: 'right',
paddingBottom: '6px',
borderBottom: 'solid 1px #E5E5E5',
marginBottom: '6px'
}
}, /*#__PURE__*/React.createElement(Checkbox, {
checked: checkedAll,
onChange: function onChange(e) {
setCheckedAll(e.target.checked);
if (checkAllChange) {
checkAllChange(e.target.checked);
}
}
}, "\u5305\u542B\u8BE5\u90E8\u95E8\u53CA\u5B50\u90E8\u95E8")), hasSearch && /*#__PURE__*/React.createElement(Search, {
onSearch: onSearch
}), treeData && treeData.length ? ( /*#__PURE__*/React.createElement(Tree, {
checkStrictly: true,
style: {
maxHeight: maxHeight,
overflow: 'auto'
},
checkable: checkable,
checkedKeys: checkedKeys,
treeData: formateTreeData(treeData),
onCheck: function onCheck(cKeys, info) {
var node = info.node,
nodeChecked = info.checked;
formateAllTreeData(cKeys === null || cKeys === void 0 ? void 0 : cKeys.checked, node);
var checkedOrgData = sOrgList;
var _node$orgId = node.orgId,
orgId = _node$orgId === void 0 ? '' : _node$orgId,
_node$parentOrgId = node.parentOrgId,
parentOrgId = _node$parentOrgId === void 0 ? '' : _node$parentOrgId;
if (nodeChecked) {
// 选中当前节点
var otherOrgs = sOrgList.filter(function (item) {
return item.orgId !== orgId;
});
var orgObj = Object.assign(Object.assign({}, node), {
// isSonOrg: checkedAll && children && children.length ? 1 : 0,
isSonOrg: checkedAll ? 1 : 0
});
otherOrgs.push(orgObj);
checkedOrgData = otherOrgs;
} else {
// 取消的情况
var _otherOrgs = sOrgList.filter(function (item) {
return item.orgId !== orgId;
});
var checkedOrgs = _otherOrgs;
if (checkedAll) {
// 有包含的情况,如果是父节点,则去掉所有的字节点
checkedOrgs = _otherOrgs.filter(function (item) {
return item.parentOrgId !== orgId;
});
}
var parentOrgObj = checkedOrgs.find(function (item) {
return item.orgId === parentOrgId;
});
var hasChildren = [];
if (parentOrgObj) {
// 有包含子节点,去掉子节点时,需要将isSonOrg设置为0
parentOrgObj.isSonOrg = 0;
if (parentOrgObj === null || parentOrgObj === void 0 ? void 0 : parentOrgObj.children) {
var checkedIds = sOrgList.map(function (item) {
return item.orgId;
});
hasChildren = recursionOrgData(parentOrgObj === null || parentOrgObj === void 0 ? void 0 : parentOrgObj.children, checkedIds, orgId);
}
}
checkedOrgData = [].concat(_toConsumableArray(checkedOrgs), _toConsumableArray(hasChildren));
}
setSOrgtList(checkedOrgData);
if (_onCheck) {
_onCheck(checkedOrgData);
}
},
selectedKeys: selectedKeys,
onSelect: function onSelect(sKeys) {
if (sKeys && sKeys.length && _onSelect) {
_onSelect(sKeys, checkedAll);
}
},
loadData: loadData
})) : emptyNode);
};
export default ZeroCodeOrgTree;