UNPKG

@wufengteam/inputs

Version:

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

371 lines 16.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; } import React, { useState, useEffect } from 'react'; import { Modal, Space, Row, Col, Empty, Tag, Tabs, Checkbox, Tooltip } from 'antd'; import { CloseOutlined, QuestionCircleOutlined } from '@ant-design/icons'; import { wufengController } from '@wufengteam/core'; import { TAG_STYLE, TAG_ICON_STYLE } from './constants'; // @ts-ignore import departIcon from '../../img/depart.png'; import ZeroCodeOrgTree from '../ZeroCodeOrgTree'; import { buildPcUrl } from '../../../utils/tool'; import { formateTreeData, getFirstChar, recursionOrgIds } from '../../tool'; import "./index.css"; import { COLOR_DATA } from '../../constants'; var prefixCls = 'inputs-default-member'; var TabPane = Tabs.TabPane; var AddDepartModal = function AddDepartModal(_ref) { var visible = _ref.visible, departListed = _ref.departListed, checkedList = _ref.checkedList, onCancel = _ref.onCancel, _onOk = _ref.onOk, enableCheckList = _ref.enableCheckList, sRecursive = _ref.sRecursive, isDefaultDepart = _ref.isDefaultDepart, selectType = _ref.selectType; if (!window.appId) { window.appId = sessionStorage.getItem('appId'); } var _useState = useState([]), _useState2 = _slicedToArray(_useState, 2), departTreeData = _useState2[0], setDepartTreeData = _useState2[1]; var _useState3 = useState([]), _useState4 = _slicedToArray(_useState3, 2), sDepartList = _useState4[0], setSDepartList = _useState4[1]; // 选中的部门信息 var _useState5 = useState('depart'), _useState6 = _slicedToArray(_useState5, 2), activeKey = _useState6[0], setActiveKey = _useState6[1]; // 是否展示需要查询的组织的下级组织 var _useState7 = useState(sRecursive), _useState8 = _slicedToArray(_useState7, 2), recursive = _useState8[0], setRecursive = _useState8[1]; // 预览态是包含基础管理模块 var _useState9 = useState(false), _useState10 = _slicedToArray(_useState9, 2), hasPriviewBasic = _useState10[0], setHasPriviewBasic = _useState10[1]; var _useState11 = useState([]), _useState12 = _slicedToArray(_useState11, 2), dynamicCheckedList = _useState12[0], setDynamicCheckedList = _useState12[1]; var _useState13 = useState([]), _useState14 = _slicedToArray(_useState13, 2), childIdFilterList = _useState14[0], setChildIdFilterList = _useState14[1]; useEffect(function () { setSDepartList(departListed); var initOrgIds = []; departListed.forEach(function (item) { var isSonOrg = item.isSonOrg, children = item.children, orgId = item.orgId; initOrgIds.push(orgId); if ("".concat(isSonOrg) === '1') { var checkes = recursionOrgIds(children, recursive === 'T'); initOrgIds = [].concat(_toConsumableArray(initOrgIds), _toConsumableArray(checkes)); } }); setChildIdFilterList(initOrgIds); }, [departListed]); useEffect(function () { setDynamicCheckedList(checkedList); }, [checkedList]); var modalCancel = function modalCancel() { onCancel(); }; var updateTreeData = function updateTreeData(list, key, children) { return list.map(function (node) { if ("".concat(node.key) === "".concat(key)) { return Object.assign(Object.assign({}, node), { children: children }); } if (node.children) { return Object.assign(Object.assign({}, node), { children: updateTreeData(node.children, key, children) }); } return node; }); }; /** * 获取部门数据 */ var getOrgInfoByAsync = function getOrgInfoByAsync(orgId) { wufengController.getAction('getOrgInfoByAsync', orgId).then(function (res) { var data = formateTreeData(res); setDepartTreeData(data); }); }; // 获取预览态是否有基础管理模块 var getIsBasicPriview = function getIsBasicPriview() { wufengController.getAction('getBasicPreviewEnabled').then(function (res) { setHasPriviewBasic(res || false); }); }; useEffect(function () { getOrgInfoByAsync('0'); getIsBasicPriview(); }, []); var loadOrgData = function loadOrgData(_ref2) { var key = _ref2.key, children = _ref2.children; return new Promise(function (resolve) { if (children) { resolve(); return; } wufengController.getAction('getOrgInfoByAsync', key).then(function (res) { var data = formateTreeData(res); setDepartTreeData(function (origin) { return updateTreeData(origin, key, data); }); setTimeout(function () { resolve(); }, 500); }); }); }; // 根据选中的tab页不同拼接不同的地址 var dealPathByTabKey = function dealPathByTabKey() { var retSelectedPage = {}; // 若是预览态无基础管理模块,则无需拼接默认页的路劲了 if ("".concat(hasPriviewBasic) === 'false') { return retSelectedPage; } switch (activeKey) { case 'depart': retSelectedPage.pagePath = '/_frame/base/orgMgr'; retSelectedPage.basicPath = '/orgMgr'; break; case 'member': retSelectedPage.pagePath = '/_frame/base/orgStaff'; retSelectedPage.basicPath = '/orgStaff'; break; case 'part': retSelectedPage.pagePath = '/_frame/base/roleMgr'; retSelectedPage.basicPath = '/roleMgr'; break; default: break; } return retSelectedPage; }; // 跳转到预览页面 var goPriview = function goPriview() { wufengController.getAction('findPreviewUrl', { appId: window === null || window === void 0 ? void 0 : window.appId }).then(function (res) { var resultCode = res.resultCode, resultObject = res.resultObject; if ("".concat(resultCode) === '0') { // PC 端预览地址 // dealPathByTabKey(); var selectedPage = dealPathByTabKey(); var webUrl = buildPcUrl({ urlData: resultObject, appId: window === null || window === void 0 ? void 0 : window.appId, selectedPage: selectedPage }); window.open(webUrl); } }); }; var renderCommonEmpty = function renderCommonEmpty() { var hasSearch = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : undefined; return typeof hasSearch === 'undefined' ? ( /*#__PURE__*/React.createElement(Empty, { description: "\u5F53\u524D\u6682\u672A\u7EF4\u62A4\u7EC4\u7EC7\u4EBA\u5458\u6570\u636E", className: "".concat(prefixCls, "-emptyStyle") }, "".concat(hasPriviewBasic) === 'true' && ( /*#__PURE__*/React.createElement("div", { className: "".concat(prefixCls, "-emptyCusText"), onClick: goPriview }, "\u524D\u5F80\u6DFB\u52A0")))) : ( /*#__PURE__*/React.createElement(Empty, { description: "\u6682\u65E0\u6570\u636E", className: "".concat(prefixCls, "-emptyStyle") })); }; // 绘制tooltip的头部信息 var renderTooltipTitle = function renderTooltipTitle() { return /*#__PURE__*/React.createElement("div", { className: "".concat(prefixCls, "-tooltipLayout") }, /*#__PURE__*/React.createElement("div", null, "\u6DFB\u52A0\u4EBA\u5458\uFF1A\u652F\u6301\u6DFB\u52A0\u7EC4\u7EC7\u3001\u4EBA\u5458\u3001\u89D2\u8272\u3001\u7FA4\u7EC4\u76F8\u5173\u7684\u6570\u636E\uFF0C\u53EF\u4F5C\u4E3A\u5E94\u7528\u6743\u9650\u5206\u914D\u4EE5\u53CA\u6D41\u7A0B\u73AF\u8282\u5904\u7406\u4EBA\u7B49\u76F8\u5173\u9A8C\u8BC1\u8C03\u8BD5\u4F7F\u7528\u3002\u8C03\u8BD5\u5B8C\u6210\u5E76\u6295\u5165\u4F7F\u7528\u65F6\u9700\u5C06\u6B64\u5904\u6DFB\u52A0\u7684\u7EC4\u7EC7\u3001\u4EBA\u5458\u3001\u89D2\u8272\u7B49\u76F8\u5173\u6570\u636E\u540C\u6B65\u81F3\u4F7F\u7528\u5E73\u53F0\uFF0C\u4FDD\u8BC1\u9875\u9762\u4EE5\u53CA\u6D41\u7A0B\u7684\u6B63\u5E38\u4F7F\u7528\u3002"), /*#__PURE__*/React.createElement("div", { className: "".concat(prefixCls, "-toolTipText") }, '注:组织人员添加入口也可通过:应用预览>>基础管理(组织管理/员工管理等)')); }; // 自定义modal的头部 var renderTitle = function renderTitle() { return /*#__PURE__*/React.createElement("div", { className: "".concat(prefixCls, "-mTitleLayout") }, /*#__PURE__*/React.createElement("div", { className: "".concat(prefixCls, "-mTitle") }, "\u6DFB\u52A0\u90E8\u95E8"), /*#__PURE__*/React.createElement("div", { className: "".concat(prefixCls, "-mTitleRight") }, "".concat(hasPriviewBasic) === 'true' && ( /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", { className: "".concat(prefixCls, "-mRightText") }, /*#__PURE__*/React.createElement("div", { className: "".concat(prefixCls, "-mRightMargin"), onClick: goPriview }, '>>添加调试数据'), /*#__PURE__*/React.createElement(Tooltip, { title: renderTooltipTitle() }, /*#__PURE__*/React.createElement(QuestionCircleOutlined, null))))), /*#__PURE__*/React.createElement(CloseOutlined, { className: "".concat(prefixCls, "-mRightClose"), onClick: modalCancel }))); }; var onDynamicChange = function onDynamicChange(checkedValues) { if (isDefaultDepart && selectType === 'single' && (sDepartList === null || sDepartList === void 0 ? void 0 : sDepartList.length) > 0) { setSDepartList([]); } // 确保只有一个被选中 if (checkedValues.length > 1) { // 如果用户尝试选中多个,只保留最后一个选中的 var data = checkedValues.filter(function (item) { return !dynamicCheckedList.includes(item); }); setDynamicCheckedList(data); } else { setDynamicCheckedList(checkedValues); } }; return /*#__PURE__*/React.createElement(Modal, { className: "".concat(prefixCls, "-addMember-modal"), title: renderTitle(), closable: false, width: 1041, bodyStyle: { padding: '0', height: '510px' }, visible: visible, onCancel: modalCancel, maskClosable: false, onOk: function onOk() { if (_onOk) { _onOk({ sDepartList: sDepartList, dynamicCheckedList: dynamicCheckedList, recursive: recursive, childIdFilterList: childIdFilterList }); } } }, /*#__PURE__*/React.createElement(Row, { style: { height: '100%' } }, /*#__PURE__*/React.createElement(Col, { span: 16, className: "".concat(prefixCls, "-itemPadding") }, /*#__PURE__*/React.createElement(Tabs, { activeKey: activeKey, onChange: function onChange(sKey) { return setActiveKey(sKey); } }, /*#__PURE__*/React.createElement(TabPane, { tab: "\u90E8\u95E8", key: "depart" }, /*#__PURE__*/React.createElement(ZeroCodeOrgTree, { hasSearch: false, emptyNode: renderCommonEmpty(), initValues: sDepartList, loadData: loadOrgData, treeData: departTreeData, recursive: recursive, onCheck: function onCheck(orgData, checkedKeys) { if (isDefaultDepart && selectType === 'single' && (dynamicCheckedList === null || dynamicCheckedList === void 0 ? void 0 : dynamicCheckedList.length) > 0) { setDynamicCheckedList([]); } if (isDefaultDepart && selectType === 'single') { var departTemp = orgData[(orgData === null || orgData === void 0 ? void 0 : orgData.length) - 1]; setSDepartList(departTemp !== undefined ? [departTemp] : []); } else { setSDepartList(orgData); } setChildIdFilterList(checkedKeys); }, checkAllChange: function checkAllChange(checkAll) { setRecursive(checkAll ? 'T' : 'F'); }, enableCheckList: enableCheckList })), /*#__PURE__*/React.createElement(TabPane, { tab: "\u52A8\u6001\u53C2\u6570", key: "dynamic" }, /*#__PURE__*/React.createElement(Checkbox.Group, { onChange: onDynamicChange, value: dynamicCheckedList, className: "dynamicCheckWrap" }, /*#__PURE__*/React.createElement(Space, { direction: "vertical" }, /*#__PURE__*/React.createElement(Checkbox, { value: "T" }, "\u5F53\u524D\u7528\u6237\u6240\u5904\u90E8\u95E8")))))), /*#__PURE__*/React.createElement(Col, { span: 8, className: "".concat(prefixCls, "-colItem"), style: { paddingTop: '16px' } }, /*#__PURE__*/React.createElement(Row, { justify: "end" }, /*#__PURE__*/React.createElement("a", { onClick: function onClick() { setSDepartList([]); setDynamicCheckedList([]); } }, "\u6E05\u9664")), console.log('sDepartList', sDepartList), /*#__PURE__*/React.createElement(Space, { size: 4, wrap: true, style: { maxHeight: '100%', overflow: 'auto', alignItems: 'start' } }, sDepartList.map(function (dItem, posIndex) { var orgId = dItem.orgId, orgName = dItem.orgName, isSonOrg = dItem.isSonOrg; return /*#__PURE__*/React.createElement(Tag, { key: orgId, icon: /*#__PURE__*/React.createElement("div", { style: { background: COLOR_DATA[posIndex % 8] }, className: "".concat(prefixCls, "-iconBg") }, getFirstChar(orgName)), closable: true, style: TAG_STYLE, onClose: function onClose() { var otherDepartInfo = sDepartList.filter(function (it) { return it.orgId !== orgId; }); setSDepartList(otherDepartInfo); } }, "".concat(isSonOrg) === '1' ? "".concat(orgName, "(\u542B\u5B50\u90E8\u95E8)") : orgName); }), dynamicCheckedList === null || dynamicCheckedList === void 0 ? void 0 : dynamicCheckedList.map(function (_) { return /*#__PURE__*/React.createElement(Tag, { icon: /*#__PURE__*/React.createElement("img", { src: departIcon, alt: "", style: TAG_ICON_STYLE }), closable: true, style: TAG_STYLE, onClose: function onClose() { setDynamicCheckedList([]); } }, "\u5F53\u524D\u7528\u6237\u6240\u5904\u90E8\u95E8"); }))))); }; export default AddDepartModal;