|
|
@ -1,6 +1,6 @@ |
|
|
|
import React, { useState, useRef, useEffect } from "react"; |
|
|
|
import { connect } from "react-redux"; |
|
|
|
import { Modal, Form } from "@douyinfe/semi-ui"; |
|
|
|
import { Modal, Form, Input, Button } from "@douyinfe/semi-ui"; |
|
|
|
import { IconAlertCircle } from '@douyinfe/semi-icons'; |
|
|
|
|
|
|
|
|
|
|
@ -9,31 +9,35 @@ function adminModal (props) { |
|
|
|
close, |
|
|
|
visible, |
|
|
|
dispatch, |
|
|
|
pepList, |
|
|
|
actions, |
|
|
|
adminEdit,//是否是编辑 |
|
|
|
editObj, |
|
|
|
systemEdit,//是否是编辑 |
|
|
|
peplist,//项企项目列表 |
|
|
|
anxincloudList,//安心云项目列表 |
|
|
|
pepProjectId |
|
|
|
} = props; |
|
|
|
const { install } = actions; |
|
|
|
const form = useRef();//表单 |
|
|
|
const [disablePeople, setDisablePeople] = useState(true); //页码信息 |
|
|
|
const [peopleList, setPeopleList] = useState([]); //人员List |
|
|
|
const [departmentId, setDepartmentId] = useState(); //部门id |
|
|
|
const [peopleId, setPeopleId] = useState(); //人员id |
|
|
|
const [custom, setCustom] = useState(false); //是否是自定义项目 |
|
|
|
const [appList, setAppList] = useState([ |
|
|
|
{ |
|
|
|
name: '', |
|
|
|
url: '' |
|
|
|
} |
|
|
|
]); //添加应用列表 |
|
|
|
//初始化 |
|
|
|
useEffect(() => { |
|
|
|
if (editObj.id) { |
|
|
|
let departmentList = [] |
|
|
|
for (let i = 0; i < pepList.length; i++) { |
|
|
|
if (pepList[i].id == editObj.departments[0].id) { |
|
|
|
departmentList = pepList[i].users |
|
|
|
} |
|
|
|
} |
|
|
|
setPeopleList(departmentList) |
|
|
|
setDepartmentId(editObj.departments[0].id) |
|
|
|
setPeopleId(editObj.pepUserId) |
|
|
|
setDisablePeople(false) |
|
|
|
} |
|
|
|
// if (editObj.id) { |
|
|
|
// let departmentList = [] |
|
|
|
// for (let i = 0; i < pepList.length; i++) { |
|
|
|
// if (pepList[i].id == editObj.departments[0].id) { |
|
|
|
// departmentList = pepList[i].users |
|
|
|
// } |
|
|
|
// } |
|
|
|
// setPeopleList(departmentList) |
|
|
|
// setDepartmentId(editObj.departments[0].id) |
|
|
|
// setPeopleId(editObj.pepUserId) |
|
|
|
// setDisablePeople(false) |
|
|
|
// } |
|
|
|
}, []); |
|
|
|
|
|
|
|
function handleOk () { |
|
|
@ -42,20 +46,20 @@ function adminModal (props) { |
|
|
|
.validate() |
|
|
|
.then((values) => { |
|
|
|
if (adminEdit) { |
|
|
|
dispatch(install.deteleOrganizationAdmin({id:editObj.id,msg:''})).then( |
|
|
|
dispatch(install.postOrganizationUser({ role: ['admin'], pepUserId: values.pepUserId, msg: '修改管理员' })).then((res) => {//获取项企(PEP)全部部门及其下用户 |
|
|
|
if (res.success) { |
|
|
|
close(); |
|
|
|
} |
|
|
|
}) |
|
|
|
) |
|
|
|
// dispatch(install.deteleOrganizationAdmin({id:editObj.id,msg:''})).then( |
|
|
|
// dispatch(install.postOrganizationUser({ role: ['admin'], pepUserId: values.pepUserId, msg: '修改管理员' })).then((res) => {//获取项企(PEP)全部部门及其下用户 |
|
|
|
// if (res.success) { |
|
|
|
// close(); |
|
|
|
// } |
|
|
|
// }) |
|
|
|
// ) |
|
|
|
} |
|
|
|
else { |
|
|
|
dispatch(install.postOrganizationUser({ role: ['admin'], pepUserId: values.pepUserId, msg: '新增管理员' })).then((res) => {//获取项企(PEP)全部部门及其下用户 |
|
|
|
if (res.success) { |
|
|
|
close(); |
|
|
|
} |
|
|
|
}) |
|
|
|
// dispatch(install.postOrganizationUser({ role: ['admin'], pepUserId: values.pepUserId, msg: '新增管理员' })).then((res) => {//获取项企(PEP)全部部门及其下用户 |
|
|
|
// if (res.success) { |
|
|
|
// close(); |
|
|
|
// } |
|
|
|
// }) |
|
|
|
} |
|
|
|
}) |
|
|
|
} |
|
|
@ -63,45 +67,41 @@ function adminModal (props) { |
|
|
|
close(); |
|
|
|
//点击弹框取消 左边按钮 |
|
|
|
} |
|
|
|
function onChange (value, index) { |
|
|
|
console.log('value', value); |
|
|
|
console.log('index', index); |
|
|
|
} |
|
|
|
return ( |
|
|
|
<> |
|
|
|
<Modal |
|
|
|
title="管理员设置" |
|
|
|
title={systemEdit ? '修改映射关系' : '添加映射关系'} |
|
|
|
okText="确定" |
|
|
|
cancelText="取消" |
|
|
|
visible={visible} |
|
|
|
onOk={handleOk} |
|
|
|
width={607} |
|
|
|
width={666} |
|
|
|
onCancel={handleCancel} |
|
|
|
> |
|
|
|
<div style={{ margin: "0px 25px" }}> |
|
|
|
<div style={{ width: '100%', height: 32, background: '#F4F8FF', borderRadius: 2, border: '1px solid #C7E1FF', display: 'flex', alignItems: 'center' }}> |
|
|
|
<div style={{ width: '100%', lineHeight: 2, background: '#F4F8FF', borderRadius: 2, border: '1px solid #C7E1FF', display: 'flex', alignItems: 'center' }}> |
|
|
|
<div style={{ display: 'flex', alignItems: 'center', marginLeft: 12 }}><IconAlertCircle style={{ color: '#0F7EFB' }} /></div> |
|
|
|
<div style={{ color: '#0F7EFB', fontSize: 12, marginLeft: 8 }}>成员成为管理员后,拥有平台所有权限和项目,成员的普通角色会被禁用。</div> |
|
|
|
<div style={{ color: '#0F7EFB', fontSize: 12, marginLeft: 8, marginRight: 12 }}>映射关系由项企立项项目与安心云项目关联产生,若项目未在项企中有记载,可选自定义项目,待项企立项项后再进行修改!</div> |
|
|
|
</div> |
|
|
|
<Form |
|
|
|
allowEmpty |
|
|
|
labelPosition="left" |
|
|
|
labelAlign="right" |
|
|
|
labelWidth="90px" |
|
|
|
labelWidth="110px" |
|
|
|
onValueChange={(values, field) => { |
|
|
|
console.log('values', values); |
|
|
|
console.log('field', field); |
|
|
|
for (var key in field) { |
|
|
|
if (key == 'department') { |
|
|
|
if (values.department >= 0) { |
|
|
|
let departmentList = [] |
|
|
|
for (let i = 0; i < pepList.length; i++) { |
|
|
|
if (pepList[i].id == values.department) { |
|
|
|
departmentList = pepList[i].users |
|
|
|
} |
|
|
|
} |
|
|
|
setPeopleList(departmentList) |
|
|
|
setDisablePeople(false) |
|
|
|
form.current.setValue('pepUserId', undefined); |
|
|
|
if (key == 'projectType') { |
|
|
|
if (field.projectType == 'pep') { |
|
|
|
setCustom(false) |
|
|
|
} |
|
|
|
else { |
|
|
|
setPeopleList([]) |
|
|
|
setDisablePeople(true) |
|
|
|
form.current.setValue('pepUserId', undefined); |
|
|
|
setCustom(true) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -109,41 +109,61 @@ function adminModal (props) { |
|
|
|
getFormApi={(formApi) => (form.current = formApi)} |
|
|
|
> |
|
|
|
<div> |
|
|
|
<Form.Select |
|
|
|
label="选择部门:" |
|
|
|
field="department" |
|
|
|
placeholder="请选择部门" |
|
|
|
style={{ width: 417 }} |
|
|
|
rules={[{ required: true, message: "请选择部门" }]} |
|
|
|
initValue={departmentId || ""} |
|
|
|
showClear |
|
|
|
> |
|
|
|
{ |
|
|
|
pepList.map((item, index) => { |
|
|
|
return ( |
|
|
|
<Form.Select.Option key={index} value={item.id}> |
|
|
|
{item.name} |
|
|
|
</Form.Select.Option> |
|
|
|
) |
|
|
|
}) |
|
|
|
} |
|
|
|
</Form.Select> |
|
|
|
<Form.RadioGroup field="projectType" initValue='pep' label='项目类型:' > |
|
|
|
<Form.Radio value='pep'>项企项目</Form.Radio> |
|
|
|
<Form.Radio value='axy'>自定义项目(未在项企中立项的项目可选)</Form.Radio> |
|
|
|
</Form.RadioGroup> |
|
|
|
</div> |
|
|
|
{custom ? ( |
|
|
|
<div> |
|
|
|
<Form.Input |
|
|
|
field="name" |
|
|
|
label='未立项项目:' |
|
|
|
style={{ width: 425 }} |
|
|
|
placeholder="请输入项目名称,且名称需与项企区分" |
|
|
|
showClear |
|
|
|
rules={[{ required: true, message: "请输入项目名称,且名称需与项企区分" }]} /> |
|
|
|
</div> |
|
|
|
) : ( |
|
|
|
<div> |
|
|
|
<Form.Select |
|
|
|
label="PEP项企项目:" |
|
|
|
field="pepUserId" |
|
|
|
filter |
|
|
|
placeholder="请选择PEP项企项目" |
|
|
|
style={{ width: 425 }} |
|
|
|
rules={[{ required: true, message: "请选择PEP项企项目" }]} |
|
|
|
initValue={pepProjectId || ""} |
|
|
|
showClear |
|
|
|
> |
|
|
|
{ |
|
|
|
peplist.map((item, index) => { |
|
|
|
return ( |
|
|
|
<Form.Select.Option key={item.id} value={item.id}> |
|
|
|
{item.project_name} |
|
|
|
</Form.Select.Option> |
|
|
|
) |
|
|
|
}) |
|
|
|
} |
|
|
|
</Form.Select> |
|
|
|
</div> |
|
|
|
)} |
|
|
|
<div> |
|
|
|
<Form.Select |
|
|
|
label="选择人员:" |
|
|
|
field="pepUserId" |
|
|
|
placeholder="请选择人员" |
|
|
|
style={{ width: 417 }} |
|
|
|
rules={[{ required: true, message: "请选择人员" }]} |
|
|
|
initValue={peopleId || ""} |
|
|
|
label="关联项目:" |
|
|
|
field="anxinProject" |
|
|
|
multiple |
|
|
|
filter |
|
|
|
placeholder="请选择关联项目" |
|
|
|
style={{ width: 425 }} |
|
|
|
rules={[{ required: true, message: "请选择关联项目" }]} |
|
|
|
// initValue={departmentId || []} |
|
|
|
showClear |
|
|
|
disabled={disablePeople} |
|
|
|
> |
|
|
|
{ |
|
|
|
peopleList.map((item, index) => { |
|
|
|
anxincloudList.map((item, index) => { |
|
|
|
return ( |
|
|
|
<Form.Select.Option key={item.id} value={item.id}> |
|
|
|
<Form.Select.Option key={index} value={item.id}> |
|
|
|
{item.name} |
|
|
|
</Form.Select.Option> |
|
|
|
) |
|
|
@ -152,6 +172,47 @@ function adminModal (props) { |
|
|
|
</Form.Select> |
|
|
|
</div> |
|
|
|
</Form> |
|
|
|
<div style={{ marginTop: 8 }}> |
|
|
|
{ |
|
|
|
appList.map((item, index) => { |
|
|
|
return ( |
|
|
|
<div style={{ display: 'flex', alignItems: 'center' }}> |
|
|
|
<div style={{ width: 110, textAlign: 'end', paddingRight: 16, color: 'rgba(0, 0, 0, 0.65)', fontWeight: 600 }}> |
|
|
|
增加应用: |
|
|
|
</div> |
|
|
|
<div> |
|
|
|
<Input |
|
|
|
style={{ width: 149 }} |
|
|
|
value={item.name} |
|
|
|
placeholder="请输入应用名称" |
|
|
|
onChange={(value) => onChange(value, index)} |
|
|
|
maxLength={18} |
|
|
|
showClear></Input> |
|
|
|
</div> |
|
|
|
<div> |
|
|
|
<Input |
|
|
|
style={{ width: 268, marginLeft: 8 }} |
|
|
|
value={item.url} |
|
|
|
placeholder="请输入URL地址" |
|
|
|
onChange={(value) => onChange(value, index)} |
|
|
|
maxLength={50} |
|
|
|
showClear></Input> |
|
|
|
</div> |
|
|
|
<div style={{ display: 'flex', alignItems: 'center', cursor: "pointer" }}> |
|
|
|
<img src="/assets/images/install/appDelete.png" alt="" style={{ height: 24, width: 24, marginLeft: 8 }} /> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
) |
|
|
|
}) |
|
|
|
} |
|
|
|
<div style={{ display: 'flex', alignItems: 'center',marginTop:12,marginLeft:110,justifyContent: 'space-between' }}> |
|
|
|
<Button type='primary' theme='solid' style={{ width: 72, height: 25, borderRadius: '1px', border: '1px solid #005ABD',background:'#FFFFFF', color: '#005ABD', fontWeight: 400, }}>继续添加</Button> |
|
|
|
<div style={{color:'#646566',fontSize:12,marginRight:32}}> |
|
|
|
<span style={{color:'#F31C1C'}}>*</span> |
|
|
|
最多可添加30条 |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</Modal> |
|
|
|
</> |
|
|
|