mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-07 20:08:21 +08:00
286a42b4e5
* site style code optimization * site style code optimization * del trigger * revert
89 lines
2.1 KiB
TypeScript
89 lines
2.1 KiB
TypeScript
import { DownOutlined } from '@ant-design/icons';
|
|
import { css } from '@emotion/react';
|
|
import type { MenuProps } from 'antd';
|
|
import { Button, Dropdown } from 'antd';
|
|
import { FormattedMessage } from 'dumi';
|
|
import React from 'react';
|
|
import type { SharedProps } from './interface';
|
|
|
|
const useStyle = (rtl?: boolean) => ({
|
|
smallStyle: css`
|
|
font-size: 12px;
|
|
color: #777;
|
|
margin-left: 0.3em;
|
|
`,
|
|
downOutlined: css`
|
|
font-size: 9px;
|
|
margin: ${rtl ? '-1px 2px 0 0' : '-1px 0 0 2px'};
|
|
vertical-align: middle;
|
|
`,
|
|
});
|
|
|
|
const Community: React.FC = () => {
|
|
const { smallStyle } = useStyle();
|
|
return (
|
|
<span css={smallStyle}>
|
|
(<FormattedMessage id="app.implementation.community" />)
|
|
</span>
|
|
);
|
|
};
|
|
|
|
export const getEcosystemGroup = (): MenuProps['items'] => [
|
|
{
|
|
label: (
|
|
<a href="https://charts.ant.design" target="_blank" rel="noopener noreferrer">
|
|
<FormattedMessage id="app.header.menu.charts" />
|
|
</a>
|
|
),
|
|
key: 'charts',
|
|
},
|
|
{
|
|
label: (
|
|
<a href="http://pro.ant.design" target="_blank" rel="noopener noreferrer">
|
|
<FormattedMessage id="app.header.menu.pro.v4" />
|
|
</a>
|
|
),
|
|
key: 'pro',
|
|
},
|
|
{
|
|
label: (
|
|
<a href="http://procomponents.ant.design" target="_blank" rel="noopener noreferrer">
|
|
<FormattedMessage id="app.header.menu.pro.components" />
|
|
</a>
|
|
),
|
|
key: 'procomponents',
|
|
},
|
|
{
|
|
label: (
|
|
<a href="http://ng.ant.design" target="_blank" rel="noopener noreferrer">
|
|
Ant Design of Angular
|
|
<Community />
|
|
</a>
|
|
),
|
|
key: 'ng',
|
|
},
|
|
{
|
|
label: (
|
|
<a href="http://antdv.com" target="_blank" rel="noopener noreferrer">
|
|
Ant Design of Vue
|
|
<Community />
|
|
</a>
|
|
),
|
|
key: 'vue',
|
|
},
|
|
];
|
|
|
|
const More: React.FC<SharedProps> = ({ isRTL }) => {
|
|
const { downOutlined } = useStyle(isRTL);
|
|
return (
|
|
<Dropdown menu={{ items: getEcosystemGroup() }} placement="bottomRight">
|
|
<Button size="small">
|
|
<FormattedMessage id="app.header.menu.more" />
|
|
<DownOutlined css={downOutlined} />
|
|
</Button>
|
|
</Dropdown>
|
|
);
|
|
};
|
|
|
|
export default More;
|