42 lines
910 B
TypeScript
42 lines
910 B
TypeScript
import { FC, ReactNode, useContext, useMemo } from 'react';
|
|
|
|
import { DialogContext } from './Dialog';
|
|
import IconButton from '../IconButton';
|
|
import { PanelHeader } from '../Panels';
|
|
import sxstring from '../../lib/sxstring';
|
|
import { HeaderText } from '../Text';
|
|
|
|
const DialogHeader: FC<DialogHeaderProps> = (props) => {
|
|
const { children, showClose } = props;
|
|
|
|
const dialogContext = useContext(DialogContext);
|
|
|
|
const title = useMemo<ReactNode>(
|
|
() => sxstring(children, HeaderText),
|
|
[children],
|
|
);
|
|
|
|
const close = useMemo<ReactNode>(
|
|
() =>
|
|
showClose && (
|
|
<IconButton
|
|
mapPreset="close"
|
|
onClick={() => {
|
|
dialogContext?.setOpen(false);
|
|
}}
|
|
size="small"
|
|
/>
|
|
),
|
|
[dialogContext, showClose],
|
|
);
|
|
|
|
return (
|
|
<PanelHeader>
|
|
{title}
|
|
{close}
|
|
</PanelHeader>
|
|
);
|
|
};
|
|
|
|
export default DialogHeader;
|