Projects STRLCPY SeaMoon Files
🤬
272 lines | UTF-8 | 8 KB

--- title: 业务组件 sidemenu: false

此功能由dumi提供,dumi 是一个 📖 为组件开发场景而生的文档工具,用过的都说好。

业务组件

这里列举了 Pro 中所有用到的组件,这些组件不适合作为组件库,但是在业务中却真实需要。所以我们准备了这个文档,来指导大家是否需要使用这个组件。

这个组件自带了一些 Pro 的配置,你一般都需要改掉它的信息。

/**
 * background: '#f0f2f5'
 */
import Footer from '@/components/Footer';
import React from 'react';

export default () => <Footer />;

HeaderDropdown 头部下拉列表

HeaderDropdown 是 antd Dropdown 的封装,但是增加了移动端的特殊处理,用法也是相同的。

/**
 * background: '#f0f2f5'
 */
import HeaderDropdown from '@/components/HeaderDropdown';
import { Button, Menu } from 'antd';
import React from 'react';

export default () => {
  const menuHeaderDropdown = (
    <Menu selectedKeys={[]}>
      <Menu.Item key="center">个人中心</Menu.Item>
      <Menu.Item key="settings">个人设置</Menu.Item>
      <Menu.Divider />
      <Menu.Item key="logout">退出登录</Menu.Item>
    </Menu>
  );
  return (
    <HeaderDropdown overlay={menuHeaderDropdown}>
      <Button>hover 展示菜单</Button>
    </HeaderDropdown>
  );
};

HeaderSearch 头部搜索框

一个带补全数据的输入框,支持收起和展开 Input

/**
 * background: '#f0f2f5'
 */
import HeaderSearch from '@/components/HeaderSearch';
import React from 'react';

export default () => {
  return (
    <HeaderSearch
      placeholder="站内搜索"
      defaultValue="umi ui"
      options={[
        { label: 'Ant Design Pro', value: 'Ant Design Pro' },
        {
          label: 'Ant Design',
          value: 'Ant Design',
        },
        {
          label: 'Pro Table',
          value: 'Pro Table',
        },
        {
          label: 'Pro Layout',
          value: 'Pro Layout',
        },
      ]}
      onSearch={(value) => {
        console.log('input', value);
      }}
    />
  );
};

API

参数说明类型默认值
value输入框的值string-
onChange值修改后触发(value?: string) => void-
onSearch查询后触发(value?: string) => void-
options选项菜单的的列表{label,value}[]-
defaultVisible输入框默认是否显示,只有第一次生效boolean-
visible输入框是否显示boolean-
onVisibleChange输入框显示隐藏的回调函数(visible: boolean) => void-

NoticeIcon 通知工具

通知工具提供一个展示多种通知信息的界面。

/**
 * background: '#f0f2f5'
 */
import NoticeIcon from '@/components/NoticeIcon/NoticeIcon';
import { message } from 'antd';
import React from 'react';

export default () => {
  const list = [
    {
      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',
    },
  ];
  return (
    <NoticeIcon
      count={10}
      onItemClick={(item) => {
        message.info(`${item.title} 被点击了`);
      }}
      onClear={(title: string, key: string) => message.info('点击了清空更多')}
      loading={false}
      clearText="清空"
      viewMoreText="查看更多"
      onViewMore={() => message.info('点击了查看更多')}
      clearClose
    >
      <NoticeIcon.Tab
        tabKey="notification"
        count={2}
        list={list}
        title="通知"
        emptyText="你已查看所有通知"
        showViewMore
      />
      <NoticeIcon.Tab
        tabKey="message"
        count={2}
        list={list}
        title="消息"
        emptyText="您已读完所有消息"
        showViewMore
      />
      <NoticeIcon.Tab
        tabKey="event"
        title="待办"
        emptyText="你已完成所有待办"
        count={2}
        list={list}
        showViewMore
      />
    </NoticeIcon>
  );
};

NoticeIcon API

参数说明类型默认值
count有多少未读通知number-
bell铃铛的图表ReactNode-
onClear点击清空数据按钮(tabName: string, tabKey: string) => void-
onItemClick未读消息列被点击(item: API.NoticeIconData, tabProps: NoticeIconTabProps) => void-
onViewMore查看更多的按钮点击(tabProps: NoticeIconTabProps, e: MouseEvent) => void-
onTabChange通知 Tab 的切换(tabTile: string) => void;-
popupVisible通知显示是否展示boolean-
onPopupVisibleChange通知信息显示隐藏的回调函数(visible: boolean) => void-
clearText清空按钮的文字string-
viewMoreText查看更多的按钮文字string-
clearClose展示清空按钮boolean-
emptyImage列表为空时的兜底展示ReactNode-

NoticeIcon.Tab API

参数说明类型默认值
count有多少未读通知number-
title通知 Tab 的标题ReactNode-
showClear展示清除按钮booleantrue
showViewMore展示加载更booleantrue
tabKeyTab 的唯一 keystring-
onClick子项的单击事件(item: API.NoticeIconData) => void-
onClear清楚按钮的点击()=>void-
emptyText为空的时候测试()=>void-
viewMoreText查看更多的按钮文字string-
onViewMore查看更多的按钮点击( e: MouseEvent) => void-
list通知信息的列表API.NoticeIconData-

NoticeIconData

export interface NoticeIconData {
  id: string;
  key: string;
  avatar: string;
  title: string;
  datetime: string;
  type: string;
  read?: boolean;
  description: string;
  clickClose?: boolean;
  extra: any;
  status: string;
}

RightContent

RightContent 是以上几个组件的组合,同时新增了 plugins 的 SelectLang 插件。

<Space>
  <HeaderSearch
    placeholder="站内搜索"
    defaultValue="umi ui"
    options={[
      { label: <a href="https://umijs.org/zh/guide/umi-ui.html">umi ui</a>, value: 'umi ui' },
      {
        label: <a href="next.ant.design">Ant Design</a>,
        value: 'Ant Design',
      },
      {
        label: <a href="https://protable.ant.design/">Pro Table</a>,
        value: 'Pro Table',
      },
      {
        label: <a href="https://prolayout.ant.design/">Pro Layout</a>,
        value: 'Pro Layout',
      },
    ]}
  />
  <Tooltip title="使用文档">
    <span
      className={styles.action}
      onClick={() => {
        window.location.href = 'https://pro.ant.design/docs/getting-started';
      }}
    >
      <QuestionCircleOutlined />
    </span>
  </Tooltip>
  <Avatar />
  {REACT_APP_ENV && (
    <span>
      <Tag color={ENVTagColor[REACT_APP_ENV]}>{REACT_APP_ENV}</Tag>
    </span>
  )}
  <SelectLang className={styles.action} />
</Space>
Please wait...
Page is in error, reload to recover