ant-design/components/message/PurePanel.tsx

72 lines
2.3 KiB
TypeScript
Raw Normal View History

import CheckCircleFilled from '@ant-design/icons/CheckCircleFilled';
import CloseCircleFilled from '@ant-design/icons/CloseCircleFilled';
import ExclamationCircleFilled from '@ant-design/icons/ExclamationCircleFilled';
import InfoCircleFilled from '@ant-design/icons/InfoCircleFilled';
import LoadingOutlined from '@ant-design/icons/LoadingOutlined';
import classNames from 'classnames';
import { Notice } from 'rc-notification';
import type { NoticeProps } from 'rc-notification/lib/Notice';
import * as React from 'react';
import { ConfigContext } from '../config-provider';
import type { NoticeType } from './interface';
import useStyle from './style';
2023-11-13 11:47:07 +08:00
import useCSSVar from './style/cssVar';
import useCSSVarCls from '../config-provider/hooks/useCSSVarCls';
export const TypeIcon = {
info: <InfoCircleFilled />,
success: <CheckCircleFilled />,
error: <CloseCircleFilled />,
warning: <ExclamationCircleFilled />,
loading: <LoadingOutlined />,
};
export interface PureContentProps {
prefixCls: string;
type?: NoticeType;
icon?: React.ReactNode;
children: React.ReactNode;
}
export const PureContent: React.FC<PureContentProps> = ({ prefixCls, type, icon, children }) => (
<div className={classNames(`${prefixCls}-custom-content`, `${prefixCls}-${type}`)}>
{icon || TypeIcon[type!]}
<span>{children}</span>
</div>
);
export interface PurePanelProps
extends Omit<NoticeProps, 'prefixCls' | 'eventKey'>,
Omit<PureContentProps, 'prefixCls' | 'children'> {
prefixCls?: string;
}
/** @private Internal Component. Do not use in your production. */
const PurePanel: React.FC<PurePanelProps> = (props) => {
const { prefixCls: staticPrefixCls, className, type, icon, content, ...restProps } = props;
const { getPrefixCls } = React.useContext(ConfigContext);
const prefixCls = staticPrefixCls || getPrefixCls('message');
const [, hashId] = useStyle(prefixCls);
2023-11-13 11:47:07 +08:00
const rootCls = useCSSVarCls(prefixCls);
const wrapCSSVar = useCSSVar(rootCls);
2023-11-13 11:47:07 +08:00
return wrapCSSVar(
<Notice
{...restProps}
prefixCls={prefixCls}
2023-11-13 11:47:07 +08:00
className={classNames(className, hashId, `${prefixCls}-notice-pure-panel`, rootCls)}
eventKey="pure"
duration={null}
content={
<PureContent prefixCls={prefixCls} type={type} icon={icon}>
{content}
</PureContent>
}
2023-11-13 11:47:07 +08:00
/>,
);
};
export default PurePanel;