import * as React from 'react'; import classNames from 'classnames'; import * as allIcons from '@ant-design/icons/lib/dist'; import ReactIcon from '@ant-design/icons-react'; import createFromIconfontCN from './IconFont'; import { svgBaseProps, withThemeSuffix, removeTypeTheme, getThemeFromTypeName, } from './utils'; import warning from '../_util/warning'; import { getTwoToneColor, setTwoToneColor } from './twoTonePrimaryColor'; // Initial setting ReactIcon.add(...Object.keys(allIcons).map((key) => (allIcons as any)[key])); setTwoToneColor('#1890ff'); let defaultTheme: ThemeType = 'outlined'; let dangerousTheme: ThemeType | undefined = undefined; export interface CustomIconComponentProps { width: string | number; height: string | number; fill: string; viewBox?: string; className?: string; style?: React.CSSProperties; ['aria-hidden']?: string; } export type ThemeType = 'filled' | 'outlined' | 'twoTone'; export interface IconProps { type?: string; className?: string; theme?: ThemeType; title?: string; onClick?: React.MouseEventHandler; component?: React.ComponentType; twoToneColor?: string; viewBox?: string; spin?: boolean; style?: React.CSSProperties; prefixCls?: string; } export interface IconComponent

extends React.SFC

{ createFromIconfontCN: typeof createFromIconfontCN; getTwoToneColor: typeof getTwoToneColor; setTwoToneColor: typeof setTwoToneColor; unstable_ChangeThemeOfIconsDangerously?: typeof unstable_ChangeThemeOfIconsDangerously; unstable_ChangeDefaultThemeOfIcons?: typeof unstable_ChangeDefaultThemeOfIcons; } const Icon: IconComponent = (props) => { const { // affect outter ... className, // affect inner ... type, component: Component, viewBox, spin, // children children, // other theme, // default to outlined twoToneColor, ...restProps } = props; warning( Boolean(type || Component || children), 'Icon should have `type` prop or `component` prop or `children`.', ); const classString = classNames({ [`anticon`]: true, [`anticon-${type}`]: Boolean(type), }, className); const svgClassString = classNames({ [`anticon-spin`]: !!spin || type === 'loading', }); let innerNode; // component > children > type if (Component) { const innerSvgProps: CustomIconComponentProps = { ...svgBaseProps, className: svgClassString, viewBox, }; if (!viewBox) { delete innerSvgProps.viewBox; } innerNode = ( {children} ); } if (children) { warning( Boolean(viewBox) || ( React.Children.count(children) === 1 && React.isValidElement(children) && React.Children.only(children).type === 'use' ), 'Make sure that you provide correct `viewBox`' + ' prop (default `0 0 1024 1024`) to the icon.', ); const innerSvgProps: CustomIconComponentProps = { ...svgBaseProps, className: svgClassString, }; innerNode = ( {children} ); } if (typeof type === 'string') { let computedType = type; if (theme) { const themeInName = getThemeFromTypeName(type); warning(!themeInName || theme === themeInName, `The icon name '${type}' already specify a theme '${themeInName}',` + ` the 'theme' prop '${theme}' will be ignored.`); } computedType = withThemeSuffix( removeTypeTheme(type), dangerousTheme || theme || defaultTheme, ); innerNode = ( ); } return ( {innerNode} ); }; function unstable_ChangeThemeOfIconsDangerously(theme?: ThemeType) { warning( false, `You are using the unstable method 'Icon.unstable_ChangeThemeOfAllIconsDangerously', ` + `make sure that all the icons with theme '${theme}' display correctly.`, ); dangerousTheme = theme; } function unstable_ChangeDefaultThemeOfIcons(theme: ThemeType) { warning( false, `You are using the unstable method 'Icon.unstable_ChangeDefaultThemeOfIcons', ` + `make sure that all the icons with theme '${theme}' display correctly.`, ); defaultTheme = theme; } Icon.createFromIconfontCN = createFromIconfontCN; Icon.getTwoToneColor = getTwoToneColor; Icon.setTwoToneColor = setTwoToneColor; export default Icon;