NoticeIcon通知菜单
用在导航工具栏上,作为整个产品统一的通知中心。
引用方式:
import NoticeIcon from 'ant-design-pro/lib/NoticeIcon';
详细使用方式请参照:独立使用 pro 组件
代码演示
import NoticeIcon from 'ant-design-pro/lib/NoticeIcon';
ReactDOM.render(<NoticeIcon count={5} />, mountNode);
import NoticeIcon from 'ant-design-pro/lib/NoticeIcon';
import { Tag } from 'antd';
const data = [
{
id: '000000001',
avatar: 'https://gw.alipayobjects.com/zos/rmsportal/ThXAXghbEsBCCSDihZxY.png',
title: '你收到了 14 份新周报',
datetime: '2017-08-09',
type: 'notification',
},
{
id: '000000002',
avatar: 'https://gw.alipayobjects.com/zos/rmsportal/OKJXDXrmkNshAMvwtvhu.png',
title: '你推荐的 曲妮妮 已通过第三轮面试',
datetime: '2017-08-08',
type: 'notification',
},
{
id: '000000003',
avatar: 'https://gw.alipayobjects.com/zos/rmsportal/kISTdvpyTAhtGxpovNWd.png',
title: '这种模板可以区分多种通知类型',
datetime: '2017-08-07',
read: true,
type: 'notification',
},
{
id: '000000004',
avatar: 'https://gw.alipayobjects.com/zos/rmsportal/GvqBnKhFgObvnSGkDsje.png',
title: '左侧图标用于区分不同的类型',
datetime: '2017-08-07',
type: 'notification',
},
{
id: '000000005',
avatar: 'https://gw.alipayobjects.com/zos/rmsportal/ThXAXghbEsBCCSDihZxY.png',
title: '内容不要超过两行字,超出时自动截断',
datetime: '2017-08-07',
type: 'notification',
},
{
id: '000000006',
avatar: 'https://gw.alipayobjects.com/zos/rmsportal/fcHMVNCjPOsbUGdEduuv.jpeg',
title: '曲丽丽 评论了你',
description: '描述信息描述信息描述信息',
datetime: '2017-08-07',
type: 'message',
clickClose: true,
},
{
id: '000000007',
avatar: 'https://gw.alipayobjects.com/zos/rmsportal/fcHMVNCjPOsbUGdEduuv.jpeg',
title: '朱偏右 回复了你',
description: '这种模板用于提醒谁与你发生了互动,左侧放『谁』的头像',
datetime: '2017-08-07',
type: 'message',
clickClose: true,
},
{
id: '000000008',
avatar: 'https://gw.alipayobjects.com/zos/rmsportal/fcHMVNCjPOsbUGdEduuv.jpeg',
title: '标题',
description: '这种模板用于提醒谁与你发生了互动,左侧放『谁』的头像',
datetime: '2017-08-07',
type: 'message',
clickClose: true,
},
{
id: '000000009',
title: '任务名称',
description: '任务需要在 2017-01-12 20:00 前启动',
extra: '未开始',
status: 'todo',
type: 'event',
},
{
id: '000000010',
title: '第三方紧急代码变更',
description: '冠霖提交于 2017-01-06,需在 2017-01-07 前完成代码变更任务',
extra: '马上到期',
status: 'urgent',
type: 'event',
},
{
id: '000000011',
title: '信息安全考试',
description: '指派竹尔于 2017-01-09 前完成更新并发布',
extra: '已耗时 8 天',
status: 'doing',
type: 'event',
},
{
id: '000000012',
title: 'ABCD 版本发布',
description: '冠霖提交于 2017-01-06,需在 2017-01-07 前完成代码变更任务',
extra: '进行中',
status: 'processing',
type: 'event',
},
];
function onItemClick(item, tabProps) {
console.log(item, tabProps);
}
function onClear(tabTitle) {
console.log(tabTitle);
}
function getNoticeData(notices) {
if (notices.length === 0) {
return {};
}
const newNotices = notices.map(notice => {
const newNotice = { ...notice };
// transform id to item key
if (newNotice.id) {
newNotice.key = newNotice.id;
}
if (newNotice.extra && newNotice.status) {
const color = {
todo: '',
processing: 'blue',
urgent: 'red',
doing: 'gold',
}[newNotice.status];
newNotice.extra = (
<Tag color={color} style={{ marginRight: 0 }}>
{newNotice.extra}
</Tag>
);
}
return newNotice;
});
return newNotices.reduce((pre, data) => {
if (!pre[data.type]) {
pre[data.type] = [];
}
pre[data.type].push(data);
return pre;
}, {});
}
const noticeData = getNoticeData(data);
const Demo = () => (
<div
style={{
textAlign: 'right',
height: '64px',
lineHeight: '64px',
boxShadow: '0 1px 4px rgba(0,21,41,.12)',
padding: '0 32px',
width: '400px',
}}
>
<NoticeIcon className="notice-icon" count={5} onItemClick={onItemClick} onClear={onClear}>
<NoticeIcon.Tab
list={noticeData.notification}
title="notification"
emptyText="你已查看所有通知"
emptyImage="https://gw.alipayobjects.com/zos/rmsportal/wAhyIChODzsoKIOBHcBk.svg"
/>
<NoticeIcon.Tab
list={noticeData.message}
title="message"
emptyText="您已读完所有消息"
emptyImage="https://gw.alipayobjects.com/zos/rmsportal/sAuJeJzSKbUmHfBQRzmZ.svg"
/>
<NoticeIcon.Tab
list={noticeData.event}
title="event"
emptyText="你已完成所有待办"
emptyImage="https://gw.alipayobjects.com/zos/rmsportal/HsIsxMZiWKrNUavQUXqx.svg"
/>
</NoticeIcon>
</div>
);
ReactDOM.render(<Demo />, mountNode);
API#
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
count | 图标上的消息总数 | number | - |
bell | translate this please -> Change the bell Icon | ReactNode | <Icon type='bell' /> |
loading | 弹出卡片加载状态 | boolean | false |
onClear | 点击清空按钮的回调 | function(tabName) | - |
onItemClick | 点击列表项的回调 | function(item, tabProps) | - |
onPopupVisibleChange | 弹出卡片显隐的回调 | function(visible) | - |
onTabChange | 切换页签的回调 | function(tabTitle) | - |
onViewMore | 点击查看更多的回调 | function(tabProps, event) | - |
popupVisible | 控制弹层显隐 | boolean | - |
locale | 默认文案 | Object | { emptyText: 'No notifications', clear: 'Clear', viewMore: 'Loading more' } |
clearClose | 点击清空按钮后关闭通知菜单 | boolean | false |
NoticeIcon.Tab#
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
count | 当前 Tab 未读消息数量 | number | list.length |
emptyText | 针对每个 Tab 定制空数据文案 | ReactNode | - |
emptyImage | 针对每个 Tab 定制空数据图片 | string | - |
list | 列表数据,格式参照下表 | Array | [] |
showClear | 是否显示清空按钮 | boolean | true |
showViewMore | 是否显示查看更多按钮 | boolean | false |
title | 消息分类的页签标题,实际的文案是 locale[title] || title |
string | - |
Tab data#
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
avatar | 头像图片链接 | string | ReactNode | - |
title | 标题 | ReactNode | - |
description | 描述信息 | ReactNode | - |
datetime | 时间戳 | ReactNode | - |
extra | 额外信息,在列表项右上角 | ReactNode | - |
clickClose | 点击列表项关闭通知菜单 | boolean | false |