Commit b4c0d538 authored by 皮倩雯's avatar 皮倩雯

fix: '定时任务'

parent c5f89b6a
Pipeline #76008 passed with stages
.agent_container {
display: flex;
flex-direction: row;
width: 80%;
.select_btn {
display: inline-block;
cursor: pointer;
text-align: center;
padding: 0 0.8rem;
color: rgba(22,133,255,1);
}
}
.exeTime{
display: flex;
align-items: center;
margin:0.2rem 0 0 7.6rem
}
.IISAgent_container {
overflow-y: scroll;
height: 500px;
}
.loopShow{
display: flex;
align-items: center;
margin-left: 3.6rem;
}
/* eslint-disable default-case */
/* eslint-disable no-unused-expressions */
import React, { useEffect, useState } from 'react';
import { Radio, Checkbox, Row, Col } from 'antd';
const DayOfWeekSelect = props => {
const { changeWeek } = props;
const [selectValues, setSelectValues] = useState([]);
const { onChange, value } = props;
const hours = [
{ name: '星期一', value: '1' },
{ name: '星期二', value: '2' },
{ name: '星期三', value: '3' },
{ name: '星期四', value: '4' },
{ name: '星期五', value: '5' },
{ name: '星期六', value: '6' },
{ name: '星期天', value: '7' },
];
const onTypeChange = e => {
let values = [];
switch (e.target.value) {
case 0:
values = ['1', '2', '3', '4', '5', '6', '7'];
break;
case 1:
const arr = ['1', '2', '3', '4', '5', '6', '7'];
let newArr = [];
selectValues &&
arr.map(item => {
if (!selectValues.includes(item)) {
newArr.push(item);
}
});
values = newArr;
break;
case 2:
values = ['1', '2', '3', '4', '5'];
break;
case 3:
values = ['6', '7'];
break;
}
changeWeek(values);
setSelectValues(values);
onChange && onChange(values);
};
const onCheckChange = val => {
setSelectValues(val);
onChange && onChange(val);
changeWeek(val);
};
useEffect(() => {
setSelectValues(value);
}, [props]);
return (
<div>
<Radio.Group onChange={onTypeChange} style={{ margin: '0.25rem 0' }}>
<Radio style={{ width: '85px' }} value={0}>
全选
</Radio>
<Radio style={{ width: '85px' }} value={1}>
反选
</Radio>
<Radio style={{ width: '88px' }} value={2}>
工作日
</Radio>
<Radio style={{ width: '88px' }} value={3}>
周末
</Radio>
</Radio.Group>
<Checkbox.Group value={selectValues} onChange={onCheckChange}>
<Row>
{hours.map((item, idx) => {
return (
<Col span={4} key={idx}>
<Checkbox value={item.value}>{item.name}</Checkbox>
</Col>
);
})}
</Row>
</Checkbox.Group>
</div>
);
};
export default DayOfWeekSelect;
/* eslint-disable no-case-declarations */
/* eslint-disable no-unused-expressions */
/* eslint-disable default-case */
import React, { useEffect, useState } from 'react';
import { Radio, Checkbox, Row, Col } from 'antd';
import styles from './HourOfDaySelect.less';
const HourOfDaySelect = props => {
const { changeDay } = props;
const [selectValues, setSelectValues] = useState([]);
const { onChange, value } = props;
const hours = [
{ name: '0:00', value: '0' },
{ name: '1:00', value: '1' },
{ name: '2:00', value: '2' },
{ name: '3:00', value: '3' },
{ name: '4:00', value: '4' },
{ name: '5:00', value: '5' },
{ name: '6:00', value: '6' },
{ name: '7:00', value: '7' },
{ name: '8:00', value: '8' },
{ name: '9:00', value: '9' },
{ name: '10:00', value: '10' },
{ name: '11:00', value: '11' },
{ name: '12:00', value: '12' },
{ name: '13:00', value: '13' },
{ name: '14:00', value: '14' },
{ name: '15:00', value: '15' },
{ name: '16:00', value: '16' },
{ name: '17:00', value: '17' },
{ name: '18:00', value: '18' },
{ name: '19:00', value: '19' },
{ name: '20:00', value: '20' },
{ name: '21:00', value: '21' },
{ name: '22:00', value: '22' },
{ name: '23:00', value: '23' },
];
const onTypeChange = e => {
let values = [];
switch (e.target.value) {
case 0:
values = [
'0',
'1',
'2',
'3',
'4',
'5',
'6',
'7',
'8',
'9',
'10',
'11',
'12',
'13',
'14',
'15',
'16',
'17',
'18',
'19',
'20',
'21',
'22',
'23',
];
break;
case 1:
const arr = [
'0',
'1',
'2',
'3',
'4',
'5',
'6',
'7',
'8',
'9',
'10',
'11',
'12',
'13',
'14',
'15',
'16',
'17',
'18',
'19',
'20',
'21',
'22',
'23',
];
let newArr = [];
selectValues &&
arr.map(item => {
if (!selectValues.includes(item)) {
newArr.push(item);
}
});
values = newArr;
break;
case 2:
values = ['6', '8'];
break;
case 3:
values = ['0', '8', '16'];
break;
case 4:
values = ['0', '6', '12', '18'];
break;
}
onChange(values);
setSelectValues(values);
changeDay(values);
};
useEffect(() => {
setSelectValues(value);
}, [props]);
const onCheckChange = val => {
setSelectValues(val);
onChange(val);
changeDay(val);
};
return (
<div className={styles.hourOfDay_container}>
<Radio.Group onChange={onTypeChange} style={{ marginBottom: '0.5rem' }}>
<Radio style={{ width: '85px' }} value={0}>
全选
</Radio>
<Radio style={{ width: '85px' }} value={1}>
反选
</Radio>
<Radio style={{ width: '88px' }} value={2}>
一天两次
</Radio>
<Radio style={{ width: '88px' }} value={3}>
一天三次
</Radio>
<Radio style={{ width: '88px' }} value={4}>
一天四次
</Radio>
</Radio.Group>
<Checkbox.Group value={selectValues} onChange={onCheckChange}>
<Row>
{hours.map((item, idx) => {
return (
<Col span={4} key={idx}>
<Checkbox value={item.value}>{item.name}</Checkbox>
</Col>
);
})}
</Row>
</Checkbox.Group>
</div>
);
};
export default HourOfDaySelect;
.hourOfDay_container{
display: flex;
flex-direction: column;
margin-top: 0.3rem;
}
import React, { useState, useEffect, useRef } from 'react';
import { Checkbox } from 'antd';
import styles from './PushTest.less';
const CheckboxGroup = Checkbox.Group;
const CardCheck = props => {
// 自定义获取改变后的值hooks
const usePrevious = value => {
const ref = useRef();
useEffect(() => {
ref.current = value;
});
return ref.current;
};
const { cardMsg, callback, checkList } = props;
const [checkedList, setCheckedList] = useState([]); // 选中列表
const [indeterminate, setIndeterminate] = useState(false);
const [checkAll, setCheckAll] = useState(false);
const [plainOptions, setPlainOptions] = useState([]);
const prevAmount = usePrevious({ checkedList });
useEffect(() => {
const msg = JSON.parse(JSON.stringify(cardMsg));
setPlainOptions(msg.plainOptions);
setCheckedList(msg.checkedList);
setIndeterminate(msg.indeterminate);
setCheckAll(msg.checkAll);
}, [cardMsg]);
// 获取勾选新增得数据
const addData = (arr1, arr2) => arr2.filter(val => arr1.indexOf(val) === -1);
// 获取勾选删除得数据
const delData = (arr1, arr2) => arr1.filter(val => arr2.indexOf(val) === -1);
// 单选监听
const onChange = list => {
let newCheckList = [...checkList];
let arr;
if (checkedList.length > list.length) {
// 取消勾选
arr = delData(checkedList, list);
arr.forEach(item => {
newCheckList.splice(newCheckList.findIndex(ele => ele.value === item), 1);
});
} else {
// 勾选元素
arr = addData(checkedList, list);
arr.forEach(item => {
let checkName = plainOptions.find(ele => ele.value === item);
newCheckList.push(checkName);
});
}
callback(newCheckList);
setCheckedList(list);
setIndeterminate(!!list.length && list.length < plainOptions.length);
setCheckAll(list.length === plainOptions.length);
};
// 全选监听
const onCheckAllChange = e => {
let newCheckList = [...checkList];
let arr;
if (e.target.checked) {
// 全选
arr = addData(checkedList, plainOptions.map(item => item.value));
arr.forEach(item => {
let checkName = plainOptions.find(ele => ele.value === item);
newCheckList.push(checkName);
});
} else {
arr = delData(checkedList, []);
arr.forEach(item => {
newCheckList.splice(newCheckList.findIndex(ele => ele.value === item), 1);
});
}
callback(newCheckList);
setCheckedList(e.target.checked ? plainOptions.map(item => item.value) : []);
setIndeterminate(false);
setCheckAll(e.target.checked);
};
return (
<div className={styles.checkContent}>
<div className={styles.topCheckbox}>
<Checkbox
indeterminate={indeterminate}
onChange={e => onCheckAllChange(e)}
checked={checkAll}
>
{cardMsg.groupName}
</Checkbox>
</div>
<div className={styles.bottomCheckbox}>
<CheckboxGroup
value={checkedList}
onChange={list => onChange(list)}
style={{ display: 'flex', flexWrap: 'wrap' }}
>
{plainOptions.map(item => (
<Checkbox key={item.value} value={item.value}>
{item.label}
</Checkbox>
))}
</CheckboxGroup>
</div>
</div>
);
};
export default CardCheck;
import React, { useState, useEffect, useCallback } from 'react';
import { Modal, Input, Button, message, Spin, Pagination, Table } from 'antd';
import { GetGroupUserTree, TestPush } from '@/services/messagemanage/messagemanage';
import styles from './PushTest.less';
import CardCheck from './CardCheck';
const PushTest = props => {
const { confirmModal, onCancel, visible, pushTestMsg } = props;
const [allList, setAllist] = useState([]); // 用于展示得数据
const [checkList, setCheckList] = useState([]); // 选中得数据集合
const [loading, setLoading] = useState(false);
const [total, setTotal] = useState();
const [currentPage, setCurrentPage] = useState(1);
const [pageSize, setPageSize] = useState(10);
const [searchName, setSearchName] = useState();
useEffect(() => {
if (visible) {
setCurrentPage(1);
getData(searchName, 1, pageSize);
} else {
setCheckList([]);
setAllist([]);
setSearchName('');
}
}, [visible]);
// 选中后得回调函数
const checkCallBack = useCallback(newCheckList => {
if (newCheckList) {
setCheckList(newCheckList);
}
});
// 监听分页
const paginationChange = (page, pageSizes) => {
setCurrentPage(page);
setPageSize(pageSizes);
getData(searchName, page, pageSizes);
};
// 提交勾选的测试人员
const onFinish = () => {
TestPush({
theme: '定时推送',
msgType: pushTestMsg.Name,
tousers: checkList.map(item => item.value),
pushPath: pushTestMsg.Url ? pushTestMsg.Url : '',
msgTypeId: pushTestMsg.ID.toString(),
})
.then(res => {
if (res.code === 0) {
confirmModal();
message.success('测试推送成功');
} else {
message.error(res.msg);
}
})
.catch(() => {
message.error('网络异常,请稍后再试');
});
};
// 搜索
const onSearch = () => {
setCurrentPage(1);
getData(searchName, 1, pageSize);
};
// 重置
const onReset = () => {
setCurrentPage(1);
getData('', 1, pageSize);
setSearchName('');
};
// 搜索框监听
const searchChange = e => {
setSearchName(e.target.value);
};
// 获取数据
const getData = (username, page, pageSizes) => {
setLoading(true);
GetGroupUserTree({
key: username,
pageSize: pageSizes,
PageIndex: page,
})
.then(res => {
setLoading(false);
if (res.code === 0) {
setTotal(res.data.count);
// 数据处理成checkbox组件需要得形式
let list = res.data.data.map(item => {
let indeterminate = false;
let checkedList = [];
let checkAll = false;
let options = item.users.map(val => {
checkList.forEach(ele => {
if (val.userId === ele.value) {
checkedList.push(ele.value);
}
});
return {
label: val.userName,
value: val.userId,
};
});
if (checkedList.length === options.length && checkedList.length > 0) {
checkAll = true;
}
if (checkedList.length < options.length && checkedList.length > 0) {
indeterminate = true;
}
return {
groupName: item.groupName,
groupId: item.groupId,
indeterminate,
checkAll,
checkedList,
plainOptions: options,
};
});
setAllist(list);
} else {
message.error(res.msg);
}
})
.catch(() => {
setLoading(false);
message.error('网络异常,请稍后再试');
});
};
// 拖拽后的回调函数
const dragCallBack = val => {
if (val) {
setCheckList(val);
}
};
const columns = [
{
title: '已选推送人',
dataIndex: 'label',
key: 'label',
width: 300,
},
];
return (
<>
<Modal
title="选择推送人"
visible={visible}
onOk={onFinish}
width="900px"
onCancel={onCancel}
maskClosable={false}
destroyOnClose
centered
>
<div className={styles.pushTestContent}>
<div className={styles.leftContent}>
{/* 头部搜索框 */}
<div className={styles.searchHeader}>
<Input.Search
value={searchName}
placeholder="请输入部门或用户"
onChange={searchChange}
onSearch={onSearch}
enterButton
style={{ width: '300px', marginRight: '15px' }}
/>
<Button type="primary" htmlType="submit" onClick={onReset}>
重置
</Button>
</div>
{/* 复选框模块 */}
<div className={styles.checkContainer}>
<Spin spinning={loading}>
{allList.map((item, index) => (
<div className={styles.checkBoxContent} key={item.groupId}>
<CardCheck
cardMsg={item}
cardIndex={index}
callback={(val, newCheckList) => checkCallBack(val, newCheckList)}
checkList={checkList}
/>
</div>
))}
</Spin>
</div>
</div>
<div className={styles.tableRight}>
<Table
bordered
style={{ width: '350px', overflowX: 'hidden' }}
rowKey={record => record.value}
columns={columns}
dataSource={checkList}
pagination={false}
size="small"
scroll={{ y: 530 }}
ItemTypes="pushTest"
/>
</div>
</div>
<div>
{/* 分页 */}
<Pagination
total={total}
showTotal={(totals, range) => `共 ${totals} 条`}
defaultPageSize={pageSize}
defaultCurrent={1}
current={currentPage}
onChange={paginationChange}
style={{ width: '100%' }}
size="small"
showQuickJumper
showSizeChanger
/>
</div>
</Modal>
</>
);
};
export default PushTest;
.pushTestContent {
display: flex;
.searchHeader {
display: flex;
}
.checkContainer {
height: 500px;
width: 500px;
overflow-y: scroll;
margin: 20px 0;
padding-right: 5px;
.checkContent {
display: flex;
width: 100%;
flex-direction: column;
border: 1px solid #c2cdfd;
border-radius: 5px;
margin-top: 20px;
min-height: 50px;
padding: 0 10px 10px 20px;
.ant-checkbox-wrapper {
background-color: #fff;
}
.topCheckbox {
height: 20px;
margin: -10px 0 0 0px;
line-height: 20px;
}
.topCheckbox > label :hover {
font-weight: 600;
}
.bottomCheckbox {
margin-top: 10px;
.ant-checkbox-wrapper {
min-width: 150px;
margin-left: 0;
}
// .ant-checkbox-group-item {
// min-width: 150px !important;
// }
// .ant-checkbox-wrapper {
// min-width: 150px !important;
// }
}
.checkdiv {
display: flex;
flex-wrap: wrap;
}
}
}
.tableRight {
margin-left: 10px;
}
}
/* eslint-disable no-else-return */
/* eslint-disable no-unneeded-ternary */
import React, { useState, useEffect, useRef } from 'react';
import {
Input,
Table,
Button,
notification,
message,
Tooltip,
Tag,
Modal,
Popconfirm,
Space,
Switch,
Select,
} from 'antd';
import {
SearchOutlined,
FundViewOutlined,
EditTwoTone,
DeleteOutlined,
PlusOutlined,
} from '@ant-design/icons';
import 'moment/dist/locale/zh-cn';
import styles from './index.less';
import {
GetIISAgentConfig,
DeleteIISAgentConfig,
AddIISAgentConfig,
} from '@/services/scheduledTasks/api';
import AddModal from './components/AddModal';
import PushTest from './components/PushTest/PushTest';
const { Option } = Select;
const ScheduledTasks = () => {
const [loading, setLoading] = useState(false); // 源数据
const [requestUrl, setRequestUrl] = useState(''); // 接口名称筛选
const [showSearchStyle, setShowSearchStyle] = useState(false); // 是否显示模糊查询样式
const [keepTableList, setKeepTableList] = useState([]);
const [addVisible, setAddVisible] = useState(false);
const [type, setType] = useState('');
const [recordItem, setRecordItem] = useState();
const [pushTestVisible, setPushTestVisible] = useState(false);
const typeValue = useRef('重复执行');
const [columnsData, setColumnsData] = useState([]);
const columns = [
{
title: '计划名称',
dataIndex: 'Name',
key: 'Name',
width: 300,
fixed: 'left',
onCell: () => ({
style: {
maxWidth: 300,
overflow: 'hidden',
whiteSpace: 'nowrap',
textOverflow: 'ellipsis',
cursor: 'pointer',
},
}),
render: text => <Tooltip title={text}>{searchStyle(text)}</Tooltip>,
},
{
title: '计划类型',
dataIndex: 'LoopMode',
key: 'LoopMode',
align: 'center',
width: 200,
render: text => {
if (text === 'ByOnce') {
return <span>执行一次</span>;
} else {
return <span>重复执行</span>;
}
},
},
{
title: '执行方式',
dataIndex: 'LoopMode',
key: 'LoopMode',
align: 'center',
width: 150,
render: text => {
if (text === 'ByLoop') {
return <Tag color="purple">循环</Tag>;
} else if (text === 'ByDay') {
return <Tag color="cyan">每天</Tag>;
} else if (text === 'ByWeek') {
return <Tag color="volcano">每周</Tag>;
}
},
},
{
title: '计划开始时间',
dataIndex: 'StartFrom',
key: 'StartFrom',
align: 'center',
width: 300,
},
{
title: '计划结束时间',
dataIndex: 'EndAt',
key: 'EndAt',
align: 'center',
width: 300,
},
{
title: '是否启用',
dataIndex: 'Enabled',
key: 'Enabled',
align: 'center',
width: 150,
render: (text, record) => {
if (text === true) {
return <Tag color="green"></Tag>;
} else if (text === false) {
return <Tag color="blue"></Tag>;
}
// return (
// <Switch
// checkedChildren="开启"
// unCheckedChildren="关闭"
// onChange={e => changeSwitch(e, record)}
// checked={text}
// />
// );
},
},
{
title: '操作',
width: 150,
align: 'center',
ellipsis: true,
render: (text, record) => (
<Space>
{/* <Tooltip title="测试">
<FundViewOutlined
style={{ fontSize: '16px', color: '#1890FF' }}
onClick={() => {
TestDesc(record);
}}
/>
</Tooltip> */}
<Tooltip title="编辑">
<EditTwoTone
style={{ fontSize: '16px', color: '#e86060' }}
onClick={() => {
editData(record);
}}
/>
</Tooltip>
<div onClick={e => e.stopPropagation()}>
<Popconfirm
title="是否删除方案?"
okText="确认"
cancelText="取消"
onConfirm={() => {
deleteData(record);
}}
>
<DeleteOutlined style={{ fontSize: '16px', color: '#e86060' }} />
</Popconfirm>
</div>
</Space>
),
},
];
useEffect(() => {
getTableList();
setColumnsData(columns);
}, []);
const getTableList = (search, planType) => {
let newSearch = search ? search : requestUrl;
let newType = planType ? planType : typeValue.current;
setLoading(true);
GetIISAgentConfig({ agentName: newSearch }).then(res => {
setLoading(false);
if (res.code === 0) {
let newData = [];
if (newType === '重复执行') {
newData = res.data.filter(i => i.LoopMode !== 'ByOnce');
} else {
newData = res.data.filter(i => i.LoopMode === 'ByOnce');
}
setKeepTableList(newData);
} else {
setKeepTableList([]);
notification.error({
message: '提示',
duration: 3,
description: res.msg,
});
}
});
};
const changeSwitch = (e, record) => {
// AddIISAgentConfig({ ...record, Enabled: e }).then(res => {
// if (res.code === 0) {
// getTableList();
// message.success(e ? `开启成功!` : `关闭成功!`);
// } else {
// message.error(res.msg);
// }
// });
};
const TestDesc = val => {
setRecordItem(val);
setPushTestVisible(true);
};
const editData = val => {
setType('edit');
setRecordItem(val);
setAddVisible(true);
};
const deleteData = val => {
DeleteIISAgentConfig({ agentName: val.Name }).then(res => {
if (res.code === 0) {
notification.success({
message: '提示',
duration: 3,
description: '删除成功',
});
getTableList();
} else {
notification.error({
message: '提示',
duration: 3,
description: res.msg,
});
}
});
};
// 模糊查询匹配的样式
const searchStyle = val => {
let n;
if (showSearchStyle) {
n = val.replace(new RegExp(requestUrl, 'g'), `<span style='color:red'>${requestUrl}</span>`);
} else {
n = val;
}
return <div dangerouslySetInnerHTML={{ __html: n }} />;
};
const handleAdd = () => {
setType('add');
setAddVisible(true);
};
const onOk = val => {
changeTable(val);
typeValue.current = val;
getTableList('', val);
};
const changeTable = e => {
if (e === '执行一次') {
let newColumns = columns;
let data = newColumns.filter(i => i.title !== '执行方式');
setColumnsData(data);
} else {
setColumnsData(columns);
}
};
return (
<div className={styles.scheduledTasks}>
<div className={styles.head}>
<div className={styles.headLeft}>
<span style={{ marginLeft: '5px' }}>计划类型:</span>
<Select
placeholder="请选择计划类型"
style={{ width: '155px' }}
value={typeValue.current}
onChange={e => {
changeTable(e);
typeValue.current = e;
getTableList('', e);
}}
>
<Option value="重复执行">重复执行</Option>
<Option value="执行一次">执行一次</Option>
</Select>
<span style={{ marginLeft: '15px' }}>计划名称:</span>
<Input.Search
style={{ width: '250px' }}
placeholder="请输入计划名称"
onChange={e => {
setRequestUrl(e.target.value);
}}
onSearch={e => {
getTableList(e);
setShowSearchStyle(true);
}}
value={requestUrl}
/>
</div>
<div className={styles.headRight}>
<Button
icon={<PlusOutlined className={styles.icon} />}
type="primary"
onClick={handleAdd}
style={{
marginLeft: '25px',
verticalAlign: 'middle',
marginTop: '-3px',
}}
>
新增
</Button>
</div>
</div>
<div className={styles.table}>
<Table
size="small"
bordered
columns={columnsData}
dataSource={keepTableList}
onRow={record => ({
onDoubleClick: event => {
event.stopPropagation();
editData(record);
}, // 双击
})}
scroll={{ y: 'calc(100vh - 225px)' }}
loading={loading}
/>
</div>
<AddModal
visible={addVisible}
onCancel={() => setAddVisible(false)}
submitCallback={onOk}
type={type}
record={recordItem}
/>
<PushTest
visible={pushTestVisible}
onCancel={() => setPushTestVisible(false)}
pushTestMsg={recordItem}
/>
</div>
);
};
export default ScheduledTasks;
.scheduledTasks {
width: 100%;
height: 100%;
.head {
padding: 10px;
background: white;
margin-bottom: 2px;
width: 100%;
height: 52px;
display: flex;
justify-content: space-between;
align-items: center;
.headLeft{
display: flex;
align-items: center;
}
}
.table {
height: calc(100% - 53px);
width: 100%;
background-color: white;
padding: 10px;
overflow: hidden;
margin-bottom: 3px;
.ant-table-container {
height: calc(100vh - 185px);
}
}
.icon {
margin-top: -5px;
vertical-align: text-bottom;
}
}
...@@ -41,6 +41,7 @@ import { ...@@ -41,6 +41,7 @@ import {
PlusOutlined, PlusOutlined,
SyncOutlined, SyncOutlined,
ClusterOutlined, ClusterOutlined,
MessageOutlined,
} from '@ant-design/icons'; } from '@ant-design/icons';
import PageContainer from '@/components/BasePageContainer'; import PageContainer from '@/components/BasePageContainer';
import voca from 'voca'; import voca from 'voca';
...@@ -68,6 +69,7 @@ import { ...@@ -68,6 +69,7 @@ import {
DragGroup, DragGroup,
GetAllSite, GetAllSite,
SetGroupManager, SetGroupManager,
ChangeSMSState,
} from '@/services/userManage/api'; } from '@/services/userManage/api';
import { AddUserAuthSetting, GetUserAuthSet } from '@/services/database/api'; import { AddUserAuthSetting, GetUserAuthSet } from '@/services/database/api';
import TreeComponents from '@/components/ExpendableTree'; import TreeComponents from '@/components/ExpendableTree';
...@@ -316,6 +318,44 @@ const UserManage = () => { ...@@ -316,6 +318,44 @@ const UserManage = () => {
/> />
</Popconfirm> </Popconfirm>
</Tooltip> </Tooltip>
<Tooltip title={record.isSendSMS === 0 ? '不接收短信' : '接收短信'}>
<Popconfirm
placement="bottomRight"
title={
record.isSendSMS === 0 ? (
<p>
确定设置用户
<span className={styles.redText}>{voca.stripTags(record.loginName)}</span>
可以接收短信吗?
</p>
) : (
<p>
确定设置用户
<span className={styles.redText}>{voca.stripTags(record.loginName)}</span>
不可接收短信吗?
</p>
)
}
okText="确认"
cancelText="取消"
onConfirm={() => {
ChangeSMSState({ userId: record.userId }).then(res => {
if (res.code === 0) {
currentSelectOrg === '-1' ? submitSearchUser() : onSelect([currentSelectOrg]);
} else {
notification.error({
message: '设置失败',
description: res.msg,
});
}
});
}}
>
<MessageOutlined
style={{ fontSize: '16px', color: record.isSendSMS === 0 ? '#e86060' : '#1890FF' }}
/>
</Popconfirm>
</Tooltip>
</Space> </Space>
), ),
}, },
......
...@@ -131,6 +131,7 @@ const BaseFrameContainer = asyncComponent(() => ...@@ -131,6 +131,7 @@ const BaseFrameContainer = asyncComponent(() =>
const IntegratedLogin = asyncComponent(() => const IntegratedLogin = asyncComponent(() =>
import('@/pages/platformCenter/integratedLogin/integrate'), import('@/pages/platformCenter/integratedLogin/integrate'),
); );
const ScheduledTasks = asyncComponent(() => import('@/pages/platformCenter/scheduledTasks/index'));
// 业务中心 // 业务中心
const TableManager = asyncComponent(() => import('@/pages/bsmanager/base/tablemanager')); const TableManager = asyncComponent(() => import('@/pages/bsmanager/base/tablemanager'));
// const FiledConfig = asyncComponent(() => // const FiledConfig = asyncComponent(() =>
...@@ -433,6 +434,11 @@ export default { ...@@ -433,6 +434,11 @@ export default {
name: '消息中心', name: '消息中心',
component: MessageManager, component: MessageManager,
}, },
{
path: '/platform/scheduledTasks',
name: '定时任务',
component: ScheduledTasks,
},
// { // {
// path: '/platform/notificationNew', // path: '/platform/notificationNew',
// name: '消息中心(新)', // name: '消息中心(新)',
......
import { get, PUBLISH_SERVICE, post } from '../index';
export const AddIISAgentConfig = data =>
post(`${PUBLISH_SERVICE}/MessageConfig/AddIISAgentConfig`, data); // 添加助理服务器配置
export const GetIISAgentConfig = param =>
get(`${PUBLISH_SERVICE}/MessageConfig/GetIISAgentConfig`, param); // 获取助理服务器配置
export const DeleteIISAgentConfig = param =>
get(`${PUBLISH_SERVICE}/MessageConfig/DeleteIISAgentConfig`, param); // 删除助理服务器配置
...@@ -187,6 +187,8 @@ export const DragGroup = params => post(`${PUBLISH_SERVICE}/UserCenter/DragGroup ...@@ -187,6 +187,8 @@ export const DragGroup = params => post(`${PUBLISH_SERVICE}/UserCenter/DragGroup
export const GetAllSite = params => get(`${PUBLISH_SERVICE}/UserCenter/GetAllSite`, params); export const GetAllSite = params => get(`${PUBLISH_SERVICE}/UserCenter/GetAllSite`, params);
// 设置为主管 // 设置为主管
export const SetGroupManager = params => get(`${PUBLISH_SERVICE}/UserCenter/SetGroupManager`, params); export const SetGroupManager = params => get(`${PUBLISH_SERVICE}/UserCenter/SetGroupManager`, params);
// 设置接收短信
export const ChangeSMSState = params => get(`${PUBLISH_SERVICE}/UserCenter/ChangeSMSState`, params);
// export const DeleteOUNew = params => // export const DeleteOUNew = params =>
// get(`${PUBLISH_SERVICE}/UserCenter/DeleteOU`, params) // get(`${PUBLISH_SERVICE}/UserCenter/DeleteOU`, params)
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