Notification 通知提醒框

全局展示通知提醒信息。

组件实现参照 antd 的 Notification 组件,并针对 ICE 做了适配

安装和升级

def add @icedesign/notification

API

config 参数如下:

参数 说明 类型 默认值
message 通知提醒标题,必选 string|ReactNode -
description 通知提醒内容,必选 string|ReactNode -
btn 自定义关闭按钮 ReactNode -
icon 自定义图标 ReactNode -
key 当前通知唯一标志 string -
onClose 点击默认关闭按钮时触发的回调函数 Function -
duration 默认 4.5 秒后自动关闭,配置为 null 则不自动关闭 number 4.5
placement 弹出位置,可选 topLeft topRight bottomLeft``bottomRight string topRight
getContainer 配置渲染节点的输出位置 () => HTMLNode () => document.body

还提供了一个全局配置方法,在调用前提前配置,全局一次生效。

IceNotification.config({
  placement: 'bottomRight',
  bottom: 50,
  duration: 3,
});
参数 说明 类型 默认值
placement 弹出位置,可选 topLeft topRight bottomLeft``bottomRight string topRight
top 消息从顶部弹出时,距离顶部的位置,单位像素。 number 24
bottom 消息从底部弹出时,距离底部的位置,单位像素。 number 24
duration 默认自动关闭延时,单位秒 number 4.5

感谢 Antd 团队

DEMO 列表

简单的用法

本 Demo 演示最基础的用法。

import React, { Component } from 'react';
import ReactDOM from 'react-dom';
import IceNotification from '@icedesign/notification';
import { Button, Icon, Select } from '@icedesign/base';

class App extends Component {
  state = {};
  basic = () => {
    IceNotification.open({
      message: '蒹葭苍苍,白露为霜',
      description:
        '所謂伊人,在水一方。 溯洄從之,道阻且長。 溯游從之,宛在水中央。 蒹葭萋萋,白露未晞。 所謂伊人,在水之湄。 溯洄從之,道...',
    });
  };

  duration = () => {
    const args = {
      message: '蒹葭苍苍,白露为霜',
      description: '不会自动关闭,除非手动点击关闭按钮!',
      duration: 0,
    };
    IceNotification.open(args);
  };

  icon = () => {
    IceNotification.open({
      message: '蒹葭苍苍,白露为霜',
      description:
        'This is the content of the notification. This is the content of the notification. This is the content of the notification.',
      icon: <Icon type="credit-level-filling" />,
    });
  };

  placement = () => {
    IceNotification.open({
      message: 'Notification Title',
      description:
        'This is the content of the notification. This is the content of the notification. This is the content of the notification.',
    });
  };

  btn = () => {
    const close = () => {
      console.log(
        'Notification was closed. Either the close button was clicked or duration time elapsed.'
      );
    };
    const key = `open${Date.now()}`;
    const btnClick = function() {
      // to hide notification box
      IceNotification.close(key);
    };
    const btn = (
      <Button type="primary" size="small" onClick={btnClick}>
        Confirm
      </Button>
    );
    IceNotification.open({
      message: 'Notification Title',
      description:
        'A function will be be called after the notification is closed (automatically after the "duration" time of manually).',
      btn,
      key,
      onClose: close,
    });
  };

  openNotificationWithIcon = (type) => {
    IceNotification[type]({
      message: 'Notification Title',
      description:
        'This is the content of the notification. This is the content of the notification. This is the content of the notification.',
    });
  };

  render() {
    return (
      <div>
        <p>
          最简单的用法,4.5 秒后自动关闭。
          <Button type="primary" onClick={this.basic}>
            ClickMe!
          </Button>
        </p>

        <p>
          自定义通知框自动关闭的延时,默认`4.5s`,取消自动关闭只要将该值设为 `0`
          即可。。
          <Button type="primary" onClick={this.duration}>
            ClickMe!
          </Button>
        </p>

        <p>
          图标可以被自定义。
          <Button type="primary" onClick={this.icon}>
            ClickMe!
          </Button>
        </p>

        <p>
          可以设置通知从右上角、右下角、左下角、左上角弹出。
          <Select
            defaultValue="topRight"
            style={{ width: 120, marginRight: 10 }}
            onChange={(val) => {
              IceNotification.config({ placement: val });
            }}
          >
            {['topLeft', 'topRight', 'bottomLeft', 'bottomRight'].map((val) => (
              <Option key={val} value={val}>
                {val}
              </Option>
            ))}
          </Select>
          <Button type="primary" onClick={this.placement}>
            ClickMe!
          </Button>
        </p>

        <p>
          自定义关闭按钮的样式和文字。
          <Button type="primary" onClick={this.btn}>
            ClickMe!
          </Button>
        </p>

        <p>
          通知提醒框左侧有图标。
          <Button onClick={() => this.openNotificationWithIcon('success')}>
            Success
          </Button>
          <Button onClick={() => this.openNotificationWithIcon('info')}>
            Info
          </Button>
          <Button onClick={() => this.openNotificationWithIcon('warning')}>
            Warning
          </Button>
          <Button onClick={() => this.openNotificationWithIcon('error')}>
            Error
          </Button>
        </p>
      </div>
    );
  }
}

ReactDOM.render(<App />, mountNode);