UNPKG

@wufengteam/inputs

Version:

平台提供的右侧属性编辑器,需要在主工程中注册

226 lines 10.2 kB
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;