mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-19 03:54:28 +08:00
40 lines
980 B
TypeScript
40 lines
980 B
TypeScript
|
/**
|
||
|
* copied: https://github.com/arvinxx/dumi-theme-antd-style/tree/master/src/builtins/Container
|
||
|
*/
|
||
|
import * as React from 'react';
|
||
|
import { Alert } from 'antd';
|
||
|
import { type FC, type ReactNode } from 'react';
|
||
|
import useStyles from './style';
|
||
|
|
||
|
const Container: FC<{
|
||
|
type: 'info' | 'warning' | 'success' | 'error';
|
||
|
title?: string;
|
||
|
children: ReactNode;
|
||
|
}> = ({ type, title, children }) => {
|
||
|
const { styles, cx } = useStyles();
|
||
|
|
||
|
return (
|
||
|
<div data-type={type} className={styles.container}>
|
||
|
<Alert
|
||
|
showIcon
|
||
|
type={type}
|
||
|
message={title || type.toUpperCase()}
|
||
|
description={
|
||
|
<div
|
||
|
className={cx(
|
||
|
styles.desc,
|
||
|
// 为了让 markdown 的样式生效,需要在这里添加一个额外的 class
|
||
|
'markdown',
|
||
|
)}
|
||
|
>
|
||
|
{children}
|
||
|
</div>
|
||
|
}
|
||
|
className={styles.alert}
|
||
|
/>
|
||
|
</div>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default Container;
|