mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-16 01:29:11 +08:00
48 lines
1.1 KiB
TypeScript
48 lines
1.1 KiB
TypeScript
import * as React from 'react';
|
|
import CopyToClipboard from 'react-copy-to-clipboard';
|
|
import { Icon as AntdIcon, Badge } from 'antd';
|
|
import { ThemeType, IconProps } from 'antd/es/icon';
|
|
import classNames from 'classnames';
|
|
|
|
const Icon: React.SFC<IconProps> = AntdIcon;
|
|
|
|
export interface CopyableIconProps {
|
|
type: string;
|
|
theme: ThemeType;
|
|
isNew: boolean;
|
|
justCopied: string | null;
|
|
onCopied: (type: string, text: string) => any;
|
|
}
|
|
|
|
const CopyableIcon: React.SFC<CopyableIconProps> = ({
|
|
type,
|
|
theme,
|
|
isNew,
|
|
justCopied,
|
|
onCopied,
|
|
}) => {
|
|
const className = classNames({
|
|
copied: justCopied === type,
|
|
outlined: theme === 'twoTone',
|
|
});
|
|
return (
|
|
<CopyToClipboard
|
|
text={
|
|
theme === 'outlined'
|
|
? `<Icon type="${type}" />`
|
|
: `<Icon type="${type}" theme="${theme}" />`
|
|
}
|
|
onCopy={(text: string) => onCopied(type, text)}
|
|
>
|
|
<li className={className}>
|
|
<Icon type={type} theme={theme} />
|
|
<span className="anticon-class">
|
|
<Badge dot={isNew}>{type}</Badge>
|
|
</span>
|
|
</li>
|
|
</CopyToClipboard>
|
|
);
|
|
};
|
|
|
|
export default CopyableIcon;
|