@wufengteam/wform
Version:
@wufengteam/wform
136 lines • 6.41 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; }
import React, { useState } from 'react';
import { Tree, Space, Checkbox, Empty } from 'antd';
var cChecked = false;
var DeptTree = function DeptTree(_ref) {
var treeData = _ref.treeData,
_ref$selectedKeys = _ref.selectedKeys,
selectedKeys = _ref$selectedKeys === void 0 ? [] : _ref$selectedKeys,
_onSelect = _ref.onSelect,
loadData = _ref.loadData,
onCheckChange = _ref.onCheckChange;
var _useState = useState(false),
_useState2 = _slicedToArray(_useState, 2),
checkedAll = _useState2[0],
setCheckedAll = _useState2[1];
var _useState3 = useState([]),
_useState4 = _slicedToArray(_useState3, 2),
loadedKeys = _useState4[0],
setLoadedKeys = _useState4[1];
var _useState5 = useState([]),
_useState6 = _slicedToArray(_useState5, 2),
expandedKeys = _useState6[0],
setExpandedKeys = _useState6[1];
/**
* 递归返回部门ID
* @param children
* @returns
*/
var recursionOrgIds = function recursionOrgIds(children) {
if (children && Array.isArray(children) && cChecked) {
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 [];
};
/**
* 递归返回全部数据
* @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 treeOnLoad = function treeOnLoad(lKey) {
setLoadedKeys(lKey);
};
var treeOnExpand = function treeOnExpand(keys) {
var newLoadKeys = loadedKeys;
// 判断当前是展开还是收起节点,当前展开的长度比之前的少,说明是收起。
if (expandedKeys.length > keys.length) {
// 当是收起的时候,把这个收起的节点从loadedKeys中移除
newLoadKeys = loadedKeys.filter(function (i) {
return keys.includes(i);
});
}
setExpandedKeys(keys);
setLoadedKeys(newLoadKeys);
};
return /*#__PURE__*/React.createElement(Space, {
direction: "vertical",
style: {
width: '100%',
height: '100%'
}
}, /*#__PURE__*/React.createElement("div", {
style: {
textAlign: 'right',
paddingBottom: '6px',
borderBottom: 'solid 1px #E5E5E5',
marginBottom: '6px',
justifyContent: 'flex-start'
}
}, /*#__PURE__*/React.createElement(Checkbox, {
checked: checkedAll,
onChange: function onChange(e) {
setCheckedAll(e.target.checked);
cChecked = e.target.checked;
if (onCheckChange) {
onCheckChange(e.target.checked);
}
}
}, "\u5305\u542B\u8BE5\u90E8\u95E8\u53CA\u5B50\u90E8\u95E8")), treeData && treeData.length ? ( /*#__PURE__*/React.createElement(Tree, {
style: {
maxHeight: '335px',
overflow: 'auto'
},
treeData: treeData,
selectedKeys: selectedKeys,
onSelect: function onSelect(sKeys) {
if (sKeys && sKeys.length && _onSelect) {
_onSelect(sKeys, cChecked);
}
},
loadData: loadData,
onLoad: treeOnLoad,
onExpand: treeOnExpand,
expandedKeys: expandedKeys,
loadedKeys: loadedKeys
})) : ( /*#__PURE__*/React.createElement(Empty, {
description: "\u6682\u65E0\u90E8\u95E8\u6570\u636E"
})));
};
export default DeptTree;