Commit 08310f08 authored by 皮倩雯's avatar 皮倩雯

fix: '权限选择器全局组件'

parent b9dd692f
Pipeline #56794 waiting for manual action with stages
/* eslint-disable no-else-return */
/* eslint-disable no-cond-assign */
/* eslint-disable react/no-array-index-key */
/* eslint-disable no-undef */
/* eslint-disable guard-for-in */
/* eslint-disable no-restricted-syntax */
/* eslint-disable camelcase */
/* eslint-disable react/jsx-no-undef */
/* eslint-disable valid-typeof */
/* eslint-disable no-unused-vars */
/* eslint-disable consistent-return */
/* eslint-disable no-shadow */
/* eslint-disable indent */
/* eslint-disable no-unused-expressions */
/* eslint-disable array-callback-return */
/* eslint-disable eqeqeq */
/* eslint-disable no-plusplus */
import React, { useState, useEffect } from 'react';
import { Modal, Checkbox, Tabs, Input, Button, Pagination, Empty, Tag } from 'antd';
import { CM_Event_LoadDepartmentAndRoles } from '@/services/standingBook/api';
import styles from './index.less';
const CheckboxGroup = Checkbox.Group;
const { TabPane } = Tabs;
const RMSComponents = props => {
const {
callBackSubmit = () => {},
pickItem,
visible,
filed11,
newCheckedList,
groupName,
chooseGroupName,
} = props;
const [checkedList, setCheckedList] = useState([]); // 选中复选框内容
const [searchWord, setSearchWord] = useState(''); // 关键字
const { Search } = Input;
const [total, setTotal] = useState();
const [pageSize, setPageSize] = useState(45);
const [currentPage, setCurrentPage] = useState(1);
const [roleValue, setRoleValue] = useState([]);
const [checkDataRole, setCheckDataRole] = useState([]);
const [checkDataPm, setCheckDataPm] = useState([]);
const [checkDataSite, setCheckDataSite] = useState([]);
const [filed1, setFiled1] = useState([]); // 角色全部数据
const [saveCheckValue, setSaveCheckValue] = useState([]); // 保存选中值
const [keepTabKey, setKeepTabKey] = useState(0); // 保存tabs的key
const [list, setList] = useState([]);
const [listPm, setListPm] = useState([]);
const [listSite, setListSite] = useState([]);
const [keyValue, setKeyValue] = useState('0');
const [emptyValue, setEmptyValue] = useState(0);
const [selected, setSelected] = useState(new Map()); // 已勾选角色列表
const onSubmit = () => {
let selectData = [];
selected.forEach((val, key) => {
selectData.push(key);
});
callBackSubmit({
str: selectData.join(','),
pickItem,
stt: selectData,
});
setKeyValue('0');
setSearchWord('');
};
useEffect(() => {
if (visible) {
if (groupName == '角色') {
setKeyValue('0');
setKeepTabKey(0);
} else if (groupName == '部门') {
setKeyValue('1');
setKeepTabKey(1);
} else if (groupName == '站点') {
setKeyValue('2');
setKeepTabKey(2);
}
getRoles(groupName, '', pageSize, 1);
setRoleValue(filed1);
let arr = Object.keys(filed1);
let checkArr = [];
// 角色
let listdata = [];
newCheckedList.map(checkItem => {
if (filed11['角色'].includes(checkItem)) {
listdata.push(checkItem);
}
});
let cs = selected;
listdata.map(i => {
cs.set(i, {
type: 0,
});
});
setSelected(cs);
setCheckDataRole(listdata); // 用于设置首次展示已选列表角色数据
checkArr[0] = listdata;
// 部门
let pmdata = [];
newCheckedList.map(checkItem => {
if (filed11['部门'].includes(checkItem)) {
pmdata.push(checkItem);
}
});
let cs1 = selected;
pmdata.map(i => {
cs1.set(i, {
type: 1,
});
});
setSelected(cs1);
setCheckDataPm(pmdata);
checkArr[1] = pmdata;
// 站点
let sitedata = [];
newCheckedList.map(checkItem => {
if (filed11['站点'].includes(checkItem)) {
sitedata.push(checkItem);
}
});
let cs2 = selected;
sitedata.map(i => {
cs2.set(i, {
type: 2,
});
});
setSelected(cs2);
setCheckDataSite(sitedata);
checkArr[2] = sitedata;
setSaveCheckValue(checkArr);
setCheckedList(checkArr);
} else {
setSelected(new Map());
setPageSize(45);
setCurrentPage(1);
}
}, [visible]);
const submitSearchUser = () => {
if (keepTabKey == 0) {
sreachRoles('角色', searchWord, pageSize, 1);
}
if (keepTabKey == 1) {
sreachRoles('部门', searchWord, pageSize, 1);
}
if (keepTabKey == 2) {
sreachRoles('站点', searchWord, pageSize, 1);
}
};
// 获取搜索框的值
const handleSearch = e => {
setSearchWord(e.target.value);
};
// 监听分页
const paginationChange = (page, pageSizes) => {
if (keepTabKey == 0) {
getRoles('角色', searchWord, pageSizes, page);
}
if (keepTabKey == 1) {
getRoles('部门', searchWord, pageSizes, page);
}
if (keepTabKey == 2) {
getRoles('站点', searchWord, pageSizes, page);
}
setCurrentPage(page);
setPageSize(pageSizes);
};
// 搜索时获取数据
const sreachRoles = (type, keywords, pageSizes, pageIndex) => {
CM_Event_LoadDepartmentAndRoles({
type,
keywords,
pageSize: pageSizes,
pageIndex,
}).then(res => {
if (res.msg === 'Ok') {
console.log(formateArrDataA1(res.data, 'groupType'));
setRoleValue(formateArrDataA1(res.data, 'groupType'));
setFiled1(formateArrDataA1(res.data, 'groupType'));
setCurrentPage(1);
setTotal(res.data.count);
if (res.data.count == 0) {
setEmptyValue(1);
} else {
setEmptyValue(0);
}
}
});
};
const getRoles = (type, keywords, pageSizes, pageIndex) => {
CM_Event_LoadDepartmentAndRoles({
type,
keywords,
pageSize: pageSizes,
pageIndex,
}).then(res => {
if (res.msg === 'Ok') {
setTotal(res.data.count);
console.log(formateArrDataA1(res.data, 'groupType'));
setRoleValue(formateArrDataA1(res.data, 'groupType'));
setFiled1(formateArrDataA1(res.data, 'groupType'));
if (res.data.count == 0) {
setEmptyValue(1);
} else {
setEmptyValue(0);
}
}
});
};
// 页面数据改变重新赋值
useEffect(() => {
let arr = Object.keys(filed1);
let checkArr = [];
let data = [];
saveCheckValue.map((item, index) => {
data = data.concat(item);
});
arr.forEach(item => {
if (item == '角色') {
checkArr[0] = [];
checkDataRole.map(checkItem => {
if (filed1['角色'].includes(checkItem)) {
checkArr[0].push(checkItem);
}
});
setCheckedList(checkArr); // 按对象数组格式
} else if (item == '部门') {
checkArr[1] = [];
checkDataPm.map(checkItem => {
if (filed1['部门'].includes(checkItem)) {
checkArr[1].push(checkItem);
}
});
setCheckedList(checkArr);
} else if (item == '站点') {
checkArr[2] = [];
checkDataSite.map(checkItem => {
if (filed1['站点'].includes(checkItem)) {
checkArr[2].push(checkItem);
}
});
setCheckedList(checkArr);
}
});
}, [filed1]);
const formateArrDataA1 = (initialArr, name) => {
let aa = [];
let a1 = [];
let a2;
let a3 = [];
initialArr.data.map(i => {
a2 = i.groupType;
a1 = i.root;
a1.map(j => {
j.group = a2;
});
aa.push(i.root);
});
aa.map(p => {
p.map(o => {
a3.push(o);
});
});
// 判定传参是否符合规则
if (!(a3 instanceof Array)) {
return '请传入正确格式的数组';
}
if (!name) {
return '请传入对象属性';
}
// 先获取一下这个数组中有多少个"name"
let nameArr = [];
a3.map(i => {
if (nameArr.indexOf(i.group) === -1) {
nameArr.push(i.group);
}
});
// 新建一个包含多个list的结果对象
let tempObj = {};
// 根据不同的"name"生成多个数组
for (let k in nameArr) {
for (let j in a3) {
if (a3[j].group == nameArr[k]) {
// 每次外循环时新建一个对应"name"的数组, 内循环时当前数组不变
tempObj[nameArr[k]] = tempObj[nameArr[k]] || [];
tempObj[nameArr[k]].push(a3[j]);
}
}
}
for (let key in tempObj) {
let arr = [];
tempObj[key].map(item => {
tempObj[key] = arr;
arr.push(item.Name);
});
}
return tempObj;
};
useEffect(() => {
let checkedListArr = [...saveCheckValue];
let data = checkDataRole;
let DataValue = [];
// 拿到当前页数据
checkDataRole.forEach(item => {
if (roleValue['角色'] && roleValue['角色'].indexOf(item) != -1) {
DataValue.push(item);
}
});
// del
if (DataValue.length > list.length) {
DataValue.forEach(item => {
if (list.indexOf(item) == -1) {
data.splice(data.findIndex(ele => ele === item), 1);
let hhh = selected;
hhh.delete(item);
setSelected(hhh);
}
});
} else {
// add
list.forEach(item => {
if (data.indexOf(item) == -1) {
data.push(item);
}
});
let cs = selected;
data.map(i => {
cs.set(i, {
type: 0,
});
});
setSelected(cs);
}
checkedListArr[0] = data;
setCheckDataRole(data);
setSaveCheckValue(checkedListArr);
setCheckedList(checkedListArr);
}, [list]);
useEffect(() => {
let checkedListArr = [...saveCheckValue];
let data = checkDataPm;
let DataValue = [];
// 拿到当前页数据
checkDataPm.forEach(item => {
if (roleValue['部门'] && roleValue['部门'].indexOf(item) != -1) {
DataValue.push(item);
}
});
// del
if (DataValue.length > listPm.length) {
DataValue.forEach(item => {
if (listPm.indexOf(item) == -1) {
data.splice(data.findIndex(ele => ele === item), 1);
let hhh = selected;
hhh.delete(item);
setSelected(hhh);
}
});
} else {
// add
listPm.forEach(item => {
if (data.indexOf(item) == -1) {
data.push(item);
}
});
let cs = selected;
data.map(i => {
cs.set(i, {
type: 1,
});
});
setSelected(cs);
}
checkedListArr[1] = data;
setCheckDataPm(data);
setSaveCheckValue(checkedListArr);
setCheckedList(checkedListArr);
}, [listPm]);
useEffect(() => {
const checkedListArr = [...saveCheckValue];
let data = checkDataSite;
let DataValue = [];
// 拿到当前页数据
checkDataSite.forEach(item => {
if (roleValue['站点'] && roleValue['站点'].indexOf(item) != -1) {
DataValue.push(item);
}
});
// del
if (DataValue.length > listSite.length) {
DataValue.forEach(item => {
if (listSite.indexOf(item) == -1) {
data.splice(data.findIndex(ele => ele === item), 1);
let hhh = selected;
hhh.delete(item);
setSelected(hhh);
}
});
} else {
// add
listSite.forEach(item => {
if (data.indexOf(item) == -1) {
data.push(item);
}
});
let cs = selected;
data.map(i => {
cs.set(i, {
type: 2,
});
});
setSelected(cs);
}
checkedListArr[2] = data;
setCheckDataSite(data);
setSaveCheckValue(checkedListArr);
setCheckedList(checkedListArr);
}, [listSite]);
const handleParChange = key => {
console.log(key);
setKeyValue(key);
// setSearchWord('');
setCurrentPage(1);
setKeepTabKey(key);
if (key == 0) {
getRoles('角色', searchWord, pageSize, 1);
}
if (key == 1) {
getRoles('部门', searchWord, pageSize, 1);
}
if (key == 2) {
getRoles('站点', searchWord, pageSize, 1);
}
};
const onChangeListNew = list => {
setList(list);
};
const onChangeListNew1 = list => {
setListPm(list);
};
const onChangeListNew2 = list => {
setListSite(list);
};
const changeColor = e => {
if (e === 0) {
return 'cyan';
} else if (e === 1) {
return 'orange';
} else {
return 'purple';
}
};
// 删除已选中列表
const delSelected = value => {
let aa = selected.get(value).type;
let list = [];
let checkedListArr = saveCheckValue;
checkedListArr[aa].map(i => {
if (i != value) {
list.push(i);
}
});
checkedListArr[aa] = list;
setSaveCheckValue(checkedListArr);
setCheckedList(checkedListArr);
if (aa === 0) {
setCheckDataRole(list);
} else if (aa === 1) {
setCheckDataPm(list);
} else if (aa === 2) {
setCheckDataSite(list);
}
let hhh = selected;
hhh.delete(value);
setSelected(hhh);
};
return (
<div className={styles.modalContainer}>
<Modal
title="权限选择"
bodyStyle={{ width: '100%', height: '550px', overflowY: 'scorll' }}
width="1000px"
style={{ top: '10px' }}
destroyOnClose
centered
cancelText="取消"
okText="确认"
{...props}
onOk={() => onSubmit()}
forceRender
getContainer={false}
afterClose={() => {
setKeyValue('0');
setSearchWord('');
}}
>
<div className={styles.pageContent}>
{/* 可选列表 */}
<div className={styles.optionalList}>
<div className={styles.header} />
<Search
className={styles.searchInput}
allowClear
placeholder="搜索"
onSearch={submitSearchUser}
onChange={e => handleSearch(e)}
value={searchWord}
/>
<div className={styles.tabContent}>
{visible && (
<Tabs type="card" activeKey={keyValue} onChange={handleParChange}>
{/* {chooseGroupName &&
chooseGroupName.map((item, index) => {
<TabPane tab={item} key={index}>
{console.log(item)}
<div className={styles.checkContent}>
{emptyValue == 0 ? (
<div className={styles.check}>
<CheckboxGroup
options={roleValue[item]}
value={checkedList[index]}
onChange={onChangeListNew}
/>
</div>
) : (
<Empty image={Empty.PRESENTED_IMAGE_SIMPLE} description="暂无数据" />
)}
</div>
</TabPane>;
})} */}
{chooseGroupName.indexOf('角色') !== -1 ? (
<TabPane tab="角色" key="0">
<div className={styles.checkContent}>
{emptyValue == 0 ? (
<div className={styles.check}>
<CheckboxGroup
options={roleValue['角色']}
value={checkedList[0]}
onChange={onChangeListNew}
/>
</div>
) : (
<Empty image={Empty.PRESENTED_IMAGE_SIMPLE} description="暂无数据" />
)}
</div>
</TabPane>
) : (
<></>
)}
{chooseGroupName.indexOf('部门') !== -1 ? (
<TabPane tab="部门" key="1">
<div className={styles.checkContent}>
{emptyValue == 0 ? (
<div className={styles.check}>
<CheckboxGroup
options={roleValue['部门']}
value={checkedList[1]}
onChange={onChangeListNew1}
/>
</div>
) : (
<Empty image={Empty.PRESENTED_IMAGE_SIMPLE} description="暂无数据" />
)}
</div>
</TabPane>
) : (
<></>
)}
{chooseGroupName.indexOf('站点') !== -1 ? (
<TabPane tab="站点" key="2">
<div className={styles.checkContent}>
{emptyValue == 0 ? (
<div className={styles.check}>
<CheckboxGroup
options={roleValue['站点']}
value={checkedList[2]}
onChange={onChangeListNew2}
/>
</div>
) : (
<Empty image={Empty.PRESENTED_IMAGE_SIMPLE} description="暂无数据" />
)}
</div>
</TabPane>
) : (
<></>
)}
</Tabs>
)}
</div>
{/* 分页 */}
<div className={styles.footer}>
<Pagination
size="small"
total={total}
showSizeChanger
defaultPageSize={pageSize}
defaultCurrent={1}
pageSizeOptions={[10, 20, 45, 100]}
current={currentPage}
onChange={paginationChange}
style={{ marginBottom: '10px' }}
/>
</div>
</div>
{/* 已选列表 */}
<div className={styles.selectedList}>
<div className={styles.header}>
<div className={styles.title}>已选列表</div>
<div className={styles.tagHead}>
{chooseGroupName.indexOf('角色') !== -1 ? (
<div className={styles.tagContent}>
<div className={styles.tagRol} />
<div>角色</div>
</div>
) : (
<></>
)}
{chooseGroupName.indexOf('部门') !== -1 ? (
<div className={styles.tagContent}>
<div className={styles.tagOrg} />
<div>部门</div>
</div>
) : (
<></>
)}
{chooseGroupName.indexOf('站点') !== -1 ? (
<div className={styles.tagContent}>
<div className={styles.tagSite} />
<div>站点</div>
</div>
) : (
<></>
)}
</div>
</div>
<div className={styles.selectBox}>
{[...selected].length > 0 ? (
<div className={styles.selectContent}>
{[...selected].map(item => (
<div className={styles.selectValue} key={item[0]}>
<Tag
closable
color={changeColor(item[1].type)}
onClose={() => delSelected(item[0])}
>
{item[0]}
</Tag>
</div>
))}
</div>
) : (
<Empty
image={Empty.PRESENTED_IMAGE_SIMPLE}
description={`请选择${chooseGroupName.toString()}`}
/>
)}
</div>
</div>
</div>
</Modal>
</div>
);
};
export default RMSComponents;
.modalContainer {
.ant-modal-body {
padding: 0;
}
.ant-modal-header {
padding: 28px 16px;
}
.pageContent {
display: flex;
height: 100%;
.optionalList {
position: relative;
width: 60%;
border-right: 1px solid #e7e7e7;
.title {
position: absolute;
left: 17px;
top: 10px;
font-weight: 700;
font-size: 14px;
z-index: 1;
color: #00070d;
}
.tabContent {
height: 550px;
.ant-tabs-content-holder {
height: 480px;
}
}
.searchInput {
position: absolute;
width: 200px;
z-index: 1;
top: 3px;
right: 40px;
.anticon svg {
margin-top: 0px;
}
.ant-input,
.ant-input-affix-wrapper {
border-top-left-radius: 20px;
border-bottom-left-radius: 20px;
}
.ant-input-group-addon {
border-top-right-radius: 20px;
border-bottom-right-radius: 20px;
}
.ant-input-search-button {
width: 40px;
border-top-right-radius: 20px;
border-bottom-right-radius: 20px;
}
}
.checkContent {
display: flex;
flex-wrap: wrap;
margin-left: 32px;
.check {
.ant-checkbox-wrapper {
width: 180px;
margin-bottom: 10px;
margin-left: 6px;
}
.ant-checkbox-wrapper span {
max-width: 160px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
}
}
.footer {
padding-left: 25px;
.ant-pagination {
border: none;
}
}
.ant-tabs-nav {
background-color: #f2f1f1;
}
.ant-tabs-tab {
background-color: #f2f1f1;
color: #666666;
border-top-left-radius: 5px;
border-top-right-radius: 5px;
}
.ant-tabs-tab-active {
background-color: #fff;
color: #1685ff;
border-top-left-radius: 5px;
border-top-right-radius: 5px;
}
}
.selectedList {
position: relative;
width: 40%;
.header {
height: 40px;
width: 100%;
background-color: #f2f1f1;
.title {
position: absolute;
left: 17px;
top: 10px;
font-weight: 700;
font-size: 14px;
z-index: 1;
color: #00070d;
}
.tagHead {
display: flex;
position: absolute;
top: 10px;
left: 88px;
.tagContent {
display: flex;
align-items: center;
margin-right: 11px;
}
.tagRol,
.tagOrg,
.tagSite {
width: 10px;
height: 3px;
margin-right: 5px;
}
.tagRol {
background-color: #87e8de;
}
.tagOrg {
background-color: #ffd591;
}
.tagSite {
background-color: #a785dd;
}
}
}
.selectBox {
height: 490px;
padding: 10px;
overflow-y: scroll;
.selectContent {
display: flex;
flex-wrap: wrap;
flex-direction: row;
.selectValue {
margin-bottom: 15px;
}
}
}
}
}
}
...@@ -31,6 +31,7 @@ import { ...@@ -31,6 +31,7 @@ import {
CM_XWBPlan_DataList, CM_XWBPlan_DataList,
} from '@/services/maintenance/api'; } from '@/services/maintenance/api';
import { CM_Event_LoadDepartmentAndRoles } from '@/services/standingBook/api'; import { CM_Event_LoadDepartmentAndRoles } from '@/services/standingBook/api';
import RMSComponents from '@/components/RolePmSite/index';
import ChangeAdd from './ChangeAdd'; import ChangeAdd from './ChangeAdd';
...@@ -56,6 +57,9 @@ const AddModal = props => { ...@@ -56,6 +57,9 @@ const AddModal = props => {
const [characterValue, setCharacterValue] = useState(''); // 打开弹框之前数据 const [characterValue, setCharacterValue] = useState(''); // 打开弹框之前数据
const [ff, setFf] = useState([]); const [ff, setFf] = useState([]);
const [chee, setChee] = useState(''); const [chee, setChee] = useState('');
const [isVisibleRoles, setIsVisibleRoles] = useState(false);
const [groupName, setGroupName] = useState('角色');
const [chooseGroupName, setChooseGroupName] = useState(['角色']);
const [form] = Form.useForm(); const [form] = Form.useForm();
const { Item } = Form; const { Item } = Form;
...@@ -181,7 +185,7 @@ const AddModal = props => { ...@@ -181,7 +185,7 @@ const AddModal = props => {
console.log(inputValue[fileds]); console.log(inputValue[fileds]);
console.log(inputValue[fileds].split(',')); console.log(inputValue[fileds].split(','));
setPickItem(fileds); setPickItem(fileds);
setIsVisible(true); setIsVisibleRoles(true);
}; };
const getRole = () => { const getRole = () => {
CM_Event_LoadDepartmentAndRoles().then(res => { CM_Event_LoadDepartmentAndRoles().then(res => {
...@@ -197,7 +201,7 @@ const AddModal = props => { ...@@ -197,7 +201,7 @@ const AddModal = props => {
}; };
const getFeedbackTable = () => { const getFeedbackTable = () => {
CM_XWBPlan_feedbackTable().then(res => { CM_XWBPlan_feedbackTable().then(res => {
if (res.msg === 'Ok') { if (res.code === 0) {
let arr = []; let arr = [];
res.data.map((item, index) => { res.data.map((item, index) => {
arr.push(item.accountName); arr.push(item.accountName);
...@@ -278,6 +282,7 @@ const AddModal = props => { ...@@ -278,6 +282,7 @@ const AddModal = props => {
}; };
const onOK = prop => { const onOK = prop => {
console.log(prop.isType); console.log(prop.isType);
setIsVisibleRoles(false);
setIsVisible(false); setIsVisible(false);
console.log(props); console.log(props);
let inputText = { ...inputValue }; let inputText = { ...inputValue };
...@@ -547,6 +552,16 @@ const AddModal = props => { ...@@ -547,6 +552,16 @@ const AddModal = props => {
pickItem={pickItem} pickItem={pickItem}
characterValue={characterValue} characterValue={characterValue}
/> />
<RMSComponents
visible={isVisibleRoles}
onCancel={() => setIsVisibleRoles(false)}
callBackSubmit={onOK}
newCheckedList={checkedList1} // 单选框中的值
filed11={filed1} // 全部待选数据
pickItem={pickItem}
groupName={groupName} // 打开组件展示的分组名,用来首次获取数据
chooseGroupName={chooseGroupName} // 可选分组名
/>
</Drawer> </Drawer>
); );
}; };
......
/* eslint-disable no-lonely-if */ /* eslint-disable no-lonely-if */
/* eslint-disable eqeqeq */ /* eslint-disable eqeqeq */
import React, { useState, useEffect, PureComponent } from 'react'; import React, { useState, useEffect, PureComponent } from 'react';
import { Modal, Divider, Checkbox, Space, Button } from 'antd'; import { Modal, Divider, Checkbox, Space, Button, Empty } from 'antd';
import styles from './maintenance.less'; import styles from './maintenance.less';
const CheckboxGroup = Checkbox.Group; const CheckboxGroup = Checkbox.Group;
...@@ -29,23 +29,10 @@ const ChangeAdd = props => { ...@@ -29,23 +29,10 @@ const ChangeAdd = props => {
list.map((item, index) => { list.map((item, index) => {
arr.push(item); arr.push(item);
}); });
console.log(list);
console.log(arr);
setCheckedList(arr); setCheckedList(arr);
setIndeterminate(!!list.length && list.length < filed.length); setIndeterminate(!!list.length && list.length < filed.length);
setCheckAll(list.length === filed.length); setCheckAll(list.length === filed.length);
}; };
const onChangeList1 = list => {
let arr = [];
list.map((item, index) => {
arr.push(item);
});
console.log(list);
console.log(arr);
setCheckedList(arr);
setIndeterminate(!!list.length && list.length < ff.length);
setCheckAll(list.length === ff.length);
};
const onSubmit = () => { const onSubmit = () => {
isType === 'rule' isType === 'rule'
...@@ -66,12 +53,9 @@ const ChangeAdd = props => { ...@@ -66,12 +53,9 @@ const ChangeAdd = props => {
setIndeterminate(false); setIndeterminate(false);
setCheckAll(e.target.checked); setCheckAll(e.target.checked);
}; };
const onCheckAllChange1 = e => {
setCheckedList(e.target.checked ? ff : []);
setIndeterminate(false);
setCheckAll(e.target.checked);
};
useEffect(() => { useEffect(() => {
console.log(filed);
selectAll(); selectAll();
}, [checkedList]); }, [checkedList]);
...@@ -90,7 +74,6 @@ const ChangeAdd = props => { ...@@ -90,7 +74,6 @@ const ChangeAdd = props => {
if (isType != '' && isType === 'add') { if (isType != '' && isType === 'add') {
// 反馈名称 // 反馈名称
let checkArr = []; let checkArr = [];
console.log(newCheckedList);
newCheckedList.map(checkItem => { newCheckedList.map(checkItem => {
if (filed.includes(checkItem)) { if (filed.includes(checkItem)) {
checkArr.push(checkItem); checkArr.push(checkItem);
...@@ -101,57 +84,25 @@ const ChangeAdd = props => { ...@@ -101,57 +84,25 @@ const ChangeAdd = props => {
setCheckAll(checkArr.length === filed.length && filed.length != 0); setCheckAll(checkArr.length === filed.length && filed.length != 0);
let newArr = characterValue.length ? characterValue.split(',') : []; let newArr = characterValue.length ? characterValue.split(',') : [];
setSelectData(newArr); setSelectData(newArr);
} else if (isType === 'app') {
// 执行角色
let checkArr = [];
console.log(newCheckedList);
newCheckedList.map(checkItem => {
if (ff.includes(checkItem)) {
checkArr.push(checkItem);
}
});
setCheckedList(checkArr);
setIndeterminate(!!checkArr.length && checkArr.length < ff.length);
setCheckAll(checkArr.length === ff.length && ff.length != 0);
let newArr = characterValue.length ? characterValue.split(',') : [];
setSelectData(newArr);
} }
} else { } else {
if (isType != '' && isType === 'add') { if (isType != '' && isType === 'add') {
// 反馈名称 // 反馈名称
let checkArr = []; let checkArr = [];
console.log(filed);
console.log(newCheckedList);
newCheckedList.map(checkItem => { newCheckedList.map(checkItem => {
if (filed.includes(checkItem)) { if (filed.includes(checkItem)) {
checkArr.push(checkItem); checkArr.push(checkItem);
} }
}); });
console.log(checkArr);
setCheckedList(checkArr); setCheckedList(checkArr);
setIndeterminate(!!checkArr.length && checkArr.length < filed.length); setIndeterminate(!!checkArr.length && checkArr.length < filed.length);
setCheckAll(checkArr.length === filed.length && filed.length != 0); setCheckAll(checkArr.length === filed.length && filed.length != 0);
let newArr = characterValue.length ? characterValue.split(',') : []; let newArr = characterValue.length ? characterValue.split(',') : [];
setSelectData(newArr); setSelectData(newArr);
} else if (isType === 'app') {
// 执行角色
let checkArr = [];
console.log(newCheckedList);
newCheckedList.map(checkItem => {
if (ff.includes(checkItem)) {
checkArr.push(checkItem);
}
});
setCheckedList(checkArr);
setIndeterminate(!!checkArr.length && checkArr.length < ff.length);
setCheckAll(checkArr.length === ff.length && ff.length != 0);
let newArr = characterValue.length ? characterValue.split(',') : [];
setSelectData(newArr);
} }
} }
}, [visible]); }, [visible]);
if (isType != 'app') {
return ( return (
<div className={styles.ChangeAddContainer}> <div className={styles.ChangeAddContainer}>
<Modal <Modal
...@@ -171,22 +122,17 @@ const ChangeAdd = props => { ...@@ -171,22 +122,17 @@ const ChangeAdd = props => {
{visible && ( {visible && (
<div className={styles.listCard}> <div className={styles.listCard}>
<div className={styles.cardItem}> <div className={styles.cardItem}>
{JSON.stringify(filed) == '{}' ? ( {filed.length == 0 ? (
<> <>
<div className={styles.cardContent}> <div className={styles.cardContent}>
<span <Empty
style={{ image={Empty.PRESENTED_IMAGE_SIMPLE}
color: 'red', description="暂无数据请先在台账管理中配置台账类型为反馈"
fontSize: '1rem', />
marginLeft: '25px',
}}
>
暂无数据请先配置台账管理台账名称为反馈
</span>
</div> </div>
</> </>
) : ( ) : (
<> <div>
<div className={styles.cardContent}> <div className={styles.cardContent}>
<div className={styles.cardItemData}> <div className={styles.cardItemData}>
<Divider <Divider
...@@ -215,68 +161,14 @@ const ChangeAdd = props => { ...@@ -215,68 +161,14 @@ const ChangeAdd = props => {
/> />
</div> </div>
</div> </div>
</>
)}
</div>
</div> </div>
)} )}
</Modal>
</div>
);
}
if (isType === 'app') {
return (
<Modal
title="角色"
bodyStyle={{ width: '100%', minHeight: '100px' }}
style={{ top: '10px' }}
width="450px"
destroyOnClose
centered
cancelText="取消"
okText="确认"
{...props}
onOk={() => onSubmit()}
forceRender
getContainer={false}
>
{visible && (
<div className={styles.listCard}>
<div className={styles.cardItem}>
<div className={styles.cardContent}>
<div className={styles.cardItemData}>
<Divider
orientation="left"
style={{
margin: '0 0 5px 0',
color: '#15428b',
borderTopColor: '#99bbe8',
}}
>
全选
<Checkbox
style={{ marginLeft: '10px' }}
indeterminate={indeterminate}
onChange={onCheckAllChange1}
checkvalue={ff}
checked={checkAll}
>
{' '}
</Checkbox>
</Divider>
<CheckboxGroup
options={ff}
value={checkedList}
onChange={e => onChangeList1(e)}
/>
</div>
</div>
</div> </div>
</div> </div>
)} )}
</Modal> </Modal>
</div>
); );
}
}; };
export default ChangeAdd; export default ChangeAdd;
...@@ -17,6 +17,7 @@ import { ...@@ -17,6 +17,7 @@ import {
CM_Feedback_QueryPatrolFeedback, CM_Feedback_QueryPatrolFeedback,
} from '@/services/PatrolFeedback/api'; } from '@/services/PatrolFeedback/api';
import { CM_Event_LoadDepartmentAndRoles } from '@/services/standingBook/api'; import { CM_Event_LoadDepartmentAndRoles } from '@/services/standingBook/api';
import RMSComponents from '@/components/RolePmSite/index';
import ChangeRoles from './ChangeRoles'; import ChangeRoles from './ChangeRoles';
import ChangeFields from './ChangeFields'; import ChangeFields from './ChangeFields';
...@@ -36,6 +37,8 @@ const AddModal = props => { ...@@ -36,6 +37,8 @@ const AddModal = props => {
const [isVisibleRoles, setIsVisibleRoles] = useState(false); const [isVisibleRoles, setIsVisibleRoles] = useState(false);
const [nu, setNu] = useState([]); const [nu, setNu] = useState([]);
const [nu1, setNu1] = useState([]); const [nu1, setNu1] = useState([]);
const [groupName, setGroupName] = useState('角色');
const [chooseGroupName, setChooseGroupName] = useState(['角色', '部门', '站点']);
const [form] = Form.useForm(); const [form] = Form.useForm();
const { Item } = Form; const { Item } = Form;
...@@ -430,13 +433,23 @@ const AddModal = props => { ...@@ -430,13 +433,23 @@ const AddModal = props => {
pickItem={pickItem} pickItem={pickItem}
formObj={formObj} formObj={formObj}
/> />
<ChangeRoles {/* <ChangeRoles
visible={isVisibleRoles} visible={isVisibleRoles}
onCancel={() => setIsVisibleRoles(false)} onCancel={() => setIsVisibleRoles(false)}
callBackSubmit={onOK} callBackSubmit={onOK}
newCheckedList={checkedList1} newCheckedList={checkedList1}
filed11={filed1} filed11={filed1}
pickItem={pickItem} pickItem={pickItem}
/> */}
<RMSComponents
visible={isVisibleRoles}
onCancel={() => setIsVisibleRoles(false)}
callBackSubmit={onOK}
newCheckedList={checkedList1} // 单选框中的值
filed11={filed1} // 全部待选数据
pickItem={pickItem}
groupName={groupName} // 打开组件展示的分组名,用来首次获取数据
chooseGroupName={chooseGroupName} // 可选分组名
/> />
</Drawer> </Drawer>
); );
......
...@@ -13,7 +13,7 @@ ...@@ -13,7 +13,7 @@
/* eslint-disable eqeqeq */ /* eslint-disable eqeqeq */
/* eslint-disable no-plusplus */ /* eslint-disable no-plusplus */
import React, { useState, useEffect, useCallback, useRef } from 'react'; import React, { useState, useEffect, useCallback, useRef } from 'react';
import { Form, Modal, Divider, Checkbox, Tabs } from 'antd'; import { Form, Modal, Divider, Checkbox, Tabs, Empty } from 'antd';
import DragTable from '@/components/DragTable/DragTable'; import DragTable from '@/components/DragTable/DragTable';
import styles from '../../workOrder/incident/incident.less'; import styles from '../../workOrder/incident/incident.less';
const CheckboxGroup = Checkbox.Group; const CheckboxGroup = Checkbox.Group;
...@@ -304,7 +304,11 @@ const ChangeFields = props => { ...@@ -304,7 +304,11 @@ const ChangeFields = props => {
{JSON.stringify(filed) == '{}' ? ( {JSON.stringify(filed) == '{}' ? (
<> <>
<div className={styles.cardContent}> <div className={styles.cardContent}>
<span <Empty
image={Empty.PRESENTED_IMAGE_SIMPLE}
description="表字段缺失请先配置表/字段"
/>
{/* <span
style={{ style={{
color: 'red', color: 'red',
fontSize: '1rem', fontSize: '1rem',
...@@ -312,7 +316,7 @@ const ChangeFields = props => { ...@@ -312,7 +316,7 @@ const ChangeFields = props => {
}} }}
> >
表字段缺失请先配置表/字段 表字段缺失请先配置表/字段
</span> </span> */}
</div> </div>
</> </>
) : ( ) : (
......
...@@ -23,6 +23,7 @@ import { ...@@ -23,6 +23,7 @@ import {
} from 'antd'; } from 'antd';
import { PlusOutlined } from '@ant-design/icons'; import { PlusOutlined } from '@ant-design/icons';
import ChangeAddFlows from './ChangeAddFlows'; import ChangeAddFlows from './ChangeAddFlows';
import RMSComponents from '@/components/RolePmSite/index';
import { import {
CM_Event_ReloadFlows, CM_Event_ReloadFlows,
CM_Event_LoadDepartmentAndRoles, CM_Event_LoadDepartmentAndRoles,
...@@ -56,22 +57,19 @@ const AddFlowsModal = props => { ...@@ -56,22 +57,19 @@ const AddFlowsModal = props => {
const [inputValue, setInputValue] = useState({ Roles: '' }); const [inputValue, setInputValue] = useState({ Roles: '' });
const [selectValue, setSelectValue] = useState(''); const [selectValue, setSelectValue] = useState('');
const [characterValue, setCharacterValue] = useState(''); const [characterValue, setCharacterValue] = useState('');
const [Order, setOrder] = useState(''); // 弹窗类型
const [strr, setStrr] = useState(''); const [strr, setStrr] = useState('');
const [groupName, setGroupName] = useState('角色');
const [chooseGroupName, setChooseGroupName] = useState(['角色', '部门', '站点']);
useEffect(() => { useEffect(() => {
console.log(formObj);
getRole(); getRole();
console.log(obj);
CM_Event_ReloadFlows({ eventTypeId: obj }).then(res => { CM_Event_ReloadFlows({ eventTypeId: obj }).then(res => {
if (res.msg === 'Ok') { if (res.msg === 'Ok') {
console.log(res.data);
let arr = formateArrDataA(res.data, 'System'); let arr = formateArrDataA(res.data, 'System');
let newArr = []; let newArr = [];
Object.keys(arr).map((item, index) => { Object.keys(arr).map((item, index) => {
newArr.push(item); newArr.push(item);
}); });
console.log(newArr);
setStandingTable(newArr); setStandingTable(newArr);
} }
}); });
...@@ -81,12 +79,10 @@ const AddFlowsModal = props => { ...@@ -81,12 +79,10 @@ const AddFlowsModal = props => {
form.resetFields(); form.resetFields();
} else if (type === 'edit') { } else if (type === 'edit') {
setStrr(record.FlowRoles); setStrr(record.FlowRoles);
console.log(record);
setInputValue({ setInputValue({
Roles: record.FlowRoles, Roles: record.FlowRoles,
}); });
setSelectValue(record.FlowName); setSelectValue(record.FlowName);
console.log(selectValue);
} }
}, [visible]); }, [visible]);
const formateArrDataA = (initialArr, name) => { const formateArrDataA = (initialArr, name) => {
...@@ -320,46 +316,9 @@ const AddFlowsModal = props => { ...@@ -320,46 +316,9 @@ const AddFlowsModal = props => {
setVisible1(true); setVisible1(true);
}; };
const onOKk = prop => { const onOKk = prop => {
// let { title } = prop;
// let selectData = prop.stt;
// let ff = prop.filed22;
// let aa = [];
// let bb = 0;
// title.map((item, index) => {
// console.log(ff[item]);
// aa = [];
// selectData.map((item1, index1) => {
// console.log(item1);
// if (ff[item].indexOf(item1) != -1) {
// aa.push(item1);
// }
// });
// console.log(aa);
// if (aa.length == 0) {
// bb = 1;
// }
// });
// console.log(aa);
// if (bb == 1) {
// notification.error({
// message: '提示',
// description: '权限角色部门必须都选至少一项',
// });
// } else {
// setVisible1(false);
// let inputText = { ...inputValue };
// inputText[prop.pickItem] = prop.str;
// console.log(prop.str);
// console.log(inputText);
// setStrr(prop.str);
// setCheckedList1(prop.checkedList);
// setInputValue(inputText);
// }
setVisible1(false); setVisible1(false);
let inputText = { ...inputValue }; let inputText = { ...inputValue };
inputText[prop.pickItem] = prop.str; inputText[prop.pickItem] = prop.str;
console.log(prop.str);
console.log(inputText);
setStrr(prop.str); setStrr(prop.str);
setCheckedList1(prop.stt); setCheckedList1(prop.stt);
setInputValue(inputText); setInputValue(inputText);
...@@ -433,15 +392,23 @@ const AddFlowsModal = props => { ...@@ -433,15 +392,23 @@ const AddFlowsModal = props => {
</Col> </Col>
</Row> </Row>
</Form> </Form>
<ChangeAddFlows {/* <ChangeAddFlows
visible={visible1} visible={visible1}
onCancel={() => setVisible1(false)} onCancel={() => setVisible1(false)}
callBackSubmit={onOKk} callBackSubmit={onOKk}
newCheckedList={checkedList1} newCheckedList={checkedList1}
filed11={filed1} filed11={filed1}
pickItem={pickItem} pickItem={pickItem}
characterValue={characterValue} /> */}
formObj={formObj} <RMSComponents
visible={visible1}
onCancel={() => setVisible1(false)}
callBackSubmit={onOKk}
newCheckedList={checkedList1} // 单选框中的值
filed11={filed1} // 全部待选数据
pickItem={pickItem}
groupName={groupName} // 打开组件展示的分组名,用来首次获取数据
chooseGroupName={chooseGroupName} // 可选分组名
/> />
</Drawer> </Drawer>
); );
......
...@@ -48,6 +48,7 @@ import { PlusOutlined, DownOutlined, InfoCircleOutlined } from '@ant-design/icon ...@@ -48,6 +48,7 @@ import { PlusOutlined, DownOutlined, InfoCircleOutlined } from '@ant-design/icon
import styles from './incident.less'; import styles from './incident.less';
import ChangeAdd from './changeAdd'; import ChangeAdd from './changeAdd';
import ChangeEdit from './changeEdit'; import ChangeEdit from './changeEdit';
import RMSComponents from '@/components/RolePmSite/index';
const { Option } = Select; const { Option } = Select;
const AddModal = props => { const AddModal = props => {
...@@ -474,6 +475,9 @@ const AddModal = props => { ...@@ -474,6 +475,9 @@ const AddModal = props => {
const [editableValue, setEditableValue] = useState(); // 保存编辑字段外部字段 const [editableValue, setEditableValue] = useState(); // 保存编辑字段外部字段
const [transitValue, setTransitValue] = useState(); // 保存转单字段外部字段 const [transitValue, setTransitValue] = useState(); // 保存转单字段外部字段
const [relatedEventValue, setRelatedEventValue] = useState(); // 保存关联字段外部字段 const [relatedEventValue, setRelatedEventValue] = useState(); // 保存关联字段外部字段
const [groupName, setGroupName] = useState('角色');
const [chooseGroupName, setChooseGroupName] = useState(['角色', '部门', '站点']);
const [keepFiled, setKeepFiled] = useState([]);
const { Item } = Form; const { Item } = Form;
const onSubmit = () => { const onSubmit = () => {
...@@ -684,6 +688,7 @@ const AddModal = props => { ...@@ -684,6 +688,7 @@ const AddModal = props => {
if (res.msg === 'Ok') { if (res.msg === 'Ok') {
setNu1(res.data); setNu1(res.data);
setFiled1(formateArrDataA1(res.data, 'groupType')); setFiled1(formateArrDataA1(res.data, 'groupType'));
setKeepFiled(groupArr(res.data, 'groupType'));
} }
}); });
}; };
...@@ -963,6 +968,26 @@ const AddModal = props => { ...@@ -963,6 +968,26 @@ const AddModal = props => {
} }
return tempObj; return tempObj;
}; };
const groupArr = (initialArr, name) => {
let list = {};
console.log(initialArr);
initialArr.data.map(i => {
console.log(i);
let ar = [];
i.root.map(j => {
let ss = {};
ss.label = j.Name;
ss.value = j.ID;
ar.push(ss);
console.log(ss);
});
list[i.groupType] = ar;
});
console.log(list);
return list;
};
const formateArrDataA1 = (initialArr, name) => { const formateArrDataA1 = (initialArr, name) => {
console.log(initialArr); console.log(initialArr);
let aa = []; let aa = [];
...@@ -1018,7 +1043,6 @@ const AddModal = props => { ...@@ -1018,7 +1043,6 @@ const AddModal = props => {
} }
} }
} }
console.log(tempObj);
for (let key in tempObj) { for (let key in tempObj) {
let arr = []; let arr = [];
tempObj[key].map(item => { tempObj[key].map(item => {
...@@ -1152,7 +1176,9 @@ const AddModal = props => { ...@@ -1152,7 +1176,9 @@ const AddModal = props => {
}; };
const pickFiled1 = fileds => { const pickFiled1 = fileds => {
console.log(nu1);
let pp = formateArrDataA1(nu1, 'group'); let pp = formateArrDataA1(nu1, 'group');
setKeepFiled(groupArr(nu1, 'group'));
if (form.getFieldValue(fileds)) { if (form.getFieldValue(fileds)) {
setFiled1(pp); setFiled1(pp);
setCheckedList1(form.getFieldValue(fileds).split(',')); setCheckedList1(form.getFieldValue(fileds).split(','));
...@@ -1748,13 +1774,24 @@ const AddModal = props => { ...@@ -1748,13 +1774,24 @@ const AddModal = props => {
</Col> </Col>
</Row> </Row>
</Form> </Form>
<ChangeAdd {/* <ChangeAdd
visible={isVisible} visible={isVisible}
onCancel={onCancel} onCancel={onCancel}
callBackSubmit={onOK} callBackSubmit={onOK}
newCheckedList={checkedList1} newCheckedList={checkedList1}
filed11={filed1} filed11={filed1}
pickItem={pickItem} pickItem={pickItem}
/> */}
<RMSComponents
visible={isVisible}
onCancel={onCancel}
callBackSubmit={onOK}
newCheckedList={checkedList1} // 单选框中的值
filed11={filed1} // 全部待选数据
pickItem={pickItem}
groupName={groupName} // 打开组件展示的分组名,用来首次获取数据
chooseGroupName={chooseGroupName} // 可选分组名
keepFiled={keepFiled}
/> />
<ChangeEdit <ChangeEdit
visible={isVisibleEdit} visible={isVisibleEdit}
......
...@@ -13,7 +13,7 @@ ...@@ -13,7 +13,7 @@
/* eslint-disable eqeqeq */ /* eslint-disable eqeqeq */
/* eslint-disable no-plusplus */ /* eslint-disable no-plusplus */
import React, { useState, useEffect, useCallback, useRef } from 'react'; import React, { useState, useEffect, useCallback, useRef } from 'react';
import { Form, Modal, Divider, Checkbox, Tabs } from 'antd'; import { Form, Modal, Divider, Checkbox, Tabs, Empty } from 'antd';
import DragTable from '@/components/DragTable/DragTable'; import DragTable from '@/components/DragTable/DragTable';
import styles from './incident.less'; import styles from './incident.less';
const CheckboxGroup = Checkbox.Group; const CheckboxGroup = Checkbox.Group;
...@@ -302,15 +302,10 @@ const EditModal = props => { ...@@ -302,15 +302,10 @@ const EditModal = props => {
{JSON.stringify(filed) == '{}' ? ( {JSON.stringify(filed) == '{}' ? (
<> <>
<div className={styles.cardContent}> <div className={styles.cardContent}>
<span <Empty
style={{ image={Empty.PRESENTED_IMAGE_SIMPLE}
color: 'red', description="表字段缺失请先配置表/字段"
fontSize: '1rem', />
marginLeft: '25px',
}}
>
表字段缺失请先配置表/字段
</span>
</div> </div>
</> </>
) : ( ) : (
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment